menu_user.dart 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. import 'package:app_flowy/startup/startup.dart';
  2. import 'package:app_flowy/workspace/application/menu/menu_user_bloc.dart';
  3. import 'package:app_flowy/workspace/presentation/widgets/menu/menu_list.dart';
  4. import 'package:flowy_infra_ui/widget/spacing.dart';
  5. import 'package:flowy_sdk/protobuf/flowy-user/user_detail.pb.dart';
  6. import 'package:flutter/material.dart';
  7. import 'package:flutter_bloc/flutter_bloc.dart';
  8. class MenuUser extends MenuItem {
  9. final UserDetail user;
  10. MenuUser(this.user, {Key? key}) : super(key: ValueKey(user.id));
  11. @override
  12. Widget build(BuildContext context) {
  13. return BlocProvider<MenuUserBloc>(
  14. create: (context) =>
  15. getIt<MenuUserBloc>(param1: user)..add(const MenuUserEvent.initial()),
  16. child: BlocBuilder<MenuUserBloc, MenuUserState>(
  17. builder: (context, state) => Row(children: [
  18. _renderAvatar(context),
  19. const HSpace(10),
  20. _renderUserName(context),
  21. const HSpace(10),
  22. _renderDropButton(context),
  23. ]),
  24. ),
  25. );
  26. }
  27. Widget _renderAvatar(BuildContext context) {
  28. return SizedBox(
  29. width: 30,
  30. height: 30,
  31. child: ClipRRect(
  32. borderRadius: BorderRadius.circular(10),
  33. child: const Image(image: AssetImage('assets/images/avatar.jpg')),
  34. ),
  35. );
  36. }
  37. Widget _renderUserName(BuildContext context) {
  38. String name = context.read<MenuUserBloc>().state.user.name;
  39. if (name.isEmpty) {
  40. name = context.read<MenuUserBloc>().state.user.email;
  41. }
  42. return Flexible(
  43. child: Text(
  44. name,
  45. overflow: TextOverflow.fade,
  46. softWrap: false,
  47. style: const TextStyle(fontSize: 18),
  48. ),
  49. );
  50. }
  51. Widget _renderDropButton(BuildContext context) {
  52. return IconButton(
  53. icon: const Icon(Icons.arrow_drop_down),
  54. alignment: Alignment.center,
  55. padding: EdgeInsets.zero,
  56. onPressed: () {},
  57. );
  58. }
  59. @override
  60. MenuItemType get type => MenuItemType.userProfile;
  61. }