my_estate_page.dart 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. import 'package:cpt_profile/modules/change_mobile/change_mobile_page.dart';
  2. import 'package:cs_resources/generated/l10n.dart';
  3. import 'package:cs_resources/theme/app_colors_theme.dart';
  4. import 'package:domain/entity/user_me_entity.dart';
  5. import 'package:flutter/material.dart';
  6. import 'package:auto_route/auto_route.dart';
  7. import 'package:flutter_hooks/flutter_hooks.dart';
  8. import 'package:hooks_riverpod/hooks_riverpod.dart';
  9. import 'package:router/componentRouter/component_service_manager.dart';
  10. import 'package:router/ext/auto_router_extensions.dart';
  11. import 'package:widgets/ext/ex_widget.dart';
  12. import 'package:widgets/load_state_layout.dart';
  13. import 'package:widgets/my_appbar.dart';
  14. import 'package:widgets/my_button.dart';
  15. import 'package:widgets/widget_export.dart';
  16. import '../../router/page/profile_page_router.dart';
  17. import 'item_estate.dart';
  18. import 'item_estate_header.dart';
  19. import 'my_estate_view_model.dart';
  20. @RoutePage()
  21. class MyEstatePage extends HookConsumerWidget {
  22. const MyEstatePage({Key? key}) : super(key: key);
  23. //启动当前页面
  24. static void startInstance({BuildContext? context}) {
  25. if (context != null) {
  26. context.router.navigate(const MyEstatePageRoute());
  27. } else {
  28. appRouter.navigate(const MyEstatePageRoute());
  29. }
  30. }
  31. @override
  32. Widget build(BuildContext context, WidgetRef ref) {
  33. final viewModel = ref.watch(myEstateViewModelProvider.notifier);
  34. final state = ref.watch(myEstateViewModelProvider);
  35. useEffect(() {
  36. // 组件挂载时执行 - 执行接口请求
  37. Future.microtask(() => viewModel.fetchList());
  38. return () {
  39. // 组件卸载时执行
  40. };
  41. }, []);
  42. return Scaffold(
  43. appBar: MyAppBar.appBar(
  44. context,
  45. S.current.yy_home_accounts,
  46. backgroundColor: context.appColors.backgroundWhite,
  47. ),
  48. backgroundColor: context.appColors.backgroundDark,
  49. body: Column(
  50. mainAxisSize: MainAxisSize.max,
  51. children: [
  52. EasyRefresh(
  53. controller: viewModel.refreshController,
  54. onRefresh: viewModel.onRefresh,
  55. child: LoadStateLayout(
  56. state: state.loadingState,
  57. errorMessage: state.errorMessage,
  58. errorRetry: () {
  59. viewModel.retryRequest();
  60. },
  61. successSliverWidget: [
  62. SliverList(
  63. delegate: SliverChildBuilderDelegate(
  64. (context, index) {
  65. return StickyHeader(
  66. header: EstateItemHeader(state.datas[index].name),
  67. content: Column(
  68. children: _buildGroup(state.datas[index].accounts!, index,viewModel),
  69. ),
  70. );
  71. },
  72. childCount: state.datas.length,
  73. ))
  74. ],
  75. ),
  76. ).expanded(),
  77. MyButton(
  78. onPressed: () {
  79. ComponentServiceManager().authService.startSelectEstatePage();
  80. },
  81. text: S.current.add,
  82. textColor: Colors.white,
  83. backgroundColor: context.appColors.btnBgDefault,
  84. fontWeight: FontWeight.w500,
  85. type: ClickType.throttle,
  86. fontSize: 16,
  87. minHeight: 50,
  88. radius: 0,
  89. )
  90. ],
  91. ),
  92. );
  93. }
  94. //当前组内的子数据
  95. List<Widget> _buildGroup(List<UserMeEstatesAccounts> list, int index, MyEstateViewModel viewModel) {
  96. return list
  97. .asMap()
  98. .map((childIndex, item) {
  99. return MapEntry(
  100. childIndex,
  101. EstateItem(
  102. item: item,
  103. childIndex: childIndex,
  104. itemAction: (){
  105. viewModel.setEstateUnitDefault(item);
  106. },
  107. deleteAction: () {
  108. viewModel.showRemoveEstateDialog(item.unit?.id);
  109. },
  110. ));
  111. })
  112. .values
  113. .toList();
  114. }
  115. }