exam_urinalys.dart 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. import 'package:flutter/material.dart';
  2. import 'package:get/get.dart';
  3. import 'package:vitalapp/components/dialog_input.dart';
  4. import 'package:vitalapp/managers/device_controller_manager.dart';
  5. import 'package:vitalapp/pages/check/widgets/device_controller.dart';
  6. import 'package:vitalapp/pages/mappers/urine.dart';
  7. import 'package:vitalapp/pages/medical/controllers/urinalysis.dart';
  8. import 'package:vnote_device_plugin/consts/types.dart';
  9. import 'package:vitalapp/managers/interfaces/models/device.dart';
  10. import 'package:vitalapp/pages/check/widgets/exam_configurable/exam_card.dart';
  11. import 'package:vitalapp/pages/medical/controller.dart';
  12. import 'package:vitalapp/pages/medical/models/worker.dart';
  13. import 'package:vitalapp/pages/medical/widgets/device_status.dart';
  14. import 'package:vnote_device_plugin/devices/urine.dart';
  15. import 'package:vnote_device_plugin/models/exams/urine.dart';
  16. /// 尿常规
  17. class ExamUrinalysis extends StatefulWidget {
  18. const ExamUrinalysis({
  19. super.key,
  20. required this.currentValue,
  21. required this.urinalysis,
  22. });
  23. final Map currentValue;
  24. final Function(Map) urinalysis;
  25. @override
  26. State<ExamUrinalysis> createState() => _ExamUrinalysisState();
  27. }
  28. class _ExamUrinalysisState extends State<ExamUrinalysis> {
  29. final controller = Get.find<DeviceController>();
  30. late DeviceControllerManager urinaly;
  31. late UrineDeviceWorker worker;
  32. UrineExamData? urineExamData;
  33. String? deviceType = MedicalController.typeConvertMap[DeviceTypes.URINE];
  34. WorkerStatus connectStatus = WorkerStatus.connecting;
  35. List<Map<String, String>> urinalysis = [
  36. {"name": '中性粒细胞', "key": 'LEU'},
  37. {"name": '红细胞', "key": 'BLD'},
  38. {"name": '尿亚硝酸盐', "key": 'NIT'},
  39. {"name": '酮体', "key": 'KET'},
  40. {"name": '尿胆原', "key": 'UBG'},
  41. {"name": '胆红素', "key": 'BIL'},
  42. {"name": '尿蛋白', "key": 'PRO'},
  43. {"name": '葡萄糖', "key": 'GLU'},
  44. {"name": '酸碱度', "key": 'PH'},
  45. {"name": '尿比重', "key": 'SG'},
  46. {"name": '维C', "key": 'VC'},
  47. ];
  48. Map _value = {};
  49. @override
  50. void initState() {
  51. initTemperature();
  52. currentDevice();
  53. super.initState();
  54. }
  55. Future<void> currentDevice() async {
  56. DeviceModel? device = await controller.getDevice(DeviceTypes.URINE);
  57. if (device == null) {
  58. connectStatus = WorkerStatus.unboundDevice;
  59. return;
  60. }
  61. urinaly =
  62. DeviceControllerManager(DeviceTypes.URINE, device.model, device.mac);
  63. worker = urinaly.worker as UrineDeviceWorker;
  64. connectStatus = urinaly.connectStatus;
  65. loadListeners();
  66. }
  67. Future<void> initTemperature() async {
  68. await initData();
  69. }
  70. void loadListeners() {
  71. worker.successEvent.addListener(_onSuccess);
  72. worker.connectErrorEvent.addListener(_onConnectFail);
  73. worker.connectedEvent.addListener(_onConnectSuccess);
  74. worker.disconnectedEvent.addListener(_onDisconnected);
  75. // worker.tempTooLowEvent.addListener(_onTempTooLowOrTooHeigh);
  76. // worker.tempTooHighEvent.addListener(_onTempTooLowOrTooHeigh);
  77. worker.connect();
  78. }
  79. Future<void> initData() async {
  80. _value = widget.currentValue;
  81. setState(() {});
  82. }
  83. Future<void> disconnect() async {
  84. if (!(worker == null)) {
  85. await worker.disconnect();
  86. releaseListeners();
  87. }
  88. }
  89. void releaseListeners() {
  90. worker.connectErrorEvent.removeListener(_onConnectFail);
  91. worker.connectedEvent.removeListener(_onConnectSuccess);
  92. worker.successEvent.removeListener(_onSuccess);
  93. worker.disconnectedEvent.removeListener(_onDisconnected);
  94. // worker.tempTooLowEvent.removeListener(_onTempTooLowOrTooHeigh);
  95. // worker.tempTooHighEvent.removeListener(_onTempTooLowOrTooHeigh);
  96. // controller.deviceCloseSuccessEvent.removeListener(_onDeviceCloseSuccess);
  97. }
  98. @override
  99. void dispose() {
  100. disconnect();
  101. super.dispose();
  102. }
  103. void _onSuccess(_, UrineExamData e) {
  104. setState(() {
  105. // _value = e.toString();
  106. print(e);
  107. urineExamData = e;
  108. _value = UrineExamDataMapper.convertUrineExamDataToMap(urineExamData!);
  109. widget.urinalysis(_value);
  110. connectStatus = WorkerStatus.connected;
  111. });
  112. }
  113. void _onConnectFail(sender, e) {
  114. print('连接设备失败');
  115. connectStatus = WorkerStatus.connectionFailed;
  116. worker.connect();
  117. setState(() {});
  118. }
  119. void _onConnectSuccess(sender, e) {
  120. connectStatus = WorkerStatus.connected;
  121. setState(() {});
  122. }
  123. void _onDisconnected(sender, e) {
  124. print('设备连接中断');
  125. connectStatus = WorkerStatus.disconnected;
  126. worker.connect();
  127. setState(() {});
  128. }
  129. @override
  130. Widget build(BuildContext context) {
  131. return Stack(
  132. children: [
  133. _buildTemperature(),
  134. DeviceStatus(connectStatus: connectStatus),
  135. ],
  136. );
  137. }
  138. Widget _buildTemperature() {
  139. return ExamCard(
  140. title: '尿常规',
  141. // clickCard: () {
  142. // _input();
  143. // },
  144. content: Container(
  145. width: double.infinity,
  146. alignment: Alignment.center,
  147. padding: const EdgeInsets.only(
  148. bottom: 20,
  149. right: 30,
  150. left: 40,
  151. ),
  152. // constraints: const BoxConstraints(minHeight: 150),
  153. child: GridView.count(
  154. shrinkWrap: true,
  155. childAspectRatio: 6,
  156. crossAxisCount: 2, // 列数为2,即两列布局
  157. children: urinalysis.map((item) {
  158. return _buildUrineItem(item);
  159. }).toList(),
  160. ),
  161. ),
  162. );
  163. }
  164. Widget _buildUrineItem(Map<String, String> urine) {
  165. return InkWell(
  166. onTap: () {
  167. _input(urine['name']!, urine['key']!);
  168. },
  169. child: Container(
  170. child: Row(
  171. mainAxisAlignment: MainAxisAlignment.start,
  172. crossAxisAlignment: CrossAxisAlignment.center,
  173. children: [
  174. Container(
  175. alignment: Alignment.center,
  176. width: 180,
  177. child: Row(
  178. children: [
  179. Text(
  180. urine['key']!,
  181. style: const TextStyle(
  182. fontSize: 22,
  183. color: Colors.black,
  184. ),
  185. ),
  186. Text(
  187. '(${urine['name']!})',
  188. // text: _value.isEmpty ? '--' : _value,
  189. textAlign: TextAlign.center,
  190. style: const TextStyle(
  191. fontSize: 22,
  192. ),
  193. ),
  194. ],
  195. ),
  196. ),
  197. Text(
  198. _value[urine['key']!] ?? '',
  199. // text: _value.isEmpty ? '--' : _value,
  200. style: const TextStyle(
  201. fontSize: 40,
  202. ),
  203. )
  204. ],
  205. ),
  206. ),
  207. );
  208. }
  209. Future<void> _input(String name, String key) async {
  210. String? result = await VDialogInput(
  211. title: name,
  212. initialValue: _value[key],
  213. ).show();
  214. if (result?.isNotEmpty ?? false) {
  215. _value[key] = result ?? '';
  216. }
  217. widget.urinalysis(_value);
  218. setState(() {});
  219. }
  220. }