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) => getIt<MenuUserBloc>(param1: user)..add(const MenuUserEvent.initial()),
  17. child: BlocBuilder<MenuUserBloc, MenuUserState>(
  18. builder: (context, state) => Row(
  19. children: [
  20. _renderAvatar(context),
  21. const HSpace(12),
  22. _renderUserName(context),
  23. const HSpace(4),
  24. _renderDropButton(context),
  25. ],
  26. mainAxisAlignment: MainAxisAlignment.start,
  27. crossAxisAlignment: CrossAxisAlignment.center,
  28. ),
  29. ),
  30. );
  31. }
  32. Widget _renderAvatar(BuildContext context) {
  33. return SizedBox(
  34. width: 20,
  35. height: 20,
  36. child: ClipRRect(
  37. borderRadius: BorderRadius.circular(4),
  38. child: const Image(image: AssetImage('assets/images/avatar.jpg')),
  39. ),
  40. );
  41. }
  42. Widget _renderUserName(BuildContext context) {
  43. String name = context.read<MenuUserBloc>().state.user.name;
  44. if (name.isEmpty) {
  45. name = context.read<MenuUserBloc>().state.user.email;
  46. }
  47. return Flexible(
  48. child: FlowyText(name, fontSize: 12),
  49. );
  50. }
  51. Widget _renderDropButton(BuildContext context) {
  52. return FlowyDropdownButton(
  53. onPressed: () {
  54. debugPrint('show user profile');
  55. },
  56. );
  57. }
  58. @override
  59. MenuItemType get type => MenuItemType.userProfile;
  60. }