menu_user.dart 2.0 KB

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