choose_card_page.dart 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. import 'package:cs_resources/generated/l10n.dart';
  2. import 'package:cs_resources/theme/app_colors_theme.dart';
  3. import 'package:flutter/material.dart';
  4. import 'package:auto_route/auto_route.dart';
  5. import 'package:flutter_hooks/flutter_hooks.dart';
  6. import 'package:hooks_riverpod/hooks_riverpod.dart';
  7. import 'package:router/ext/auto_router_extensions.dart';
  8. import 'package:widgets/ext/ex_widget.dart';
  9. import 'package:widgets/load_state_layout.dart';
  10. import 'package:widgets/my_appbar.dart';
  11. import 'package:widgets/my_button.dart';
  12. import 'package:widgets/my_text_view.dart';
  13. import 'package:widgets/widget_export.dart';
  14. import '../../router/page/payment_page_router.dart';
  15. import 'choose_card_view_model.dart';
  16. import 'item_card.dart';
  17. @RoutePage()
  18. class ChooseCardPage extends HookConsumerWidget {
  19. const ChooseCardPage({Key? key}) : super(key: key);
  20. //启动当前页面
  21. static void startInstance({BuildContext? context}) {
  22. if (context != null) {
  23. context.router.push(const ChooseCardPageRoute());
  24. } else {
  25. appRouter.push(const ChooseCardPageRoute());
  26. }
  27. }
  28. @override
  29. Widget build(BuildContext context, WidgetRef ref) {
  30. final viewModel = ref.watch(chooseCardViewModelProvider.notifier);
  31. final state = ref.watch(chooseCardViewModelProvider);
  32. useEffect(() {
  33. // 组件挂载时执行 - 执行接口请求
  34. Future.microtask(() => viewModel.fetchList());
  35. return () {
  36. // 组件卸载时执行
  37. };
  38. }, []);
  39. return Scaffold(
  40. appBar: MyAppBar.appBar(
  41. context,
  42. S.current.payment,
  43. backgroundColor: context.appColors.backgroundWhite,
  44. ),
  45. backgroundColor: context.appColors.backgroundDark,
  46. body: SizedBox(
  47. width: double.infinity,
  48. height: double.infinity,
  49. child: Column(
  50. children: [
  51. EasyRefresh(
  52. controller: viewModel.refreshController,
  53. onRefresh: viewModel.onRefresh,
  54. onLoad: viewModel.loadMore,
  55. child: LoadStateLayout(
  56. state: state.loadingState,
  57. errorMessage: state.errorMessage,
  58. errorRetry: () {
  59. viewModel.retryRequest();
  60. },
  61. successSliverWidget: [
  62. //添加新卡
  63. SliverToBoxAdapter(
  64. child: MyTextView(
  65. S.current.add_new_card,
  66. fontSize: 16,
  67. textAlign: TextAlign.center,
  68. marginLeft: 22.5,
  69. marginTop: 14,
  70. marginBottom: 15,
  71. marginRight: 22.5,
  72. cornerRadius: 5,
  73. paddingTop: 12,
  74. paddingBottom: 12,
  75. onClick: viewModel.gotoAddCardPage,
  76. borderWidth: 1,
  77. borderColor: context.appColors.textPrimary,
  78. isFontMedium: true,
  79. textColor: context.appColors.textPrimary,
  80. ),
  81. ),
  82. //列表
  83. SliverList(
  84. delegate: SliverChildBuilderDelegate(
  85. (context, index) {
  86. return CardItem(
  87. index: index,
  88. item: state.datas[index],
  89. ).onTap(() {
  90. viewModel.setAsPrimary(index);
  91. });
  92. },
  93. childCount: state.datas.length,
  94. ))
  95. ],
  96. ),
  97. ).marginOnly(top: 5, bottom: 5).expanded(),
  98. //底部按钮(其实就是返回)
  99. MyButton(
  100. onPressed: () {
  101. context.appRouter.maybePop();
  102. },
  103. text: S.current.next,
  104. textColor: Colors.white,
  105. backgroundColor: context.appColors.btnBgDefault,
  106. fontWeight: FontWeight.w500,
  107. type: ClickType.throttle,
  108. fontSize: 16,
  109. minHeight: 50,
  110. radius: 0,
  111. ),
  112. ],
  113. ),
  114. ),
  115. );
  116. }
  117. }