vue2-client 1.9.78 → 1.9.79

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (337) hide show
  1. package/.env +19 -19
  2. package/.env.gaslink +19 -19
  3. package/.env.his +19 -19
  4. package/.env.revenue +19 -19
  5. package/.eslintrc.js +90 -90
  6. package/CHANGELOG.md +824 -824
  7. package/Components.md +60 -60
  8. package/babel.config.js +21 -21
  9. package/docs/Logic/345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +45 -45
  10. package/docs/LowCode/lowcode.md +155 -155
  11. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  12. package/docs/index.md +30 -30
  13. package/docs//345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +143 -143
  14. package/index.js +31 -31
  15. package/jest-transform-stub.js +8 -8
  16. package/jest.config.js +21 -21
  17. package/jest.setup.js +7 -7
  18. package/package.json +1 -1
  19. package/public/his/editor/editor.html +51 -51
  20. package/public/his/editor/mock/bind_data.html +779 -779
  21. package/public/his/editor/mock/data_table.html +40 -40
  22. package/public/his/editor/mock/sign.html +75 -75
  23. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  24. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  25. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  26. package/public/his/editor/vender/date97/calendar.js +4 -4
  27. package/public/his/editor/vender/date97/lang/en.js +13 -13
  28. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  29. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  30. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  31. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  32. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  33. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  34. package/public/his/editor/vender/diff.js +1627 -1627
  35. package/public/his/editor/vender/editor.js +1 -1
  36. package/public/his/editor/vender/fabric.js +31187 -31187
  37. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  38. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  39. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  40. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  41. package/public/his/editor/vender/mui/mui.min.css +4 -4
  42. package/public/his/editor/vender/mui/mui.min.js +5 -5
  43. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  44. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  45. package/public/his/editor/vender/qrcode.js +7 -7
  46. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  47. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  48. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  49. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  50. package/public/his/editor/vender/validator.js +5094 -5094
  51. package/public/his/editor/vender/weui/weui.css +5659 -5659
  52. package/public/his/editor/vender/weui/weui.min.css +4 -4
  53. package/public/his/editor/vender/weui/weui.min.js +11 -11
  54. package/public/index.html +27 -27
  55. package/src/App.vue +192 -192
  56. package/src/ReportView.js +19 -19
  57. package/src/assets/img/querySlotDemo.svg +15 -15
  58. package/src/assets/svg/badtwo.svg +1 -1
  59. package/src/assets/svg/goodtwo.svg +1 -1
  60. package/src/base-client/components/common/AMisRender/index.js +3 -3
  61. package/src/base-client/components/common/AMisRender/index.vue +263 -263
  62. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +470 -470
  63. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  64. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  65. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  66. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  67. package/src/base-client/components/common/CitySelect/CitySelect.vue +342 -342
  68. package/src/base-client/components/common/CitySelect/index.js +3 -3
  69. package/src/base-client/components/common/CitySelect/index.md +109 -109
  70. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  71. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  72. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  73. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  74. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  75. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  76. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  77. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  78. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +149 -149
  79. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  80. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  81. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  82. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  83. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  84. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  85. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  86. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  87. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  88. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  89. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  90. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  91. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  92. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  93. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  94. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  95. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  96. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  97. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  98. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  99. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  100. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  101. package/src/base-client/components/common/Tree/index.js +2 -2
  102. package/src/base-client/components/common/Upload/Upload.vue +239 -239
  103. package/src/base-client/components/common/Upload/index.js +3 -3
  104. package/src/base-client/components/common/XAddForm/XAddForm.vue +107 -107
  105. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +868 -868
  106. package/src/base-client/components/common/XAddNativeForm/demo.vue +30 -30
  107. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  108. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  109. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  110. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  111. package/src/base-client/components/common/XAddReport/XAddReport.vue +207 -207
  112. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  113. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  114. package/src/base-client/components/common/XButtons/XButtons.vue +71 -71
  115. package/src/base-client/components/common/XButtons/index.js +3 -3
  116. package/src/base-client/components/common/XButtons/index.md +61 -61
  117. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  118. package/src/base-client/components/common/XConversation/XConversation.vue +140 -140
  119. package/src/base-client/components/common/XConversation/XConversationDemo.vue +28 -28
  120. package/src/base-client/components/common/XDataCard/XDataCard.vue +420 -420
  121. package/src/base-client/components/common/XDataCard/index.js +3 -3
  122. package/src/base-client/components/common/XDataCard/index.md +1 -1
  123. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  124. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  125. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  126. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +169 -169
  127. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +304 -304
  128. package/src/base-client/components/common/XDescriptions/demo.vue +50 -50
  129. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  130. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  131. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  132. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  133. package/src/base-client/components/common/XForm/XForm.vue +340 -340
  134. package/src/base-client/components/common/XForm/XFormItem.vue +4 -3
  135. package/src/base-client/components/common/XForm/XTreeSelect.vue +250 -250
  136. package/src/base-client/components/common/XForm/index.md +178 -178
  137. package/src/base-client/components/common/XFormCol/XFormCol.vue +96 -96
  138. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +261 -261
  139. package/src/base-client/components/common/XFormGroup/demo.vue +45 -45
  140. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  141. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  142. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  143. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  144. package/src/base-client/components/common/XFormTable/XFormTable.vue +713 -713
  145. package/src/base-client/components/common/XFormTable/demo.vue +76 -76
  146. package/src/base-client/components/common/XFormTable/index.md +92 -92
  147. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +162 -162
  148. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  149. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  150. package/src/base-client/components/common/XReport/XReport.vue +892 -892
  151. package/src/base-client/components/common/XReport/XReportDemo.vue +304 -304
  152. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  153. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  154. package/src/base-client/components/common/XReport/XReportTrGroup.vue +808 -808
  155. package/src/base-client/components/common/XReport/index.js +3 -3
  156. package/src/base-client/components/common/XReport/index.md +44 -44
  157. package/src/base-client/components/common/XReport/print.js +186 -186
  158. package/src/base-client/components/common/XReportDrawer/XReportDrawer.vue +201 -201
  159. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  160. package/src/base-client/components/common/XReportGrid/XReport.vue +995 -959
  161. package/src/base-client/components/common/XReportGrid/XReportDemo.vue +42 -42
  162. package/src/base-client/components/common/XReportGrid/XReportDesign.vue +557 -557
  163. package/src/base-client/components/common/XReportGrid/XReportJsonRender.vue +380 -380
  164. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +999 -999
  165. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  166. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  167. package/src/base-client/components/common/XReportGrid/print.js +184 -184
  168. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  169. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  170. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  171. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  172. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  173. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  174. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  175. package/src/base-client/components/common/XStepView/index.js +3 -3
  176. package/src/base-client/components/common/XStepView/index.md +31 -31
  177. package/src/base-client/components/common/XTab/XTab.vue +201 -201
  178. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  179. package/src/base-client/components/common/XTab/index.js +3 -3
  180. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  181. package/src/base-client/components/common/XTable/XTable.vue +1191 -1191
  182. package/src/base-client/components/common/XTable/index.md +255 -255
  183. package/src/base-client/components/common/XTree/XTree.vue +423 -423
  184. package/src/base-client/components/common/XTree/XTreePro.vue +434 -434
  185. package/src/base-client/components/common/XTree/index.js +3 -3
  186. package/src/base-client/components/common/XTree/index.md +36 -36
  187. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  188. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  189. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  190. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  191. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +203 -203
  192. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  193. package/src/base-client/components/index.js +51 -51
  194. package/src/base-client/components/layout/XPageView/RenderRow.vue +63 -63
  195. package/src/base-client/components/layout/XPageView/XErrorView.vue +11 -11
  196. package/src/base-client/components/layout/XPageView/XPageView.vue +155 -155
  197. package/src/base-client/components/layout/XPageView/index.js +3 -3
  198. package/src/base-client/components/layout/XPageView/index.md +38 -38
  199. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  200. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  201. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  202. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  203. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  204. package/src/base-client/plugins/AppData.js +121 -121
  205. package/src/base-client/plugins/Config.js +19 -19
  206. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  207. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  208. package/src/bootstrap.js +39 -39
  209. package/src/components/CodeMirror/inedx.vue +118 -118
  210. package/src/components/CodeMirror/setting.js +40 -40
  211. package/src/components/FilePreview/FilePreview.vue +166 -166
  212. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  213. package/src/components/STable/index.js +380 -380
  214. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  215. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  216. package/src/components/exception/ExceptionPage.vue +70 -70
  217. package/src/components/menu/SideMenu.vue +75 -75
  218. package/src/components/menu/menu.js +273 -273
  219. package/src/components/tool/AStepItem.vue +60 -60
  220. package/src/config/default/antd.config.js +89 -89
  221. package/src/config/default/setting.config.js +55 -55
  222. package/src/font-style/font.css +4 -4
  223. package/src/layouts/CommonLayout.vue +56 -56
  224. package/src/layouts/GridView.vue +45 -45
  225. package/src/layouts/PageLayout.vue +151 -151
  226. package/src/layouts/SinglePageView.vue +136 -136
  227. package/src/layouts/header/AdminHeader.vue +132 -132
  228. package/src/layouts/header/HeaderNotice.vue +177 -177
  229. package/src/layouts/tabs/TabsHead.vue +189 -189
  230. package/src/layouts/tabs/TabsView.vue +389 -389
  231. package/src/lib.js +1 -1
  232. package/src/main.js +30 -30
  233. package/src/mock/extend/index.js +84 -84
  234. package/src/mock/goods/index.js +108 -108
  235. package/src/pages/AMisDemo/AMisDemo.vue +325 -325
  236. package/src/pages/AMisDemo/AMisDemo2.vue +74 -74
  237. package/src/pages/DefaultExample/index.vue +77 -77
  238. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  239. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  240. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  241. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  242. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  243. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  244. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  245. package/src/pages/DynamicStatistics/index.vue +282 -282
  246. package/src/pages/Example/childIndex.vue +15 -15
  247. package/src/pages/Example/index.vue +30 -30
  248. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  249. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  250. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  251. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  252. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  253. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  254. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  255. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  256. package/src/pages/Recording/index.vue +76 -0
  257. package/src/pages/ReportGrid/index.vue +76 -76
  258. package/src/pages/ServiceReview/index.vue +284 -284
  259. package/src/pages/SubExample/index.vue +26 -26
  260. package/src/pages/WorkflowDetail/WorkFlowDemo.vue +32 -32
  261. package/src/pages/WorkflowDetail/WorkflowDetail.vue +230 -230
  262. package/src/pages/WorkflowDetail/WorkflowPageDetail/LeaveMessage.vue +131 -131
  263. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  264. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformation.vue +302 -302
  265. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformationDetails.vue +276 -276
  266. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +864 -864
  267. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandleReso.vue +997 -997
  268. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +222 -222
  269. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkOrderParentDetails.vue +233 -233
  270. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowDetailResso.vue +261 -261
  271. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowListResolution.vue +248 -248
  272. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowLog.vue +73 -73
  273. package/src/pages/XPageViewExample/index.vue +38 -38
  274. package/src/pages/XReportView/index.vue +64 -64
  275. package/src/pages/XTreeOneProExample/index.vue +67 -67
  276. package/src/pages/login/Login.vue +378 -378
  277. package/src/pages/login/LoginV3.vue +389 -389
  278. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  279. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  280. package/src/pages/resourceManage/orgListManage.vue +98 -98
  281. package/src/pages/system/dictionary/index.vue +44 -44
  282. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  283. package/src/pages/system/monitor/operLog/index.vue +37 -37
  284. package/src/pages/system/settings/modifyPassword.vue +117 -117
  285. package/src/pages/system/ticket/index.vue +480 -480
  286. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  287. package/src/plugins/EventLogPlugin.js +33 -33
  288. package/src/plugins/FindParentsData.js +17 -17
  289. package/src/router/async/config.async.js +1 -0
  290. package/src/router/async/router.map.js +183 -183
  291. package/src/router/guards.js +263 -263
  292. package/src/router/index.js +27 -27
  293. package/src/router.js +19 -19
  294. package/src/services/api/TicketDetailsViewApi.js +46 -46
  295. package/src/services/api/cas.js +79 -79
  296. package/src/services/api/common.js +329 -329
  297. package/src/services/api/entity.js +18 -18
  298. package/src/services/api/index.js +17 -17
  299. package/src/services/api/restTools.js +67 -67
  300. package/src/services/api/workFlow.js +63 -63
  301. package/src/services/apiService.js +15 -15
  302. package/src/services/user.js +90 -90
  303. package/src/services/v3Api.js +116 -116
  304. package/src/store/modules/account.js +115 -115
  305. package/src/store/modules/index.js +5 -5
  306. package/src/store/modules/lowCode.js +33 -33
  307. package/src/store/modules/setting.js +119 -119
  308. package/src/theme/default/style.less +58 -58
  309. package/src/theme/global.less +159 -159
  310. package/src/utils/authority-utils.js +85 -85
  311. package/src/utils/errorCode.js +6 -6
  312. package/src/utils/formatter.js +74 -74
  313. package/src/utils/htmlToPDF.js +108 -108
  314. package/src/utils/htmlToPDFApi.js +5 -5
  315. package/src/utils/indexedDB.js +263 -263
  316. package/src/utils/login.js +188 -188
  317. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  318. package/src/utils/lowcode/lowcodeLog.js +29 -29
  319. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  320. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  321. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  322. package/src/utils/map-utils.js +47 -47
  323. package/src/utils/microAppUtils.js +40 -40
  324. package/src/utils/reg.js +95 -95
  325. package/src/utils/request.js +362 -362
  326. package/src/utils/routerUtil.js +450 -450
  327. package/src/utils/runEvalFunction.js +14 -14
  328. package/src/utils/util.js +313 -313
  329. package/src/utils/waterMark.js +31 -31
  330. package/test/Amis.spec.js +163 -163
  331. package/test/Tree.spec.js +167 -167
  332. package/test/myDialog.spec.js +46 -46
  333. package/test/util.test.js +36 -36
  334. package/test/v3Api.test.js +1983 -1983
  335. package/vue.config.js +199 -199
  336. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
  337. /package/src/base-client/components/common/Recording/{Recoding.vue → Recording.vue} +0 -0
