vue2-client 1.10.27 → 1.10.30

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 (426) hide show
  1. package/.cursorrules +19 -19
  2. package/.env +19 -19
  3. package/.env.gaslink +19 -19
  4. package/.env.his +19 -19
  5. package/.env.liuli +19 -19
  6. package/.env.revenue +19 -19
  7. package/.env.scada +19 -19
  8. package/.eslintrc.js +90 -90
  9. package/CHANGELOG.md +824 -824
  10. package/Components.md +60 -60
  11. package/babel.config.js +21 -21
  12. package/docs/Logic/345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +45 -45
  13. package/docs/LowCode/lowcode.md +155 -155
  14. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  15. package/docs/index.md +30 -30
  16. package/docs//345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +174 -174
  17. package/index.js +31 -31
  18. package/jest-transform-stub.js +8 -8
  19. package/jest.config.js +21 -21
  20. package/jest.setup.js +7 -7
  21. package/jsconfig.json +19 -19
  22. package/package.json +1 -1
  23. package/public/his/editor/editor.html +51 -51
  24. package/public/his/editor/mock/bind_data.html +779 -779
  25. package/public/his/editor/mock/data_table.html +40 -40
  26. package/public/his/editor/mock/sign.html +75 -75
  27. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  28. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  29. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  30. package/public/his/editor/vender/date97/calendar.js +4 -4
  31. package/public/his/editor/vender/date97/lang/en.js +13 -13
  32. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  33. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  34. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  35. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  36. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  37. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  38. package/public/his/editor/vender/diff.js +1627 -1627
  39. package/public/his/editor/vender/editor.js +1 -1
  40. package/public/his/editor/vender/fabric.js +31187 -31187
  41. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  42. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  43. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  44. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  45. package/public/his/editor/vender/mui/mui.min.css +4 -4
  46. package/public/his/editor/vender/mui/mui.min.js +5 -5
  47. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  48. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  49. package/public/his/editor/vender/qrcode.js +7 -7
  50. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  51. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  52. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  53. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  54. package/public/his/editor/vender/validator.js +5094 -5094
  55. package/public/his/editor/vender/weui/weui.css +5659 -5659
  56. package/public/his/editor/vender/weui/weui.min.css +4 -4
  57. package/public/his/editor/vender/weui/weui.min.js +11 -11
  58. package/public/index.html +27 -27
  59. package/src/App.vue +196 -196
  60. package/src/ReportView.js +19 -19
  61. package/src/assets/img/querySlotDemo.svg +15 -15
  62. package/src/assets/svg/badtwo.svg +1 -1
  63. package/src/assets/svg/goodtwo.svg +1 -1
  64. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  65. package/src/base-client/components/AI/demo.vue +31 -31
  66. package/src/base-client/components/common/AMisRender/index.js +3 -3
  67. package/src/base-client/components/common/AMisRender/index.vue +263 -263
  68. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +470 -470
  69. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  70. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  71. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  72. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  73. package/src/base-client/components/common/CitySelect/CitySelect.vue +342 -342
  74. package/src/base-client/components/common/CitySelect/index.js +3 -3
  75. package/src/base-client/components/common/CitySelect/index.md +109 -109
  76. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  77. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  78. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  79. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  80. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  81. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  82. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  83. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  84. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +149 -149
  85. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  86. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  87. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  88. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  89. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  90. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  91. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  92. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  93. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  94. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  95. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  96. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  97. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  98. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  99. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  100. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  101. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  102. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  103. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  104. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  105. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  106. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  107. package/src/base-client/components/common/Recording/index.js +3 -3
  108. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  109. package/src/base-client/components/common/Tree/index.js +2 -2
  110. package/src/base-client/components/common/Upload/Upload.vue +322 -322
  111. package/src/base-client/components/common/Upload/index.js +3 -3
  112. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  113. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +1146 -1146
  114. package/src/base-client/components/common/XAddNativeForm/demo.vue +43 -43
  115. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  116. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  117. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  118. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  119. package/src/base-client/components/common/XAddReport/XAddReport.vue +207 -207
  120. package/src/base-client/components/common/XAddReport/index.js +3 -3
  121. package/src/base-client/components/common/XAddReport/index.md +56 -56
  122. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  123. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  124. package/src/base-client/components/common/XButtons/XButtons.vue +71 -71
  125. package/src/base-client/components/common/XButtons/index.js +3 -3
  126. package/src/base-client/components/common/XButtons/index.md +61 -61
  127. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  128. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  129. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  130. package/src/base-client/components/common/XConversation/XConversation.vue +263 -263
  131. package/src/base-client/components/common/XConversation/XConversationDemo.vue +28 -28
  132. package/src/base-client/components/common/XDataCard/XDataCard.vue +26 -17
  133. package/src/base-client/components/common/XDataCard/index.js +3 -3
  134. package/src/base-client/components/common/XDataCard/index.md +1 -1
  135. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  136. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  137. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  138. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  139. package/src/base-client/components/common/XDatePicker/index.vue +259 -259
  140. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +169 -169
  141. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +304 -304
  142. package/src/base-client/components/common/XDescriptions/demo.vue +50 -50
  143. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  144. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  145. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  146. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  147. package/src/base-client/components/common/XForm/XForm.vue +393 -393
  148. package/src/base-client/components/common/XForm/XFormItem.vue +1286 -1286
  149. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  150. package/src/base-client/components/common/XForm/XTreeSelect.vue +250 -250
  151. package/src/base-client/components/common/XForm/index.md +178 -178
  152. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  153. package/src/base-client/components/common/XFormCol/XFormCol.vue +157 -157
  154. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +304 -304
  155. package/src/base-client/components/common/XFormGroup/demo.vue +46 -46
  156. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  157. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  158. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  159. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  160. package/src/base-client/components/common/XFormTable/XFormTable.vue +856 -856
  161. package/src/base-client/components/common/XFormTable/demo.vue +60 -60
  162. package/src/base-client/components/common/XFormTable/index.md +92 -92
  163. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +167 -167
  164. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  165. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  166. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  167. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  168. package/src/base-client/components/common/XPrint/Demo.vue +41 -41
  169. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  170. package/src/base-client/components/common/XPrint/PrintBill.vue +302 -302
  171. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  172. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  173. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  174. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  175. package/src/base-client/components/common/XPrint/index.vue +97 -97
  176. package/src/base-client/components/common/XReport/XReport.vue +892 -892
  177. package/src/base-client/components/common/XReport/XReportDemo.vue +71 -71
  178. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  179. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  180. package/src/base-client/components/common/XReport/XReportTrGroup.vue +816 -816
  181. package/src/base-client/components/common/XReport/index.js +3 -3
  182. package/src/base-client/components/common/XReport/index.md +44 -44
  183. package/src/base-client/components/common/XReport/print.js +186 -186
  184. package/src/base-client/components/common/XReportDrawer/XReportDrawer.vue +201 -201
  185. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  186. package/src/base-client/components/common/XReportGrid/XReport.vue +1070 -1070
  187. package/src/base-client/components/common/XReportGrid/XReportDemo.vue +47 -47
  188. package/src/base-client/components/common/XReportGrid/XReportDesign.vue +628 -628
  189. package/src/base-client/components/common/XReportGrid/XReportJsonRender.vue +380 -380
  190. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +1104 -1104
  191. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  192. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  193. package/src/base-client/components/common/XReportGrid/print.js +184 -184
  194. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  195. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  196. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  197. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  198. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  199. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  200. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  201. package/src/base-client/components/common/XStepView/index.js +3 -3
  202. package/src/base-client/components/common/XStepView/index.md +31 -31
  203. package/src/base-client/components/common/XTab/XTab.vue +201 -201
  204. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  205. package/src/base-client/components/common/XTab/index.js +3 -3
  206. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  207. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  208. package/src/base-client/components/common/XTable/index.md +255 -255
  209. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  210. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  211. package/src/base-client/components/common/XTree/XTreePro.vue +452 -452
  212. package/src/base-client/components/common/XTree/index.js +3 -3
  213. package/src/base-client/components/common/XTree/index.md +36 -36
  214. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  215. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  216. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  217. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  218. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +359 -359
  219. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  220. package/src/base-client/components/index.js +51 -51
  221. package/src/base-client/components/layout/XPageView/RenderRow.vue +63 -63
  222. package/src/base-client/components/layout/XPageView/XErrorView.vue +11 -11
  223. package/src/base-client/components/layout/XPageView/XPageView.vue +155 -155
  224. package/src/base-client/components/layout/XPageView/index.js +3 -3
  225. package/src/base-client/components/layout/XPageView/index.md +38 -38
  226. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  227. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  228. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  229. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  230. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  231. package/src/base-client/plugins/AppData.js +121 -121
  232. package/src/base-client/plugins/Config.js +19 -19
  233. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  234. package/src/base-client/plugins/Recording.js +258 -258
  235. package/src/base-client/plugins/index.js +23 -23
  236. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  237. package/src/bootstrap.js +42 -42
  238. package/src/components/Charts/Bar.vue +62 -62
  239. package/src/components/Charts/ChartCard.vue +134 -134
  240. package/src/components/Charts/Liquid.vue +67 -67
  241. package/src/components/Charts/MiniArea.vue +39 -39
  242. package/src/components/Charts/MiniBar.vue +39 -39
  243. package/src/components/Charts/MiniProgress.vue +75 -75
  244. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  245. package/src/components/Charts/Radar.vue +68 -68
  246. package/src/components/Charts/RankList.vue +77 -77
  247. package/src/components/Charts/TagCloud.vue +113 -113
  248. package/src/components/Charts/TransferBar.vue +64 -64
  249. package/src/components/Charts/Trend.vue +82 -82
  250. package/src/components/Charts/chart.less +12 -12
  251. package/src/components/Charts/smooth.area.less +13 -13
  252. package/src/components/CodeMirror/inedx.vue +118 -118
  253. package/src/components/CodeMirror/setting.js +40 -40
  254. package/src/components/FilePreview/FilePreview.vue +166 -166
  255. package/src/components/HeightScanner/index.vue +571 -571
  256. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  257. package/src/components/NumberInfo/index.js +3 -3
  258. package/src/components/NumberInfo/index.less +54 -54
  259. package/src/components/NumberInfo/index.md +43 -43
  260. package/src/components/STable/index.js +390 -390
  261. package/src/components/card/ChartCard.vue +79 -79
  262. package/src/components/chart/Bar.vue +60 -60
  263. package/src/components/chart/MiniArea.vue +67 -67
  264. package/src/components/chart/MiniBar.vue +59 -59
  265. package/src/components/chart/MiniProgress.vue +57 -57
  266. package/src/components/chart/Radar.vue +80 -80
  267. package/src/components/chart/RankingList.vue +60 -60
  268. package/src/components/chart/Trend.vue +79 -79
  269. package/src/components/chart/index.less +9 -9
  270. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  271. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  272. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  273. package/src/components/checkbox/index.js +9 -9
  274. package/src/components/exception/ExceptionPage.vue +70 -70
  275. package/src/components/g2Charts/constants.js +202 -202
  276. package/src/components/g2Charts/demo.vue +808 -808
  277. package/src/components/g2Charts/designer.vue +228 -228
  278. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  279. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  280. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  281. package/src/components/g2Charts/index.vue +397 -397
  282. package/src/components/index.js +36 -36
  283. package/src/components/input/IInput.vue +66 -66
  284. package/src/components/menu/SideMenu.vue +75 -75
  285. package/src/components/menu/menu.js +273 -273
  286. package/src/components/setting/Setting.vue +234 -234
  287. package/src/components/tool/AStepItem.vue +60 -60
  288. package/src/config/CreateQueryConfig.js +325 -325
  289. package/src/config/default/antd.config.js +89 -89
  290. package/src/config/default/setting.config.js +55 -55
  291. package/src/font-style/font.css +4 -4
  292. package/src/layouts/CommonLayout.vue +56 -56
  293. package/src/layouts/GridView.vue +45 -45
  294. package/src/layouts/PageLayout.vue +151 -151
  295. package/src/layouts/SinglePageView.vue +136 -136
  296. package/src/layouts/header/AdminHeader.vue +132 -132
  297. package/src/layouts/header/HeaderNotice.vue +177 -177
  298. package/src/layouts/header/InstitutionDetail.vue +181 -181
  299. package/src/layouts/tabs/TabsHead.vue +189 -189
  300. package/src/layouts/tabs/TabsView.vue +389 -389
  301. package/src/lib.js +1 -1
  302. package/src/main.js +34 -34
  303. package/src/mock/extend/index.js +84 -84
  304. package/src/mock/goods/index.js +108 -108
  305. package/src/pages/AMisDemo/AMisDemo.vue +325 -325
  306. package/src/pages/AMisDemo/AMisDemo2.vue +74 -74
  307. package/src/pages/DefaultExample/index.vue +77 -77
  308. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  309. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  310. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  311. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  312. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  313. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  314. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  315. package/src/pages/DynamicStatistics/index.vue +282 -282
  316. package/src/pages/Example/childIndex.vue +15 -15
  317. package/src/pages/Example/index.vue +30 -30
  318. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  319. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  320. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  321. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  322. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  323. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  324. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  325. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  326. package/src/pages/Recording/index.vue +77 -77
  327. package/src/pages/ReportGrid/index.vue +76 -76
  328. package/src/pages/ServiceReview/index.vue +284 -284
  329. package/src/pages/SubExample/index.vue +26 -26
  330. package/src/pages/WorkflowDetail/WorkFlowDemo.vue +32 -32
  331. package/src/pages/WorkflowDetail/WorkflowDetail.vue +230 -230
  332. package/src/pages/WorkflowDetail/WorkflowPageDetail/LeaveMessage.vue +131 -131
  333. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  334. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformation.vue +302 -302
  335. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformationDetails.vue +276 -276
  336. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +864 -864
  337. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandleReso.vue +997 -997
  338. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +222 -222
  339. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkOrderParentDetails.vue +233 -233
  340. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowDetailResso.vue +261 -261
  341. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowListResolution.vue +248 -248
  342. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowLog.vue +73 -73
  343. package/src/pages/XPageViewExample/index.vue +38 -38
  344. package/src/pages/XReportView/index.vue +64 -64
  345. package/src/pages/XTreeOneProExample/index.vue +67 -67
  346. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  347. package/src/pages/login/Login.vue +378 -378
  348. package/src/pages/login/LoginV3.vue +389 -389
  349. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  350. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  351. package/src/pages/report/ReportTable.js +124 -124
  352. package/src/pages/resourceManage/orgListManage.vue +98 -98
  353. package/src/pages/system/dictionary/index.vue +44 -44
  354. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  355. package/src/pages/system/monitor/operLog/index.vue +37 -37
  356. package/src/pages/system/settings/modifyPassword.vue +117 -117
  357. package/src/pages/system/ticket/index.vue +480 -480
  358. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  359. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  360. package/src/pages/userInfoDetailManage/FillCardRecordQuery/index.vue +76 -76
  361. package/src/pages/userInfoDetailManage/FillGasRecordQuery/index.vue +74 -74
  362. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  363. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  364. package/src/pages/userInfoDetailManage/MachineRecordQuery/index.vue +74 -74
  365. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  366. package/src/pages/userInfoDetailManage/OtherChargeRecordQuery/index.vue +74 -74
  367. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  368. package/src/pages/userInfoDetailManage/UserChargeRecordQuery/index.vue +92 -92
  369. package/src/pages/userInfoDetailManage/UserHandRecordQuery/index.vue +86 -86
  370. package/src/pages/userInfoDetailManage/UserRecordQuery/index.vue +73 -73
  371. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  372. package/src/pages/userInfoDetailManage/index.vue +82 -82
  373. package/src/pages/userInfoDetailManage/userInfoDetailQueryTabs.vue +132 -132
  374. package/src/plugins/EventLogPlugin.js +33 -33
  375. package/src/plugins/FindParentsData.js +17 -17
  376. package/src/plugins/HiPrintPlugin.js +124 -124
  377. package/src/router/async/config.async.js +35 -35
  378. package/src/router/async/router.map.js +188 -188
  379. package/src/router/guards.js +263 -263
  380. package/src/router/index.js +27 -27
  381. package/src/router.js +19 -19
  382. package/src/services/DataModel.js +30 -30
  383. package/src/services/LodopFuncs.js +137 -137
  384. package/src/services/api/TicketDetailsViewApi.js +46 -46
  385. package/src/services/api/cas.js +79 -79
  386. package/src/services/api/common.js +346 -346
  387. package/src/services/api/entity.js +18 -18
  388. package/src/services/api/index.js +17 -17
  389. package/src/services/api/restTools.js +145 -145
  390. package/src/services/api/workFlow.js +63 -63
  391. package/src/services/apiService.js +15 -15
  392. package/src/services/user.js +90 -90
  393. package/src/services/v3Api.js +116 -116
  394. package/src/store/modules/account.js +115 -115
  395. package/src/store/modules/index.js +5 -5
  396. package/src/store/modules/lowCode.js +33 -33
  397. package/src/store/modules/setting.js +119 -119
  398. package/src/theme/default/style.less +58 -58
  399. package/src/theme/global.less +159 -159
  400. package/src/utils/authority-utils.js +85 -85
  401. package/src/utils/errorCode.js +6 -6
  402. package/src/utils/formatter.js +74 -74
  403. package/src/utils/htmlToPDF.js +108 -108
  404. package/src/utils/htmlToPDFApi.js +5 -5
  405. package/src/utils/indexedDB.js +263 -263
  406. package/src/utils/login.js +188 -188
  407. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  408. package/src/utils/lowcode/lowcodeLog.js +29 -29
  409. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  410. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  411. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  412. package/src/utils/map-utils.js +47 -47
  413. package/src/utils/microAppUtils.js +40 -40
  414. package/src/utils/reg.js +95 -95
  415. package/src/utils/request.js +362 -362
  416. package/src/utils/routerUtil.js +450 -450
  417. package/src/utils/runEvalFunction.js +14 -14
  418. package/src/utils/util.js +329 -329
  419. package/src/utils/waterMark.js +31 -31
  420. package/test/Amis.spec.js +163 -163
  421. package/test/Tree.spec.js +167 -167
  422. package/test/myDialog.spec.js +46 -46
  423. package/test/util.test.js +52 -52
  424. package/test/v3Api.test.js +1983 -1983
  425. package/vue.config.js +213 -213
  426. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,1146 +1,1146 @@
