quick_create.dart 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  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. // navId: NavIds.CREATE,
  22. items: _buildItems(),
  23. ),
  24. Positioned(
  25. bottom: 8,
  26. left: 200,
  27. right: 200,
  28. child: Row(
  29. mainAxisAlignment: MainAxisAlignment.spaceAround,
  30. children: [
  31. VButton(
  32. label: "保存",
  33. onTap: () {
  34. controller.saveAndBack();
  35. },
  36. ),
  37. ],
  38. ),
  39. ),
  40. ],
  41. );
  42. }
  43. VSideNavMenuItem _buildCreateManualRecord() {
  44. return VSideNavMenuItem(
  45. title: "手动建档",
  46. icon: Icon(Icons.edit_document, color: Colors.grey.shade700),
  47. pageBuilder: (_) => _buildInterval(
  48. PatientInfo(),
  49. ),
  50. );
  51. }
  52. VSideNavMenuItem _buildIDReaderRecord() {
  53. return VSideNavMenuItem(
  54. title: "读卡建档",
  55. icon: Icon(Icons.chrome_reader_mode, color: Colors.grey.shade700),
  56. onTap: () {
  57. controller.onReadCardClicked();
  58. },
  59. );
  60. }
  61. VSideNavMenuItem _buildScanIdCardRecord() {
  62. return VSideNavMenuItem(
  63. title: "身份证识别建档",
  64. icon: Icon(Icons.perm_contact_cal_rounded, color: Colors.grey.shade700),
  65. onTap: () {
  66. if (!kIsOnline) {
  67. PromptBox.toast("当前为离线模式,不支持此功能");
  68. return;
  69. }
  70. controller.onIdCardScanClicked();
  71. },
  72. );
  73. }
  74. VSideNavMenuItem _buildFaceIdLogin() {
  75. return VSideNavMenuItem(
  76. title: "人脸识别",
  77. icon: Icon(Icons.sensor_occupied, color: Colors.grey.shade700),
  78. onTap: () {
  79. if (!kIsOnline) {
  80. PromptBox.toast("当前为离线模式,不支持此功能");
  81. return;
  82. }
  83. controller.onFaceIdLoginClicked();
  84. },
  85. );
  86. }
  87. List<VSideNavMenuItem> _buildItems() {
  88. final items = <VSideNavMenuItem>[];
  89. items.add(_buildCreateManualRecord());
  90. if (Store.user.hasFeature(FeatureKeys.IDCardReader)) {
  91. items.add(_buildIDReaderRecord());
  92. }
  93. if (Store.user.hasFeature(FeatureKeys.FaceRecognition)) {
  94. items.add(_buildScanIdCardRecord());
  95. }
  96. if (Store.user.hasFeature(FeatureKeys.FaceRecognition)) {
  97. items.add(_buildFaceIdLogin());
  98. }
  99. // items.add(_buildLogOutItem());
  100. // items.add(_buildSignatureItem());
  101. // items.add(_buildAboutItem());
  102. return items;
  103. }
  104. VSideNavMenuItem _buildSignatureItem() {
  105. return VSideNavMenuItem(
  106. title: "服务信息",
  107. icon: Icon(Icons.edit_document, color: Colors.grey.shade700),
  108. pageBuilder: (_) => _buildInterval(
  109. const Area(),
  110. ),
  111. );
  112. }
  113. VSideNavMenuItem _buildAboutItem() {
  114. return VSideNavMenuItem(
  115. title: "人群分类",
  116. isRequired: true,
  117. icon: Icon(Icons.info_outline, color: Colors.grey.shade700),
  118. pageBuilder: (_) => _buildInterval(
  119. const CrowdLabelView(),
  120. ),
  121. );
  122. }
  123. VSideNavMenuItem _buildLogOutItem() {
  124. return VSideNavMenuItem(
  125. title: "个人信息",
  126. icon:
  127. Icon(Icons.medical_information_outlined, color: Colors.grey.shade700),
  128. pageBuilder: (_) => _buildInterval(
  129. PatientInfo(),
  130. ),
  131. // route: VRouteSetting(
  132. // "/patient_info_panel",
  133. // () => const PatientInfo(),
  134. // binding: BindingsBuilder(
  135. // () {
  136. // Get.lazyPut(() => CreatePatientController());
  137. // },
  138. // ),
  139. // ),
  140. // shouldRearrage: true, // TODO: 调整样式后启用
  141. );
  142. }
  143. Widget _buildInterval(Widget child) {
  144. return Padding(
  145. padding: const EdgeInsets.symmetric(
  146. horizontal: 16,
  147. ),
  148. child: child,
  149. );
  150. }
  151. }