@@ -1,868 +1,868 @@
1
- <template>
2
- <div>
3
- <a-form-model
4
- v-if="loaded"
5
- ref="selectForm"
6
- :zIndex="1001"
7
- :model="form"
8
- v-bind="formItemLayout"
9
- :layout="layout"
10
- :rules="rules">
11
- <a-row :gutter="16" type="flex">
12
- <x-form-item
13
- v-for="(item, index) in realJsonData"
14
- :key="index"
15
- :attr="item"
16
- :disabled="itemDisabled(item)"
17
- :read-only="readonly(item)"
18
- :files="files"
19
- :style="layout === 'inline' ? { marginTop:'5px' } : undefined"
20
- :form="form"
21
- :images="images"
22
- :service-name="serviceName"
23
- mode="新增/修改"
24
- :layout="layout"
25
- :get-data-params="getDataParams"
26
- :env="env"
27
- @x-form-item-emit-func="emitFunc"
28
- @rowChoose="rowChoose"
29
- :setForm="setForm"
30
- />
31
- </a-row>
32
- <a-row :gutter="16" v-for="(groupItem, groupIndex) in groupJsonData" :key="groupIndex">
33
- <a-card v-if="groupItem.groupItems.length > 0" :title="groupItem.name" :bordered="false" size="small">
34
- <x-form-item
35
- v-for="(item, index) in groupItem.groupItems"
36
- :key="index"
37
- :attr="item"
38
- :disabled="itemDisabled(item)"
39
- :readonly="readonly(item)"
40
- :files="files"
41
- :style="layout ==='inline'?{marginTop:'5px'}:undefined"
42
- :form="form[groupItem.model]"
43
- :images="images"
44
- :service-name="serviceName"
45
- mode="新增/修改"
46
- :get-data-params="getDataParams"
47
- :env="env"
48
- :setForm="setForm"
49
- @rowChoose="rowChoose"
50
- />
51
- </a-card>
52
- <template v-else>
53
- <slot
54
- name="groupFormItems"
55
- :form="form"
56
- :model="groupItem.model"
57
- :rules="rules"
58
- :modifyModelData="modifyModelData"></slot>
59
- </template>
60
- </a-row>
61
- <a-row :gutter="16" v-for="(item, key) in simpleFormJsonData" :key="'row' + key">
62
- <a-card v-if="item.value.length > 0" :title="item.name" :bordered="false" size="small">
63
- <x-form-item
64
- v-for="(formItem, formItemIndex) in item.value"
65
- :key="key + formItemIndex"
66
- :attr="formItem"
67
- :disabled="itemDisabled(formItem)"
68
- :readonly="readonly(formItem)"
69
- :files="files"
70
- :style="layout ==='inline'?{marginTop:'5px'}:undefined"
71
- :form="form[groupItem.model]"
72
- :images="images"
73
- :service-name="serviceName"
74
- mode="新增/修改"
75
- :get-data-params="getDataParams"
76
- :env="env"
77
- :setForm="setForm"
78
- @rowChoose="rowChoose"
79
- />
80
- </a-card>
81
- </a-row>
82
- <a-row :gutter="16" v-for="(item, key) in childTableData" :key="'childTableRow' + key">
83
- <a-card :title="item.name" :bordered="false" size="small">
84
- <x-form-table
85
- :key="'childTable_' + item.model"
86
- :title="item.name"
87
- :queryParamsName="item.childTableConfigName"
88
- :localEditMode="true"
89
- :fixed-query-form="childTableFixedQueryForm(item)"
90
- :service-name="serviceName"
91
- :ref="'childXFormTable_' + item.model">
92
- </x-form-table>
93
- </a-card>
94
- </a-row>
95
- <a-row type="flex" justify="center">
96
- <a-button v-if="showSubmitBtn" :loading="loading" type="primary" @click="onSubmit()">提交</a-button>
97
- </a-row>
98
- </a-form-model>
99
- </div>
100
- </template>
101
- <script>
102
- import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
103
- import util, { formatDate, setDataByRealKey } from '@vue2-client/utils/util'
104
- import { mapState } from 'vuex'
105
- import { addOrModify, getConfigByName, getConfigByNameAsync, runLogic } from '@vue2-client/services/api/common'
106
- import { checkIdNumber, REG_EMAIL, REG_LANDLINE, REG_PHONE } from '@vue2-client/utils/reg'
107
- import moment from 'moment/moment'
108
- import { executeStrFunction, executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
109
-
110
- export default {
111
- name: 'XAddNativeForm',
112
- components: {
113
- XFormItem,
114
- XFormTable: () => import('@vue2-client/base-client/components/common/XFormTable/XFormTable.vue')
115
- },
116
- props: {},
117
- data () {
118
- return {
119
- // 预览模式
120
- viewMode: false,
121
- // 是否处理表单Key值
122
- isHandleFormKey: true,
123
- // 内容加载是否完成
124
- loaded: false,
125
- // 业务类型
126
- businessType: '',
127
- // 业务标题
128
- title: '',
129
- // 新增或修改业务是否执行中
130
- loading: false,
131
- // 表单Model
132
- form: {},
133
- // 配置名称
134
- configName: undefined,
135
- // 配置内容,用于查询配置生成器的预览
136
- configContent: undefined,
137
- // 表单项集合
138
- formItems: [],
139
- // 服务名称
140
- serviceName: undefined,
141
- // 是否显示提交按钮
142
- showSubmitBtn: true,
143
- // 修改有文件的表单时使用
144
- files: [],
145
- images: [],
146
- // 校验
147
- rules: {},
148
- // 调用logic获取数据源的追加参数
149
- getDataParams: {},
150
- // 动态简易表单集合
151
- simpleFormJsonData: {},
152
- // 待修改的数据集
153
- modifyModelData: {},
154
- // 当前环境
155
- env: 'prod',
156
- // 表单模式 horizontal | vertical | inline
157
- layout: 'horizontal'
158
- }
159
- },
160
- computed: {
161
- // 过滤出用于新增/修改场景的表单项
162
- realJsonData: function () {
163
- return this.formItems.filter((item) => {
164
- return item.addOrEdit && item.addOrEdit !== 'no' && item.addOrEdit !== 'silenceAdd' && item.addOrEdit !== 'version' && !this.itemDisabled(item)
165
- })
166
- },
167
- // 过滤出用于新增/修改场景的表单项
168
- groupJsonData: function () {
169
- return this.formItems.filter((item) => {
170
- return item.type === 'group'
171
- }).map((item) => {
172
- item.groupItems = item.groupItems.filter((item) => {
173
- return item.addOrEdit && item.addOrEdit !== 'no' && item.addOrEdit !== 'silenceAdd' && item.addOrEdit !== 'version' && !this.itemDisabled(item)
174
- }).map((groupItem) => {
175
- // 只保留第一个下划线后面的内容
176
- // 多层校验规则需要将prop设置为 key1.key2.....
177
- groupItem.prop = `${item.model}.${groupItem.model.substring(groupItem.model.indexOf('_') + 1)}`
178
- groupItem.model = groupItem.model.substring(groupItem.model.indexOf('_') + 1)
179
- return groupItem
180
- })
181
- return item
182
- }
183
- )
184
- },
185
- // 过滤出用于子表数据新增/修改场景的表单项
186
- childTableData: function () {
187
- return this.formItems.filter((item) => {
188
- return item.type === 'childTable'
189
- })
190
- },
191
- // 过滤出用于静默新增场景的表单项
192
- silenceAddJsonData: function () {
193
- return this.formItems.filter(function (item) {
194
- return item.addOrEdit === 'silenceAdd'
195
- })
196
- },
197
- // 过滤出版本号表单项
198
- versionJsonData: function () {
199
- return this.formItems.filter(function (item) {
200
- return item.addOrEdit === 'version'
201
- })
202
- },
203
- formItemLayout () {
204
- if (this.layout === 'horizontal') {
205
- return {
206
- labelCol: { span: 4, offset: 2 },
207
- wrapperCol: { span: 14 },
208
- }
209
- }
210
- if (this.layout === 'vertical') {
211
- return {}
212
- }
213
- return {
214
- labelCol: { span: 6 },
215
- wrapperCol: { span: 18 },
216
- }
217
- },
218
- ...mapState('account', { currUser: 'user' })
219
- },
220
- methods: {
221
- runLogic,
222
- getConfigByNameAsync,
223
- getConfigByName,
224
- init (params) {
225
- const {
226
- configName, configContent, formItems, formJson, viewMode, isHandleFormKey, isKeyHandle = true,
227
- showSubmitBtn = true, serviceName,
228
- modifyModelData = {}, businessType, title, fixedAddForm = {}, getDataParams = {},
229
- simpleFormJsonData = {}, env = 'prod', layout, xAddFormLayout = 'horizontal'
230
- } = params
231
- this.loaded = false
232
- // 兼容需要省略 传递 layout: res.xAddFormLayout 可以使用 ...res 展开运算符 直接转递
233
- if (xAddFormLayout && layout === undefined) {
234
- this.layout = xAddFormLayout
235
- } else {
236
- this.layout = layout
237
- }
238
- if (isHandleFormKey && !isKeyHandle) {
239
- this.isHandleFormKey = isKeyHandle
240
- } else if (isHandleFormKey) {
241
- this.isHandleFormKey = isHandleFormKey
242
- } else {
243
- this.isHandleFormKey = isKeyHandle
244
- }
245
- this.configName = configName
246
- this.configContent = configContent
247
- this.formItems = this.getFromItem(formItems, formJson)
248
- this.viewMode = viewMode
249
- this.isHandleFormKey = isHandleFormKey
250
- this.showSubmitBtn = showSubmitBtn
251
- this.serviceName = serviceName
252
- this.businessType = businessType
253
- this.title = title
254
- this.getDataParams = getDataParams
255
- this.simpleFormJsonData = simpleFormJsonData
256
- this.env = env
257
- // 如果 fixedAddForm 有 selected_id 值,并且设置了处理表单key值,则多给 selected_id 加前缀 避免处理错误
258
- if (fixedAddForm.selected_id && this.isHandleFormKey) {
259
- fixedAddForm._selected_id = fixedAddForm.selected_id
260
- delete fixedAddForm.selected_id
261
- }
262
- // 设置普通表单项的相关参数
263
- const formData = Object.assign({}, fixedAddForm)
264
- for (let i = 0; i < this.realJsonData.length; i++) {
265
- const item = this.realJsonData[i]
266
- this.setFormProps(formData, item, null)
267
- }
268
- // 设置表单分组项目相关参数
269
- for (let i = 0; i < this.groupJsonData.length; i++) {
270
- const groupItem = this.groupJsonData[i]
271
- formData[groupItem.model] = {}
272
- for (let j = 0; j < groupItem.groupItems.length; j++) {
273
- const item = groupItem.groupItems[j]
274
- this.setFormProps(formData[groupItem.model], item, item.prop)
275
- }
276
- }
277
- // 设置动态简易表单项的相关参数
278
- for (const key in this.simpleFormJsonData) {
279
- for (const item of this.simpleFormJsonData[key].value) {
280
- item.model = key + '@' + item.model
281
- this.setFormProps(formData, item, null)
282
- }
283
- }
284
-
285
- this.form = formData
286
- // 修改场景下对表单项赋值
287
- if (modifyModelData && modifyModelData.data) {
288
- this.modifyModelData = modifyModelData
289
- if (Object.keys(modifyModelData.data).length > 0) {
290
- this.getModifyModelData(modifyModelData)
291
- }
292
- }
293
- // 处理表单得附件
294
- if (modifyModelData && modifyModelData.files) {
295
- this.files = modifyModelData.files
296
- }
297
- if (modifyModelData && modifyModelData.images) {
298
- this.images = modifyModelData.images
299
- }
300
- this.loaded = true
301
- },
302
- // 兼容需要省略 传递 [formItems: res.formJson ] 可以使用 ...res 展开运算符 直接转递
303
- getFromItem (formItems, formJson) {
304
- const _formItems = formItems || formJson
305
- if (typeof formItems === 'string') {
306
- return JSON.parse(_formItems)
307
- } else {
308
- return JSON.parse(JSON.stringify(_formItems))
309
- }
310
- },
311
- // 时间组件赋默认值
312
- getDateRange (type, defaultValue) {
313
- // const format = type === 'datePicker' ? 'YYYY-MM-DD' : 'YYYY-MM-DD HH:mm:ss'
314
- const format = 'YYYY-MM-DD HH:mm:ss'
315
- let start
316
- switch (defaultValue) {
317
- case 'curYear':
318
- start = moment().startOf('year').format(format)
319
- break
320
- case 'curMonth':
321
- start = moment().startOf('month').format(format)
322
- break
323
- case 'curDay':
324
- start = moment().startOf('day').format(format)
325
- break
326
- default:
327
- return defaultValue
328
- }
329
- return start
330
- },
331
- setFormProps (formData, item, groupItem) {
332
- if (formData[item.model] === undefined || formData[item.model] === null) {
333
- formData[item.model] = undefined
334
- }
335
- if (!formData[item.model] && item.formDefault) {
336
- if (['datePicker', 'rangePicker', 'yearPicker', 'monthPicker'].includes(item.type)) {
337
- formData[item.model] = this.getDateRange(item.type, item.formDefault)
338
- } else if (['treeSelect', 'select', 'checkbox'].includes(item.type) && ['curOrgId', 'curDepId', 'curUserId'].includes(item.formDefault)) {
339
- if (item.formDefault === 'curOrgId') {
340
- formData[item.model] = item.type === 'select' ? this.currUser.orgid : [this.currUser.orgid]
341
- }
342
- if (item.formDefault === 'curDepId') {
343
- formData[item.model] = item.type === 'select' ? this.currUser.depids : [this.currUser.depids]
344
- }
345
- if (item.formDefault === 'curUserId') {
346
- formData[item.model] = item.type === 'select' ? this.currUser.id : [this.currUser.id]
347
- }
348
- } else {
349
- formData[item.model] = item.formDefault
350
- }
351
- }
352
- // 处理表单校验情况
353
- if (item.rule) {
354
- if (groupItem) {
355
- this.rules[groupItem] = []
356
- } else {
357
- this.rules[item.model] = []
358
- }
359
- const required = item.rule.required ? item.rule.required === true || item.rule.required === 'true' : false
360
- let trigger
361
- let message
362
- if (required) {
363
- switch (item.type) {
364
- case 'select':
365
- case 'checkbox':
366
- case 'radio':
367
- case 'treeSelect':
368
- case 'rangePicker':
369
- case 'monthPicker':
370
- case 'yearPicker':
371
- case 'datePicker':
372
- case 'file':
373
- case 'image':
374
- case 'citySelect':
375
- case 'addressSearch':
376
- case 'personSetting':
377
- message = '请选择' + item.name
378
- trigger = 'change'
379
- break
380
- default:
381
- message = '请输入' + item.name
382
- trigger = 'blur'
383
- }
384
- if (groupItem) {
385
- this.rules[groupItem].push({
386
- required: true,
387
- message: message,
388
- trigger: trigger
389
- })
390
- } else {
391
- this.rules[item.model].push({
392
- required: true,
393
- message: message,
394
- trigger: trigger
395
- })
396
- }
397
- }
398
-
399
- switch (item.rule.type) {
400
- case 'number':
401
- case 'integer':
402
- case 'float':
403
- // eslint-disable-next-line no-case-declarations
404
- let defaultValue
405
- // eslint-disable-next-line no-case-declarations
406
- let message
407
- switch (item.rule.type) {
408
- case 'number':
409
- item.numberInput = true
410
- message = '数字'
411
- defaultValue = 0
412
- break
413
- case 'integer':
414
- item.numberInput = true
415
- message = '整数'
416
- defaultValue = 0
417
- break
418
- case 'float':
419
- item.numberInput = true
420
- message = '小数'
421
- defaultValue = 0.0
422
- break
423
- }
424
- if (groupItem) {
425
- this.rules[groupItem].push({
426
- type: item.rule.type,
427
- message: item.name + '必须为' + message,
428
- transform: (value) => {
429
- if (value && value.length !== 0) {
430
- return Number(value)
431
- } else {
432
- return defaultValue
433
- }
434
- },
435
- trigger: 'blur'
436
- })
437
- } else {
438
- this.rules[item.model].push({
439
- type: item.rule.type,
440
- message: item.name + '必须为' + message,
441
- transform: (value) => {
442
- if (value && value.length !== 0) {
443
- return Number(value)
444
- } else {
445
- return defaultValue
446
- }
447
- },
448
- trigger: 'blur'
449
- })
450
- }
451
- break
452
- case 'email': {
453
- const validator = (rule, value, callback) => {
454
- if (value && !REG_EMAIL.test(value)) {
455
- callback(new Error('请输入正确的邮箱地址'))
456
- } else {
457
- callback()
458
- }
459
- }
460
- this.rules[groupItem || item.model].push({
461
- type: 'email',
462
- validator: validator,
463
- message: '请输入正确的邮箱地址',
464
- trigger: 'blur'
465
- })
466
- break
467
- }
468
- case 'userPhone': {
469
- this.rules[groupItem || item.model].push({
470
- type: 'userPhone',
471
- validator: (rule, value, callback) => {
472
- if (value && !REG_PHONE.test(value)) {
473
- callback(new Error('请输入正确的手机号码'))
474
- } else {
475
- callback()
476
- }
477
- },
478
- message: '请输入正确的手机号码',
479
- trigger: 'blur'
480
- })
481
- break
482
- }
483
- case 'idNumber': {
484
- this.rules[groupItem || item.model].push({
485
- validator: (rule, value, callback) => {
486
- if (value && !checkIdNumber(value)) {
487
- callback(new Error('请输入正确的身份证号码'))
488
- } else {
489
- callback()
490
- }
491
- },
492
- trigger: 'blur'
493
- })
494
- break
495
- }
496
- case 'landlineNumber': {
497
- this.rules[item.model].push({
498
- validator: (rule, value, callback) => {
499
- if (value && !REG_LANDLINE.test(value)) {
500
- callback(new Error('请输入正确的座机号码'))
501
- } else {
502
- callback()
503
- }
504
- },
505
- trigger: 'blur'
506
- })
507
- break
508
- }
509
- // 大于0
510
- case 'greaterThanZero': {
511
- item.numberInput = true
512
- this.rules[item.model].push({
513
- validator: (rule, value, callback) => {
514
- if (isNaN(value) || value <= 0) {
515
- callback(new Error('请输入一个大于0的数字'))
516
- } else {
517
- callback()
518
- }
519
- },
520
- trigger: 'blur'
521
- })
522
- break
523
- }
524
- // 大于等于0
525
- case 'greaterThanOrEqualZero': {
526
- item.numberInput = true
527
- this.rules[item.model].push({
528
- validator: (rule, value, callback) => {
529
- if (isNaN(value) || value < 0) {
530
- callback(new Error('请输入一个大于等于0的数字'))
531
- } else {
532
- callback()
533
- }
534
- },
535
- trigger: 'blur'
536
- })
537
- break
538
- }
539
- case 'stringLength': {
540
- this.rules[item.model].push({
541
- validator: (rule, value, callback) => {
542
- if (value && value.length < item.rule.minLen) {
543
- callback(new Error('长度不能少于' + item.rule.minLen + '个字符'))
544
- } else if (value && value.length > item.rule.maxLen) {
545
- callback(new Error('长度不能超过' + item.rule.maxLen + '个字符'))
546
- } else {
547
- callback()
548
- }
549
- },
550
- trigger: 'blur'
551
- })
552
- break
553
- }
554
- case 'customJs': {
555
- this.rules[item.model].push({
556
- validator: (rule, value, callback) => {
557
- this.customJsValidate(rule, value, callback, item)
558
- },
559
- trigger: 'blur'
560
- })
561
- break
562
- }
563
- }
564
- }
565
- },
566
- customJsValidate (rule, value, callback, item) {
567
- if (item.rule.customValidatorFunc) {
568
- executeStrFunctionByContext(this, item.rule.customValidatorFunc, [rule, value, callback, this.form, item, this.util, runLogic, getConfigByNameAsync])
569
- } else {
570
- callback()
571
- }
572
- },
573
- itemDisabled (value) {
574
- return (this.businessType === '新增' && value.addOrEdit === 'edit') ||
575
- (this.businessType === '修改' && value.addOrEdit === 'add')
576
- },
577
- readonly (value) {
578
- return value.addOrEdit === 'readonly'
579
- },
580
- async onSubmit () {
581
- const valid = await this.validateForm()
582
- if (!valid) return false
583
- if (this.viewMode) {
584
- this.$message.info('预览模式禁止新增和修改')
585
- return false
586
- }
587
- this.loading = true
588
- const requestForm = this.prepareForm()
589
- await this.appendSilenceAddFields(requestForm)
590
- const realForm = this.handleFormKeys(requestForm)
591
- // 增加子表数据
592
- if (this.childTableData.length > 0) {
593
- for (const item of this.childTableData) {
594
- const childModel = item.model
595
- const childData = this.$refs['childXFormTable_' + item.model][0].getTableData()
596
- for (let i = 0; i < childData.length; i++) {
597
- childData[i] = this.handleFormKeys(childData[i])
598
- // 外键不需要带表别名,所以此处放到表单处理后赋值
599
- if (realForm.id) {
600
- childData[i][item.childTableForeignKeyName] = realForm.id
601
- }
602
- }
603
- realForm[childModel] = childData
604
- }
605
- }
606
- if (this.$listeners.onSubmit) {
607
- // 交由父级处理
608
- this.$emit('onSubmit', {
609
- businessType: this.businessType,
610
- serviceName: this.serviceName,
611
- realForm: realForm,
612
- currUserName: this.currUser.name,
613
- currUserId: this.currUser.id,
614
- orgId: this.currUser.orgid
615
- })
616
- } else {
617
- this.defaultSubmit(realForm)
618
- }
619
- },
620
-
621
- async asyncSubmit () {
622
- return new Promise((resolve, reject) => {
623
- this.$refs.selectForm.validate(async valid => {
624
- if (!valid) {
625
- reject(new Error('Form validation failed'))
626
- return
627
- }
628
- this.loading = true
629
- const requestForm = this.prepareForm()
630
- await this.appendSilenceAddFields(requestForm)
631
- const realForm = this.handleFormKeys(requestForm)
632
- if (this.businessType === '新增') {
633
- delete realForm.id
634
- }
635
- resolve({
636
- realForm,
637
- businessType: this.businessType,
638
- serviceName: this.serviceName,
639
- currUserName: this.currUser.name,
640
- currUserId: this.currUser.id,
641
- orgId: this.currUser.orgid
642
- })
643
- })
644
- })
645
- },
646
-
647
- validateForm () {
648
- return new Promise((resolve) => {
649
- this.$refs.selectForm.validate(valid => resolve(valid))
650
- })
651
- },
652
-
653
- childTableFixedQueryForm (item) {
654
- if (this.modifyModelData?.primaryKeyData) {
655
- const fixedForm = {}
656
- fixedForm[item.childTableForeignKeyName] = Object.values(this.modifyModelData.primaryKeyData)[0]
657
- return fixedForm
658
- }
659
- return null
660
- },
661
-
662
- prepareForm () {
663
- const form = { ...this.form }
664
- for (const key of Object.keys(form)) {
665
- const value = form[key]
666
- if (value === null || (typeof value === 'object' && Object.keys(value).length === 0)) {
667
- form[key] = undefined
668
- }
669
- }
670
- return form
671
- },
672
-
673
- async appendSilenceAddFields (form) {
674
- if (this.businessType === '新增') {
675
- for (const item of this.silenceAddJsonData) {
676
- switch (item.silencePurpose) {
677
- case 'createTime':
678
- form[item.model] = formatDate('now')
679
- break
680
- case 'operator':
681
- form[item.model] = this.currUser.name
682
- break
683
- case 'operatorId':
684
- form[item.model] = this.currUser.id
685
- break
686
- case 'orgId':
687
- form[item.model] = this.currUser.orgid
688
- break
689
- case 'orgName':
690
- form[item.model] = this.currUser.orgs
691
- break
692
- case 'depId':
693
- form[item.model] = this.currUser.depids
694
- break
695
- case 'depName':
696
- form[item.model] = this.currUser.deps
697
- break
698
- }
699
- }
700
- for (const item of this.silenceAddJsonData.filter((item) => item.silencePurpose === 'customize')) {
701
- form[item.model] = await runLogic(item.silenceSource, form, this.serviceName)
702
- }
703
- }
704
- },
705
-
706
- handleFormKeys (form) {
707
- const realForm = {}
708
- for (const key of Object.keys(form)) {
709
- const value = form[key]
710
- const extraFormKeyTagIndex = key.indexOf('@')
711
- if (extraFormKeyTagIndex !== -1) {
712
- const extraFormKey = key.substring(0, extraFormKeyTagIndex)
713
- const realKey = key.substring(extraFormKeyTagIndex + 1)
714
- if (!realForm[extraFormKey]) {
715
- realForm[extraFormKey] = {}
716
- }
717
- realForm[extraFormKey][realKey] = value
718
- } else {
719
- const realKey = this.isHandleFormKey ? this.getRealKey(key) : key
720
- // 如果发生重名,不覆盖,把key的别名带上
721
- if (realForm[realKey]) {
722
- realForm[key] = value
723
- } else {
724
- realForm[realKey] = value
725
- }
726
- }
727
- }
728
- return realForm
729
- },
730
- // 默认提交事件
731
- defaultSubmit (realForm, callback) {
732
- // 新增移除id
733
- if (this.businessType === '新增') {
734
- delete realForm.id
735
- }
736
- // 组织请求
737
- const requestParameters = {
738
- queryParamsName: this.configName,
739
- queryParams: this.configContent,
740
- form: realForm,
741
- businessType: this.businessType,
742
- operator: this.currUser.name
743
- }
744
- addOrModify(requestParameters, this.serviceName, this.env === 'dev').then(data => {
745
- this.$message.success(this.businessType + '成功!')
746
- // commit
747
- this.$emit('afterSubmit', { type: this.businessType, id: data.id, form: requestParameters.form })
748
- }).catch(e => {
749
- this.$message.error(this.businessType + '失败:' + e)
750
- }).finally(() => {
751
- if (callback) {
752
- callback()
753
- }
754
- })
755
- },
756
- // 获取表单字段实际值
757
- getRealKey (key) {
758
- if (this.isHandleFormKey) {
759
- return key.substring(key.indexOf('_') + 1)
760
- } else {
761
- return key
762
- }
763
- },
764
- /**
765
- * 获取被修改记录数据
766
- * @param modifyModelData 被修改记录的数据
767
- */
768
- getModifyModelData (modifyModelData) {
769
- if (modifyModelData.primaryKeyData) {
770
- this.form = Object.assign(this.form, modifyModelData.primaryKeyData)
771
- }
772
- // 对动态简易表单项特殊处理
773
- for (const key in modifyModelData.data) {
774
- const realKey = this.isHandleFormKey ? this.getRealKey(key) : key
775
- if (this.simpleFormJsonData[realKey]) {
776
- const extraForm = JSON.parse(modifyModelData.data[key])
777
- for (const key in extraForm) {
778
- const model = realKey + '@' + key
779
- this.form[model] = extraForm[key]
780
- }
781
- }
782
- }
783
- // 对普通表单项处理
784
- for (let i = 0; i < this.realJsonData.length; i++) {
785
- if (['FilesId', 'Images'].includes(this.realJsonData[i])) {
786
- // 附件需要跳过 因为会通过 modifyModelData中的files,images属性给upload赋值
787
- // 新增修改表单每次提交时只会提交最新添加的文件
788
- continue
789
- }
790
- const item = this.realJsonData[i]
791
- if (modifyModelData.data[item.model] || modifyModelData.data[item.model] === 0) {
792
- if (modifyModelData.data[item.model] instanceof Array) {
793
- this.form[item.model] = modifyModelData.data[item.model]
794
- } else {
795
- this.form[item.model] = modifyModelData.data[item.model] + ''
796
- }
797
- }
798
- }
799
- // 对分组表单进行处理
800
- for (let i = 0; i < this.groupJsonData.length; i++) {
801
- const item = this.groupJsonData[i]
802
- try {
803
- if (modifyModelData.data[item.model]) {
804
- this.form[item.model] = JSON.parse(modifyModelData.data[item.model])
805
- }
806
- } catch (e) {
807
- }
808
- }
809
- // 追加版本号信息
810
- for (const item of this.versionJsonData) {
811
- if (!modifyModelData.data[item.model]) {
812
- this.form[item.model] = 0
813
- } else {
814
- this.form[item.model] = modifyModelData.data[item.model] + ''
815
- }
816
- }
817
- },
818
- setForm (obj) {
819
- this.form = Object.assign(this.form, obj)
820
- },
821
- setFormWithKey (obj) {
822
- setDataByRealKey(this.form, obj)
823
- },
824
- emitFunc (func, data) {
825
- // 打开列表选择框逻辑
826
- if (data?.model) {
827
- this.$emit(func, data, this.form[data.model])
828
- } else {
829
- this.$emit(func, data)
830
- }
831
- this.$emit('x-form-item-emit-func', func, data)
832
- },
833
- close () {
834
- this.loaded = false
835
- },
836
- /**
837
- * 行选择事件
838
- * @param row 选中行集合
839
- * @param attr 表单项属性
840
- */
841
- async rowChoose (row, attr, callback) {
842
- // 如果配置了自定义函数
843
- if (attr.dataChangeFunc) {
844
- await executeStrFunction(attr.dataChangeFunc, [this.form, this.setForm, {
845
- ...attr,
846
- selectRows: row
847
- }, util, this.mode, runLogic, getConfigByNameAsync])
848
- } else {
849
- // 默认填充选中行数据到当前表单
850
- setDataByRealKey(this.form, row[0])
851
- }
852
- if (callback) {
853
- callback()
854
- }
855
- }
856
- }
857
- }
858
- </script>
859
-
860
- <style scoped>
861
- :deep(.ant-form-inline .ant-form-item ) {
862
- display: block !important;
863
- }
864
-
865
- :deep(.ant-form-item-with-help) {
866
- margin-bottom: 0;
867
- }
868
- </style>
1
+ <template>
2
+ <div>
3
+ <a-form-model
4
+ v-if="loaded"
5
+ ref="selectForm"
6
+ :zIndex="1001"
7
+ :model="form"
8
+ v-bind="formItemLayout"
9
+ :layout="layout"
10
+ :rules="rules">
11
+ <a-row :gutter="16" type="flex">
12
+ <x-form-item
13
+ v-for="(item, index) in realJsonData"
14
+ :key="index"
15
+ :attr="item"
16
+ :disabled="itemDisabled(item)"
17
+ :read-only="readonly(item)"
18
+ :files="files"
19
+ :style="layout === 'inline' ? { marginTop:'5px' } : undefined"
20
+ :form="form"
21
+ :images="images"
22
+ :service-name="serviceName"
23
+ mode="新增/修改"
24
+ :layout="layout"
25
+ :get-data-params="getDataParams"
26
+ :env="env"
27
+ @x-form-item-emit-func="emitFunc"
28
+ @rowChoose="rowChoose"
29
+ :setForm="setForm"
30
+ />
31
+ </a-row>
32
+ <a-row :gutter="16" v-for="(groupItem, groupIndex) in groupJsonData" :key="groupIndex">
33
+ <a-card v-if="groupItem.groupItems.length > 0" :title="groupItem.name" :bordered="false" size="small">
34
+ <x-form-item
35
+ v-for="(item, index) in groupItem.groupItems"
36
+ :key="index"
37
+ :attr="item"
38
+ :disabled="itemDisabled(item)"
39
+ :readonly="readonly(item)"
40
+ :files="files"
41
+ :style="layout ==='inline'?{marginTop:'5px'}:undefined"
42
+ :form="form[groupItem.model]"
43
+ :images="images"
44
+ :service-name="serviceName"
45
+ mode="新增/修改"
46
+ :get-data-params="getDataParams"
47
+ :env="env"
48
+ :setForm="setForm"
49
+ @rowChoose="rowChoose"
50
+ />
51
+ </a-card>
52
+ <template v-else>
53
+ <slot
54
+ name="groupFormItems"
55
+ :form="form"
56
+ :model="groupItem.model"
57
+ :rules="rules"
58
+ :modifyModelData="modifyModelData"></slot>
59
+ </template>
60
+ </a-row>
61
+ <a-row :gutter="16" v-for="(item, key) in simpleFormJsonData" :key="'row' + key">
62
+ <a-card v-if="item.value.length > 0" :title="item.name" :bordered="false" size="small">
63
+ <x-form-item
64
+ v-for="(formItem, formItemIndex) in item.value"
65
+ :key="key + formItemIndex"
66
+ :attr="formItem"
67
+ :disabled="itemDisabled(formItem)"
68
+ :readonly="readonly(formItem)"
69
+ :files="files"
70
+ :style="layout ==='inline'?{marginTop:'5px'}:undefined"
71
+ :form="form[groupItem.model]"
72
+ :images="images"
73
+ :service-name="serviceName"
74
+ mode="新增/修改"
75
+ :get-data-params="getDataParams"
76
+ :env="env"
77
+ :setForm="setForm"
78
+ @rowChoose="rowChoose"
79
+ />
80
+ </a-card>
81
+ </a-row>
82
+ <a-row :gutter="16" v-for="(item, key) in childTableData" :key="'childTableRow' + key">
83
+ <a-card :title="item.name" :bordered="false" size="small">
84
+ <x-form-table
85
+ :key="'childTable_' + item.model"
86
+ :title="item.name"
87
+ :queryParamsName="item.childTableConfigName"
88
+ :localEditMode="true"
89
+ :fixed-query-form="childTableFixedQueryForm(item)"
90
+ :service-name="serviceName"
91
+ :ref="'childXFormTable_' + item.model">
92
+ </x-form-table>
93
+ </a-card>
94
+ </a-row>
95
+ <a-row type="flex" justify="center">
96
+ <a-button v-if="showSubmitBtn" :loading="loading" type="primary" @click="onSubmit()">提交</a-button>
97
+ </a-row>
98
+ </a-form-model>
99
+ </div>
100
+ </template>
101
+ <script>
102
+ import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
103
+ import util, { formatDate, setDataByRealKey } from '@vue2-client/utils/util'
104
+ import { mapState } from 'vuex'
105
+ import { addOrModify, getConfigByName, getConfigByNameAsync, runLogic } from '@vue2-client/services/api/common'
106
+ import { checkIdNumber, REG_EMAIL, REG_LANDLINE, REG_PHONE } from '@vue2-client/utils/reg'
107
+ import moment from 'moment/moment'
108
+ import { executeStrFunction, executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
109
+
110
+ export default {
111
+ name: 'XAddNativeForm',
112
+ components: {
113
+ XFormItem,
114
+ XFormTable: () => import('@vue2-client/base-client/components/common/XFormTable/XFormTable.vue')
115
+ },
116
+ props: {},
117
+ data () {
118
+ return {
119
+ // 预览模式
120
+ viewMode: false,
121
+ // 是否处理表单Key值
122
+ isHandleFormKey: true,
123
+ // 内容加载是否完成
124
+ loaded: false,
125
+ // 业务类型
126
+ businessType: '',
127
+ // 业务标题
128
+ title: '',
129
+ // 新增或修改业务是否执行中
130
+ loading: false,
131
+ // 表单Model
132
+ form: {},
133
+ // 配置名称
134
+ configName: undefined,
135
+ // 配置内容,用于查询配置生成器的预览
136
+ configContent: undefined,
137
+ // 表单项集合
138
+ formItems: [],
139
+ // 服务名称
140
+ serviceName: undefined,
141
+ // 是否显示提交按钮
142
+ showSubmitBtn: true,
143
+ // 修改有文件的表单时使用
144
+ files: [],
145
+ images: [],
146
+ // 校验
147
+ rules: {},
148
+ // 调用logic获取数据源的追加参数
149
+ getDataParams: {},
150
+ // 动态简易表单集合
151
+ simpleFormJsonData: {},
152
+ // 待修改的数据集
153
+ modifyModelData: {},
154
+ // 当前环境
155
+ env: 'prod',
156
+ // 表单模式 horizontal | vertical | inline
157
+ layout: 'horizontal'
158
+ }
159
+ },
160
+ computed: {
161
+ // 过滤出用于新增/修改场景的表单项
162
+ realJsonData: function () {
163
+ return this.formItems.filter((item) => {
164
+ return item.addOrEdit && item.addOrEdit !== 'no' && item.addOrEdit !== 'silenceAdd' && item.addOrEdit !== 'version' && !this.itemDisabled(item)
165
+ })
166
+ },
167
+ // 过滤出用于新增/修改场景的表单项
168
+ groupJsonData: function () {
169
+ return this.formItems.filter((item) => {
170
+ return item.type === 'group'
171
+ }).map((item) => {
172
+ item.groupItems = item.groupItems.filter((item) => {
173
+ return item.addOrEdit && item.addOrEdit !== 'no' && item.addOrEdit !== 'silenceAdd' && item.addOrEdit !== 'version' && !this.itemDisabled(item)
174
+ }).map((groupItem) => {
175
+ // 只保留第一个下划线后面的内容
176
+ // 多层校验规则需要将prop设置为 key1.key2.....
177
+ groupItem.prop = `${item.model}.${groupItem.model.substring(groupItem.model.indexOf('_') + 1)}`
178
+ groupItem.model = groupItem.model.substring(groupItem.model.indexOf('_') + 1)
179
+ return groupItem
180
+ })
181
+ return item
182
+ }
183
+ )
184
+ },
185
+ // 过滤出用于子表数据新增/修改场景的表单项
186
+ childTableData: function () {
187
+ return this.formItems.filter((item) => {
188
+ return item.type === 'childTable'
189
+ })
190
+ },
191
+ // 过滤出用于静默新增场景的表单项
192
+ silenceAddJsonData: function () {
193
+ return this.formItems.filter(function (item) {
194
+ return item.addOrEdit === 'silenceAdd'
195
+ })
196
+ },
197
+ // 过滤出版本号表单项
198
+ versionJsonData: function () {
199
+ return this.formItems.filter(function (item) {
200
+ return item.addOrEdit === 'version'
201
+ })
202
+ },
203
+ formItemLayout () {
204
+ if (this.layout === 'horizontal') {
205
+ return {
206
+ labelCol: { span: 4, offset: 2 },
207
+ wrapperCol: { span: 14 },
208
+ }
209
+ }
210
+ if (this.layout === 'vertical') {
211
+ return {}
212
+ }
213
+ return {
214
+ labelCol: { span: 6 },
215
+ wrapperCol: { span: 18 },
216
+ }
217
+ },
218
+ ...mapState('account', { currUser: 'user' })
219
+ },
220
+ methods: {
221
+ runLogic,
222
+ getConfigByNameAsync,
223
+ getConfigByName,
224
+ init (params) {
225
+ const {
226
+ configName, configContent, formItems, formJson, viewMode, isHandleFormKey, isKeyHandle = true,
227
+ showSubmitBtn = true, serviceName,
228
+ modifyModelData = {}, businessType, title, fixedAddForm = {}, getDataParams = {},
229
+ simpleFormJsonData = {}, env = 'prod', layout, xAddFormLayout = 'horizontal'
230
+ } = params
231
+ this.loaded = false
232
+ // 兼容需要省略 传递 layout: res.xAddFormLayout 可以使用 ...res 展开运算符 直接转递
233
+ if (xAddFormLayout && layout === undefined) {
234
+ this.layout = xAddFormLayout
235
+ } else {
236
+ this.layout = layout
237
+ }
238
+ if (isHandleFormKey && !isKeyHandle) {
239
+ this.isHandleFormKey = isKeyHandle
240
+ } else if (isHandleFormKey) {
241
+ this.isHandleFormKey = isHandleFormKey
242
+ } else {
243
+ this.isHandleFormKey = isKeyHandle
244
+ }
245
+ this.configName = configName
246
+ this.configContent = configContent
247
+ this.formItems = this.getFromItem(formItems, formJson)
248
+ this.viewMode = viewMode
249
+ this.isHandleFormKey = isHandleFormKey
250
+ this.showSubmitBtn = showSubmitBtn
251
+ this.serviceName = serviceName
252
+ this.businessType = businessType
253
+ this.title = title
254
+ this.getDataParams = getDataParams
255
+ this.simpleFormJsonData = simpleFormJsonData
256
+ this.env = env
257
+ // 如果 fixedAddForm 有 selected_id 值,并且设置了处理表单key值,则多给 selected_id 加前缀 避免处理错误
258
+ if (fixedAddForm.selected_id && this.isHandleFormKey) {
259
+ fixedAddForm._selected_id = fixedAddForm.selected_id
260
+ delete fixedAddForm.selected_id
261
+ }
262
+ // 设置普通表单项的相关参数
263
+ const formData = Object.assign({}, fixedAddForm)
264
+ for (let i = 0; i < this.realJsonData.length; i++) {
265
+ const item = this.realJsonData[i]
266
+ this.setFormProps(formData, item, null)
267
+ }
268
+ // 设置表单分组项目相关参数
269
+ for (let i = 0; i < this.groupJsonData.length; i++) {
270
+ const groupItem = this.groupJsonData[i]
271
+ formData[groupItem.model] = {}
272
+ for (let j = 0; j < groupItem.groupItems.length; j++) {
273
+ const item = groupItem.groupItems[j]
274
+ this.setFormProps(formData[groupItem.model], item, item.prop)
275
+ }
276
+ }
277
+ // 设置动态简易表单项的相关参数
278
+ for (const key in this.simpleFormJsonData) {
279
+ for (const item of this.simpleFormJsonData[key].value) {
280
+ item.model = key + '@' + item.model
281
+ this.setFormProps(formData, item, null)
282
+ }
283
+ }
284
+
285
+ this.form = formData
286
+ // 修改场景下对表单项赋值
287
+ if (modifyModelData && modifyModelData.data) {
288
+ this.modifyModelData = modifyModelData
289
+ if (Object.keys(modifyModelData.data).length > 0) {
290
+ this.getModifyModelData(modifyModelData)
291
+ }
292
+ }
293
+ // 处理表单得附件
294
+ if (modifyModelData && modifyModelData.files) {
295
+ this.files = modifyModelData.files
296
+ }
297
+ if (modifyModelData && modifyModelData.images) {
298
+ this.images = modifyModelData.images
299
+ }
300
+ this.loaded = true
301
+ },
302
+ // 兼容需要省略 传递 [formItems: res.formJson ] 可以使用 ...res 展开运算符 直接转递
303
+ getFromItem (formItems, formJson) {
304
+ const _formItems = formItems || formJson
305
+ if (typeof formItems === 'string') {
306
+ return JSON.parse(_formItems)
307
+ } else {
308
+ return JSON.parse(JSON.stringify(_formItems))
309
+ }
310
+ },
311
+ // 时间组件赋默认值
312
+ getDateRange (type, defaultValue) {
313
+ // const format = type === 'datePicker' ? 'YYYY-MM-DD' : 'YYYY-MM-DD HH:mm:ss'
314
+ const format = 'YYYY-MM-DD HH:mm:ss'
315
+ let start
316
+ switch (defaultValue) {
317
+ case 'curYear':
318
+ start = moment().startOf('year').format(format)
319
+ break
320
+ case 'curMonth':
321
+ start = moment().startOf('month').format(format)
322
+ break
323
+ case 'curDay':
324
+ start = moment().startOf('day').format(format)
325
+ break
326
+ default:
327
+ return defaultValue
328
+ }
329
+ return start
330
+ },
331
+ setFormProps (formData, item, groupItem) {
332
+ if (formData[item.model] === undefined || formData[item.model] === null) {
333
+ formData[item.model] = undefined
334
+ }
335
+ if (!formData[item.model] && item.formDefault) {
336
+ if (['datePicker', 'rangePicker', 'yearPicker', 'monthPicker'].includes(item.type)) {
337
+ formData[item.model] = this.getDateRange(item.type, item.formDefault)
338
+ } else if (['treeSelect', 'select', 'checkbox'].includes(item.type) && ['curOrgId', 'curDepId', 'curUserId'].includes(item.formDefault)) {
339
+ if (item.formDefault === 'curOrgId') {
340
+ formData[item.model] = item.type === 'select' ? this.currUser.orgid : [this.currUser.orgid]
341
+ }
342
+ if (item.formDefault === 'curDepId') {
343
+ formData[item.model] = item.type === 'select' ? this.currUser.depids : [this.currUser.depids]
344
+ }
345
+ if (item.formDefault === 'curUserId') {
346
+ formData[item.model] = item.type === 'select' ? this.currUser.id : [this.currUser.id]
347
+ }
348
+ } else {
349
+ formData[item.model] = item.formDefault
350
+ }
351
+ }
352
+ // 处理表单校验情况
353
+ if (item.rule) {
354
+ if (groupItem) {
355
+ this.rules[groupItem] = []
356
+ } else {
357
+ this.rules[item.model] = []
358
+ }
359
+ const required = item.rule.required ? item.rule.required === true || item.rule.required === 'true' : false
360
+ let trigger
361
+ let message
362
+ if (required) {
363
+ switch (item.type) {
364
+ case 'select':
365
+ case 'checkbox':
366
+ case 'radio':
367
+ case 'treeSelect':
368
+ case 'rangePicker':
369
+ case 'monthPicker':
370
+ case 'yearPicker':
371
+ case 'datePicker':
372
+ case 'file':
373
+ case 'image':
374
+ case 'citySelect':
375
+ case 'addressSearch':
376
+ case 'personSetting':
377
+ message = '请选择' + item.name
378
+ trigger = 'change'
379
+ break
380
+ default:
381
+ message = '请输入' + item.name
382
+ trigger = 'blur'
383
+ }
384
+ if (groupItem) {
385
+ this.rules[groupItem].push({
386
+ required: true,
387
+ message: message,
388
+ trigger: trigger
389
+ })
390
+ } else {
391
+ this.rules[item.model].push({
392
+ required: true,
393
+ message: message,
394
+ trigger: trigger
395
+ })
396
+ }
397
+ }
398
+
399
+ switch (item.rule.type) {
400
+ case 'number':
401
+ case 'integer':
402
+ case 'float':
403
+ // eslint-disable-next-line no-case-declarations
404
+ let defaultValue
405
+ // eslint-disable-next-line no-case-declarations
406
+ let message
407
+ switch (item.rule.type) {
408
+ case 'number':
409
+ item.numberInput = true
410
+ message = '数字'
411
+ defaultValue = 0
412
+ break
413
+ case 'integer':
414
+ item.numberInput = true
415
+ message = '整数'
416
+ defaultValue = 0
417
+ break
418
+ case 'float':
419
+ item.numberInput = true
420
+ message = '小数'
421
+ defaultValue = 0.0
422
+ break
423
+ }
424
+ if (groupItem) {
425
+ this.rules[groupItem].push({
426
+ type: item.rule.type,
427
+ message: item.name + '必须为' + message,
428
+ transform: (value) => {
429
+ if (value && value.length !== 0) {
430
+ return Number(value)
431
+ } else {
432
+ return defaultValue
433
+ }
434
+ },
435
+ trigger: 'blur'
436
+ })
437
+ } else {
438
+ this.rules[item.model].push({
439
+ type: item.rule.type,
440
+ message: item.name + '必须为' + message,
441
+ transform: (value) => {
442
+ if (value && value.length !== 0) {
443
+ return Number(value)
444
+ } else {
445
+ return defaultValue
446
+ }
447
+ },
448
+ trigger: 'blur'
449
+ })
450
+ }
451
+ break
452
+ case 'email': {
453
+ const validator = (rule, value, callback) => {
454
+ if (value && !REG_EMAIL.test(value)) {
455
+ callback(new Error('请输入正确的邮箱地址'))
456
+ } else {
457
+ callback()
458
+ }
459
+ }
460
+ this.rules[groupItem || item.model].push({
461
+ type: 'email',
462
+ validator: validator,
463
+ message: '请输入正确的邮箱地址',
464
+ trigger: 'blur'
465
+ })
466
+ break
467
+ }
468
+ case 'userPhone': {
469
+ this.rules[groupItem || item.model].push({
470
+ type: 'userPhone',
471
+ validator: (rule, value, callback) => {
472
+ if (value && !REG_PHONE.test(value)) {
473
+ callback(new Error('请输入正确的手机号码'))
474
+ } else {
475
+ callback()
476
+ }
477
+ },
478
+ message: '请输入正确的手机号码',
479
+ trigger: 'blur'
480
+ })
481
+ break
482
+ }
483
+ case 'idNumber': {
484
+ this.rules[groupItem || item.model].push({
485
+ validator: (rule, value, callback) => {
486
+ if (value && !checkIdNumber(value)) {
487
+ callback(new Error('请输入正确的身份证号码'))
488
+ } else {
489
+ callback()
490
+ }
491
+ },
492
+ trigger: 'blur'
493
+ })
494
+ break
495
+ }
496
+ case 'landlineNumber': {
497
+ this.rules[item.model].push({
498
+ validator: (rule, value, callback) => {
499
+ if (value && !REG_LANDLINE.test(value)) {
500
+ callback(new Error('请输入正确的座机号码'))
501
+ } else {
502
+ callback()
503
+ }
504
+ },
505
+ trigger: 'blur'
506
+ })
507
+ break
508
+ }
509
+ // 大于0
510
+ case 'greaterThanZero': {
511
+ item.numberInput = true
512
+ this.rules[item.model].push({
513
+ validator: (rule, value, callback) => {
514
+ if (isNaN(value) || value <= 0) {
515
+ callback(new Error('请输入一个大于0的数字'))
516
+ } else {
517
+ callback()
518
+ }
519
+ },
520
+ trigger: 'blur'
521
+ })
522
+ break
523
+ }
524
+ // 大于等于0
525
+ case 'greaterThanOrEqualZero': {
526
+ item.numberInput = true
527
+ this.rules[item.model].push({
528
+ validator: (rule, value, callback) => {
529
+ if (isNaN(value) || value < 0) {
530
+ callback(new Error('请输入一个大于等于0的数字'))
531
+ } else {
532
+ callback()
533
+ }
534
+ },
535
+ trigger: 'blur'
536
+ })
537
+ break
538
+ }
539
+ case 'stringLength': {
540
+ this.rules[item.model].push({
541
+ validator: (rule, value, callback) => {
542
+ if (value && value.length < item.rule.minLen) {
543
+ callback(new Error('长度不能少于' + item.rule.minLen + '个字符'))
544
+ } else if (value && value.length > item.rule.maxLen) {
545
+ callback(new Error('长度不能超过' + item.rule.maxLen + '个字符'))
546
+ } else {
547
+ callback()
548
+ }
549
+ },
550
+ trigger: 'blur'
551
+ })
552
+ break
553
+ }
554
+ case 'customJs': {
555
+ this.rules[item.model].push({
556
+ validator: (rule, value, callback) => {
557
+ this.customJsValidate(rule, value, callback, item)
558
+ },
559
+ trigger: 'blur'
560
+ })
561
+ break
562
+ }
563
+ }
564
+ }
565
+ },
566
+ customJsValidate (rule, value, callback, item) {
567
+ if (item.rule.customValidatorFunc) {
568
+ executeStrFunctionByContext(this, item.rule.customValidatorFunc, [rule, value, callback, this.form, item, this.util, runLogic, getConfigByNameAsync])
569
+ } else {
570
+ callback()
571
+ }
572
+ },
573
+ itemDisabled (value) {
574
+ return (this.businessType === '新增' && value.addOrEdit === 'edit') ||
575
+ (this.businessType === '修改' && value.addOrEdit === 'add')
576
+ },
577
+ readonly (value) {
578
+ return value.addOrEdit === 'readonly'
579
+ },
580
+ async onSubmit () {
581
+ const valid = await this.validateForm()
582
+ if (!valid) return false
583
+ if (this.viewMode) {
584
+ this.$message.info('预览模式禁止新增和修改')
585
+ return false
586
+ }
587
+ this.loading = true
588
+ const requestForm = this.prepareForm()
589
+ await this.appendSilenceAddFields(requestForm)
590
+ const realForm = this.handleFormKeys(requestForm)
591
+ // 增加子表数据
592
+ if (this.childTableData.length > 0) {
593
+ for (const item of this.childTableData) {
594
+ const childModel = item.model
595
+ const childData = this.$refs['childXFormTable_' + item.model][0].getTableData()
596
+ for (let i = 0; i < childData.length; i++) {
597
+ childData[i] = this.handleFormKeys(childData[i])
598
+ // 外键不需要带表别名,所以此处放到表单处理后赋值
599
+ if (realForm.id) {
600
+ childData[i][item.childTableForeignKeyName] = realForm.id
601
+ }
602
+ }
603
+ realForm[childModel] = childData
604
+ }
605
+ }
606
+ if (this.$listeners.onSubmit) {
607
+ // 交由父级处理
608
+ this.$emit('onSubmit', {
609
+ businessType: this.businessType,
610
+ serviceName: this.serviceName,
611
+ realForm: realForm,
612
+ currUserName: this.currUser.name,
613
+ currUserId: this.currUser.id,
614
+ orgId: this.currUser.orgid
615
+ })
616
+ } else {
617
+ this.defaultSubmit(realForm)
618
+ }
619
+ },
620
+
621
+ async asyncSubmit () {
622
+ return new Promise((resolve, reject) => {
623
+ this.$refs.selectForm.validate(async valid => {
624
+ if (!valid) {
625
+ reject(new Error('Form validation failed'))
626
+ return
627
+ }
628
+ this.loading = true
629
+ const requestForm = this.prepareForm()
630
+ await this.appendSilenceAddFields(requestForm)
631
+ const realForm = this.handleFormKeys(requestForm)
632
+ if (this.businessType === '新增') {
633
+ delete realForm.id
634
+ }
635
+ resolve({
636
+ realForm,
637
+ businessType: this.businessType,
638
+ serviceName: this.serviceName,
639
+ currUserName: this.currUser.name,
640
+ currUserId: this.currUser.id,
641
+ orgId: this.currUser.orgid
642
+ })
643
+ })
644
+ })
645
+ },
646
+
647
+ validateForm () {
648
+ return new Promise((resolve) => {
649
+ this.$refs.selectForm.validate(valid => resolve(valid))
650
+ })
651
+ },
652
+
653
+ childTableFixedQueryForm (item) {
654
+ if (this.modifyModelData?.primaryKeyData) {
655
+ const fixedForm = {}
656
+ fixedForm[item.childTableForeignKeyName] = Object.values(this.modifyModelData.primaryKeyData)[0]
657
+ return fixedForm
658
+ }
659
+ return null
660
+ },
661
+
662
+ prepareForm () {
663
+ const form = { ...this.form }
664
+ for (const key of Object.keys(form)) {
665
+ const value = form[key]
666
+ if (value === null || (typeof value === 'object' && Object.keys(value).length === 0)) {
667
+ form[key] = undefined
668
+ }
669
+ }
670
+ return form
671
+ },
672
+
673
+ async appendSilenceAddFields (form) {
674
+ if (this.businessType === '新增') {
675
+ for (const item of this.silenceAddJsonData) {
676
+ switch (item.silencePurpose) {
677
+ case 'createTime':
678
+ form[item.model] = formatDate('now')
679
+ break
680
+ case 'operator':
681
+ form[item.model] = this.currUser.name
682
+ break
683
+ case 'operatorId':
684
+ form[item.model] = this.currUser.id
685
+ break
686
+ case 'orgId':
687
+ form[item.model] = this.currUser.orgid
688
+ break
689
+ case 'orgName':
690
+ form[item.model] = this.currUser.orgs
691
+ break
692
+ case 'depId':
693
+ form[item.model] = this.currUser.depids
694
+ break
695
+ case 'depName':
696
+ form[item.model] = this.currUser.deps
697
+ break
698
+ }
699
+ }
700
+ for (const item of this.silenceAddJsonData.filter((item) => item.silencePurpose === 'customize')) {
701
+ form[item.model] = await runLogic(item.silenceSource, form, this.serviceName)
702
+ }
703
+ }
704
+ },
705
+
706
+ handleFormKeys (form) {
707
+ const realForm = {}
708
+ for (const key of Object.keys(form)) {
709
+ const value = form[key]
710
+ const extraFormKeyTagIndex = key.indexOf('@')
711
+ if (extraFormKeyTagIndex !== -1) {
712
+ const extraFormKey = key.substring(0, extraFormKeyTagIndex)
713
+ const realKey = key.substring(extraFormKeyTagIndex + 1)
714
+ if (!realForm[extraFormKey]) {
715
+ realForm[extraFormKey] = {}
716
+ }
717
+ realForm[extraFormKey][realKey] = value
718
+ } else {
719
+ const realKey = this.isHandleFormKey ? this.getRealKey(key) : key
720
+ // 如果发生重名,不覆盖,把key的别名带上
721
+ if (realForm[realKey]) {
722
+ realForm[key] = value
723
+ } else {
724
+ realForm[realKey] = value
725
+ }
726
+ }
727
+ }
728
+ return realForm
729
+ },
730
+ // 默认提交事件
731
+ defaultSubmit (realForm, callback) {
732
+ // 新增移除id
733
+ if (this.businessType === '新增') {
734
+ delete realForm.id
735
+ }
736
+ // 组织请求
737
+ const requestParameters = {
738
+ queryParamsName: this.configName,
739
+ queryParams: this.configContent,
740
+ form: realForm,
741
+ businessType: this.businessType,
742
+ operator: this.currUser.name
743
+ }
744
+ addOrModify(requestParameters, this.serviceName, this.env === 'dev').then(data => {
745
+ this.$message.success(this.businessType + '成功!')
746
+ // commit
747
+ this.$emit('afterSubmit', { type: this.businessType, id: data.id, form: requestParameters.form })
748
+ }).catch(e => {
749
+ this.$message.error(this.businessType + '失败:' + e)
750
+ }).finally(() => {
751
+ if (callback) {
752
+ callback()
753
+ }
754
+ })
755
+ },
756
+ // 获取表单字段实际值
757
+ getRealKey (key) {
758
+ if (this.isHandleFormKey) {
759
+ return key.substring(key.indexOf('_') + 1)
760
+ } else {
761
+ return key
762
+ }
763
+ },
764
+ /**
765
+ * 获取被修改记录数据
766
+ * @param modifyModelData 被修改记录的数据
767
+ */
768
+ getModifyModelData (modifyModelData) {
769
+ if (modifyModelData.primaryKeyData) {
770
+ this.form = Object.assign(this.form, modifyModelData.primaryKeyData)
771
+ }
772
+ // 对动态简易表单项特殊处理
773
+ for (const key in modifyModelData.data) {
774
+ const realKey = this.isHandleFormKey ? this.getRealKey(key) : key
775
+ if (this.simpleFormJsonData[realKey]) {
776
+ const extraForm = JSON.parse(modifyModelData.data[key])
777
+ for (const key in extraForm) {
778
+ const model = realKey + '@' + key
779
+ this.form[model] = extraForm[key]
780
+ }
781
+ }
782
+ }
783
+ // 对普通表单项处理
784
+ for (let i = 0; i < this.realJsonData.length; i++) {
785
+ if (['FilesId', 'Images'].includes(this.realJsonData[i])) {
786
+ // 附件需要跳过 因为会通过 modifyModelData中的files,images属性给upload赋值
787
+ // 新增修改表单每次提交时只会提交最新添加的文件
788
+ continue
789
+ }
790
+ const item = this.realJsonData[i]
791
+ if (modifyModelData.data[item.model] || modifyModelData.data[item.model] === 0) {
792
+ if (modifyModelData.data[item.model] instanceof Array) {
793
+ this.form[item.model] = modifyModelData.data[item.model]
794
+ } else {
795
+ this.form[item.model] = modifyModelData.data[item.model] + ''
796
+ }
797
+ }
798
+ }
799
+ // 对分组表单进行处理
800
+ for (let i = 0; i < this.groupJsonData.length; i++) {
801
+ const item = this.groupJsonData[i]
802
+ try {
803
+ if (modifyModelData.data[item.model]) {
804
+ this.form[item.model] = JSON.parse(modifyModelData.data[item.model])
805
+ }
806
+ } catch (e) {
807
+ }
808
+ }
809
+ // 追加版本号信息
810
+ for (const item of this.versionJsonData) {
811
+ if (!modifyModelData.data[item.model]) {
812
+ this.form[item.model] = 0
813
+ } else {
814
+ this.form[item.model] = modifyModelData.data[item.model] + ''
815
+ }
816
+ }
817
+ },
818
+ setForm (obj) {
819
+ this.form = Object.assign(this.form, obj)
820
+ },
821
+ setFormWithKey (obj) {
822
+ setDataByRealKey(this.form, obj)
823
+ },
824
+ emitFunc (func, data) {
825
+ // 打开列表选择框逻辑
826
+ if (data?.model) {
827
+ this.$emit(func, data, this.form[data.model])
828
+ } else {
829
+ this.$emit(func, data)
830
+ }
831
+ this.$emit('x-form-item-emit-func', func, data)
832
+ },
833
+ close () {
834
+ this.loaded = false
835
+ },
836
+ /**
837
+ * 行选择事件
838
+ * @param row 选中行集合
839
+ * @param attr 表单项属性
840
+ */
841
+ async rowChoose (row, attr, callback) {
842
+ // 如果配置了自定义函数
843
+ if (attr.dataChangeFunc) {
844
+ await executeStrFunction(attr.dataChangeFunc, [this.form, this.setForm, {
845
+ ...attr,
846
+ selectRows: row
847
+ }, util, this.mode, runLogic, getConfigByNameAsync])
848
+ } else {
849
+ // 默认填充选中行数据到当前表单
850
+ setDataByRealKey(this.form, row[0])
851
+ }
852
+ if (callback) {
853
+ callback()
854
+ }
855
+ }
856
+ }
857
+ }
858
+ </script>
859
+
860
+ <style scoped>
861
+ :deep(.ant-form-inline .ant-form-item ) {
862
+ display: block !important;
863
+ }
864
+
865
+ :deep(.ant-form-item-with-help) {
866
+ margin-bottom: 0;
867
+ }
868
+ </style>