vue2-client 1.10.12 → 1.10.13

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