1
- <template>
2
- <div id="XAddNativeForm">
3
- <a-form-model
4
- v-if="loaded"
5
- ref="selectForm"
6
- :zIndex="1001"
7
- :model="form"
8
- v-bind="formItemLayoutGen"
9
- :layout="layout"
10
- :rules="rules">
11
- <template v-for="(item, key) in childTableData">
12
- <a-row
13
- v-if="childTablePriority"
14
- :gutter="16"
15
- :key="'childTableRow' + key">
16
- <a-card :title="item.name" :bordered="false" size="small">
17
- <x-form-table
18
- :key="'childTable_' + item.model"
19
- :title="item.name"
20
- :queryParamsName="item.childTableConfigName"
21
- :localEditMode="true"
22
- :fixed-query-form="childTableFixedQueryForm(item)"
23
- :service-name="serviceName"
24
- @innerXFormTableEmit="innerXFormTableEmit"
25
- @afterTableInit="childTableMounted(item)"
26
- :ref="'childXFormTable_' + item.model">
27
- </x-form-table>
28
- </a-card>
29
- </a-row>
30
- </template>
31
- <a-row ref="GroupItemRow">
32
- <a-col :span="3" v-if="!inXFormGroup && !(groups[0].groupName === DEFAULT_GROUP_NAME)">
33
- <a-tabs tab-position="left" v-model="activeTab" @change="scrollToGroup">
34
- <a-tab-pane
35
- v-for="(groupsItem,groupsIndex) in groups"
36
- :tab="groupsItem.groupName"
37
- :key="groupsIndex">
38
- </a-tab-pane>
39
- </a-tabs>
40
- </a-col>
41
- <a-col
42
- :span="(!inXFormGroup && !(groups[0].groupName === DEFAULT_GROUP_NAME)) ? 21: 24">
43
- <a-row
44
- :gutter="16"
45
- type="flex"
46
- :key="groupsIndex"
47
- v-for="(groupsItem,groupsIndex) in groups"
48
- >
49
- <a-col
50
- :span="24"
51
- :style="{ marginTop: groupsIndex === 0 ? '' : '8px',fontSize:inXFormGroup?'15px':'14px', marginLeft:'-5px' }"
52
- v-if="groupsItem.groupName !== DEFAULT_GROUP_NAME">
53
- <span class="xFormGroupTitle" :ref="`group-title-${groupsIndex}`">{{ groupsItem.groupName }}</span>
54
- </a-col>
55
- <x-form-item
56
- v-for="(item, index) in groupsItem.realJsonData"
57
- :key="index"
58
- :attr="item"
59
- :disabled="itemDisabled(item)"
60
- :read-only="readonly(item)"
61
- :files="files"
62
- v-bind="formItemLayoutGen"
63
- :style="layout === 'inline' ? { marginTop:'5px' } : undefined"
64
- :form="form"
65
- :images="images"
66
- :service-name="serviceName"
67
- mode="新增/修改"
68
- :layout="layout"
69
- :get-data-params="getDataParams"
70
- :env="env"
71
- @x-form-item-emit-func="emitFunc"
72
- @rowChoose="rowChoose"
73
- :setForm="setForm"
74
- />
75
- </a-row>
76
- </a-col>
77
- </a-row>
78
- <a-row :gutter="16" v-for="(groupItem, groupIndex) in groupJsonData" :key="groupIndex">
79
- <a-card v-if="groupItem.groupItems.length > 0" :title="groupItem.name" :bordered="false" size="small">
80
- <x-form-item
81
- v-for="(item, index) in groupItem.groupItems"
82
- :key="index"
83
- :attr="item"
84
- :disabled="itemDisabled(item)"
85
- :readonly="readonly(item)"
86
- :files="files"
87
- v-bind="formItemLayoutGen"
88
- :style="layout ==='inline'?{marginTop:'5px'}:undefined"
89
- :form="form[groupItem.model]"
90
- :images="images"
91
- :service-name="serviceName"
92
- mode="新增/修改"
93
- :get-data-params="getDataParams"
94
- :env="env"
95
- :setForm="setForm"
96
- @rowChoose="rowChoose"
97
- />
98
- </a-card>
99
- <template v-else>
100
- <slot
101
- name="groupFormItems"
102
- :form="form"
103
- :model="groupItem.model"
104
- :rules="rules"
105
- :modifyModelData="modifyModelData"></slot>
106
- </template>
107
- </a-row>
108
- <a-row :gutter="16" v-for="(item, key) in simpleFormJsonData" :key="'row' + key">
109
- <a-card v-if="item.value.length > 0" :title="item.name" :bordered="false" size="small">
110
- <x-form-item
111
- v-for="(formItem, formItemIndex) in item.value"
112
- :key="key + formItemIndex"
113
- :attr="formItem"
114
- :disabled="itemDisabled(formItem)"
115
- :readonly="readonly(formItem)"
116
- :files="files"
117
- v-bind="formItemLayoutGen"
118
- :style="layout ==='inline'?{marginTop:'5px'}:undefined"
119
- :form="form[groupItem.model]"
120
- :images="images"
121
- :service-name="serviceName"
122
- mode="新增/修改"
123
- :get-data-params="getDataParams"
124
- :env="env"
125
- :setForm="setForm"
126
- @rowChoose="rowChoose"
127
- />
128
- </a-card>
129
- </a-row>
130
- <template v-for="(item, key) in childTableData">
131
- <a-row
132
- v-if="!childTablePriority"
133
- :gutter="16"
134
- :key="'childTableRow' + key">
135
- <a-card :title="item.name" :bordered="false" size="small">
136
- <x-form-table
137
- :key="'childTable_' + item.model"
138
- :title="item.name"
139
- :queryParamsName="item.childTableConfigName"
140
- :localEditMode="true"
141
- @innerXFormTableEmit="innerXFormTableEmit"
142
- :fixed-query-form="childTableFixedQueryForm(item)"
143
- :service-name="serviceName"
144
- @afterTableInit="childTableMounted(item)"
145
- :ref="'childXFormTable_' + item.model">
146
- </x-form-table>
147
- </a-card>
148
- </a-row>
149
- </template>
150
- <a-row type="flex" :justify="btnPlace" :style="{paddingLeft: '16px',paddingRight: '16px'}">
151
- <slot name="footer" :loading="loading">
152
- <a-button v-if="showSubmitBtn" :loading="loading" type="primary" @click="onSubmit()">{{ btnName }}</a-button>
153
- </slot>
154
- </a-row>
155
- </a-form-model>
156
- </div>
157
- </template>
158
- <script>
159
- import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
160
- import { formatDate, setDataByRealKey } from '@vue2-client/utils/util'
161
- import * as util from '@vue2-client/utils/util'
162
- import { mapState } from 'vuex'
163
- import { addOrModify, getConfigByName, getConfigByNameAsync, runLogic } from '@vue2-client/services/api/common'
164
- import { checkIdNumber, REG_EMAIL, REG_LANDLINE, REG_PHONE } from '@vue2-client/utils/reg'
165
- import moment from 'moment/moment'
166
- import { executeStrFunction, executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
167
-
168
- const DEFAULT_GROUP_NAME = '__default__'
169
- export default {
170
- name: 'XAddNativeForm',
171
- components: {
172
- XFormItem,
173
- XFormTable: () => import('@vue2-client/base-client/components/common/XFormTable/XFormTable.vue')
174
- },
175
- inject: {
176
- inXFormGroup: {
177
- default: false
178
- },
179
- formGroupContext: {
180
- default: null
181
- }
182
- },
183
- props: {},
184
- data () {
185
- return {
186
- DEFAULT_GROUP_NAME,
187
- // 预览模式
188
- viewMode: false,
189
- // 是否处理表单Key值
190
- isHandleFormKey: true,
191
- // 内容加载是否完成
192
- loaded: false,
193
- // 业务类型
194
- businessType: '',
195
- // 业务标题
196
- title: '',
197
- // 新增或修改业务是否执行中
198
- loading: false,
199
- // 表单Model
200
- form: {},
201
- // 配置名称
202
- configName: undefined,
203
- // 配置内容,用于查询配置生成器的预览
204
- configContent: undefined,
205
- // 表单项集合
206
- formItems: [],
207
- // 服务名称
208
- serviceName: undefined,
209
- // 是否显示提交按钮
210
- showSubmitBtn: true,
211
- // 修改有文件的表单时使用
212
- files: [],
213
- images: [],
214
- // 校验
215
- rules: {},
216
- // 调用logic获取数据源的追加参数
217
- getDataParams: {},
218
- // 动态简易表单集合
219
- simpleFormJsonData: {},
220
- // 待修改的数据集
221
- modifyModelData: {},
222
- // 当前环境
223
- env: 'prod',
224
- // 表单主键
225
- primaryKey: null,
226
- // 表单模式 horizontal | vertical | inline
227
- layout: 'horizontal',
228
- // 提交按钮名称
229
- btnName: '提交',
230
- // 提交按钮位置 start / center / end
231
- btnPlace: 'center',
232
- // 子表是否排在前面
233
- childTablePriority: false
234
- }
235
- },
236
- computed: {
237
- // 过滤出用于新增/修改场景的表单项
238
- realJsonData: function () {
239
- return this.formItems.filter((item) => {
240
- return item.addOrEdit && item.addOrEdit !== 'no' && item.addOrEdit !== 'silenceAdd' && item.addOrEdit !== 'version' && !this.itemDisabled(item)
241
- })
242
- },
243
- // 表单项组 / 不是 数据组
244
- groups: function () {
245
- if (!this.realJsonData || this.realJsonData.length === 0) {
246
- return [{
247
- groupName: DEFAULT_GROUP_NAME,
248
- realJsonData: this.realJsonData,
249
- xAddFormLayout: 'horizontal'
250
- }]
251
- }
252
- const uniqueGroups = new Set(this.realJsonData.map(item => item.group).filter(Boolean))
253
- const allGroup = Array.from(uniqueGroups).map(group => {
254
- return {
255
- groupName: group,
256
- realJsonData: this.realJsonData.filter(item => item.group === group),
257
- xAddFormLayout: 'horizontal'
258
- }
259
- })
260
- // 判断每一组得formJson 长度相加是否等于 realJsonData 长度 避免错误数据
261
- if (allGroup.reduce((total, item) => total + item.realJsonData.length, 0) === this.realJsonData.length) {
262
- return allGroup
263
- } else {
264
- return [{
265
- groupName: DEFAULT_GROUP_NAME,
266
- realJsonData: this.realJsonData,
267
- xAddFormLayout: 'horizontal'
268
- }]
269
- }
270
- },
271
- // 拥有自定义校验函数得表单项
272
- customValidateItems: function () {
273
- return this.formItems.filter((item) => {
274
- return item?.rule?.type === 'customJs'
275
- })
276
- },
277
- // 过滤出用于新增/修改场景的表单项
278
- groupJsonData: function () {
279
- return this.formItems.filter((item) => {
280
- return item.type === 'group'
281
- }).map((item) => {
282
- item.groupItems = item.groupItems.filter((item) => {
283
- return item.addOrEdit && item.addOrEdit !== 'no' && item.addOrEdit !== 'silenceAdd' && item.addOrEdit !== 'version' && !this.itemDisabled(item)
284
- }).map((groupItem) => {
285
- // 只保留第一个下划线后面的内容
286
- // 多层校验规则需要将prop设置为 key1.key2.....
287
- groupItem.prop = `${item.model}.${groupItem.model.substring(groupItem.model.indexOf('_') + 1)}`
288
- groupItem.model = groupItem.model.substring(groupItem.model.indexOf('_') + 1)
289
- return groupItem
290
- })
291
- return item
292
- }
293
- )
294
- },
295
- // 过滤出用于子表数据新增/修改场景的表单项
296
- childTableData: function () {
297
- return this.formItems.filter((item) => {
298
- return item.type === 'childTable'
299
- })
300
- },
301
- // 过滤出用于form子表数据新增/修改场景的表单项
302
- childFormData: function () {
303
- return this.formItems.filter((item) => {
304
- return item.type === 'rowEdit'
305
- })
306
- },
307
- // 过滤出用于静默新增场景的表单项
308
- silenceAddJsonData: function () {
309
- return this.formItems.filter(function (item) {
310
- return item.addOrEdit === 'silenceAdd'
311
- })
312
- },
313
- // 过滤出版本号表单项
314
- versionJsonData: function () {
315
- return this.formItems.filter(function (item) {
316
- return item.addOrEdit === 'version'
317
- })
318
- },
319
- formItemLayoutGen () {
320
- if (this.layout === 'horizontal') {
321
- return {
322
- labelCol: { span: 4, offset: 2 },
323
- wrapperCol: { span: 14 },
324
- }
325
- } else if (this.layout === 'vertical') {
326
- return {}
327
- } else {
328
- if (!this.formItemLayout.labelCol || !this.formItemLayout.wrapperCol) {
329
- return {
330
- labelCol: { span: 8 },
331
- wrapperCol: { span: 16 },
332
- }
333
- }
334
- return {
335
- labelCol: { span: this.formItemLayout.labelCol },
336
- wrapperCol: { span: this.formItemLayout.wrapperCol },
337
- }
338
- }
339
- },
340
- ...mapState('account', { currUser: 'user' })
341
- },
342
- provide () {
343
- return {
344
- getComponentByName: this.getComponentByName,
345
- registerComponent: this.registerComponent,
346
- getSelf: () => this,
347
- }
348
- },
349
- /** //todo 本来想要实现 配置 自定义函数时,表单项得红星提示,根据自定义校验函数得返回值来判断
350
- * 但是监听不到父组件formgorup得其他form得变化,所以暂时不实现
351
- */
352
- //
353
- // watch: {
354
- // form: {
355
- // handler (val) {
356
- // // 遍历表单配置
357
- // if (this.customValidateItems.length > 0) {
358
- // for (const item of this.customValidateItems) {
359
- // const itemIndex = this.formItems.findIndex(formItem => formItem.model === item.model)
360
- // if (itemIndex < 0) {
361
- // continue
362
- // }
363
- // try {
364
- // this.customJsValidate(null, val[item.model], (res) => {
365
- // // 如果返回error则设置错误信息
366
- // if (res instanceof Error) {
367
- // // 设置表单项的错误状态
368
- // this.$set(this.formItems[itemIndex], 'tempRequired', true)
369
- // } else {
370
- // // 清除错误状态
371
- // this.$set(this.formItems[itemIndex], 'tempRequired', true)
372
- // }
373
- // }, item)
374
- // } catch (e) {
375
- // console.error(e)
376
- // this.$set(this.formItems[itemIndex], 'tempRequired', true)
377
- // }
378
- // }
379
- // console.log('customValidateItems', JSON.stringify(this.customValidateItems))
380
- // }
381
- // },
382
- // deep: true
383
- // }
384
- // },
385
- methods: {
386
- runLogic,
387
- getConfigByNameAsync,
388
- getConfigByName,
389
- init (params) {
390
- const {
391
- configName,
392
- configContent,
393
- formItems,
394
- formJson,
395
- viewMode,
396
- isHandleFormKey,
397
- isKeyHandle = true,
398
- showSubmitBtn = true,
399
- serviceName,
400
- primaryKey,
401
- modifyModelData = {},
402
- businessType,
403
- title,
404
- fixedAddForm = {},
405
- getDataParams = {},
406
- simpleFormJsonData = {},
407
- env = 'prod',
408
- layout,
409
- xAddFormLayout = 'horizontal',
410
- formItemLayout = {},
411
- btnName = '提交',
412
- childTablePriority = false,
413
- btnPlace = 'center'
414
- } = params
415
- this.loaded = false
416
- // 兼容需要省略 传递 layout: res.xAddFormLayout 可以使用 ...res 展开运算符 直接转递
417
- if (xAddFormLayout && layout === undefined) {
418
- this.layout = xAddFormLayout
419
- } else {
420
- this.layout = layout
421
- }
422
- this.formItemLayout = formItemLayout
423
- if ((isHandleFormKey === null || isHandleFormKey === undefined) && !isKeyHandle) {
424
- this.isHandleFormKey = isKeyHandle
425
- } else if (isHandleFormKey) {
426
- this.isHandleFormKey = isHandleFormKey
427
- } else {
428
- this.isHandleFormKey = isKeyHandle
429
- }
430
- this.childTablePriority = childTablePriority
431
- this.configName = configName
432
- this.configContent = configContent
433
- this.formItems = this.getFromItem(formItems, formJson)
434
- this.viewMode = viewMode
435
- this.showSubmitBtn = showSubmitBtn
436
- this.primaryKey = primaryKey
437
- this.serviceName = serviceName
438
- this.businessType = businessType
439
- this.title = title
440
- this.getDataParams = getDataParams
441
- this.simpleFormJsonData = simpleFormJsonData
442
- this.env = env
443
- this.btnName = btnName
444
- this.btnPlace = btnPlace
445
- // 如果 fixedAddForm 有 selected_id 值,并且设置了处理表单key值,则多给 selected_id 加前缀 避免处理错误
446
- if (fixedAddForm.selected_id && this.isHandleFormKey) {
447
- fixedAddForm._selected_id = fixedAddForm.selected_id
448
- delete fixedAddForm.selected_id
449
- }
450
- // 设置普通表单项的相关参数
451
- const formData = Object.assign({}, fixedAddForm)
452
- for (let i = 0; i < this.realJsonData.length; i++) {
453
- const item = this.realJsonData[i]
454
- this.setFormProps(formData, item, null)
455
- }
456
- // 设置表单分组项目相关参数
457
- for (let i = 0; i < this.groupJsonData.length; i++) {
458
- const groupItem = this.groupJsonData[i]
459
- formData[groupItem.model] = {}
460
- for (let j = 0; j < groupItem.groupItems.length; j++) {
461
- const item = groupItem.groupItems[j]
462
- this.setFormProps(formData[groupItem.model], item, item.prop)
463
- }
464
- }
465
- // 设置动态简易表单项的相关参数
466
- for (const key in this.simpleFormJsonData) {
467
- for (const item of this.simpleFormJsonData[key].value) {
468
- item.model = key + '@' + item.model
469
- this.setFormProps(formData, item, null)
470
- }
471
- }
472
-
473
- this.form = formData
474
- // 修改场景下对表单项赋值
475
- if (modifyModelData && modifyModelData.data) {
476
- this.modifyModelData = modifyModelData
477
- if (Object.keys(modifyModelData.data).length > 0) {
478
- this.getModifyModelData(modifyModelData)
479
- }
480
- }
481
- // 处理表单得附件
482
- if (modifyModelData && modifyModelData.files) {
483
- this.files = modifyModelData.files
484
- }
485
- if (modifyModelData && modifyModelData.images) {
486
- this.images = modifyModelData.images
487
- }
488
- this.loaded = true
489
- },
490
- scrollToGroup (index) {
491
- const groupElement = this.$refs[`group-title-${index}`][0]
492
- if (groupElement) {
493
- groupElement.scrollIntoView({ behavior: 'smooth' })
494
- }
495
- },
496
- registerComponent (componentName, component) {
497
- console.log('内部注册', this.$options.name, componentName)
498
- this.$refs[componentName] = component
499
- console.log('内部注册完成', this.$refs)
500
- },
501
- // 根据名字从注册到组件中获取组件
502
- getComponentByName (componentName) {
503
- console.log('内部取组件', this.$options.name, componentName)
504
- console.log('内部组件内容', this.$refs)
505
- return this.$refs[componentName]
506
- },
507
- // 兼容需要省略 传递 [formItems: res.formJson ] 可以使用 ...res 展开运算符 直接转递
508
- getFromItem (formItems, formJson) {
509
- const _formItems = formItems || formJson
510
- if (typeof formItems === 'string') {
511
- return JSON.parse(_formItems)
512
- } else {
513
- return JSON.parse(JSON.stringify(_formItems))
514
- }
515
- },
516
- innerXFormTableEmit (fun, record, id, actionType, index) {
517
- this.$emit(fun, record, id, actionType, index)
518
- },
519
- // 时间组件赋默认值
520
- // .type, item.formDefault
521
- getDateRange ({ type, formDefault: defaultValue, formValueFormat }) {
522
- // const format = type === 'datePicker' ? 'YYYY-MM-DD' : 'YYYY-MM-DD HH:mm:ss'
523
- let format = 'YYYY-MM-DD HH:mm:ss'
524
- if (formValueFormat) {
525
- format = formValueFormat
526
- }
527
- let start
528
- switch (defaultValue) {
529
- case 'curYear':
530
- start = moment().startOf('year').format(format)
531
- break
532
- case 'curMonth':
533
- start = moment().startOf('month').format(format)
534
- break
535
- case 'curDay':
536
- start = moment().startOf('day').format(format)
537
- break
538
- case 'curTime':
539
- start = moment().format(format)
540
- break
541
- default:
542
- return defaultValue
543
- }
544
- return start
545
- },
546
- setFormProps (formData, item, groupItem) {
547
- if (formData[item.model] === undefined || formData[item.model] === null) {
548
- formData[item.model] = undefined
549
- }
550
- if (!formData[item.model] && item.formDefault) {
551
- if (['datePicker', 'rangePicker', 'yearPicker', 'monthPicker', 'yearRangePicker', 'monthRangePicker'].includes(item.type)) {
552
- formData[item.model] = this.getDateRange(item)
553
- } else if (['treeSelect', 'select', 'checkbox'].includes(item.type) && ['curOrgId', 'curDepId', 'curUserId'].includes(item.formDefault)) {
554
- if (item.formDefault === 'curOrgId') {
555
- formData[item.model] = item.type === 'select' ? this.currUser.orgid : [this.currUser.orgid]
556
- }
557
- if (item.formDefault === 'curDepId') {
558
- formData[item.model] = item.type === 'select' ? this.currUser.depids : [this.currUser.depids]
559
- }
560
- if (item.formDefault === 'curUserId') {
561
- formData[item.model] = item.type === 'select' ? this.currUser.id : [this.currUser.id]
562
- }
563
- } else {
564
- formData[item.model] = item.formDefault
565
- }
566
- }
567
- // 处理表单校验情况
568
- if (item.rule) {
569
- if (groupItem) {
570
- this.rules[groupItem] = []
571
- } else {
572
- this.rules[item.model] = []
573
- }
574
- const required = item.rule.required ? item.rule.required === true || item.rule.required === 'true' : false
575
- let trigger
576
- let message
577
- if (required) {
578
- switch (item.type) {
579
- case 'select':
580
- case 'checkbox':
581
- case 'radio':
582
- case 'treeSelect':
583
- case 'rangePicker':
584
- case 'monthPicker':
585
- case 'yearPicker':
586
- case 'datePicker':
587
- case 'file':
588
- case 'image':
589
- case 'citySelect':
590
- case 'addressSearch':
591
- case 'personSetting':
592
- message = '请选择' + item.name
593
- trigger = 'change'
594
- break
595
- default:
596
- message = '请输入' + item.name
597
- trigger = 'blur'
598
- }
599
- if (groupItem) {
600
- this.rules[groupItem].push({
601
- required: true,
602
- message: message,
603
- trigger: trigger
604
- })
605
- } else {
606
- this.rules[item.model].push({
607
- required: true,
608
- message: message,
609
- trigger: trigger
610
- })
611
- }
612
- }
613
-
614
- switch (item.rule.type) {
615
- case 'number':
616
- case 'integer':
617
- case 'float':
618
- // eslint-disable-next-line no-case-declarations
619
- let defaultValue
620
- // eslint-disable-next-line no-case-declarations
621
- let message
622
- switch (item.rule.type) {
623
- case 'number':
624
- item.numberInput = true
625
- message = '数字'
626
- defaultValue = 0
627
- break
628
- case 'integer':
629
- item.numberInput = true
630
- message = '整数'
631
- defaultValue = 0
632
- break
633
- case 'float':
634
- item.numberInput = true
635
- message = '小数'
636
- defaultValue = 0.0
637
- break
638
- }
639
- if (groupItem) {
640
- this.rules[groupItem].push({
641
- type: item.rule.type,
642
- message: item.name + '必须为' + message,
643
- transform: (value) => {
644
- if (value && value.length !== 0) {
645
- return Number(value)
646
- } else {
647
- return defaultValue
648
- }
649
- },
650
- trigger: 'blur'
651
- })
652
- } else {
653
- this.rules[item.model].push({
654
- type: item.rule.type,
655
- message: item.name + '必须为' + message,
656
- transform: (value) => {
657
- if (value && value.length !== 0) {
658
- return Number(value)
659
- } else {
660
- return defaultValue
661
- }
662
- },
663
- trigger: 'blur'
664
- })
665
- }
666
- break
667
- case 'email': {
668
- const validator = (rule, value, callback) => {
669
- if (value && !REG_EMAIL.test(value)) {
670
- callback(new Error('请输入正确的邮箱地址'))
671
- } else {
672
- callback()
673
- }
674
- }
675
- this.rules[groupItem || item.model].push({
676
- type: 'email',
677
- validator: validator,
678
- message: '请输入正确的邮箱地址',
679
- trigger: 'blur'
680
- })
681
- break
682
- }
683
- case 'userPhone': {
684
- this.rules[groupItem || item.model].push({
685
- type: 'userPhone',
686
- validator: (rule, value, callback) => {
687
- if (value && !REG_PHONE.test(value)) {
688
- callback(new Error('请输入正确的手机号码'))
689
- } else {
690
- callback()
691
- }
692
- },
693
- message: '请输入正确的手机号码',
694
- trigger: 'blur'
695
- })
696
- break
697
- }
698
- case 'idNumber': {
699
- this.rules[groupItem || item.model].push({
700
- validator: (rule, value, callback) => {
701
- if (value && !checkIdNumber(value)) {
702
- callback(new Error('请输入正确的身份证号码'))
703
- } else {
704
- callback()
705
- }
706
- },
707
- trigger: 'blur'
708
- })
709
- break
710
- }
711
- case 'landlineNumber': {
712
- this.rules[item.model].push({
713
- validator: (rule, value, callback) => {
714
- if (value && !REG_LANDLINE.test(value)) {
715
- callback(new Error('请输入正确的座机号码'))
716
- } else {
717
- callback()
718
- }
719
- },
720
- trigger: 'blur'
721
- })
722
- break
723
- }
724
- // 大于0
725
- case 'greaterThanZero': {
726
- item.numberInput = true
727
- this.rules[item.model].push({
728
- validator: (rule, value, callback) => {
729
- if (isNaN(value) || value <= 0) {
730
- callback(new Error('请输入一个大于0的数字'))
731
- } else {
732
- callback()
733
- }
734
- },
735
- trigger: 'blur'
736
- })
737
- break
738
- }
739
- // 大于等于0
740
- case 'greaterThanOrEqualZero': {
741
- item.numberInput = true
742
- this.rules[item.model].push({
743
- validator: (rule, value, callback) => {
744
- if (isNaN(value) || value < 0) {
745
- callback(new Error('请输入一个大于等于0的数字'))
746
- } else {
747
- callback()
748
- }
749
- },
750
- trigger: 'blur'
751
- })
752
- break
753
- }
754
- case 'stringLength': {
755
- this.rules[item.model].push({
756
- validator: (rule, value, callback) => {
757
- if (value && value.length < item.rule.minLen) {
758
- callback(new Error('长度不能少于' + item.rule.minLen + '个字符'))
759
- } else if (value && value.length > item.rule.maxLen) {
760
- callback(new Error('长度不能超过' + item.rule.maxLen + '个字符'))
761
- } else {
762
- callback()
763
- }
764
- },
765
- trigger: 'blur'
766
- })
767
- break
768
- }
769
- case 'customJs': {
770
- this.rules[item.model].push({
771
- validator: (rule, value, callback) => {
772
- this.customJsValidate(rule, value, callback, item)
773
- },
774
- trigger: 'blur'
775
- })
776
- break
777
- }
778
- }
779
- }
780
- },
781
- childTableMounted (item) {
782
- // 子表初始化时,设置表格数据
783
- if (this.form[item.model] && this.form[item.model].length > 0) {
784
- this.$refs[`childXFormTable_${item.model}`][0].setTableData(this.form[item.model])
785
- }
786
- },
787
- customJsValidate (rule, value, callback, item) {
788
- if (item.rule.customValidatorFunc) {
789
- executeStrFunctionByContext(this, item.rule.customValidatorFunc, [rule, value, callback, this.form, item, this.util, runLogic, getConfigByNameAsync])
790
- } else {
791
- callback()
792
- }
793
- },
794
- itemDisabled (value) {
795
- return (this.businessType === '新增' && value.addOrEdit === 'edit') ||
796
- (this.businessType === '修改' && value.addOrEdit === 'add')
797
- },
798
- readonly (value) {
799
- return value.addOrEdit === 'readonly'
800
- },
801
- async onSubmit () {
802
- const valid = await this.validateForm()
803
- if (!valid) return false
804
- if (this.viewMode) {
805
- this.$message.info('预览模式禁止新增和修改')
806
- return false
807
- }
808
- this.loading = true
809
- const requestForm = this.prepareForm()
810
- await this.appendSilenceAddFields(requestForm)
811
- const realForm = this.handleFormKeys(requestForm)
812
- // 增加子表数据
813
- if (this.childTableData.length > 0) {
814
- for (const item of this.childTableData) {
815
- const childModel = item.model
816
- const childDataRef = this.$refs['childXFormTable_' + item.model][0].getTableData()
817
- const childData = []
818
- for (const item of childDataRef) {
819
- childData.push(JSON.parse(JSON.stringify(item)))
820
- }
821
- for (let i = 0; i < childData.length; i++) {
822
- childData[i] = this.handleFormKeys(childData[i])
823
- // 外键不需要带表别名,所以此处放到表单处理后赋值
824
- if (realForm.id) {
825
- childData[i][item.childTableForeignKeyName] = realForm.id
826
- }
827
- }
828
- realForm[childModel] = childData
829
- }
830
- }
831
- // 增加form子表数据
832
- if (this.childFormData.length > 0) {
833
- for (const item of this.childFormData) {
834
- const childModel = item.model
835
- const childData = this.$refs[item.model].getTableData()
836
- for (let i = 0; i < childData.length; i++) {
837
- childData[i] = this.handleFormKeys(childData[i], true)
838
- // 外键不需要带表别名,所以此处放到表单处理后赋值
839
- if (realForm.id) {
840
- childData[i][item.foreignKey] = realForm.id
841
- }
842
- }
843
- realForm[childModel] = childData
844
- }
845
- }
846
- if (this.$listeners.onSubmit) {
847
- // 交由父级处理
848
- this.$emit('onSubmit', {
849
- businessType: this.businessType,
850
- serviceName: this.serviceName,
851
- realForm: realForm,
852
- currUserName: this.currUser.name,
853
- currUserId: this.currUser.id,
854
- orgId: this.currUser.orgid
855
- })
856
- } else {
857
- this.defaultSubmit(realForm)
858
- }
859
- },
860
-
861
- async asyncSubmit () {
862
- return new Promise((resolve, reject) => {
863
- this.$refs.selectForm.validate(async valid => {
864
- if (!valid) {
865
- reject(new Error('Form validation failed'))
866
- return
867
- }
868
- this.loading = true
869
- const requestForm = this.prepareForm()
870
- await this.appendSilenceAddFields(requestForm)
871
- const realForm = this.handleFormKeys(requestForm)
872
- resolve({
873
- realForm,
874
- businessType: this.businessType,
875
- serviceName: this.serviceName,
876
- currUserName: this.currUser.name,
877
- currUserId: this.currUser.id,
878
- orgId: this.currUser.orgid
879
- })
880
- })
881
- })
882
- },
883
-
884
- validateForm () {
885
- return new Promise((resolve) => {
886
- this.$refs.selectForm.validate(valid => resolve(valid))
887
- })
888
- },
889
-
890
- childTableFixedQueryForm (item) {
891
- if (this.modifyModelData?.primaryKeyData) {
892
- const fixedForm = {}
893
- fixedForm[item.childTableForeignKeyName] = Object.values(this.modifyModelData.primaryKeyData)[0]
894
- return fixedForm
895
- }
896
- return null
897
- },
898
-
899
- prepareForm () {
900
- const form = { ...this.form }
901
- for (const key of Object.keys(form)) {
902
- const value = form[key]
903
- if (value === null || (typeof value === 'object' && Object.keys(value).length === 0)) {
904
- form[key] = undefined
905
- }
906
- }
907
- return form
908
- },
909
-
910
- async appendSilenceAddFields (form) {
911
- if (this.businessType === '新增') {
912
- for (const item of this.silenceAddJsonData) {
913
- switch (item.silencePurpose) {
914
- case 'createTime':
915
- form[item.model] = formatDate('now')
916
- break
917
- case 'operator':
918
- form[item.model] = this.currUser.name
919
- break
920
- case 'operatorId':
921
- form[item.model] = this.currUser.id
922
- break
923
- case 'orgId':
924
- form[item.model] = this.currUser.orgid
925
- break
926
- case 'orgName':
927
- form[item.model] = this.currUser.orgs
928
- break
929
- case 'depId':
930
- form[item.model] = this.currUser.depids
931
- break
932
- case 'depName':
933
- form[item.model] = this.currUser.deps
934
- break
935
- }
936
- }
937
- for (const item of this.silenceAddJsonData.filter((item) => item.silencePurpose === 'customize')) {
938
- const result = await runLogic(item.silenceSource, form, this.serviceName)
939
- if (result) {
940
- const keys = Object.keys(result)
941
- if (keys.length === 1 && keys[0] === 'value') {
942
- form[item.model] = result.value
943
- } else {
944
- form[item.model] = result
945
- }
946
- } else {
947
- form[item.model] = result
948
- }
949
- }
950
- }
951
- },
952
-
953
- handleFormKeys (form, mustHandleKey = false) {
954
- const realForm = {}
955
- for (const key of Object.keys(form)) {
956
- const value = form[key]
957
- const extraFormKeyTagIndex = key.indexOf('@')
958
- if (extraFormKeyTagIndex !== -1) {
959
- const extraFormKey = key.substring(0, extraFormKeyTagIndex)
960
- const realKey = key.substring(extraFormKeyTagIndex + 1)
961
- if (!realForm[extraFormKey]) {
962
- realForm[extraFormKey] = {}
963
- }
964
- realForm[extraFormKey][realKey] = value
965
- } else {
966
- const realKey = this.isHandleFormKey || mustHandleKey ? this.getRealKey(key, mustHandleKey) : key
967
- // 如果发生重名,不覆盖,把key的别名带上
968
- if (realForm[realKey]) {
969
- realForm[key] = value
970
- } else {
971
- realForm[realKey] = value
972
- }
973
- }
974
- }
975
- return realForm
976
- },
977
- // 默认提交事件
978
- defaultSubmit (realForm, callback) {
979
- // 新增移除id
980
- if (this.businessType === '新增') {
981
- delete realForm.id
982
- }
983
- // 组织请求
984
- const requestParameters = {
985
- queryParamsName: this.configName,
986
- queryParams: this.configContent,
987
- form: realForm,
988
- businessType: this.businessType,
989
- operator: this.currUser.name
990
- }
991
- addOrModify(requestParameters, this.serviceName, this.env === 'dev').then(data => {
992
- this.$message.success(this.businessType + '成功!')
993
- // commit
994
- this.$emit('afterSubmit', { type: this.businessType, id: data.id, data: data, form: requestParameters.form })
995
- this.loading = false
996
- if (callback) {
997
- callback()
998
- }
999
- }).catch(e => {
1000
- this.loading = false
1001
- this.$message.error(this.businessType + '失败:' + e)
1002
- })
1003
- },
1004
- // 获取表单字段实际值
1005
- getRealKey (key, mustHandleKey = false) {
1006
- if (key === 'selected_id') return key
1007
- if (this.isHandleFormKey || mustHandleKey) {
1008
- return key.substring(key.indexOf('_') + 1)
1009
- } else {
1010
- return key
1011
- }
1012
- },
1013
- /**
1014
- * 获取被修改记录数据
1015
- * @param modifyModelData 被修改记录的数据
1016
- */
1017
- getModifyModelData (modifyModelData) {
1018
- if (modifyModelData.primaryKeyData) {
1019
- this.form = Object.assign(this.form, modifyModelData.primaryKeyData)
1020
- }
1021
- // 对动态简易表单项特殊处理
1022
- for (const key in modifyModelData.data) {
1023
- const realKey = this.isHandleFormKey ? this.getRealKey(key) : key
1024
- if (this.simpleFormJsonData[realKey]) {
1025
- const extraForm = JSON.parse(modifyModelData.data[key])
1026
- for (const key in extraForm) {
1027
- const model = realKey + '@' + key
1028
- this.form[model] = extraForm[key]
1029
- }
1030
- }
1031
- }
1032
- // 对普通表单项处理
1033
- for (let i = 0; i < this.realJsonData.length; i++) {
1034
- if (['FilesId', 'Images'].includes(this.realJsonData[i])) {
1035
- // 附件需要跳过 因为会通过 modifyModelData中的files,images属性给upload赋值
1036
- // 新增修改表单每次提交时只会提交最新添加的文件
1037
- continue
1038
- }
1039
- const item = this.realJsonData[i]
1040
- if (modifyModelData.data[item.model] || modifyModelData.data[item.model] === 0) {
1041
- if (modifyModelData.data[item.model] instanceof Array) {
1042
- this.form[item.model] = modifyModelData.data[item.model]
1043
- } else {
1044
- this.form[item.model] = modifyModelData.data[item.model] + ''
1045
- }
1046
- }
1047
- }
1048
- // 对分组表单进行处理
1049
- for (let i = 0; i < this.groupJsonData.length; i++) {
1050
- const item = this.groupJsonData[i]
1051
- try {
1052
- if (modifyModelData.data[item.model]) {
1053
- this.form[item.model] = JSON.parse(modifyModelData.data[item.model])
1054
- }
1055
- } catch (e) {
1056
- if (modifyModelData.data[item.model]) {
1057
- this.form[item.model] = modifyModelData.data[item.model]
1058
- }
1059
- }
1060
- }
1061
- // 追加版本号信息
1062
- for (const item of this.versionJsonData) {
1063
- if (!modifyModelData.data[item.model]) {
1064
- this.form[item.model] = 0
1065
- } else {
1066
- this.form[item.model] = modifyModelData.data[item.model] + ''
1067
- }
1068
- }
1069
- },
1070
- setForm (obj) {
1071
- this.form = Object.assign(this.form, obj)
1072
- // 给子表赋外键条件
1073
- if (this.childFormData.length > 0) {
1074
- for (const item of this.childFormData) {
1075
- const child = this.$refs[item.model]
1076
- // 获取子表别名,以便在条件上添加别名
1077
- const alias = child.realQueryConfig.tableAliasName
1078
- // 有主键,且主键有值,添加主键条件
1079
- if (this.primaryKey && this.form[this.primaryKey]) {
1080
- const foreignKey = item.foreignKey
1081
- const fixedQueryForm = { [alias + '_' + foreignKey]: this.form[this.primaryKey] }
1082
- if (!child.fixedQueryForm) {
1083
- child.fixedQueryForm = fixedQueryForm
1084
- } else {
1085
- Object.assign(child.fixedQueryForm, fixedQueryForm)
1086
- }
1087
- child.refreshTable()
1088
- }
1089
- }
1090
- }
1091
- },
1092
- setFormWithKey (obj) {
1093
- setDataByRealKey(this.form, obj)
1094
- },
1095
- setFormWithNoKey (obj) {
1096
- setDataByRealKey(this.form, obj)
1097
- },
1098
- emitFunc (func, data, value) {
1099
- this.$emit(func, data, value)
1100
- this.$emit('x-form-item-emit-func', func, data, value)
1101
- },
1102
- // 直接转发事件的函数
1103
- emitEvent (event, ...args) {
1104
- this.$emit(event, ...args)
1105
- },
1106
- close () {
1107
- this.loaded = false
1108
- },
1109
- /**
1110
- * 行选择事件
1111
- * @param row 选中行集合
1112
- * @param attr 表单项属性
1113
- */
1114
- async rowChoose (row, attr, callback) {
1115
- // 如果配置了自定义函数
1116
- if (attr.dataChangeFunc) {
1117
- await executeStrFunction(attr.dataChangeFunc, [this.form, this.setForm, {
1118
- ...attr,
1119
- selectRows: row
1120
- }, util, this.mode, runLogic, getConfigByNameAsync])
1121
- } else {
1122
- // 默认填充选中行数据到当前表单
1123
- setDataByRealKey(this.form, row[0])
1124
- }
1125
- if (callback) {
1126
- callback()
1127
- }
1128
- }
1129
- }
1130
- }
1131
- </script>
1132
-
1133
- <style scoped lang="less">
1134
- :deep(.ant-form-inline .ant-form-item ) {
1135
- display: block !important;
1136
- }
1137
-
1138
- :deep(.ant-form-item-with-help) {
1139
- margin-bottom: 0;
1140
- }
1141
-
1142
- .xFormGroupTitle {
1143
- font-weight: bold;
1144
- color: @primary-color;
1145
- }
1146
- </style>
1
+ <template>
2
+ <div id="XAddNativeForm">
3
+ <a-form-model
4
+ v-if="loaded"
5
+ ref="selectForm"
6
+ :zIndex="1001"
7
+ :model="form"
8
+ v-bind="formItemLayoutGen"
9
+ :layout="layout"
10
+ :rules="rules">
11
+ <template v-for="(item, key) in childTableData">
12
+ <a-row
13
+ v-if="childTablePriority"
14
+ :gutter="16"
15
+ :key="'childTableRow' + key">
16
+ <a-card :title="item.name" :bordered="false" size="small">
17
+ <x-form-table
18
+ :key="'childTable_' + item.model"
19
+ :title="item.name"
20
+ :queryParamsName="item.childTableConfigName"
21
+ :localEditMode="true"
22
+ :fixed-query-form="childTableFixedQueryForm(item)"
23
+ :service-name="serviceName"
24
+ @innerXFormTableEmit="innerXFormTableEmit"
25
+ @afterTableInit="childTableMounted(item)"
26
+ :ref="'childXFormTable_' + item.model">
27
+ </x-form-table>
28
+ </a-card>
29
+ </a-row>
30
+ </template>
31
+ <a-row ref="GroupItemRow">
32
+ <a-col :span="3" v-if="!inXFormGroup && !(groups[0].groupName === DEFAULT_GROUP_NAME)">
33
+ <a-tabs tab-position="left" v-model="activeTab" @change="scrollToGroup">
34
+ <a-tab-pane
35
+ v-for="(groupsItem,groupsIndex) in groups"
36
+ :tab="groupsItem.groupName"
37
+ :key="groupsIndex">
38
+ </a-tab-pane>
39
+ </a-tabs>
40
+ </a-col>
41
+ <a-col
42
+ :span="(!inXFormGroup && !(groups[0].groupName === DEFAULT_GROUP_NAME)) ? 21: 24">
43
+ <a-row
44
+ :gutter="16"
45
+ type="flex"
46
+ :key="groupsIndex"
47
+ v-for="(groupsItem,groupsIndex) in groups"
48
+ >
49
+ <a-col
50
+ :span="24"
51
+ :style="{ marginTop: groupsIndex === 0 ? '' : '8px',fontSize:inXFormGroup?'15px':'14px', marginLeft:'-5px' }"
52
+ v-if="groupsItem.groupName !== DEFAULT_GROUP_NAME">
53
+ <span class="xFormGroupTitle" :ref="`group-title-${groupsIndex}`">{{ groupsItem.groupName }}</span>
54
+ </a-col>
55
+ <x-form-item
56
+ v-for="(item, index) in groupsItem.realJsonData"
57
+ :key="index"
58
+ :attr="item"
59
+ :disabled="itemDisabled(item)"
60
+ :read-only="readonly(item)"
61
+ :files="files"
62
+ v-bind="formItemLayoutGen"
63
+ :style="layout === 'inline' ? { marginTop:'5px' } : undefined"
64
+ :form="form"
65
+ :images="images"
66
+ :service-name="serviceName"
67
+ mode="新增/修改"
68
+ :layout="layout"
69
+ :get-data-params="getDataParams"
70
+ :env="env"
71
+ @x-form-item-emit-func="emitFunc"
72
+ @rowChoose="rowChoose"
73
+ :setForm="setForm"
74
+ />
75
+ </a-row>
76
+ </a-col>
77
+ </a-row>
78
+ <a-row :gutter="16" v-for="(groupItem, groupIndex) in groupJsonData" :key="groupIndex">
79
+ <a-card v-if="groupItem.groupItems.length > 0" :title="groupItem.name" :bordered="false" size="small">
80
+ <x-form-item
81
+ v-for="(item, index) in groupItem.groupItems"
82
+ :key="index"
83
+ :attr="item"
84
+ :disabled="itemDisabled(item)"
85
+ :readonly="readonly(item)"
86
+ :files="files"
87
+ v-bind="formItemLayoutGen"
88
+ :style="layout ==='inline'?{marginTop:'5px'}:undefined"
89
+ :form="form[groupItem.model]"
90
+ :images="images"
91
+ :service-name="serviceName"
92
+ mode="新增/修改"
93
+ :get-data-params="getDataParams"
94
+ :env="env"
95
+ :setForm="setForm"
96
+ @rowChoose="rowChoose"
97
+ />
98
+ </a-card>
99
+ <template v-else>
100
+ <slot
101
+ name="groupFormItems"
102
+ :form="form"
103
+ :model="groupItem.model"
104
+ :rules="rules"
105
+ :modifyModelData="modifyModelData"></slot>
106
+ </template>
107
+ </a-row>
108
+ <a-row :gutter="16" v-for="(item, key) in simpleFormJsonData" :key="'row' + key">
109
+ <a-card v-if="item.value.length > 0" :title="item.name" :bordered="false" size="small">
110
+ <x-form-item
111
+ v-for="(formItem, formItemIndex) in item.value"
112
+ :key="key + formItemIndex"
113
+ :attr="formItem"
114
+ :disabled="itemDisabled(formItem)"
115
+ :readonly="readonly(formItem)"
116
+ :files="files"
117
+ v-bind="formItemLayoutGen"
118
+ :style="layout ==='inline'?{marginTop:'5px'}:undefined"
119
+ :form="form[groupItem.model]"
120
+ :images="images"
121
+ :service-name="serviceName"
122
+ mode="新增/修改"
123
+ :get-data-params="getDataParams"
124
+ :env="env"
125
+ :setForm="setForm"
126
+ @rowChoose="rowChoose"
127
+ />
128
+ </a-card>
129
+ </a-row>
130
+ <template v-for="(item, key) in childTableData">
131
+ <a-row
132
+ v-if="!childTablePriority"
133
+ :gutter="16"
134
+ :key="'childTableRow' + key">
135
+ <a-card :title="item.name" :bordered="false" size="small">
136
+ <x-form-table
137
+ :key="'childTable_' + item.model"
138
+ :title="item.name"
139
+ :queryParamsName="item.childTableConfigName"
140
+ :localEditMode="true"
141
+ @innerXFormTableEmit="innerXFormTableEmit"
142
+ :fixed-query-form="childTableFixedQueryForm(item)"
143
+ :service-name="serviceName"
144
+ @afterTableInit="childTableMounted(item)"
145
+ :ref="'childXFormTable_' + item.model">
146
+ </x-form-table>
147
+ </a-card>
148
+ </a-row>
149
+ </template>
150
+ <a-row type="flex" :justify="btnPlace" :style="{paddingLeft: '16px',paddingRight: '16px'}">
151
+ <slot name="footer" :loading="loading">
152
+ <a-button v-if="showSubmitBtn" :loading="loading" type="primary" @click="onSubmit()">{{ btnName }}</a-button>
153
+ </slot>
154
+ </a-row>
155
+ </a-form-model>
156
+ </div>
157
+ </template>
158
+ <script>
159
+ import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
160
+ import { formatDate, setDataByRealKey } from '@vue2-client/utils/util'
161
+ import * as util from '@vue2-client/utils/util'
162
+ import { mapState } from 'vuex'
163
+ import { addOrModify, getConfigByName, getConfigByNameAsync, runLogic } from '@vue2-client/services/api/common'
164
+ import { checkIdNumber, REG_EMAIL, REG_LANDLINE, REG_PHONE } from '@vue2-client/utils/reg'
165
+ import moment from 'moment/moment'
166
+ import { executeStrFunction, executeStrFunctionByContext } from '@vue2-client/utils/runEvalFunction'
167
+
168
+ const DEFAULT_GROUP_NAME = '__default__'
169
+ export default {
170
+ name: 'XAddNativeForm',
171
+ components: {
172
+ XFormItem,
173
+ XFormTable: () => import('@vue2-client/base-client/components/common/XFormTable/XFormTable.vue')
174
+ },
175
+ inject: {
176
+ inXFormGroup: {
177
+ default: false
178
+ },
179
+ formGroupContext: {
180
+ default: null
181
+ }
182
+ },
183
+ props: {},
184
+ data () {
185
+ return {
186
+ DEFAULT_GROUP_NAME,
187
+ // 预览模式
188
+ viewMode: false,
189
+ // 是否处理表单Key值
190
+ isHandleFormKey: true,
191
+ // 内容加载是否完成
192
+ loaded: false,
193
+ // 业务类型
194
+ businessType: '',
195
+ // 业务标题
196
+ title: '',
197
+ // 新增或修改业务是否执行中
198
+ loading: false,
199
+ // 表单Model
200
+ form: {},
201
+ // 配置名称
202
+ configName: undefined,
203
+ // 配置内容,用于查询配置生成器的预览
204
+ configContent: undefined,
205
+ // 表单项集合
206
+ formItems: [],
207
+ // 服务名称
208
+ serviceName: undefined,
209
+ // 是否显示提交按钮
210
+ showSubmitBtn: true,
211
+ // 修改有文件的表单时使用
212
+ files: [],
213
+ images: [],
214
+ // 校验
215
+ rules: {},
216
+ // 调用logic获取数据源的追加参数
217
+ getDataParams: {},
218
+ // 动态简易表单集合
219
+ simpleFormJsonData: {},
220
+ // 待修改的数据集
221
+ modifyModelData: {},
222
+ // 当前环境
223
+ env: 'prod',
224
+ // 表单主键
225
+ primaryKey: null,
226
+ // 表单模式 horizontal | vertical | inline
227
+ layout: 'horizontal',
228
+ // 提交按钮名称
229
+ btnName: '提交',
230
+ // 提交按钮位置 start / center / end
231
+ btnPlace: 'center',
232
+ // 子表是否排在前面
233
+ childTablePriority: false
234
+ }
235
+ },
236
+ computed: {
237
+ // 过滤出用于新增/修改场景的表单项
238
+ realJsonData: function () {
239
+ return this.formItems.filter((item) => {
240
+ return item.addOrEdit && item.addOrEdit !== 'no' && item.addOrEdit !== 'silenceAdd' && item.addOrEdit !== 'version' && !this.itemDisabled(item)
241
+ })
242
+ },
243
+ // 表单项组 / 不是 数据组
244
+ groups: function () {
245
+ if (!this.realJsonData || this.realJsonData.length === 0) {
246
+ return [{
247
+ groupName: DEFAULT_GROUP_NAME,
248
+ realJsonData: this.realJsonData,
249
+ xAddFormLayout: 'horizontal'
250
+ }]
251
+ }
252
+ const uniqueGroups = new Set(this.realJsonData.map(item => item.group).filter(Boolean))
253
+ const allGroup = Array.from(uniqueGroups).map(group => {
254
+ return {
255
+ groupName: group,
256
+ realJsonData: this.realJsonData.filter(item => item.group === group),
257
+ xAddFormLayout: 'horizontal'
258
+ }
259
+ })
260
+ // 判断每一组得formJson 长度相加是否等于 realJsonData 长度 避免错误数据
261
+ if (allGroup.reduce((total, item) => total + item.realJsonData.length, 0) === this.realJsonData.length) {
262
+ return allGroup
263
+ } else {
264
+ return [{
265
+ groupName: DEFAULT_GROUP_NAME,
266
+ realJsonData: this.realJsonData,
267
+ xAddFormLayout: 'horizontal'
268
+ }]
269
+ }
270
+ },
271
+ // 拥有自定义校验函数得表单项
272
+ customValidateItems: function () {
273
+ return this.formItems.filter((item) => {
274
+ return item?.rule?.type === 'customJs'
275
+ })
276
+ },
277
+ // 过滤出用于新增/修改场景的表单项
278
+ groupJsonData: function () {
279
+ return this.formItems.filter((item) => {
280
+ return item.type === 'group'
281
+ }).map((item) => {
282
+ item.groupItems = item.groupItems.filter((item) => {
283
+ return item.addOrEdit && item.addOrEdit !== 'no' && item.addOrEdit !== 'silenceAdd' && item.addOrEdit !== 'version' && !this.itemDisabled(item)
284
+ }).map((groupItem) => {
285
+ // 只保留第一个下划线后面的内容
286
+ // 多层校验规则需要将prop设置为 key1.key2.....
287
+ groupItem.prop = `${item.model}.${groupItem.model.substring(groupItem.model.indexOf('_') + 1)}`
288
+ groupItem.model = groupItem.model.substring(groupItem.model.indexOf('_') + 1)
289
+ return groupItem
290
+ })
291
+ return item
292
+ }
293
+ )
294
+ },
295
+ // 过滤出用于子表数据新增/修改场景的表单项
296
+ childTableData: function () {
297
+ return this.formItems.filter((item) => {
298
+ return item.type === 'childTable'
299
+ })
300
+ },
301
+ // 过滤出用于form子表数据新增/修改场景的表单项
302
+ childFormData: function () {
303
+ return this.formItems.filter((item) => {
304
+ return item.type === 'rowEdit'
305
+ })
306
+ },
307
+ // 过滤出用于静默新增场景的表单项
308
+ silenceAddJsonData: function () {
309
+ return this.formItems.filter(function (item) {
310
+ return item.addOrEdit === 'silenceAdd'
311
+ })
312
+ },
313
+ // 过滤出版本号表单项
314
+ versionJsonData: function () {
315
+ return this.formItems.filter(function (item) {
316
+ return item.addOrEdit === 'version'
317
+ })
318
+ },
319
+ formItemLayoutGen () {
320
+ if (this.layout === 'horizontal') {
321
+ return {
322
+ labelCol: { span: 4, offset: 2 },
323
+ wrapperCol: { span: 14 },
324
+ }
325
+ } else if (this.layout === 'vertical') {
326
+ return {}
327
+ } else {
328
+ if (!this.formItemLayout.labelCol || !this.formItemLayout.wrapperCol) {
329
+ return {
330
+ labelCol: { span: 8 },
331
+ wrapperCol: { span: 16 },
332
+ }
333
+ }
334
+ return {
335
+ labelCol: { span: this.formItemLayout.labelCol },
336
+ wrapperCol: { span: this.formItemLayout.wrapperCol },
337
+ }
338
+ }
339
+ },
340
+ ...mapState('account', { currUser: 'user' })
341
+ },
342
+ provide () {
343
+ return {
344
+ getComponentByName: this.getComponentByName,
345
+ registerComponent: this.registerComponent,
346
+ getSelf: () => this,
347
+ }
348
+ },
349
+ /** //todo 本来想要实现 配置 自定义函数时,表单项得红星提示,根据自定义校验函数得返回值来判断
350
+ * 但是监听不到父组件formgorup得其他form得变化,所以暂时不实现
351
+ */
352
+ //
353
+ // watch: {
354
+ // form: {
355
+ // handler (val) {
356
+ // // 遍历表单配置
357
+ // if (this.customValidateItems.length > 0) {
358
+ // for (const item of this.customValidateItems) {
359
+ // const itemIndex = this.formItems.findIndex(formItem => formItem.model === item.model)
360
+ // if (itemIndex < 0) {
361
+ // continue
362
+ // }
363
+ // try {
364
+ // this.customJsValidate(null, val[item.model], (res) => {
365
+ // // 如果返回error则设置错误信息
366
+ // if (res instanceof Error) {
367
+ // // 设置表单项的错误状态
368
+ // this.$set(this.formItems[itemIndex], 'tempRequired', true)
369
+ // } else {
370
+ // // 清除错误状态
371
+ // this.$set(this.formItems[itemIndex], 'tempRequired', true)
372
+ // }
373
+ // }, item)
374
+ // } catch (e) {
375
+ // console.error(e)
376
+ // this.$set(this.formItems[itemIndex], 'tempRequired', true)
377
+ // }
378
+ // }
379
+ // console.log('customValidateItems', JSON.stringify(this.customValidateItems))
380
+ // }
381
+ // },
382
+ // deep: true
383
+ // }
384
+ // },
385
+ methods: {
386
+ runLogic,
387
+ getConfigByNameAsync,
388
+ getConfigByName,
389
+ init (params) {
390
+ const {
391
+ configName,
392
+ configContent,
393
+ formItems,
394
+ formJson,
395
+ viewMode,
396
+ isHandleFormKey,
397
+ isKeyHandle = true,
398
+ showSubmitBtn = true,
399
+ serviceName,
400
+ primaryKey,
401
+ modifyModelData = {},
402
+ businessType,
403
+ title,
404
+ fixedAddForm = {},
405
+ getDataParams = {},
406
+ simpleFormJsonData = {},
407
+ env = 'prod',
408
+ layout,
409
+ xAddFormLayout = 'horizontal',
410
+ formItemLayout = {},
411
+ btnName = '提交',
412
+ childTablePriority = false,
413
+ btnPlace = 'center'
414
+ } = params
415
+ this.loaded = false
416
+ // 兼容需要省略 传递 layout: res.xAddFormLayout 可以使用 ...res 展开运算符 直接转递
417
+ if (xAddFormLayout && layout === undefined) {
418
+ this.layout = xAddFormLayout
419
+ } else {
420
+ this.layout = layout
421
+ }
422
+ this.formItemLayout = formItemLayout
423
+ if ((isHandleFormKey === null || isHandleFormKey === undefined) && !isKeyHandle) {
424
+ this.isHandleFormKey = isKeyHandle
425
+ } else if (isHandleFormKey) {
426
+ this.isHandleFormKey = isHandleFormKey
427
+ } else {
428
+ this.isHandleFormKey = isKeyHandle
429
+ }
430
+ this.childTablePriority = childTablePriority
431
+ this.configName = configName
432
+ this.configContent = configContent
433
+ this.formItems = this.getFromItem(formItems, formJson)
434
+ this.viewMode = viewMode
435
+ this.showSubmitBtn = showSubmitBtn
436
+ this.primaryKey = primaryKey
437
+ this.serviceName = serviceName
438
+ this.businessType = businessType
439
+ this.title = title
440
+ this.getDataParams = getDataParams
441
+ this.simpleFormJsonData = simpleFormJsonData
442
+ this.env = env
443
+ this.btnName = btnName
444
+ this.btnPlace = btnPlace
445
+ // 如果 fixedAddForm 有 selected_id 值,并且设置了处理表单key值,则多给 selected_id 加前缀 避免处理错误
446
+ if (fixedAddForm.selected_id && this.isHandleFormKey) {
447
+ fixedAddForm._selected_id = fixedAddForm.selected_id
448
+ delete fixedAddForm.selected_id
449
+ }
450
+ // 设置普通表单项的相关参数
451
+ const formData = Object.assign({}, fixedAddForm)
452
+ for (let i = 0; i < this.realJsonData.length; i++) {
453
+ const item = this.realJsonData[i]
454
+ this.setFormProps(formData, item, null)
455
+ }
456
+ // 设置表单分组项目相关参数
457
+ for (let i = 0; i < this.groupJsonData.length; i++) {
458
+ const groupItem = this.groupJsonData[i]
459
+ formData[groupItem.model] = {}
460
+ for (let j = 0; j < groupItem.groupItems.length; j++) {
461
+ const item = groupItem.groupItems[j]
462
+ this.setFormProps(formData[groupItem.model], item, item.prop)
463
+ }
464
+ }
465
+ // 设置动态简易表单项的相关参数
466
+ for (const key in this.simpleFormJsonData) {
467
+ for (const item of this.simpleFormJsonData[key].value) {
468
+ item.model = key + '@' + item.model
469
+ this.setFormProps(formData, item, null)
470
+ }
471
+ }
472
+
473
+ this.form = formData
474
+ // 修改场景下对表单项赋值
475
+ if (modifyModelData && modifyModelData.data) {
476
+ this.modifyModelData = modifyModelData
477
+ if (Object.keys(modifyModelData.data).length > 0) {
478
+ this.getModifyModelData(modifyModelData)
479
+ }
480
+ }
481
+ // 处理表单得附件
482
+ if (modifyModelData && modifyModelData.files) {
483
+ this.files = modifyModelData.files
484
+ }
485
+ if (modifyModelData && modifyModelData.images) {
486
+ this.images = modifyModelData.images
487
+ }
488
+ this.loaded = true
489
+ },
490
+ scrollToGroup (index) {
491
+ const groupElement = this.$refs[`group-title-${index}`][0]
492
+ if (groupElement) {
493
+ groupElement.scrollIntoView({ behavior: 'smooth' })
494
+ }
495
+ },
496
+ registerComponent (componentName, component) {
497
+ console.log('内部注册', this.$options.name, componentName)
498
+ this.$refs[componentName] = component
499
+ console.log('内部注册完成', this.$refs)
500
+ },
501
+ // 根据名字从注册到组件中获取组件
502
+ getComponentByName (componentName) {
503
+ console.log('内部取组件', this.$options.name, componentName)
504
+ console.log('内部组件内容', this.$refs)
505
+ return this.$refs[componentName]
506
+ },
507
+ // 兼容需要省略 传递 [formItems: res.formJson ] 可以使用 ...res 展开运算符 直接转递
508
+ getFromItem (formItems, formJson) {
509
+ const _formItems = formItems || formJson
510
+ if (typeof formItems === 'string') {
511
+ return JSON.parse(_formItems)
512
+ } else {
513
+ return JSON.parse(JSON.stringify(_formItems))
514
+ }
515
+ },
516
+ innerXFormTableEmit (fun, record, id, actionType, index) {
517
+ this.$emit(fun, record, id, actionType, index)
518
+ },
519
+ // 时间组件赋默认值
520
+ // .type, item.formDefault
521
+ getDateRange ({ type, formDefault: defaultValue, formValueFormat }) {
522
+ // const format = type === 'datePicker' ? 'YYYY-MM-DD' : 'YYYY-MM-DD HH:mm:ss'
523
+ let format = 'YYYY-MM-DD HH:mm:ss'
524
+ if (formValueFormat) {
525
+ format = formValueFormat
526
+ }
527
+ let start
528
+ switch (defaultValue) {
529
+ case 'curYear':
530
+ start = moment().startOf('year').format(format)
531
+ break
532
+ case 'curMonth':
533
+ start = moment().startOf('month').format(format)
534
+ break
535
+ case 'curDay':
536
+ start = moment().startOf('day').format(format)
537
+ break
538
+ case 'curTime':
539
+ start = moment().format(format)
540
+ break
541
+ default:
542
+ return defaultValue
543
+ }
544
+ return start
545
+ },
546
+ setFormProps (formData, item, groupItem) {
547
+ if (formData[item.model] === undefined || formData[item.model] === null) {
548
+ formData[item.model] = undefined
549
+ }
550
+ if (!formData[item.model] && item.formDefault) {
551
+ if (['datePicker', 'rangePicker', 'yearPicker', 'monthPicker', 'yearRangePicker', 'monthRangePicker'].includes(item.type)) {
552
+ formData[item.model] = this.getDateRange(item)
553
+ } else if (['treeSelect', 'select', 'checkbox'].includes(item.type) && ['curOrgId', 'curDepId', 'curUserId'].includes(item.formDefault)) {
554
+ if (item.formDefault === 'curOrgId') {
555
+ formData[item.model] = item.type === 'select' ? this.currUser.orgid : [this.currUser.orgid]
556
+ }
557
+ if (item.formDefault === 'curDepId') {
558
+ formData[item.model] = item.type === 'select' ? this.currUser.depids : [this.currUser.depids]
559
+ }
560
+ if (item.formDefault === 'curUserId') {
561
+ formData[item.model] = item.type === 'select' ? this.currUser.id : [this.currUser.id]
562
+ }
563
+ } else {
564
+ formData[item.model] = item.formDefault
565
+ }
566
+ }
567
+ // 处理表单校验情况
568
+ if (item.rule) {
569
+ if (groupItem) {
570
+ this.rules[groupItem] = []
571
+ } else {
572
+ this.rules[item.model] = []
573
+ }
574
+ const required = item.rule.required ? item.rule.required === true || item.rule.required === 'true' : false
575
+ let trigger
576
+ let message
577
+ if (required) {
578
+ switch (item.type) {
579
+ case 'select':
580
+ case 'checkbox':
581
+ case 'radio':
582
+ case 'treeSelect':
583
+ case 'rangePicker':
584
+ case 'monthPicker':
585
+ case 'yearPicker':
586
+ case 'datePicker':
587
+ case 'file':
588
+ case 'image':
589
+ case 'citySelect':
590
+ case 'addressSearch':
591
+ case 'personSetting':
592
+ message = '请选择' + item.name
593
+ trigger = 'change'
594
+ break
595
+ default:
596
+ message = '请输入' + item.name
597
+ trigger = 'blur'
598
+ }
599
+ if (groupItem) {
600
+ this.rules[groupItem].push({
601
+ required: true,
602
+ message: message,
603
+ trigger: trigger
604
+ })
605
+ } else {
606
+ this.rules[item.model].push({
607
+ required: true,
608
+ message: message,
609
+ trigger: trigger
610
+ })
611
+ }
612
+ }
613
+
614
+ switch (item.rule.type) {
615
+ case 'number':
616
+ case 'integer':
617
+ case 'float':
618
+ // eslint-disable-next-line no-case-declarations
619
+ let defaultValue
620
+ // eslint-disable-next-line no-case-declarations
621
+ let message
622
+ switch (item.rule.type) {
623
+ case 'number':
624
+ item.numberInput = true
625
+ message = '数字'
626
+ defaultValue = 0
627
+ break
628
+ case 'integer':
629
+ item.numberInput = true
630
+ message = '整数'
631
+ defaultValue = 0
632
+ break
633
+ case 'float':
634
+ item.numberInput = true
635
+ message = '小数'
636
+ defaultValue = 0.0
637
+ break
638
+ }
639
+ if (groupItem) {
640
+ this.rules[groupItem].push({
641
+ type: item.rule.type,
642
+ message: item.name + '必须为' + message,
643
+ transform: (value) => {
644
+ if (value && value.length !== 0) {
645
+ return Number(value)
646
+ } else {
647
+ return defaultValue
648
+ }
649
+ },
650
+ trigger: 'blur'
651
+ })
652
+ } else {
653
+ this.rules[item.model].push({
654
+ type: item.rule.type,
655
+ message: item.name + '必须为' + message,
656
+ transform: (value) => {
657
+ if (value && value.length !== 0) {
658
+ return Number(value)
659
+ } else {
660
+ return defaultValue
661
+ }
662
+ },
663
+ trigger: 'blur'
664
+ })
665
+ }
666
+ break
667
+ case 'email': {
668
+ const validator = (rule, value, callback) => {
669
+ if (value && !REG_EMAIL.test(value)) {
670
+ callback(new Error('请输入正确的邮箱地址'))
671
+ } else {
672
+ callback()
673
+ }
674
+ }
675
+ this.rules[groupItem || item.model].push({
676
+ type: 'email',
677
+ validator: validator,
678
+ message: '请输入正确的邮箱地址',
679
+ trigger: 'blur'
680
+ })
681
+ break
682
+ }
683
+ case 'userPhone': {
684
+ this.rules[groupItem || item.model].push({
685
+ type: 'userPhone',
686
+ validator: (rule, value, callback) => {
687
+ if (value && !REG_PHONE.test(value)) {
688
+ callback(new Error('请输入正确的手机号码'))
689
+ } else {
690
+ callback()
691
+ }
692
+ },
693
+ message: '请输入正确的手机号码',
694
+ trigger: 'blur'
695
+ })
696
+ break
697
+ }
698
+ case 'idNumber': {
699
+ this.rules[groupItem || item.model].push({
700
+ validator: (rule, value, callback) => {
701
+ if (value && !checkIdNumber(value)) {
702
+ callback(new Error('请输入正确的身份证号码'))
703
+ } else {
704
+ callback()
705
+ }
706
+ },
707
+ trigger: 'blur'
708
+ })
709
+ break
710
+ }
711
+ case 'landlineNumber': {
712
+ this.rules[item.model].push({
713
+ validator: (rule, value, callback) => {
714
+ if (value && !REG_LANDLINE.test(value)) {
715
+ callback(new Error('请输入正确的座机号码'))
716
+ } else {
717
+ callback()
718
+ }
719
+ },
720
+ trigger: 'blur'
721
+ })
722
+ break
723
+ }
724
+ // 大于0
725
+ case 'greaterThanZero': {
726
+ item.numberInput = true
727
+ this.rules[item.model].push({
728
+ validator: (rule, value, callback) => {
729
+ if (isNaN(value) || value <= 0) {
730
+ callback(new Error('请输入一个大于0的数字'))
731
+ } else {
732
+ callback()
733
+ }
734
+ },
735
+ trigger: 'blur'
736
+ })
737
+ break
738
+ }
739
+ // 大于等于0
740
+ case 'greaterThanOrEqualZero': {
741
+ item.numberInput = true
742
+ this.rules[item.model].push({
743
+ validator: (rule, value, callback) => {
744
+ if (isNaN(value) || value < 0) {
745
+ callback(new Error('请输入一个大于等于0的数字'))
746
+ } else {
747
+ callback()
748
+ }
749
+ },
750
+ trigger: 'blur'
751
+ })
752
+ break
753
+ }
754
+ case 'stringLength': {
755
+ this.rules[item.model].push({
756
+ validator: (rule, value, callback) => {
757
+ if (value && value.length < item.rule.minLen) {
758
+ callback(new Error('长度不能少于' + item.rule.minLen + '个字符'))
759
+ } else if (value && value.length > item.rule.maxLen) {
760
+ callback(new Error('长度不能超过' + item.rule.maxLen + '个字符'))
761
+ } else {
762
+ callback()
763
+ }
764
+ },
765
+ trigger: 'blur'
766
+ })
767
+ break
768
+ }
769
+ case 'customJs': {
770
+ this.rules[item.model].push({
771
+ validator: (rule, value, callback) => {
772
+ this.customJsValidate(rule, value, callback, item)
773
+ },
774
+ trigger: 'blur'
775
+ })
776
+ break
777
+ }
778
+ }
779
+ }
780
+ },
781
+ childTableMounted (item) {
782
+ // 子表初始化时,设置表格数据
783
+ if (this.form[item.model] && this.form[item.model].length > 0) {
784
+ this.$refs[`childXFormTable_${item.model}`][0].setTableData(this.form[item.model])
785
+ }
786
+ },
787
+ customJsValidate (rule, value, callback, item) {
788
+ if (item.rule.customValidatorFunc) {
789
+ executeStrFunctionByContext(this, item.rule.customValidatorFunc, [rule, value, callback, this.form, item, this.util, runLogic, getConfigByNameAsync])
790
+ } else {
791
+ callback()
792
+ }
793
+ },
794
+ itemDisabled (value) {
795
+ return (this.businessType === '新增' && value.addOrEdit === 'edit') ||
796
+ (this.businessType === '修改' && value.addOrEdit === 'add')
797
+ },
798
+ readonly (value) {
799
+ return value.addOrEdit === 'readonly'
800
+ },
801
+ async onSubmit () {
802
+ const valid = await this.validateForm()
803
+ if (!valid) return false
804
+ if (this.viewMode) {
805
+ this.$message.info('预览模式禁止新增和修改')
806
+ return false
807
+ }
808
+ this.loading = true
809
+ const requestForm = this.prepareForm()
810
+ await this.appendSilenceAddFields(requestForm)
811
+ const realForm = this.handleFormKeys(requestForm)
812
+ // 增加子表数据
813
+ if (this.childTableData.length > 0) {
814
+ for (const item of this.childTableData) {
815
+ const childModel = item.model
816
+ const childDataRef = this.$refs['childXFormTable_' + item.model][0].getTableData()
817
+ const childData = []
818
+ for (const item of childDataRef) {
819
+ childData.push(JSON.parse(JSON.stringify(item)))
820
+ }
821
+ for (let i = 0; i < childData.length; i++) {
822
+ childData[i] = this.handleFormKeys(childData[i])
823
+ // 外键不需要带表别名,所以此处放到表单处理后赋值
824
+ if (realForm.id) {
825
+ childData[i][item.childTableForeignKeyName] = realForm.id
826
+ }
827
+ }
828
+ realForm[childModel] = childData
829
+ }
830
+ }
831
+ // 增加form子表数据
832
+ if (this.childFormData.length > 0) {
833
+ for (const item of this.childFormData) {
834
+ const childModel = item.model
835
+ const childData = this.$refs[item.model].getTableData()
836
+ for (let i = 0; i < childData.length; i++) {
837
+ childData[i] = this.handleFormKeys(childData[i], true)
838
+ // 外键不需要带表别名,所以此处放到表单处理后赋值
839
+ if (realForm.id) {
840
+ childData[i][item.foreignKey] = realForm.id
841
+ }
842
+ }
843
+ realForm[childModel] = childData
844
+ }
845
+ }
846
+ if (this.$listeners.onSubmit) {
847
+ // 交由父级处理
848
+ this.$emit('onSubmit', {
849
+ businessType: this.businessType,
850
+ serviceName: this.serviceName,
851
+ realForm: realForm,
852
+ currUserName: this.currUser.name,
853
+ currUserId: this.currUser.id,
854
+ orgId: this.currUser.orgid
855
+ })
856
+ } else {
857
+ this.defaultSubmit(realForm)
858
+ }
859
+ },
860
+
861
+ async asyncSubmit () {
862
+ return new Promise((resolve, reject) => {
863
+ this.$refs.selectForm.validate(async valid => {
864
+ if (!valid) {
865
+ reject(new Error('Form validation failed'))
866
+ return
867
+ }
868
+ this.loading = true
869
+ const requestForm = this.prepareForm()
870
+ await this.appendSilenceAddFields(requestForm)
871
+ const realForm = this.handleFormKeys(requestForm)
872
+ resolve({
873
+ realForm,
874
+ businessType: this.businessType,
875
+ serviceName: this.serviceName,
876
+ currUserName: this.currUser.name,
877
+ currUserId: this.currUser.id,
878
+ orgId: this.currUser.orgid
879
+ })
880
+ })
881
+ })
882
+ },
883
+
884
+ validateForm () {
885
+ return new Promise((resolve) => {
886
+ this.$refs.selectForm.validate(valid => resolve(valid))
887
+ })
888
+ },
889
+
890
+ childTableFixedQueryForm (item) {
891
+ if (this.modifyModelData?.primaryKeyData) {
892
+ const fixedForm = {}
893
+ fixedForm[item.childTableForeignKeyName] = Object.values(this.modifyModelData.primaryKeyData)[0]
894
+ return fixedForm
895
+ }
896
+ return null
897
+ },
898
+
899
+ prepareForm () {
900
+ const form = { ...this.form }
901
+ for (const key of Object.keys(form)) {
902
+ const value = form[key]
903
+ if (value === null || (typeof value === 'object' && Object.keys(value).length === 0)) {
904
+ form[key] = undefined
905
+ }
906
+ }
907
+ return form
908
+ },
909
+
910
+ async appendSilenceAddFields (form) {
911
+ if (this.businessType === '新增') {
912
+ for (const item of this.silenceAddJsonData) {
913
+ switch (item.silencePurpose) {
914
+ case 'createTime':
915
+ form[item.model] = formatDate('now')
916
+ break
917
+ case 'operator':
918
+ form[item.model] = this.currUser.name
919
+ break
920
+ case 'operatorId':
921
+ form[item.model] = this.currUser.id
922
+ break
923
+ case 'orgId':
924
+ form[item.model] = this.currUser.orgid
925
+ break
926
+ case 'orgName':
927
+ form[item.model] = this.currUser.orgs
928
+ break
929
+ case 'depId':
930
+ form[item.model] = this.currUser.depids
931
+ break
932
+ case 'depName':
933
+ form[item.model] = this.currUser.deps
934
+ break
935
+ }
936
+ }
937
+ for (const item of this.silenceAddJsonData.filter((item) => item.silencePurpose === 'customize')) {
938
+ const result = await runLogic(item.silenceSource, form, this.serviceName)
939
+ if (result) {
940
+ const keys = Object.keys(result)
941
+ if (keys.length === 1 && keys[0] === 'value') {
942
+ form[item.model] = result.value
943
+ } else {
944
+ form[item.model] = result
945
+ }
946
+ } else {
947
+ form[item.model] = result
948
+ }
949
+ }
950
+ }
951
+ },
952
+
953
+ handleFormKeys (form, mustHandleKey = false) {
954
+ const realForm = {}
955
+ for (const key of Object.keys(form)) {
956
+ const value = form[key]
957
+ const extraFormKeyTagIndex = key.indexOf('@')
958
+ if (extraFormKeyTagIndex !== -1) {
959
+ const extraFormKey = key.substring(0, extraFormKeyTagIndex)
960
+ const realKey = key.substring(extraFormKeyTagIndex + 1)
961
+ if (!realForm[extraFormKey]) {
962
+ realForm[extraFormKey] = {}
963
+ }
964
+ realForm[extraFormKey][realKey] = value
965
+ } else {
966
+ const realKey = this.isHandleFormKey || mustHandleKey ? this.getRealKey(key, mustHandleKey) : key
967
+ // 如果发生重名,不覆盖,把key的别名带上
968
+ if (realForm[realKey]) {
969
+ realForm[key] = value
970
+ } else {
971
+ realForm[realKey] = value
972
+ }
973
+ }
974
+ }
975
+ return realForm
976
+ },
977
+ // 默认提交事件
978
+ defaultSubmit (realForm, callback) {
979
+ // 新增移除id
980
+ if (this.businessType === '新增') {
981
+ delete realForm.id
982
+ }
983
+ // 组织请求
984
+ const requestParameters = {
985
+ queryParamsName: this.configName,
986
+ queryParams: this.configContent,
987
+ form: realForm,
988
+ businessType: this.businessType,
989
+ operator: this.currUser.name
990
+ }
991
+ addOrModify(requestParameters, this.serviceName, this.env === 'dev').then(data => {
992
+ this.$message.success(this.businessType + '成功!')
993
+ // commit
994
+ this.$emit('afterSubmit', { type: this.businessType, id: data.id, data: data, form: requestParameters.form })
995
+ this.loading = false
996
+ if (callback) {
997
+ callback()
998
+ }
999
+ }).catch(e => {
1000
+ this.loading = false
1001
+ this.$message.error(this.businessType + '失败:' + e)
1002
+ })
1003
+ },
1004
+ // 获取表单字段实际值
1005
+ getRealKey (key, mustHandleKey = false) {
1006
+ if (key === 'selected_id') return key
1007
+ if (this.isHandleFormKey || mustHandleKey) {
1008
+ return key.substring(key.indexOf('_') + 1)
1009
+ } else {
1010
+ return key
1011
+ }
1012
+ },
1013
+ /**
1014
+ * 获取被修改记录数据
1015
+ * @param modifyModelData 被修改记录的数据
1016
+ */
1017
+ getModifyModelData (modifyModelData) {
1018
+ if (modifyModelData.primaryKeyData) {
1019
+ this.form = Object.assign(this.form, modifyModelData.primaryKeyData)
1020
+ }
1021
+ // 对动态简易表单项特殊处理
1022
+ for (const key in modifyModelData.data) {
1023
+ const realKey = this.isHandleFormKey ? this.getRealKey(key) : key
1024
+ if (this.simpleFormJsonData[realKey]) {
1025
+ const extraForm = JSON.parse(modifyModelData.data[key])
1026
+ for (const key in extraForm) {
1027
+ const model = realKey + '@' + key
1028
+ this.form[model] = extraForm[key]
1029
+ }
1030
+ }
1031
+ }
1032
+ // 对普通表单项处理
1033
+ for (let i = 0; i < this.realJsonData.length; i++) {
1034
+ if (['FilesId', 'Images'].includes(this.realJsonData[i])) {
1035
+ // 附件需要跳过 因为会通过 modifyModelData中的files,images属性给upload赋值
1036
+ // 新增修改表单每次提交时只会提交最新添加的文件
1037
+ continue
1038
+ }
1039
+ const item = this.realJsonData[i]
1040
+ if (modifyModelData.data[item.model] || modifyModelData.data[item.model] === 0) {
1041
+ if (modifyModelData.data[item.model] instanceof Array) {
1042
+ this.form[item.model] = modifyModelData.data[item.model]
1043
+ } else {
1044
+ this.form[item.model] = modifyModelData.data[item.model] + ''
1045
+ }
1046
+ }
1047
+ }
1048
+ // 对分组表单进行处理
1049
+ for (let i = 0; i < this.groupJsonData.length; i++) {
1050
+ const item = this.groupJsonData[i]
1051
+ try {
1052
+ if (modifyModelData.data[item.model]) {
1053
+ this.form[item.model] = JSON.parse(modifyModelData.data[item.model])
1054
+ }
1055
+ } catch (e) {
1056
+ if (modifyModelData.data[item.model]) {
1057
+ this.form[item.model] = modifyModelData.data[item.model]
1058
+ }
1059
+ }
1060
+ }
1061
+ // 追加版本号信息
1062
+ for (const item of this.versionJsonData) {
1063
+ if (!modifyModelData.data[item.model]) {
1064
+ this.form[item.model] = 0
1065
+ } else {
1066
+ this.form[item.model] = modifyModelData.data[item.model] + ''
1067
+ }
1068
+ }
1069
+ },
1070
+ setForm (obj) {
1071
+ this.form = Object.assign(this.form, obj)
1072
+ // 给子表赋外键条件
1073
+ if (this.childFormData.length > 0) {
1074
+ for (const item of this.childFormData) {
1075
+ const child = this.$refs[item.model]
1076
+ // 获取子表别名,以便在条件上添加别名
1077
+ const alias = child.realQueryConfig.tableAliasName
1078
+ // 有主键,且主键有值,添加主键条件
1079
+ if (this.primaryKey && this.form[this.primaryKey]) {
1080
+ const foreignKey = item.foreignKey
1081
+ const fixedQueryForm = { [alias + '_' + foreignKey]: this.form[this.primaryKey] }
1082
+ if (!child.fixedQueryForm) {
1083
+ child.fixedQueryForm = fixedQueryForm
1084
+ } else {
1085
+ Object.assign(child.fixedQueryForm, fixedQueryForm)
1086
+ }
1087
+ child.refreshTable()
1088
+ }
1089
+ }
1090
+ }
1091
+ },
1092
+ setFormWithKey (obj) {
1093
+ setDataByRealKey(this.form, obj)
1094
+ },
1095
+ setFormWithNoKey (obj) {
1096
+ setDataByRealKey(this.form, obj)
1097
+ },
1098
+ emitFunc (func, data, value) {
1099
+ this.$emit(func, data, value)
1100
+ this.$emit('x-form-item-emit-func', func, data, value)
1101
+ },
1102
+ // 直接转发事件的函数
1103
+ emitEvent (event, ...args) {
1104
+ this.$emit(event, ...args)
1105
+ },
1106
+ close () {
1107
+ this.loaded = false
1108
+ },
1109
+ /**
1110
+ * 行选择事件
1111
+ * @param row 选中行集合
1112
+ * @param attr 表单项属性
1113
+ */
1114
+ async rowChoose (row, attr, callback) {
1115
+ // 如果配置了自定义函数
1116
+ if (attr.dataChangeFunc) {
1117
+ await executeStrFunction(attr.dataChangeFunc, [this.form, this.setForm, {
1118
+ ...attr,
1119
+ selectRows: row
1120
+ }, util, this.mode, runLogic, getConfigByNameAsync])
1121
+ } else {
1122
+ // 默认填充选中行数据到当前表单
1123
+ setDataByRealKey(this.form, row[0])
1124
+ }
1125
+ if (callback) {
1126
+ callback()
1127
+ }
1128
+ }
1129
+ }
1130
+ }
1131
+ </script>
1132
+
1133
+ <style scoped lang="less">
1134
+ :deep(.ant-form-inline .ant-form-item ) {
1135
+ display: block !important;
1136
+ }
1137
+
1138
+ :deep(.ant-form-item-with-help) {
1139
+ margin-bottom: 0;
1140
+ }
1141
+
1142
+ .xFormGroupTitle {
1143
+ font-weight: bold;
1144
+ color: @primary-color;
1145
+ }
1146
+ </style>