quick_create.dart 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. import 'package:flutter/material.dart';
  2. import 'package:get/get.dart';
  3. import 'package:vitalapp/architecture/utils/prompt_box.dart';
  4. import 'package:vitalapp/architecture/values/features.dart';
  5. import 'package:vitalapp/components/button.dart';
  6. import 'package:vitalapp/components/side_nav/defines.dart';
  7. import 'package:vitalapp/components/side_nav/side_nav.dart';
  8. import 'package:vitalapp/global.dart';
  9. import 'package:vitalapp/pages/patient/create/controller.dart';
  10. import 'package:vitalapp/pages/patient/create/widgets/area.dart';
  11. import 'package:vitalapp/pages/patient/create/widgets/crowd_label.dart';
  12. import 'package:vitalapp/pages/patient/create/widgets/patient_info.dart';
  13. import 'package:vitalapp/store/store.dart';
  14. class QuickCreatePatientPage extends GetView<CreatePatientController> {
  15. const QuickCreatePatientPage({super.key});
  16. @override
  17. Widget build(BuildContext context) {
  18. return Stack(
  19. children: [
  20. VSideNavView(
  21. items: _buildItems(),
  22. ),
  23. Positioned(
  24. bottom: 8,
  25. left: 200,
  26. right: 200,
  27. child: Row(
  28. mainAxisAlignment: MainAxisAlignment.spaceAround,
  29. children: [
  30. VButton(
  31. label: "保存",
  32. onTap: () {
  33. controller.saveAndBack();
  34. },
  35. ),
  36. ],
  37. ),
  38. ),
  39. ],
  40. );
  41. }
  42. VSideNavMenuItem _buildCreateManualRecord() {
  43. return VSideNavMenuItem(
  44. title: "手动录入",
  45. icon: Icon(Icons.edit_document, color: Colors.grey.shade700),
  46. pageBuilder: (_) => _buildInterval(
  47. PatientInfo(),
  48. ),
  49. );
  50. }
  51. VSideNavMenuItem _buildIDReaderRecord() {
  52. return VSideNavMenuItem(
  53. title: "读卡器录入",
  54. icon: Icon(Icons.chrome_reader_mode, color: Colors.grey.shade700),
  55. onTap: () {
  56. controller.onReadCardClicked();
  57. },
  58. );
  59. }
  60. VSideNavMenuItem _buildScanIdCardRecord() {
  61. return VSideNavMenuItem(
  62. title: "身份证识别录入",
  63. icon: Icon(Icons.perm_contact_cal_rounded, color: Colors.grey.shade700),
  64. onTap: () {
  65. if (!Store.user.hasFeature(FeatureKeys.IdCardOfflineRecognition)) {
  66. if (!kIsOnline) {
  67. PromptBox.toast("当前为离线模式,不支持此功能");
  68. return;
  69. }
  70. }
  71. controller.onIdCardScanClicked();
  72. },
  73. );
  74. }
  75. VSideNavMenuItem _buildFaceIdLogin() {
  76. return VSideNavMenuItem(
  77. title: "人脸识别",
  78. icon: Icon(Icons.sensor_occupied, color: Colors.grey.shade700),
  79. onTap: () {
  80. if (!kIsOnline) {
  81. PromptBox.toast("当前为离线模式,不支持此功能");
  82. return;
  83. }
  84. controller.onFaceIdLoginClicked();
  85. },
  86. );
  87. }
  88. List<VSideNavMenuItem> _buildItems() {
  89. final items = <VSideNavMenuItem>[];
  90. items.add(_buildCreateManualRecord());
  91. if (Store.user.hasFeature(FeatureKeys.IDCardReader)) {
  92. items.add(_buildIDReaderRecord());
  93. }
  94. if (Store.user.hasFeature(FeatureKeys.FaceRecognition)) {
  95. items.add(_buildScanIdCardRecord());
  96. }
  97. if (Store.user.hasFeature(FeatureKeys.FaceRecognition)) {
  98. items.add(_buildFaceIdLogin());
  99. }
  100. return items;
  101. }
  102. VSideNavMenuItem _buildSignatureItem() {
  103. return VSideNavMenuItem(
  104. title: "服务信息",
  105. icon: Icon(Icons.edit_document, color: Colors.grey.shade700),
  106. pageBuilder: (_) => _buildInterval(
  107. const Area(),
  108. ),
  109. );
  110. }
  111. VSideNavMenuItem _buildAboutItem() {
  112. return VSideNavMenuItem(
  113. title: "人群分类",
  114. isRequired: true,
  115. icon: Icon(Icons.info_outline, color: Colors.grey.shade700),
  116. pageBuilder: (_) => _buildInterval(
  117. const CrowdLabelView(),
  118. ),
  119. );
  120. }
  121. VSideNavMenuItem _buildLogOutItem() {
  122. return VSideNavMenuItem(
  123. title: "个人信息",
  124. icon:
  125. Icon(Icons.medical_information_outlined, color: Colors.grey.shade700),
  126. pageBuilder: (_) => _buildInterval(
  127. PatientInfo(),
  128. ),
  129. // route: VRouteSetting(
  130. // "/patient_info_panel",
  131. // () => const PatientInfo(),
  132. // binding: BindingsBuilder(
  133. // () {
  134. // Get.lazyPut(() => CreatePatientController());
  135. // },
  136. // ),
  137. // ),
  138. // shouldRearrage: true, // TODO: 调整样式后启用
  139. );
  140. }
  141. Widget _buildInterval(Widget child) {
  142. return Padding(
  143. padding: const EdgeInsets.symmetric(
  144. horizontal: 16,
  145. ),
  146. child: child,
  147. );
  148. }
  149. }