view.dart 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. import 'package:fis_jsonrpc/services/diagnosis.m.dart';
  2. import 'package:flutter/material.dart';
  3. import 'package:get/get.dart';
  4. import 'package:intl/intl.dart';
  5. import 'package:vitalapp/architecture/utils/prompt_box.dart';
  6. import 'package:vitalapp/components/appbar.dart';
  7. import 'package:vitalapp/components/dialog_table.dart';
  8. import 'package:vitalapp/consts/styles.dart';
  9. import 'package:vitalapp/global.dart';
  10. import 'package:vitalapp/managers/interfaces/models/diagnosis_aggregation_record_model.dart';
  11. import 'package:vitalapp/pages/medical/records/controller.dart';
  12. import 'package:vitalapp/pages/patient/list/widgets/status.dart';
  13. import 'package:vitalapp/pages/widgets/record_common_item.dart';
  14. class MedicalRecordsPage extends GetView<MedicalRecordsController> {
  15. const MedicalRecordsPage({super.key});
  16. @override
  17. Widget build(BuildContext context) {
  18. return GetBuilder(
  19. init: MedicalRecordsController(),
  20. id: "MedicalRecords",
  21. builder: (_) {
  22. return Scaffold(
  23. backgroundColor: const Color.fromRGBO(238, 238, 238, 1),
  24. appBar: VAppBar(
  25. titleWidget: const Text('健康检测记录'),
  26. ),
  27. body: Stack(
  28. children: [
  29. Row(
  30. mainAxisAlignment: MainAxisAlignment.start,
  31. crossAxisAlignment: CrossAxisAlignment.start,
  32. children: [
  33. _buildDiagram(),
  34. _buildListView(),
  35. ],
  36. )
  37. ],
  38. ),
  39. );
  40. },
  41. );
  42. }
  43. Widget _buildDiagram() {
  44. return Expanded(
  45. flex: 1,
  46. child: Padding(
  47. padding: const EdgeInsets.all(16.0).copyWith(right: 0),
  48. child: Container(
  49. // color: Colors.white,
  50. padding: const EdgeInsets.all(16),
  51. decoration: BoxDecoration(
  52. color: Colors.white,
  53. border: Border.all(
  54. color: Colors.white,
  55. ),
  56. borderRadius: GlobalStyles.borderRadius,
  57. ),
  58. child: Image.asset(
  59. 'assets/images/exam/normalMeasurementChart.png',
  60. height: double.infinity,
  61. fit: BoxFit.fitWidth,
  62. ),
  63. ),
  64. ),
  65. );
  66. }
  67. Widget _buildListView() {
  68. final scrollController = ScrollController();
  69. scrollController.addListener(
  70. () {
  71. // 如果滑动到底部
  72. try {
  73. if (scrollController.position.atEdge) {
  74. if (scrollController.position.pixels != 0) {
  75. if (controller.state.hasNextPage) {
  76. controller.loadNextPageList();
  77. }
  78. }
  79. }
  80. } catch (e) {
  81. // logger.e("listViewScrollController exception:", e);
  82. }
  83. },
  84. );
  85. return Expanded(
  86. flex: 2,
  87. child: Padding(
  88. padding: const EdgeInsets.all(16.0),
  89. child: RefreshIndicator(
  90. child: Obx(() {
  91. final children = <Widget>[];
  92. for (var element in controller.state.dataList) {
  93. children.add(_MedicalRecordCard(
  94. dto: element,
  95. ));
  96. }
  97. return controller.state.dataList.isEmpty
  98. ? Container(
  99. margin: const EdgeInsets.only(top: 80),
  100. child: Column(
  101. children: [
  102. Center(
  103. child: Image.asset(
  104. "assets/images/no_data.png",
  105. width: 300,
  106. height: 300,
  107. fit: BoxFit.cover,
  108. ),
  109. ),
  110. const Text(
  111. "暂无数据,先看看别的吧",
  112. style: TextStyle(fontSize: 18),
  113. ),
  114. ],
  115. ),
  116. )
  117. : Scrollbar(
  118. trackVisibility: true,
  119. controller: scrollController,
  120. child: GridView(
  121. shrinkWrap: true,
  122. controller: scrollController,
  123. gridDelegate:
  124. const SliverGridDelegateWithFixedCrossAxisCount(
  125. crossAxisCount: 1,
  126. mainAxisSpacing: 16,
  127. crossAxisSpacing: 20,
  128. childAspectRatio: 1080 / 180,
  129. ),
  130. children: children,
  131. ),
  132. );
  133. }),
  134. onRefresh: () async {}),
  135. ),
  136. );
  137. }
  138. }
  139. class _MedicalRecordCard extends GetView<MedicalRecordsController> {
  140. final DiagnosisAggregationRecordModel dto;
  141. const _MedicalRecordCard({required this.dto});
  142. @override
  143. Widget build(BuildContext context) {
  144. final body = Stack(
  145. children: [
  146. Row(
  147. children: [
  148. Expanded(
  149. flex: 10,
  150. child: Container(
  151. padding: const EdgeInsets.symmetric(
  152. horizontal: 30,
  153. vertical: 12,
  154. ),
  155. child: Column(
  156. crossAxisAlignment: CrossAxisAlignment.start,
  157. children: [
  158. const SizedBox(
  159. height: 8,
  160. ),
  161. Wrap(
  162. alignment: WrapAlignment.start,
  163. spacing: 20,
  164. runSpacing: 8,
  165. children: [
  166. RecordCommonItem(
  167. itemName: '姓名',
  168. itemValue: dto.patientName ?? '',
  169. fontSize: 18,
  170. ),
  171. ],
  172. ),
  173. const SizedBox(
  174. height: 20,
  175. ),
  176. Wrap(
  177. alignment: WrapAlignment.start,
  178. spacing: 20,
  179. runSpacing: 8,
  180. children: [
  181. SizedBox(
  182. width: 250,
  183. child: RecordCommonItem(
  184. itemName: '检查医生',
  185. itemValue: dto.doctorName ?? '',
  186. fontSize: 18,
  187. ),
  188. ),
  189. RecordCommonItem(
  190. itemName: '诊断时间',
  191. itemValue: DateFormat("yyyy-MM-dd HH:mm:ss")
  192. .format(dto.diagnosisTime!.toLocal()),
  193. fontSize: 18,
  194. ),
  195. ],
  196. )
  197. ],
  198. ),
  199. ),
  200. ),
  201. Expanded(
  202. flex: 1,
  203. child: Icon(
  204. Icons.keyboard_arrow_right,
  205. size: 64,
  206. color: Colors.grey.shade400,
  207. ))
  208. ],
  209. ),
  210. Positioned(
  211. top: 16,
  212. right: 0,
  213. child: _diagnosisSignStatusTag(
  214. dto: dto,
  215. ),
  216. ),
  217. ],
  218. );
  219. return Material(
  220. borderRadius: GlobalStyles.borderRadius,
  221. child: Ink(
  222. decoration: BoxDecoration(
  223. color: Colors.white,
  224. borderRadius: GlobalStyles.borderRadius,
  225. ),
  226. child: InkWell(
  227. borderRadius: GlobalStyles.borderRadius,
  228. onTap: () async {
  229. var result = await controller.getTableData(dto);
  230. await VDialogTable(
  231. isExistLocalData: dto.isExistLocalData,
  232. title: '数据展示',
  233. columnNames: const ['序号', '检测项目', '检测结果', '单位'],
  234. tableData: result,
  235. diagnosisTime: DateFormat("yyyy-MM-dd HH:mm:ss")
  236. .format(dto.diagnosisTime!.toLocal()),
  237. ).show();
  238. },
  239. child: body,
  240. ),
  241. ),
  242. );
  243. }
  244. }
  245. // ignore: camel_case_types
  246. class _diagnosisSignStatusTag extends StatelessWidget {
  247. final DiagnosisAggregationRecordModel dto;
  248. const _diagnosisSignStatusTag({required this.dto});
  249. @override
  250. Widget build(BuildContext context) {
  251. return Container(
  252. alignment: Alignment.centerRight,
  253. width: 120,
  254. child: StatusLabel(
  255. title: dto.isExistLocalData! ? "未上传" : "已上传",
  256. color: dto.isExistLocalData! ? Colors.red : Colors.green,
  257. ),
  258. );
  259. }
  260. }