feedback_detail_page.dart 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. import 'package:cs_resources/generated/assets.dart';
  2. import 'package:cs_resources/generated/l10n.dart';
  3. import 'package:cs_resources/theme/app_colors_theme.dart';
  4. import 'package:flutter/material.dart';
  5. import 'package:auto_route/auto_route.dart';
  6. import 'package:flutter_hooks/flutter_hooks.dart';
  7. import 'package:hooks_riverpod/hooks_riverpod.dart';
  8. import 'package:plugin_platform/engine/image/image_nine_grid.dart';
  9. import 'package:router/ext/auto_router_extensions.dart';
  10. import 'package:widgets/ext/ex_widget.dart';
  11. import 'package:widgets/my_appbar.dart';
  12. import 'package:widgets/my_load_image.dart';
  13. import 'package:widgets/my_text_view.dart';
  14. import 'package:widgets/utils/dark_theme_util.dart';
  15. import '../../../router/page/main_page_router.dart';
  16. import 'feedback_detail_view_model.dart';
  17. @RoutePage()
  18. class FeedbackDetailPage extends HookConsumerWidget {
  19. //Feedback的Id
  20. final String? id;
  21. const FeedbackDetailPage({Key? key, required this.id}) : super(key: key);
  22. //启动当前页面
  23. static void startInstance({BuildContext? context, required String? id}) {
  24. if (context != null) {
  25. context.router.push(FeedbackDetailPageRoute(id: id));
  26. } else {
  27. appRouter.push(FeedbackDetailPageRoute(id: id));
  28. }
  29. }
  30. @override
  31. Widget build(BuildContext context, WidgetRef ref) {
  32. final viewModel = ref.watch(feedbackDetailViewModelProvider.notifier);
  33. final state = ref.watch(feedbackDetailViewModelProvider);
  34. useEffect(() {
  35. // 组件挂载时执行 - 执行接口请求
  36. Future.microtask(() => viewModel.fetchFeedbackDetail(id));
  37. return () {
  38. // 组件卸载时执行
  39. };
  40. }, []);
  41. return Scaffold(
  42. appBar: MyAppBar.appBar(context, S.current.feedback_details, showBottomDivider: true),
  43. backgroundColor: context.appColors.backgroundDark,
  44. body: SingleChildScrollView(
  45. scrollDirection: Axis.vertical,
  46. physics: const BouncingScrollPhysics(),
  47. child: Column(
  48. mainAxisSize: MainAxisSize.max,
  49. crossAxisAlignment: CrossAxisAlignment.start,
  50. children: [
  51. Container(
  52. color: context.appColors.whiteBG,
  53. width: double.infinity,
  54. padding: const EdgeInsets.symmetric(horizontal: 10),
  55. height: 85,
  56. child: Column(
  57. mainAxisAlignment: MainAxisAlignment.center,
  58. mainAxisSize: MainAxisSize.max,
  59. crossAxisAlignment: CrossAxisAlignment.start,
  60. children: [
  61. MyTextView(
  62. state.detail?.title ?? "-",
  63. fontSize: 21,
  64. isFontMedium: true,
  65. textColor: context.appColors.textBlack,
  66. ),
  67. MyTextView(
  68. "${state.detail?.createdAt ?? ""} | ${state.detail?.category?.name ?? ""} | ${state.detail?.status == 1 ? S.current.in_progress : S.current.replied}",
  69. fontSize: 12,
  70. marginTop: 8,
  71. isFontRegular: true,
  72. textColor: context.appColors.textDarkGray,
  73. ),
  74. ],
  75. ),
  76. ),
  77. //反馈的内容
  78. Container(
  79. width: double.infinity,
  80. margin: const EdgeInsets.only(left: 12.5, right: 12.5, top: 12.5, bottom: 12.5),
  81. padding: const EdgeInsets.symmetric(vertical: 24, horizontal: 25),
  82. decoration: BoxDecoration(
  83. color: context.appColors.whiteBG,
  84. borderRadius: BorderRadius.circular(6.0), // 圆角
  85. boxShadow: [
  86. BoxShadow(
  87. color: context.appColors.itemBGShadow, // 阴影颜色
  88. offset: const Offset(0, 3), // 阴影的偏移量
  89. blurRadius: 8.0, // 模糊半径
  90. spreadRadius: 3.0, // 扩散半径
  91. ),
  92. ],
  93. ),
  94. child: Column(
  95. crossAxisAlignment: CrossAxisAlignment.start,
  96. children: [
  97. MyTextView(
  98. state.detail?.content ?? "",
  99. fontSize: 15,
  100. marginBottom: 15,
  101. isFontRegular: true,
  102. textColor: context.appColors.textDarkGray,
  103. ),
  104. //九宫格展示
  105. ImageNineGrid(
  106. isSelectEnable: false,
  107. maxImages: 10,
  108. spacing: 10,
  109. aspectRatio: 108 / 80,
  110. initialImages: state.detail?.resources ?? [],
  111. onImagesChanged: (list) {},
  112. ),
  113. ],
  114. ),
  115. ),
  116. //回复的数据
  117. state.isReplyState ? _buildReplyWidget(context, ref) : _buildWaitingWidget(context)
  118. ],
  119. )),
  120. );
  121. }
  122. Widget _buildReplyWidget(BuildContext context, WidgetRef ref) {
  123. final state = ref.watch(feedbackDetailViewModelProvider);
  124. return Column(
  125. crossAxisAlignment: CrossAxisAlignment.start,
  126. children: [
  127. Row(
  128. mainAxisSize: MainAxisSize.max,
  129. mainAxisAlignment: MainAxisAlignment.start,
  130. crossAxisAlignment: CrossAxisAlignment.center,
  131. children: [
  132. MyTextView(
  133. S.current.administrator_reply,
  134. fontSize: 18,
  135. isFontRegular: true,
  136. textColor: context.appColors.textBlack,
  137. ).expanded(),
  138. MyTextView(
  139. state.detail?.replies?[0].createdAt ?? "-",
  140. fontSize: 12,
  141. isFontRegular: true,
  142. textColor: context.appColors.textDarkGray,
  143. )
  144. ],
  145. ).marginOnly(left: 12.5, right: 12.5, bottom: 14, top: 2.5),
  146. //回复的内容
  147. Container(
  148. width: double.infinity,
  149. margin: const EdgeInsets.only(left: 12.5, right: 12.5, bottom: 13.5),
  150. padding: const EdgeInsets.symmetric(vertical: 24, horizontal: 25),
  151. decoration: BoxDecoration(
  152. color: context.appColors.whiteBG,
  153. borderRadius: BorderRadius.circular(6.0), // 圆角
  154. boxShadow: [
  155. BoxShadow(
  156. color: context.appColors.itemBGShadow, // 阴影颜色
  157. offset: const Offset(0, 3), // 阴影的偏移量
  158. blurRadius: 8.0, // 模糊半径
  159. spreadRadius: 3.0, // 扩散半径
  160. ),
  161. ],
  162. ),
  163. child: Column(
  164. crossAxisAlignment: CrossAxisAlignment.start,
  165. children: [
  166. MyTextView(
  167. state.detail?.replies?[0].content ?? "",
  168. fontSize: 15,
  169. marginBottom: 15,
  170. isFontRegular: true,
  171. textColor: context.appColors.textDarkGray,
  172. ),
  173. //九宫格展示
  174. ImageNineGrid(
  175. isSelectEnable: false,
  176. maxImages: 10,
  177. spacing: 10,
  178. aspectRatio: 108 / 80,
  179. initialImages: state.detail?.replies?[0].resources ?? [],
  180. onImagesChanged: (list) {},
  181. ),
  182. ],
  183. ),
  184. )
  185. ],
  186. );
  187. }
  188. Widget _buildWaitingWidget(BuildContext context) {
  189. return SizedBox(
  190. width: double.infinity,
  191. child: Column(
  192. children: [
  193. const SizedBox(height: 40),
  194. MyAssetImage(
  195. Assets.mainFeedbackWaitingIcon,
  196. width: 38,
  197. height: 38,
  198. color: DarkThemeUtil.multiColors(context, AppColorsTheme.colorPrimary, darkColor: Colors.white),
  199. ),
  200. MyTextView(
  201. S.current.waiting_for_the_administrator,
  202. fontSize: 15,
  203. marginTop: 11,
  204. marginBottom: 40,
  205. isFontRegular: true,
  206. textColor: context.appColors.textDarkGray,
  207. )
  208. ],
  209. ),
  210. );
  211. }
  212. }