menu_user.dart 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  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. import 'package:flowy_infra_ui/style_widget/styled_text.dart';
  9. class MenuUser extends MenuItem {
  10. final UserDetail user;
  11. MenuUser(this.user, {Key? key}) : super(key: ValueKey(user.id));
  12. @override
  13. Widget build(BuildContext context) {
  14. return BlocProvider<MenuUserBloc>(
  15. create: (context) =>
  16. getIt<MenuUserBloc>(param1: user)..add(const MenuUserEvent.initial()),
  17. child: BlocBuilder<MenuUserBloc, MenuUserState>(
  18. builder: (context, state) => Row(children: [
  19. _renderAvatar(context),
  20. const HSpace(10),
  21. _renderUserName(context),
  22. const HSpace(10),
  23. _renderDropButton(context),
  24. ]),
  25. ),
  26. );
  27. }
  28. Widget _renderAvatar(BuildContext context) {
  29. return SizedBox(
  30. width: 30,
  31. height: 30,
  32. child: ClipRRect(
  33. borderRadius: BorderRadius.circular(10),
  34. child: const Image(image: AssetImage('assets/images/avatar.jpg')),
  35. ),
  36. );
  37. }
  38. Widget _renderUserName(BuildContext context) {
  39. String name = context.read<MenuUserBloc>().state.user.name;
  40. if (name.isEmpty) {
  41. name = context.read<MenuUserBloc>().state.user.email;
  42. }
  43. return Flexible(
  44. child: StyledText(name, fontSize: 18),
  45. );
  46. }
  47. Widget _renderDropButton(BuildContext context) {
  48. return IconButton(
  49. icon: const Icon(Icons.arrow_drop_down),
  50. alignment: Alignment.center,
  51. padding: EdgeInsets.zero,
  52. onPressed: () {},
  53. );
  54. }
  55. @override
  56. MenuItemType get type => MenuItemType.userProfile;
  57. }