controller.dart 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. import 'dart:io';
  2. import 'package:fis_jsonrpc/rpc.dart';
  3. import 'package:get/get.dart';
  4. import 'package:path_provider/path_provider.dart';
  5. import 'package:uuid/uuid.dart';
  6. import 'package:vitalapp/architecture/storage/text_storage.dart';
  7. import 'package:vitalapp/architecture/utils/prompt_box.dart';
  8. import 'package:vitalapp/global.dart';
  9. import 'package:vitalapp/managers/interfaces/exam.dart';
  10. import 'package:vitalapp/pages/check/models/form.dart';
  11. import 'package:vitalapp/store/store.dart';
  12. class ExaminationController extends GetxController {
  13. ExaminationController();
  14. final _examManager = Get.find<IExamManager>();
  15. late String patientCode;
  16. late String batchNumber;
  17. _initData() {
  18. update(["examination"]);
  19. patientCode = Store.user.currentSelectPatientInfo?.code ?? '';
  20. getBatchNumber();
  21. }
  22. Future<void> getBatchNumber() async {
  23. var cachedBatchNumber = await readCachedBatchNumber();
  24. if (cachedBatchNumber != null) {
  25. batchNumber = cachedBatchNumber;
  26. } else {
  27. await saveCachedBatchNumber();
  28. }
  29. }
  30. Future<bool?> saveCachedBatchNumber() async {
  31. batchNumber = const Uuid().v4().replaceAll('-', '');
  32. TextStorage cachedRecord = TextStorage(
  33. fileName: 'batchNumber',
  34. directory: "patient/$patientCode",
  35. );
  36. return cachedRecord.save(batchNumber);
  37. }
  38. Future<String?> readCachedBatchNumber() async {
  39. TextStorage cachedRecord = TextStorage(
  40. fileName: 'batchNumber',
  41. directory: "patient/$patientCode",
  42. );
  43. return cachedRecord.read();
  44. }
  45. List<MenuItem> menuList = [
  46. MenuItem(label: "一般状况", value: 'ZZYBZK'),
  47. MenuItem(label: "辅助检查", value: 'FZJC'),
  48. MenuItem(label: "生活方式", value: 'SHFS'),
  49. MenuItem(label: "脏器及查体", value: 'ZQCT'),
  50. MenuItem(label: "现存主要健康问题", value: 'XCZYWT'),
  51. MenuItem(label: "住院及用药情况", value: 'ZYYYFMYGHYFJZS'),
  52. MenuItem(label: "健康评价及指导", value: 'JKPJJZD'),
  53. ];
  54. Future<void> createOrUpdateExam(key, templateCode, data) async {
  55. if (!kIsOnline) {
  56. // TODO: 暂不支持离线体检
  57. PromptBox.toast("请检查网络连接");
  58. return;
  59. }
  60. TextStorage template = TextStorage(
  61. fileName: key,
  62. directory: "patient/$patientCode/exam",
  63. );
  64. var result = await _examManager.createExam(CreateExamRequest(
  65. key: key,
  66. patientCode: patientCode,
  67. templateCode: templateCode,
  68. examData: data,
  69. batchNumber: batchNumber,
  70. ));
  71. if (result ?? false) {
  72. try {
  73. template.save(data);
  74. PromptBox.toast('保存成功');
  75. } catch (err) {
  76. PromptBox.toast('保存失败');
  77. }
  78. }
  79. }
  80. /// 检查数据是否为空
  81. Future<bool> checkExamEmpty() async {
  82. try {
  83. final root = await getExternalStorageDirectory();
  84. final dir = Directory("${root!.path}/patient/$patientCode/exam");
  85. if (await dir.exists()) {
  86. final files = dir.listSync();
  87. return files.isEmpty;
  88. } else {
  89. return true;
  90. }
  91. } catch (e) {
  92. return false;
  93. }
  94. }
  95. Future<void> deleteCached() async {
  96. saveCachedBatchNumber();
  97. TextStorage template = TextStorage(
  98. fileName: '',
  99. directory: "patient/$patientCode/exam",
  100. );
  101. final result = await template.deleteDirectory();
  102. if (result) {
  103. PromptBox.toast('本轮体检已结束');
  104. Get.back();
  105. }
  106. }
  107. @override
  108. void onReady() {
  109. _initData();
  110. super.onReady();
  111. }
  112. }