n20-common-lib 1.3.46 → 1.3.49

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 (402) hide show
  1. package/README.md +2 -2
  2. package/g6.js +2 -2
  3. package/nstc-g6/assets/svg/addFile.svg +31 -31
  4. package/nstc-g6/assets/svg/deleteFile.svg +27 -27
  5. package/nstc-g6/assets/svg/filter.svg +15 -15
  6. package/nstc-g6/assets/svg/filterActive.svg +16 -16
  7. package/nstc-g6/assets/svg/hourglass.svg +18 -18
  8. package/nstc-g6/assets/svg/newsearch.svg +18 -18
  9. package/nstc-g6/assets/svg/searchActive.svg +18 -18
  10. package/nstc-g6/components/Calendar/index.js +8 -8
  11. package/nstc-g6/components/Calendar/src/basic/month-table.vue +129 -129
  12. package/nstc-g6/components/Calendar/src/basic/year-table.vue +126 -126
  13. package/nstc-g6/components/Calendar/src/main.vue +442 -442
  14. package/nstc-g6/components/DialogForm/index.js +8 -8
  15. package/nstc-g6/components/DialogForm/src/demo/index.vue +56 -56
  16. package/nstc-g6/components/DialogForm/src/main.vue +189 -189
  17. package/nstc-g6/components/Form/A_DEMO/component/originalForm.vue +280 -280
  18. package/nstc-g6/components/Form/A_DEMO/config/config_3.js +1222 -1222
  19. package/nstc-g6/components/Form/A_DEMO/index.vue +803 -803
  20. package/nstc-g6/components/Form/AutocompleteCustom/index.vue +72 -72
  21. package/nstc-g6/components/Form/BusinessSpecific/InputMultiple.vue +191 -191
  22. package/nstc-g6/components/Form/BusinessSpecific/InputWithUnit.vue +128 -128
  23. package/nstc-g6/components/Form/BusinessSpecific/SelectTreeDialog.vue +233 -233
  24. package/nstc-g6/components/Form/BusinessSpecific/readme.md +7 -7
  25. package/nstc-g6/components/Form/CascaderCustom/index.vue +101 -101
  26. package/nstc-g6/components/Form/CheckboxCustom/index.vue +84 -84
  27. package/nstc-g6/components/Form/Component.vue +661 -661
  28. package/nstc-g6/components/Form/ComponentSecond.vue +650 -650
  29. package/nstc-g6/components/Form/DatepickerCustom/index.vue +130 -130
  30. package/nstc-g6/components/Form/InputAndDialog/index.js +15 -15
  31. package/nstc-g6/components/Form/InputAndDialog/src/main.vue +394 -394
  32. package/nstc-g6/components/Form/InputCustom/demo/index.vue +65 -65
  33. package/nstc-g6/components/Form/InputCustom/index.vue +307 -307
  34. package/nstc-g6/components/Form/IntervalinputCustom/demo/index.vue +31 -31
  35. package/nstc-g6/components/Form/IntervalinputCustom/index.vue +118 -118
  36. package/nstc-g6/components/Form/Item.vue +330 -330
  37. package/nstc-g6/components/Form/ItemSecond.vue +269 -269
  38. package/nstc-g6/components/Form/List.vue +146 -146
  39. package/nstc-g6/components/Form/ListSecond.vue +130 -130
  40. package/nstc-g6/components/Form/RadioCustom/index.vue +73 -73
  41. package/nstc-g6/components/Form/SelectAccount/index.js +15 -15
  42. package/nstc-g6/components/Form/SelectAccount/src/demo/index.vue +57 -57
  43. package/nstc-g6/components/Form/SelectAccount/src/main.vue +282 -282
  44. package/nstc-g6/components/Form/SelectAndDialog/index.js +15 -15
  45. package/nstc-g6/components/Form/SelectAndDialog/src/main.vue +383 -383
  46. package/nstc-g6/components/Form/SelectCashFlow/index.js +15 -15
  47. package/nstc-g6/components/Form/SelectCashFlow/src/demo/index.vue +41 -41
  48. package/nstc-g6/components/Form/SelectCashFlow/src/main.vue +125 -125
  49. package/nstc-g6/components/Form/SelectCustom/demo/index.vue +82 -82
  50. package/nstc-g6/components/Form/SelectCustom/index.vue +488 -488
  51. package/nstc-g6/components/Form/SelectSubject/index.js +15 -15
  52. package/nstc-g6/components/Form/SelectSubject/src/demo/index.vue +84 -84
  53. package/nstc-g6/components/Form/SelectSubject/src/main.vue +181 -181
  54. package/nstc-g6/components/Form/SelectindialogCustom/demo/index.vue +188 -188
  55. package/nstc-g6/components/Form/SelectindialogCustom/index.vue +650 -650
  56. package/nstc-g6/components/Form/SelectindialogCustom/install.js +6 -6
  57. package/nstc-g6/components/Form/TableRadioCustom/demo/index.vue +53 -53
  58. package/nstc-g6/components/Form/TableRadioCustom/index.vue +183 -183
  59. package/nstc-g6/components/Form/TextCustom/index.vue +38 -38
  60. package/nstc-g6/components/Form/UploadCustom/demo/index.vue +31 -31
  61. package/nstc-g6/components/Form/UploadCustom/index.vue +506 -506
  62. package/nstc-g6/components/Form/configs.js +191 -191
  63. package/nstc-g6/components/Form/configsSecond.js +161 -161
  64. package/nstc-g6/components/Form/index.js +8 -8
  65. package/nstc-g6/components/Form/index.scss +29 -29
  66. package/nstc-g6/components/Form/payeePersonSelect/index.js +15 -15
  67. package/nstc-g6/components/Form/payeePersonSelect/src/demo/index.vue +163 -163
  68. package/nstc-g6/components/Form/payeePersonSelect/src/main.vue +184 -184
  69. package/nstc-g6/components/Form/readme.txt +4 -4
  70. package/nstc-g6/components/FormGroup/index.js +8 -8
  71. package/nstc-g6/components/FormGroup/src/demo/config.js +23 -23
  72. package/nstc-g6/components/FormGroup/src/demo/index.vue +85 -85
  73. package/nstc-g6/components/FormGroup/src/main.vue +639 -639
  74. package/nstc-g6/components/FormGroup/src/validate.js +22 -22
  75. package/nstc-g6/components/InputTag/InputTag.vue +269 -269
  76. package/nstc-g6/components/NstcApprovel/NstcApprovel.vue +24 -24
  77. package/nstc-g6/components/NstcBackToTop/NstcBackToTop.vue +150 -150
  78. package/nstc-g6/components/NstcBranchLazyLoad/NstcBranchLazyLoad.vue +123 -123
  79. package/nstc-g6/components/NstcCharts/NstcCharts.vue +162 -162
  80. package/nstc-g6/components/NstcCharts/define.js +74 -74
  81. package/nstc-g6/components/NstcCharts/mixins/resize.js +56 -56
  82. package/nstc-g6/components/NstcConfirm/NstcConfirm.vue +152 -152
  83. package/nstc-g6/components/NstcConfirm/index.js +24 -24
  84. package/nstc-g6/components/NstcDialog/NstcDialog.vue +184 -184
  85. package/nstc-g6/components/NstcDialogForm/NstcDialogForm.vue +175 -175
  86. package/nstc-g6/components/NstcDialogTable/NstcDialogTable.vue +280 -280
  87. package/nstc-g6/components/NstcDropdown/NstcDropdown.vue +52 -52
  88. package/nstc-g6/components/NstcDropdownTree/NstcDropdownTree.vue +396 -396
  89. package/nstc-g6/components/NstcElectronicFile/NstcElectronicFile.vue +711 -711
  90. package/nstc-g6/components/NstcExcelCustomImport/NstcExcelCustomImport.vue +475 -475
  91. package/nstc-g6/components/NstcExcelExport/NstcExcelExport.vue +145 -145
  92. package/nstc-g6/components/NstcExcelImport/NstcExcelImport.vue +1074 -1074
  93. package/nstc-g6/components/NstcExcelImportN/NstcExcelImportN.vue +1166 -1166
  94. package/nstc-g6/components/NstcExpandCollapse/NstcExpandCollapse.vue +130 -130
  95. package/nstc-g6/components/NstcExpandCollapse/index.scss +77 -77
  96. package/nstc-g6/components/NstcFileUpload/NstcFileUpload.vue +989 -989
  97. package/nstc-g6/components/NstcFileUpload/img/addFile.svg +31 -31
  98. package/nstc-g6/components/NstcFileUpload/img/delete.svg +23 -23
  99. package/nstc-g6/components/NstcFileUpload/img/deleteFile.svg +27 -27
  100. package/nstc-g6/components/NstcFileUpload/img/download.svg +23 -23
  101. package/nstc-g6/components/NstcFileUpload/img/inputUpload.svg +29 -29
  102. package/nstc-g6/components/NstcFileUpload/img/look-diabled.svg +23 -23
  103. package/nstc-g6/components/NstcFileUpload/img/look.svg +23 -23
  104. package/nstc-g6/components/NstcForm/A_DEMO/component/originalForm.vue +280 -280
  105. package/nstc-g6/components/NstcForm/A_DEMO/config/config_3.js +1222 -1222
  106. package/nstc-g6/components/NstcForm/A_DEMO/index.vue +796 -796
  107. package/nstc-g6/components/NstcForm/AutocompleteCustom/index.vue +68 -68
  108. package/nstc-g6/components/NstcForm/BusinessSpecific/InputMultiple.vue +189 -189
  109. package/nstc-g6/components/NstcForm/BusinessSpecific/InputWithUnit.vue +128 -128
  110. package/nstc-g6/components/NstcForm/BusinessSpecific/SelectTreeDialog.vue +233 -233
  111. package/nstc-g6/components/NstcForm/BusinessSpecific/readme.md +7 -7
  112. package/nstc-g6/components/NstcForm/CascaderCustom/index.vue +101 -101
  113. package/nstc-g6/components/NstcForm/CheckboxCustom/index.vue +84 -84
  114. package/nstc-g6/components/NstcForm/Component.vue +684 -684
  115. package/nstc-g6/components/NstcForm/ComponentSecond.vue +650 -650
  116. package/nstc-g6/components/NstcForm/DatepickerCustom/index.vue +130 -130
  117. package/nstc-g6/components/NstcForm/InputAndDialog/NstcInputAndDialog.vue +389 -389
  118. package/nstc-g6/components/NstcForm/InputCustom/index.vue +313 -313
  119. package/nstc-g6/components/NstcForm/IntervalInputCustom/index.vue +111 -111
  120. package/nstc-g6/components/NstcForm/Item.vue +327 -327
  121. package/nstc-g6/components/NstcForm/ItemSecond.vue +269 -269
  122. package/nstc-g6/components/NstcForm/List.vue +146 -146
  123. package/nstc-g6/components/NstcForm/ListSecond.vue +130 -130
  124. package/nstc-g6/components/NstcForm/RadioCustom/index.vue +73 -73
  125. package/nstc-g6/components/NstcForm/SelectAccount/NstcSelectAccount.vue +334 -334
  126. package/nstc-g6/components/NstcForm/SelectAndDialog/NstcSelectAndDialog.vue +377 -377
  127. package/nstc-g6/components/NstcForm/SelectCashFlow/NstcSelectCashFlow.vue +122 -122
  128. package/nstc-g6/components/NstcForm/SelectCustom/index.vue +460 -460
  129. package/nstc-g6/components/NstcForm/SelectSubject/NstcSelectSubject.vue +184 -184
  130. package/nstc-g6/components/NstcForm/SelectindialogCustom/index.vue +648 -648
  131. package/nstc-g6/components/NstcForm/TableRadioCustom/index.vue +183 -183
  132. package/nstc-g6/components/NstcForm/TextCustom/index.vue +38 -38
  133. package/nstc-g6/components/NstcForm/UploadCustom/index.vue +500 -500
  134. package/nstc-g6/components/NstcForm/configs.js +191 -191
  135. package/nstc-g6/components/NstcForm/configsSecond.js +161 -161
  136. package/nstc-g6/components/NstcForm/index.js +8 -8
  137. package/nstc-g6/components/NstcForm/index.scss +29 -29
  138. package/nstc-g6/components/NstcForm/payeePersonSelect/NstcPayeePerson.vue +187 -187
  139. package/nstc-g6/components/NstcForm/readme.txt +4 -4
  140. package/nstc-g6/components/NstcPagination/NstcPagination.vue +428 -428
  141. package/nstc-g6/components/NstcScreenFull/NstcScreenFull.vue +70 -70
  142. package/nstc-g6/components/NstcSelectTree/NstcSelectTree.vue +730 -730
  143. package/nstc-g6/components/NstcSelectTreeList/NstcSelectTreeList.vue +677 -677
  144. package/nstc-g6/components/NstcSticky/NstcSticky.vue +97 -97
  145. package/nstc-g6/components/NstcSvgIcon/NstcSvgIcon.vue +72 -72
  146. package/nstc-g6/components/NstcTab/NstcTab.vue +80 -80
  147. package/nstc-g6/components/NstcTabWithBadge/NstcTabWithBadge.vue +45 -45
  148. package/nstc-g6/components/NstcTabWithBadge/index.scss +31 -31
  149. package/nstc-g6/components/NstcTable/ElTableColumnCustom/index.vue +292 -292
  150. package/nstc-g6/components/NstcTable/NstcTable.vue +460 -460
  151. package/nstc-g6/components/NstcTableSet/NstcTableSet.vue +802 -802
  152. package/nstc-g6/components/NstcThemePicker/NstcThemePicker.vue +186 -186
  153. package/nstc-g6/components/NstcUploadCustomExcel/NstcUploadCustomExcel.vue +328 -328
  154. package/nstc-g6/components/NstcUploadExcel/NstcUploadExcel.vue +145 -145
  155. package/nstc-g6/components/NstcWorkBench/NstcWorkBench.vue +180 -180
  156. package/nstc-g6/components/Search/NstcSearch.vue +583 -583
  157. package/nstc-g6/components/Search/src/demo/index copy.vue +101 -101
  158. package/nstc-g6/components/Search/src/demo/index.vue +103 -103
  159. package/nstc-g6/components/Search/src/main copy.vue +607 -607
  160. package/nstc-g6/components/approvelTwo/main.vue +220 -220
  161. package/nstc-g6/components/approvelTwo/progress.vue +154 -154
  162. package/nstc-g6/directives/VCopy/index.js +59 -59
  163. package/nstc-g6/directives/VNstcNumber/index.js +14 -14
  164. package/nstc-g6/directives/VNstcNumber/temp.js +446 -446
  165. package/nstc-g6/index.js +193 -193
  166. package/nstc-g6/utils/auth.js +2 -2
  167. package/nstc-g6/utils/axios.js +2 -2
  168. package/nstc-g6/utils/dateAndValidator.js +649 -649
  169. package/nstc-g6/utils/debounce.js +40 -40
  170. package/nstc-g6/utils/mapper_aims.js +809 -809
  171. package/nstc-g6/utils/parseTime.js +48 -48
  172. package/nstc-g6/utils/validate/index.js +6 -6
  173. package/nstc-g6/utils/vendor/Export2Excel.js +229 -229
  174. package/nstc-g6/utils/vendor/Export2Zip.js +24 -24
  175. package/nstc-g6/utils/vue-bus.js +4 -4
  176. package/package.json +103 -103
  177. package/src/_qiankun/index.js +113 -113
  178. package/src/_qiankun/postMessage.js +24 -24
  179. package/src/assets/css/_coreLib.scss +43 -43
  180. package/src/assets/css/alert.scss +28 -28
  181. package/src/assets/css/cl-anchor.scss +70 -70
  182. package/src/assets/css/cl-approve-card.scss +68 -68
  183. package/src/assets/css/cl-dialog.scss +113 -113
  184. package/src/assets/css/cl-drag-list.scss +24 -24
  185. package/src/assets/css/cl-empty.scss +10 -10
  186. package/src/assets/css/cl-expandable-pane.scss +37 -37
  187. package/src/assets/css/cl-expandable.scss +27 -27
  188. package/src/assets/css/cl-file-upload-table.scss +31 -31
  189. package/src/assets/css/cl-filter.scss +4 -4
  190. package/src/assets/css/cl-flow-step.scss +185 -185
  191. package/src/assets/css/cl-footer-box.scss +10 -10
  192. package/src/assets/css/cl-form-item.scss +729 -729
  193. package/src/assets/css/cl-general-card.scss +11 -11
  194. package/src/assets/css/cl-layout-aside.scss +92 -92
  195. package/src/assets/css/cl-layout-content.scss +16 -16
  196. package/src/assets/css/cl-layout-header.scss +89 -89
  197. package/src/assets/css/cl-layout-tabs.scss +87 -87
  198. package/src/assets/css/cl-layout.scss +97 -97
  199. package/src/assets/css/cl-login-temporary.scss +37 -37
  200. package/src/assets/css/cl-message.scss +159 -159
  201. package/src/assets/css/cl-more-tab.scss +98 -98
  202. package/src/assets/css/cl-nav-menu.scss +5 -5
  203. package/src/assets/css/cl-pagination.scss +130 -130
  204. package/src/assets/css/cl-secondary-tab.scss +53 -53
  205. package/src/assets/css/cl-showcolumn.scss +40 -40
  206. package/src/assets/css/cl-sifting.scss +51 -51
  207. package/src/assets/css/cl-statis.scss +54 -54
  208. package/src/assets/css/cl-step.scss +73 -73
  209. package/src/assets/css/cl-suspend.scss +19 -19
  210. package/src/assets/css/cl-tertiary-tab.scss +56 -56
  211. package/src/assets/css/cl-upload.scss +52 -52
  212. package/src/assets/css/cl-worn-pagination.scss +50 -50
  213. package/src/assets/css/el-button.scss +186 -186
  214. package/src/assets/css/el-table.scss +88 -88
  215. package/src/assets/css/element-variables.scss +1061 -1061
  216. package/src/assets/css/element.dev.scss +22 -22
  217. package/src/assets/css/font-icon.scss +26 -26
  218. package/src/assets/css/index.dev.scss +4 -4
  219. package/src/assets/css/index.scss +11 -11
  220. package/src/assets/css/normalize.scss +845 -845
  221. package/src/assets/css/plain-text.scss +36 -36
  222. package/src/assets/css/rootvar.scss +143 -143
  223. package/src/assets/css/select.scss +25 -25
  224. package/src/assets/css/title-pop.scss +23 -23
  225. package/src/assets/getJsonc.js +53 -53
  226. package/src/assets/iconFont/demo.css +539 -539
  227. package/src/assets/iconFont/demo_index.html +1614 -1614
  228. package/src/assets/iconFont/iconfont.css +263 -263
  229. package/src/assets/iconFont/iconfont.json +443 -443
  230. package/src/assets/realUrl.js +13 -13
  231. package/src/components/Anchor/AnchorItem.vue +30 -30
  232. package/src/components/Anchor/index.vue +208 -208
  233. package/src/components/ApprovalButtons/index.vue +240 -240
  234. package/src/components/ApprovalCard/index.vue +132 -132
  235. package/src/components/ApprovalRecord/approvalImg.vue +39 -39
  236. package/src/components/ApprovalRecord/approvalImgPro.vue +424 -424
  237. package/src/components/ApprovalRecord/flowDialog.vue +47 -47
  238. package/src/components/ApprovalRecord/index.vue +63 -63
  239. package/src/components/Button/button-group.vue +148 -148
  240. package/src/components/Button/icon-group-button.vue +63 -63
  241. package/src/components/Button/index.vue +56 -56
  242. package/src/components/CascaderArea/index.vue +103 -103
  243. package/src/components/ChildRange/index.vue +169 -169
  244. package/src/components/ChildRange/style.scss +34 -34
  245. package/src/components/ContentLoading/index.vue +41 -41
  246. package/src/components/ContentNull/index.vue +19 -19
  247. package/src/components/DatePicker/index.vue +33 -33
  248. package/src/components/DatePicker/por.vue +171 -171
  249. package/src/components/Descriptions/index.vue +42 -42
  250. package/src/components/Dialog/index.vue +26 -26
  251. package/src/components/Dialog/indexO.vue +116 -116
  252. package/src/components/DragList/index.vue +79 -79
  253. package/src/components/ECharts/define.js +74 -74
  254. package/src/components/ECharts/index.vue +170 -170
  255. package/src/components/ECharts/mixins/resize.js +23 -23
  256. package/src/components/Empty/img/400.svg +101 -101
  257. package/src/components/Empty/img/401.svg +101 -101
  258. package/src/components/Empty/img/403.svg +101 -101
  259. package/src/components/Empty/img/405.svg +101 -101
  260. package/src/components/Empty/img/901.svg +95 -95
  261. package/src/components/Empty/img/902.svg +95 -95
  262. package/src/components/Empty/img/903.svg +95 -95
  263. package/src/components/Empty/img/904.svg +95 -95
  264. package/src/components/Empty/img/905.svg +95 -95
  265. package/src/components/Empty/img/906.svg +95 -95
  266. package/src/components/Empty/img/907.svg +95 -95
  267. package/src/components/Empty/img/abnormal.svg +108 -108
  268. package/src/components/Empty/img/dispose.svg +71 -71
  269. package/src/components/Empty/img/empty.svg +57 -57
  270. package/src/components/Empty/img/general.svg +58 -58
  271. package/src/components/Empty/img/lock.svg +57 -57
  272. package/src/components/Empty/img/network.svg +59 -59
  273. package/src/components/Empty/img/relevant.svg +68 -68
  274. package/src/components/Empty/img/search.svg +72 -72
  275. package/src/components/Empty/index.vue +147 -147
  276. package/src/components/EventBubble/demo/a.vue +29 -29
  277. package/src/components/EventBubble/demo/b.vue +12 -12
  278. package/src/components/EventBubble/demo/c.vue +18 -18
  279. package/src/components/EventBubble/index.vue +57 -57
  280. package/src/components/Expandable/index.vue +49 -49
  281. package/src/components/Expandable/main.vue +64 -64
  282. package/src/components/FileExportAsync/index.vue +191 -191
  283. package/src/components/FileImport/index.vue +108 -108
  284. package/src/components/FileUploadTable/index.vue +583 -583
  285. package/src/components/Filters/form-item-input.vue +185 -185
  286. package/src/components/Filters/index.vue +216 -216
  287. package/src/components/Filters/indexO.vue +106 -106
  288. package/src/components/FlowStep/index.vue +92 -92
  289. package/src/components/FooterBox/index.vue +21 -21
  290. package/src/components/GeneralCard/index.vue +15 -15
  291. package/src/components/InputNumber/index.vue +184 -184
  292. package/src/components/InputNumber/numberRange.vue +62 -62
  293. package/src/components/InputSearch/index.vue +79 -75
  294. package/src/components/Layout/AsideNav/index.vue +120 -120
  295. package/src/components/Layout/AsideNav/menuItem.vue +34 -34
  296. package/src/components/Layout/AsideNav/submenuTitle.vue +26 -26
  297. package/src/components/Layout/HeaderWrap/changePwd.vue +215 -215
  298. package/src/components/Layout/HeaderWrap/index.vue +412 -412
  299. package/src/components/Layout/HeaderWrap/noticePop.vue +316 -316
  300. package/src/components/Layout/SubContent/index.vue +127 -127
  301. package/src/components/Layout/TabsNav/index.vue +169 -169
  302. package/src/components/Layout/index.vue +518 -518
  303. package/src/components/Layout/utils.js +12 -12
  304. package/src/components/LoginTemporary/form.vue +581 -581
  305. package/src/components/LoginTemporary/index.vue +198 -198
  306. package/src/components/LoginTemporary/qrcode.vue +92 -92
  307. package/src/components/LoginTemporary/retrievePw.vue +375 -375
  308. package/src/components/LoginTemporary/utils.js +73 -73
  309. package/src/components/MicroApp/index.js +67 -67
  310. package/src/components/MicroFrame/index.vue +95 -95
  311. package/src/components/MoreTab/index.vue +229 -229
  312. package/src/components/NavMenu/index.vue +60 -60
  313. package/src/components/PageHeader/index.vue +39 -39
  314. package/src/components/PageHeader/style.scss +44 -44
  315. package/src/components/PageLayout/page.vue +15 -15
  316. package/src/components/Pagination/index.vue +165 -165
  317. package/src/components/SecondaryTab/index.vue +57 -57
  318. package/src/components/SelectLazy/index.vue +75 -75
  319. package/src/components/SelectTree/SelectTreeLazy.vue +241 -241
  320. package/src/components/SelectTree/index.vue +206 -206
  321. package/src/components/ShowColumn/index.vue +252 -252
  322. package/src/components/Sifting/index.vue +98 -98
  323. package/src/components/Stamp/index.vue +75 -75
  324. package/src/components/Statis/index.vue +113 -113
  325. package/src/components/Statis/statisItem.vue +65 -65
  326. package/src/components/Statis/statisPopover.vue +63 -63
  327. package/src/components/Step/index.vue +37 -37
  328. package/src/components/Suspend/index.vue +72 -72
  329. package/src/components/Table/filters.js +60 -60
  330. package/src/components/Table/index.vue +89 -89
  331. package/src/components/Table/indexO.vue +149 -149
  332. package/src/components/TableOperateColumn/OperateBtns.vue +86 -86
  333. package/src/components/TableOperateColumn/index.vue +26 -26
  334. package/src/components/Task/index.vue +26 -26
  335. package/src/components/TertiaryTab/index.vue +62 -62
  336. package/src/components/TimePicker/index.vue +28 -28
  337. package/src/components/Upload/index.vue +280 -280
  338. package/src/components/Upload/uploadMsg.vue +114 -114
  339. package/src/components/WornPagination/index.vue +73 -73
  340. package/src/directives/VClickOutside/index.js +27 -27
  341. package/src/directives/VHas/index.js +58 -58
  342. package/src/directives/VMove/index.js +42 -42
  343. package/src/directives/VRuleKey/index.js +201 -201
  344. package/src/directives/VTitle/index.js +109 -109
  345. package/src/index.js +265 -265
  346. package/src/plugins/CompatibleOld/index.js +11 -11
  347. package/src/plugins/Print/index.js +4 -4
  348. package/src/plugins/Print/print-js/.babelrc +12 -12
  349. package/src/plugins/Print/print-js/LICENSE +21 -21
  350. package/src/plugins/Print/print-js/README.md +98 -98
  351. package/src/plugins/Print/print-js/dist/print.css +96 -96
  352. package/src/plugins/Print/print-js/dist/print.js +990 -990
  353. package/src/plugins/Print/print-js/package.json +60 -60
  354. package/src/plugins/Print/print-js/src/index.d.ts +45 -45
  355. package/src/plugins/Print/print-js/src/index.js +10 -10
  356. package/src/plugins/Print/print-js/src/js/browser.js +33 -33
  357. package/src/plugins/Print/print-js/src/js/functions.js +103 -103
  358. package/src/plugins/Print/print-js/src/js/html.js +70 -70
  359. package/src/plugins/Print/print-js/src/js/image.js +48 -48
  360. package/src/plugins/Print/print-js/src/js/init.js +168 -168
  361. package/src/plugins/Print/print-js/src/js/json.js +109 -109
  362. package/src/plugins/Print/print-js/src/js/modal.js +62 -62
  363. package/src/plugins/Print/print-js/src/js/pdf.js +62 -62
  364. package/src/plugins/Print/print-js/src/js/print.js +102 -102
  365. package/src/plugins/Print/print-js/src/js/raw-html.js +15 -15
  366. package/src/plugins/Print/print-js/src/sass/index.scss +13 -13
  367. package/src/plugins/Print/print-js/src/sass/modules/_colors.scss +9 -9
  368. package/src/plugins/Print/print-js/src/sass/partials/_modal.scss +40 -40
  369. package/src/plugins/Print/print-js/src/sass/partials/_spinner.scss +45 -45
  370. package/src/plugins/Print/print.js +2 -2
  371. package/src/plugins/Print/print.scss +1 -1
  372. package/src/plugins/SetMenuTree/index.vue +41 -41
  373. package/src/plugins/SetMenuTree/logoIcon.vue +37 -37
  374. package/src/plugins/SetMenuTree/setmenutree.vue +427 -427
  375. package/src/plugins/SetMenuTree/utils.js +74 -74
  376. package/src/plugins/Sign/InfosecNetSignCNGAgent.min.js +2000 -2000
  377. package/src/plugins/Sign/bjca/XTXSAB.js +2395 -2395
  378. package/src/plugins/Sign/bjca/index.js +129 -129
  379. package/src/plugins/Sign/index.js +28 -28
  380. package/src/plugins/Sign/sign.js +108 -64
  381. package/src/plugins/setTabsForSub.js +2 -2
  382. package/src/utils/auth.js +56 -56
  383. package/src/utils/axios.js +205 -205
  384. package/src/utils/downloadBlob.js +19 -19
  385. package/src/utils/forEachs.js +16 -16
  386. package/src/utils/getScrollContainer.js +43 -43
  387. package/src/utils/handleTab.js +109 -109
  388. package/src/utils/i18n/cn2hk.json +1270 -1270
  389. package/src/utils/i18n/index.js +50 -50
  390. package/src/utils/importGlobal.js +16 -16
  391. package/src/utils/list2tree.js +36 -36
  392. package/src/utils/msgboxPor.js +26 -26
  393. package/src/utils/print.js +161 -161
  394. package/src/utils/relaNo.js +72 -72
  395. package/src/utils/repairElementUI.js +169 -169
  396. package/src/utils/tableheaderFilterpanel.vue +248 -248
  397. package/src/utils/theme.config.js +22 -22
  398. package/src/utils/theme.js +31 -31
  399. package/src/utils/toExcel.js +103 -103
  400. package/src/utils/urlToGo.js +82 -82
  401. package/src/utils/xls2json.js +44 -44
  402. package/src/utils/xlsx2json.js +28 -28
@@ -1,661 +1,661 @@
1
- <template>
2
- <el-form
3
- :id="formID"
4
- :key="formID"
5
- :ref="formID"
6
- :model="model"
7
- :label-width="innerLabelWidth"
8
- :label-position="labelPosition"
9
- :rules="rules"
10
- :show-message="showMessage"
11
- v-bind="$attrs"
12
- :class="['form-custom', `form-custom-${mode}`]"
13
- v-on="$listeners"
14
- @submit.native.prevent
15
- >
16
- <!-- 常规查询 -->
17
- <BaseList
18
- v-model="model"
19
- :config="normalConfig"
20
- :resets.sync="resets"
21
- :loading="queryLoading"
22
- :disableds="disableds"
23
- :popper-class="computedPopperClass"
24
- :formData="formData"
25
- :show-mode="showMode"
26
- @after-leave="val => $emit('after-leave', val)"
27
- @query-click="handleExpectQuery"
28
- @add-click="$emit('add-click')"
29
- @other-click="$emit('other-click')"
30
- @enter-click="handleExpectQuery"
31
- @tree-node-click="(prop, data, node) => $emit('tree-node-click', prop, data, node)"
32
- />
33
-
34
- <div
35
- v-if="isVertical && queryBtn"
36
- :class="[
37
- `form-item`,
38
- `form-item-button`
39
- ]"
40
- >
41
- <el-button
42
- v-bind="queryBtn"
43
- :loading="queryLoading"
44
- :disabled="disableds.querybutton"
45
- @click="handleExpectQuery"
46
- >
47
- {{ queryBtn.name || '查询' }}
48
- </el-button>
49
- </div>
50
- </el-form>
51
- </template>
52
-
53
- <script>
54
- // 注: 支持的类型 请查看configs.js
55
- import BaseList from './List'
56
-
57
- import { SUPPORT_TYPE, getDefaultValue } from './configs'
58
-
59
- const deepEquals = (a, b) => {
60
- if (Array.isArray(a) && Array.isArray(b)) {
61
- if (a.length !== b.length) {
62
- return false
63
- }
64
-
65
- for (let i = 0; i < a.length; i++) {
66
- if (a[i] !== b[i]) {
67
- return false
68
- }
69
- }
70
-
71
- return true
72
- }
73
-
74
- return a === b
75
- }
76
- export default {
77
- name: 'NstcForm',
78
-
79
- components: {
80
- BaseList
81
- },
82
-
83
- inheritAttrs: false,
84
-
85
- props: {
86
- formData: {
87
- type: Object,
88
- default: () => ({})
89
- },
90
- from: {
91
- type: String,
92
- default: null
93
- },
94
- config: {
95
- type: Array,
96
- default: () => []
97
- },
98
-
99
- popperClass: {
100
- type: String,
101
- default: ''
102
- },
103
-
104
- reset: {
105
- type: Boolean,
106
- default: false
107
- },
108
-
109
- // 组件加载完成时, 执行一次默认查询
110
- mountAndQuery: {
111
- type: Boolean,
112
- default: true
113
- },
114
-
115
- // 用于表单异步时 手动触发查询
116
- asyncQuery: {
117
- default: false,
118
- type: Boolean
119
- },
120
-
121
- // 样式 : 水平 | 垂直
122
- mode: {
123
- default: 'horizontal',
124
- validator: function(val) {
125
- return ['horizontal', 'vertical'].includes(val)
126
- }
127
- },
128
-
129
- // 是否是纯净模式 (删除 renderable === false 的item.prop对应model的值)
130
- pureable: {
131
- default: false,
132
- type: Boolean
133
- },
134
-
135
- value: {
136
- default: () => ({}),
137
- type: Object
138
- },
139
-
140
- showMessage: {
141
- type: Boolean,
142
- default: true
143
- },
144
-
145
- disabled: {
146
- type: Boolean,
147
- default: false
148
- },
149
-
150
- labelPosition: {
151
- type: String,
152
- default: 'right'
153
- },
154
-
155
- labelWidth: {
156
- default: '136px',
157
- type: [String, Number]
158
- },
159
-
160
- rules: {
161
- type: Object,
162
- default: undefined
163
- },
164
-
165
- // 显示模式
166
- showMode: {
167
- type: String,
168
- default: ''
169
- }
170
- },
171
-
172
- data() {
173
- return {
174
- resets: {},
175
-
176
- disableds: {
177
- querybutton: false
178
- },
179
-
180
- formID: `formID-${Math.random()
181
- .toString(36)
182
- .slice(2)}`,
183
-
184
- linkItems: [],
185
- unwatchers: [],
186
-
187
- queryBtn: null,
188
-
189
- normalConfig: [],
190
-
191
- uploadKeys: new Set([]),
192
-
193
- isRendering: false,
194
- queryLoading: false,
195
- innerMountAndQuery: false,
196
- isInit: true
197
- }
198
- },
199
-
200
- computed: {
201
- model: {
202
- get() {
203
- return this.value
204
- },
205
- set(val) {
206
- this.$emit('input', val)
207
- this.$emit('change', val)
208
- }
209
- },
210
-
211
- isVertical() {
212
- return this.mode === 'vertical'
213
- },
214
-
215
- computedPopperClass() {
216
- return (this.isVertical ? ['form-custom-popper', this.popperClass] : []).join(' ')
217
- },
218
-
219
- innerLabelWidth() {
220
- return (this.labelWidth + '').replace(/px/, '') + 'px'
221
- }
222
-
223
- },
224
-
225
- watch: {
226
- config: {
227
- deep: true,
228
- immediate: true,
229
- handler: function(newVal) {
230
- if (!this.isRendering && newVal.length) {
231
- this.init()
232
- }
233
- }
234
- },
235
-
236
- value: {
237
- deep: true,
238
- immediate: true,
239
- handler: function(newVal) {
240
- if (!this.isEmptyObject(newVal) && !this.isRendering && this.innerMountAndQuery) {
241
- this.innerMountAndQuery = false
242
- this.handleExpectQuery()
243
- }
244
- }
245
- },
246
-
247
- reset(newVal) {
248
- console.log('__log_reset', newVal)
249
- if (newVal) {
250
- this.init()
251
- console.log('__log_reset', newVal)
252
-
253
- // temporary hack
254
- this.setResets(true)
255
-
256
- this.$emit('update:reset', false)
257
- }
258
- },
259
-
260
- disabled(newVal, oldVal) {
261
- if (newVal !== oldVal) {
262
- this.setDisableds(newVal)
263
-
264
- this.$emit('disabled')
265
- }
266
- },
267
-
268
- asyncQuery(newVal) {
269
- if (newVal) {
270
- this.$nextTick(() => {
271
- this.handleExpectQuery()
272
- this.$emit('update:asyncQuery', false)
273
- })
274
- }
275
- }
276
- },
277
-
278
- created() {
279
- // this.innerMountAndQuery = this.mountAndQuery;
280
- },
281
-
282
- methods: {
283
- init() {
284
- if (!this.isRendering) {
285
- this.isRendering = true
286
-
287
- this.clearValidate()
288
-
289
- this.uploadKeys.clear()
290
-
291
- this.disableds = {
292
- querybutton: this.disabled
293
- }
294
-
295
- const {
296
- querybutton,
297
- normalItems = []
298
- } = this.separateAdvanceAndNormal(this.config)
299
- this.normalConfig = normalItems
300
-
301
- this.generateFormModel(normalItems)
302
-
303
- this.queryBtn = querybutton
304
-
305
- this.generateLink()
306
-
307
- this.innerMountAndQuery = this.mountAndQuery
308
-
309
- this.isInit = false
310
-
311
- this.isRendering = false
312
- }
313
- },
314
-
315
- generateFormModel(config) {
316
- if (Array.isArray(config)) {
317
- config.forEach(item => {
318
- if (Array.isArray(item)) {
319
- this.generateFormModel(item)
320
- } else {
321
- if (!item.mold) {
322
- throw Error(
323
- `Each config's child must has a 'mold' prop, it could be ${SUPPORT_TYPE.concat(
324
- 'querybutton'
325
- ).join('|')}`
326
- )
327
- }
328
-
329
- item.mold = item.mold.toLowerCase()
330
-
331
- this.setModel(item)
332
-
333
- if (item.link) {
334
- this.linkItems.push(item)
335
- }
336
- }
337
- })
338
- } else {
339
- if (!Object.keys(config).length) {
340
- return
341
- }
342
-
343
- if (!config.mold) {
344
- throw Error(
345
- `Each config's child must has a 'mold' prop, it could be ${SUPPORT_TYPE.concat(
346
- 'querybutton'
347
- ).join('|')}`
348
- )
349
- }
350
-
351
- config.mold = config.mold.toLowerCase()
352
-
353
- this.setModel(config)
354
- }
355
- },
356
-
357
- generateLink() {
358
- while (this.unwatchers.length) {
359
- this.unwatchers.pop()()
360
- }
361
-
362
- this.linkItems.map(item => {
363
- this.setWatchers(item)
364
- })
365
-
366
- this.linkItems = []
367
- },
368
-
369
- /**
370
- * item
371
- * setValue,(第二个参数)
372
- */
373
- setModel(item) {
374
- let { prop, mold } = item
375
-
376
- if (this.pureable) { // 纯净模式
377
- if (item.renderable === false) {
378
- this.$delete(this.model, prop)
379
- return
380
- }
381
- }
382
-
383
- prop = prop || mold
384
-
385
- const matchedResult = getDefaultValue(item)
386
-
387
- if (matchedResult !== null) {
388
- if (!(this.isInit && this.model[prop] !== undefined)) {
389
- this.$set(this.model, prop, matchedResult.value)
390
- // this.$set(this.model, prop, (setValue ? this.model[prop] : matchedResult.value) || matchedResult.value);
391
- }
392
-
393
- this.$set(this.resets, prop, false)
394
- this.$set(this.disableds, prop, this.disabled || item.disabled)
395
- }
396
- },
397
-
398
- setWatchers(item) {
399
- const { link, prop: itemProp } = item
400
- let isOneToLinkAll = false
401
- let links; let isComplex
402
-
403
- if (Array.isArray(link)) {
404
- links = link
405
- isOneToLinkAll = links.every(item => item.mold)
406
- isComplex = !!(links.find(item => item.mold) && links.find(item => !item.mold))
407
- } else {
408
- links = [link]
409
- }
410
-
411
- links.forEach(link =>
412
- this.setSingleLinkWatch(link, itemProp, isOneToLinkAll, isComplex, link.mold)
413
- )
414
- },
415
-
416
- setSingleLinkWatch(link, itemProp, isOneToLinkAll, isComplex, isModelEverGenerated) {
417
- const { prop, handler, mold } = link
418
-
419
- if (!this.isFunc(handler)) {
420
- return
421
- }
422
-
423
- let targetProp, watchedProp
424
-
425
- if (isOneToLinkAll) {
426
- this.generateFormModel(link)
427
- targetProp = itemProp
428
- watchedProp = prop
429
- } else if (isComplex) {
430
- if (isModelEverGenerated) {
431
- this.generateFormModel(link)
432
- }
433
- targetProp = itemProp
434
- watchedProp = prop
435
- } else {
436
- if (mold) {
437
- this.generateFormModel(link)
438
- targetProp = prop
439
- watchedProp = itemProp
440
- } else {
441
- targetProp = itemProp
442
- watchedProp = prop
443
- }
444
- }
445
-
446
- const unwatcher = this.$watch(`model.${targetProp}`, {
447
- immediate: true,
448
- deep: true,
449
- handler: async function(newVal, oldVal) {
450
- if (watchedProp) {
451
- if (!deepEquals(newVal, oldVal)) {
452
- const defaultAndOptions = await handler(newVal)
453
-
454
- const newItem = {
455
- prop: watchedProp,
456
- ...defaultAndOptions
457
- }
458
-
459
- this.replaceOptions(newItem)
460
- }
461
- }
462
- }
463
- })
464
-
465
- this.unwatchers.push(unwatcher)
466
- },
467
-
468
- replaceOptions({ prop, ...pramas }, config) {
469
- let finded = false
470
-
471
- const replaceOptionsHelper = ({ prop, pramas }, config) => {
472
- if (finded) {
473
- return
474
- }
475
-
476
- const tConfig = config || this.normalConfig
477
-
478
- tConfig.forEach((item, idx) => {
479
- if (Array.isArray(item)) {
480
- replaceOptionsHelper(
481
- {
482
- prop,
483
- pramas
484
- },
485
- item
486
- )
487
- } else if (Array.isArray(item.link) && !(item.prop === prop && item.mold)) {
488
- replaceOptionsHelper(
489
- {
490
- prop,
491
- pramas
492
- },
493
- item.link
494
- )
495
- } else {
496
- if (item.prop === prop && item.mold) {
497
- finded = true
498
- const newItem = { ...item, ...pramas }
499
-
500
- tConfig.splice(idx, 1, newItem)
501
-
502
- if (newItem.mold) {
503
- this.setModel(newItem, true)
504
- }
505
- }
506
- }
507
- })
508
- }
509
-
510
- replaceOptionsHelper({ prop, pramas }, config)
511
- },
512
-
513
- setResets(val = false, prop = null) {
514
- if (prop) {
515
- this.resets[prop] = val
516
- } else {
517
- Object.keys(this.resets).forEach(key => {
518
- this.resets[key] = val
519
- })
520
- }
521
- this.$nextTick(() => {
522
- this.resetFields()
523
- })
524
- },
525
-
526
- setDisableds(val = false, prop = null) {
527
- if (prop) {
528
- this.disableds[prop] = val
529
- } else {
530
- Object.keys(this.disableds).forEach(key => {
531
- this.disableds[key] = val
532
- })
533
- }
534
- },
535
-
536
- separateAdvanceAndNormal(config = this.config) {
537
- const isVertical = this.isVertical
538
-
539
- const reducer = config => config.reduce(
540
- (prev, item) => {
541
- if (Array.isArray(item)) {
542
- const { normalItems, ...rest } = reducer(item)
543
-
544
- normalItems.length && prev.normalItems.push(normalItems)
545
-
546
- return {
547
- ...prev,
548
- ...rest
549
- }
550
- } else {
551
- const { mold } = item
552
- // if (mold === "upload") {
553
- // this.uploadKeys.add(prop);
554
- // }
555
-
556
- if (isVertical) {
557
- if (mold === 'querybutton') {
558
- prev[mold] = item
559
- } else {
560
- prev.normalItems.push(item)
561
- }
562
- } else {
563
- prev.normalItems.push(item)
564
- }
565
- }
566
-
567
- return prev
568
- },
569
- {
570
- normalItems: []
571
- }
572
- )
573
-
574
- return reducer(config)
575
- },
576
-
577
- isFunc(callBack) {
578
- return callBack && typeof callBack === 'function'
579
- },
580
-
581
- isEmptyObject(obj) {
582
- const isObj = Object.prototype.toString.call(obj).toLowerCase() !== '[object object]'
583
- return !Object.keys(isObj ? {} : obj).length
584
- },
585
-
586
- async handleExpectQuery(config) {
587
- this.queryLoading = true
588
-
589
- try {
590
- if (this.$listeners.query) {
591
- await this.validate()
592
-
593
- let model
594
-
595
- if (this.uploadKeys.size) {
596
- model = this.convertModelToFormData(this.model)
597
- config = {
598
- headers: {
599
- 'Content-Type': 'multipart/form-data'
600
- },
601
- ...config
602
- }
603
- } else {
604
- model = JSON.parse(JSON.stringify(this.model))
605
- }
606
-
607
- await this.$listeners.query(model, config)
608
- } else {
609
- throw new Error(
610
- 'must specify @query event when there is a query button'
611
- )
612
- }
613
- } catch (err) {
614
- console.error('form custom error -> handleExpectQuery:', err)
615
- } finally {
616
- this.queryLoading = false
617
- }
618
- },
619
-
620
- convertModelToFormData(model) {
621
- const fd = new FormData()
622
- Object.entries(model).forEach(([key, value]) => {
623
- fd.append(key, value instanceof window.FormData ? value.get(key) : value)
624
- })
625
- return fd
626
- },
627
-
628
- clearValidate() {
629
- if (this.rules && this.$refs[this.formID]) {
630
- this.$refs[this.formID] && this.$refs[this.formID].clearValidate()
631
- }
632
- },
633
-
634
- resetFields() {
635
- console.log('__log_formID', this.formID, this.$refs[this.formID])
636
- this.$refs[this.formID] && this.$refs[this.formID].resetFields()
637
- },
638
-
639
- validate() {
640
- if (this.rules && this.$refs[this.formID]) {
641
- return this.$refs[this.formID].validate()
642
- }
643
-
644
- return Promise.resolve()
645
- },
646
-
647
- /**
648
- * 生成formId
649
- */
650
- createFormId() {
651
- return `formID-${Math.random()
652
- .toString(36)
653
- .slice(2)}`
654
- }
655
- }
656
- }
657
- </script>
658
-
659
- <style lang="scss">
660
- @import "index";
661
- </style>
1
+ <template>
2
+ <el-form
3
+ :id="formID"
4
+ :key="formID"
5
+ :ref="formID"
6
+ :model="model"
7
+ :label-width="innerLabelWidth"
8
+ :label-position="labelPosition"
9
+ :rules="rules"
10
+ :show-message="showMessage"
11
+ v-bind="$attrs"
12
+ :class="['form-custom', `form-custom-${mode}`]"
13
+ v-on="$listeners"
14
+ @submit.native.prevent
15
+ >
16
+ <!-- 常规查询 -->
17
+ <BaseList
18
+ v-model="model"
19
+ :config="normalConfig"
20
+ :resets.sync="resets"
21
+ :loading="queryLoading"
22
+ :disableds="disableds"
23
+ :popper-class="computedPopperClass"
24
+ :formData="formData"
25
+ :show-mode="showMode"
26
+ @after-leave="val => $emit('after-leave', val)"
27
+ @query-click="handleExpectQuery"
28
+ @add-click="$emit('add-click')"
29
+ @other-click="$emit('other-click')"
30
+ @enter-click="handleExpectQuery"
31
+ @tree-node-click="(prop, data, node) => $emit('tree-node-click', prop, data, node)"
32
+ />
33
+
34
+ <div
35
+ v-if="isVertical && queryBtn"
36
+ :class="[
37
+ `form-item`,
38
+ `form-item-button`
39
+ ]"
40
+ >
41
+ <el-button
42
+ v-bind="queryBtn"
43
+ :loading="queryLoading"
44
+ :disabled="disableds.querybutton"
45
+ @click="handleExpectQuery"
46
+ >
47
+ {{ queryBtn.name || '查询' }}
48
+ </el-button>
49
+ </div>
50
+ </el-form>
51
+ </template>
52
+
53
+ <script>
54
+ // 注: 支持的类型 请查看configs.js
55
+ import BaseList from './List'
56
+
57
+ import { SUPPORT_TYPE, getDefaultValue } from './configs'
58
+
59
+ const deepEquals = (a, b) => {
60
+ if (Array.isArray(a) && Array.isArray(b)) {
61
+ if (a.length !== b.length) {
62
+ return false
63
+ }
64
+
65
+ for (let i = 0; i < a.length; i++) {
66
+ if (a[i] !== b[i]) {
67
+ return false
68
+ }
69
+ }
70
+
71
+ return true
72
+ }
73
+
74
+ return a === b
75
+ }
76
+ export default {
77
+ name: 'NstcForm',
78
+
79
+ components: {
80
+ BaseList
81
+ },
82
+
83
+ inheritAttrs: false,
84
+
85
+ props: {
86
+ formData: {
87
+ type: Object,
88
+ default: () => ({})
89
+ },
90
+ from: {
91
+ type: String,
92
+ default: null
93
+ },
94
+ config: {
95
+ type: Array,
96
+ default: () => []
97
+ },
98
+
99
+ popperClass: {
100
+ type: String,
101
+ default: ''
102
+ },
103
+
104
+ reset: {
105
+ type: Boolean,
106
+ default: false
107
+ },
108
+
109
+ // 组件加载完成时, 执行一次默认查询
110
+ mountAndQuery: {
111
+ type: Boolean,
112
+ default: true
113
+ },
114
+
115
+ // 用于表单异步时 手动触发查询
116
+ asyncQuery: {
117
+ default: false,
118
+ type: Boolean
119
+ },
120
+
121
+ // 样式 : 水平 | 垂直
122
+ mode: {
123
+ default: 'horizontal',
124
+ validator: function(val) {
125
+ return ['horizontal', 'vertical'].includes(val)
126
+ }
127
+ },
128
+
129
+ // 是否是纯净模式 (删除 renderable === false 的item.prop对应model的值)
130
+ pureable: {
131
+ default: false,
132
+ type: Boolean
133
+ },
134
+
135
+ value: {
136
+ default: () => ({}),
137
+ type: Object
138
+ },
139
+
140
+ showMessage: {
141
+ type: Boolean,
142
+ default: true
143
+ },
144
+
145
+ disabled: {
146
+ type: Boolean,
147
+ default: false
148
+ },
149
+
150
+ labelPosition: {
151
+ type: String,
152
+ default: 'right'
153
+ },
154
+
155
+ labelWidth: {
156
+ default: '136px',
157
+ type: [String, Number]
158
+ },
159
+
160
+ rules: {
161
+ type: Object,
162
+ default: undefined
163
+ },
164
+
165
+ // 显示模式
166
+ showMode: {
167
+ type: String,
168
+ default: ''
169
+ }
170
+ },
171
+
172
+ data() {
173
+ return {
174
+ resets: {},
175
+
176
+ disableds: {
177
+ querybutton: false
178
+ },
179
+
180
+ formID: `formID-${Math.random()
181
+ .toString(36)
182
+ .slice(2)}`,
183
+
184
+ linkItems: [],
185
+ unwatchers: [],
186
+
187
+ queryBtn: null,
188
+
189
+ normalConfig: [],
190
+
191
+ uploadKeys: new Set([]),
192
+
193
+ isRendering: false,
194
+ queryLoading: false,
195
+ innerMountAndQuery: false,
196
+ isInit: true
197
+ }
198
+ },
199
+
200
+ computed: {
201
+ model: {
202
+ get() {
203
+ return this.value
204
+ },
205
+ set(val) {
206
+ this.$emit('input', val)
207
+ this.$emit('change', val)
208
+ }
209
+ },
210
+
211
+ isVertical() {
212
+ return this.mode === 'vertical'
213
+ },
214
+
215
+ computedPopperClass() {
216
+ return (this.isVertical ? ['form-custom-popper', this.popperClass] : []).join(' ')
217
+ },
218
+
219
+ innerLabelWidth() {
220
+ return (this.labelWidth + '').replace(/px/, '') + 'px'
221
+ }
222
+
223
+ },
224
+
225
+ watch: {
226
+ config: {
227
+ deep: true,
228
+ immediate: true,
229
+ handler: function(newVal) {
230
+ if (!this.isRendering && newVal.length) {
231
+ this.init()
232
+ }
233
+ }
234
+ },
235
+
236
+ value: {
237
+ deep: true,
238
+ immediate: true,
239
+ handler: function(newVal) {
240
+ if (!this.isEmptyObject(newVal) && !this.isRendering && this.innerMountAndQuery) {
241
+ this.innerMountAndQuery = false
242
+ this.handleExpectQuery()
243
+ }
244
+ }
245
+ },
246
+
247
+ reset(newVal) {
248
+ console.log('__log_reset', newVal)
249
+ if (newVal) {
250
+ this.init()
251
+ console.log('__log_reset', newVal)
252
+
253
+ // temporary hack
254
+ this.setResets(true)
255
+
256
+ this.$emit('update:reset', false)
257
+ }
258
+ },
259
+
260
+ disabled(newVal, oldVal) {
261
+ if (newVal !== oldVal) {
262
+ this.setDisableds(newVal)
263
+
264
+ this.$emit('disabled')
265
+ }
266
+ },
267
+
268
+ asyncQuery(newVal) {
269
+ if (newVal) {
270
+ this.$nextTick(() => {
271
+ this.handleExpectQuery()
272
+ this.$emit('update:asyncQuery', false)
273
+ })
274
+ }
275
+ }
276
+ },
277
+
278
+ created() {
279
+ // this.innerMountAndQuery = this.mountAndQuery;
280
+ },
281
+
282
+ methods: {
283
+ init() {
284
+ if (!this.isRendering) {
285
+ this.isRendering = true
286
+
287
+ this.clearValidate()
288
+
289
+ this.uploadKeys.clear()
290
+
291
+ this.disableds = {
292
+ querybutton: this.disabled
293
+ }
294
+
295
+ const {
296
+ querybutton,
297
+ normalItems = []
298
+ } = this.separateAdvanceAndNormal(this.config)
299
+ this.normalConfig = normalItems
300
+
301
+ this.generateFormModel(normalItems)
302
+
303
+ this.queryBtn = querybutton
304
+
305
+ this.generateLink()
306
+
307
+ this.innerMountAndQuery = this.mountAndQuery
308
+
309
+ this.isInit = false
310
+
311
+ this.isRendering = false
312
+ }
313
+ },
314
+
315
+ generateFormModel(config) {
316
+ if (Array.isArray(config)) {
317
+ config.forEach(item => {
318
+ if (Array.isArray(item)) {
319
+ this.generateFormModel(item)
320
+ } else {
321
+ if (!item.mold) {
322
+ throw Error(
323
+ `Each config's child must has a 'mold' prop, it could be ${SUPPORT_TYPE.concat(
324
+ 'querybutton'
325
+ ).join('|')}`
326
+ )
327
+ }
328
+
329
+ item.mold = item.mold.toLowerCase()
330
+
331
+ this.setModel(item)
332
+
333
+ if (item.link) {
334
+ this.linkItems.push(item)
335
+ }
336
+ }
337
+ })
338
+ } else {
339
+ if (!Object.keys(config).length) {
340
+ return
341
+ }
342
+
343
+ if (!config.mold) {
344
+ throw Error(
345
+ `Each config's child must has a 'mold' prop, it could be ${SUPPORT_TYPE.concat(
346
+ 'querybutton'
347
+ ).join('|')}`
348
+ )
349
+ }
350
+
351
+ config.mold = config.mold.toLowerCase()
352
+
353
+ this.setModel(config)
354
+ }
355
+ },
356
+
357
+ generateLink() {
358
+ while (this.unwatchers.length) {
359
+ this.unwatchers.pop()()
360
+ }
361
+
362
+ this.linkItems.map(item => {
363
+ this.setWatchers(item)
364
+ })
365
+
366
+ this.linkItems = []
367
+ },
368
+
369
+ /**
370
+ * item
371
+ * setValue,(第二个参数)
372
+ */
373
+ setModel(item) {
374
+ let { prop, mold } = item
375
+
376
+ if (this.pureable) { // 纯净模式
377
+ if (item.renderable === false) {
378
+ this.$delete(this.model, prop)
379
+ return
380
+ }
381
+ }
382
+
383
+ prop = prop || mold
384
+
385
+ const matchedResult = getDefaultValue(item)
386
+
387
+ if (matchedResult !== null) {
388
+ if (!(this.isInit && this.model[prop] !== undefined)) {
389
+ this.$set(this.model, prop, matchedResult.value)
390
+ // this.$set(this.model, prop, (setValue ? this.model[prop] : matchedResult.value) || matchedResult.value);
391
+ }
392
+
393
+ this.$set(this.resets, prop, false)
394
+ this.$set(this.disableds, prop, this.disabled || item.disabled)
395
+ }
396
+ },
397
+
398
+ setWatchers(item) {
399
+ const { link, prop: itemProp } = item
400
+ let isOneToLinkAll = false
401
+ let links; let isComplex
402
+
403
+ if (Array.isArray(link)) {
404
+ links = link
405
+ isOneToLinkAll = links.every(item => item.mold)
406
+ isComplex = !!(links.find(item => item.mold) && links.find(item => !item.mold))
407
+ } else {
408
+ links = [link]
409
+ }
410
+
411
+ links.forEach(link =>
412
+ this.setSingleLinkWatch(link, itemProp, isOneToLinkAll, isComplex, link.mold)
413
+ )
414
+ },
415
+
416
+ setSingleLinkWatch(link, itemProp, isOneToLinkAll, isComplex, isModelEverGenerated) {
417
+ const { prop, handler, mold } = link
418
+
419
+ if (!this.isFunc(handler)) {
420
+ return
421
+ }
422
+
423
+ let targetProp, watchedProp
424
+
425
+ if (isOneToLinkAll) {
426
+ this.generateFormModel(link)
427
+ targetProp = itemProp
428
+ watchedProp = prop
429
+ } else if (isComplex) {
430
+ if (isModelEverGenerated) {
431
+ this.generateFormModel(link)
432
+ }
433
+ targetProp = itemProp
434
+ watchedProp = prop
435
+ } else {
436
+ if (mold) {
437
+ this.generateFormModel(link)
438
+ targetProp = prop
439
+ watchedProp = itemProp
440
+ } else {
441
+ targetProp = itemProp
442
+ watchedProp = prop
443
+ }
444
+ }
445
+
446
+ const unwatcher = this.$watch(`model.${targetProp}`, {
447
+ immediate: true,
448
+ deep: true,
449
+ handler: async function(newVal, oldVal) {
450
+ if (watchedProp) {
451
+ if (!deepEquals(newVal, oldVal)) {
452
+ const defaultAndOptions = await handler(newVal)
453
+
454
+ const newItem = {
455
+ prop: watchedProp,
456
+ ...defaultAndOptions
457
+ }
458
+
459
+ this.replaceOptions(newItem)
460
+ }
461
+ }
462
+ }
463
+ })
464
+
465
+ this.unwatchers.push(unwatcher)
466
+ },
467
+
468
+ replaceOptions({ prop, ...pramas }, config) {
469
+ let finded = false
470
+
471
+ const replaceOptionsHelper = ({ prop, pramas }, config) => {
472
+ if (finded) {
473
+ return
474
+ }
475
+
476
+ const tConfig = config || this.normalConfig
477
+
478
+ tConfig.forEach((item, idx) => {
479
+ if (Array.isArray(item)) {
480
+ replaceOptionsHelper(
481
+ {
482
+ prop,
483
+ pramas
484
+ },
485
+ item
486
+ )
487
+ } else if (Array.isArray(item.link) && !(item.prop === prop && item.mold)) {
488
+ replaceOptionsHelper(
489
+ {
490
+ prop,
491
+ pramas
492
+ },
493
+ item.link
494
+ )
495
+ } else {
496
+ if (item.prop === prop && item.mold) {
497
+ finded = true
498
+ const newItem = { ...item, ...pramas }
499
+
500
+ tConfig.splice(idx, 1, newItem)
501
+
502
+ if (newItem.mold) {
503
+ this.setModel(newItem, true)
504
+ }
505
+ }
506
+ }
507
+ })
508
+ }
509
+
510
+ replaceOptionsHelper({ prop, pramas }, config)
511
+ },
512
+
513
+ setResets(val = false, prop = null) {
514
+ if (prop) {
515
+ this.resets[prop] = val
516
+ } else {
517
+ Object.keys(this.resets).forEach(key => {
518
+ this.resets[key] = val
519
+ })
520
+ }
521
+ this.$nextTick(() => {
522
+ this.resetFields()
523
+ })
524
+ },
525
+
526
+ setDisableds(val = false, prop = null) {
527
+ if (prop) {
528
+ this.disableds[prop] = val
529
+ } else {
530
+ Object.keys(this.disableds).forEach(key => {
531
+ this.disableds[key] = val
532
+ })
533
+ }
534
+ },
535
+
536
+ separateAdvanceAndNormal(config = this.config) {
537
+ const isVertical = this.isVertical
538
+
539
+ const reducer = config => config.reduce(
540
+ (prev, item) => {
541
+ if (Array.isArray(item)) {
542
+ const { normalItems, ...rest } = reducer(item)
543
+
544
+ normalItems.length && prev.normalItems.push(normalItems)
545
+
546
+ return {
547
+ ...prev,
548
+ ...rest
549
+ }
550
+ } else {
551
+ const { mold } = item
552
+ // if (mold === "upload") {
553
+ // this.uploadKeys.add(prop);
554
+ // }
555
+
556
+ if (isVertical) {
557
+ if (mold === 'querybutton') {
558
+ prev[mold] = item
559
+ } else {
560
+ prev.normalItems.push(item)
561
+ }
562
+ } else {
563
+ prev.normalItems.push(item)
564
+ }
565
+ }
566
+
567
+ return prev
568
+ },
569
+ {
570
+ normalItems: []
571
+ }
572
+ )
573
+
574
+ return reducer(config)
575
+ },
576
+
577
+ isFunc(callBack) {
578
+ return callBack && typeof callBack === 'function'
579
+ },
580
+
581
+ isEmptyObject(obj) {
582
+ const isObj = Object.prototype.toString.call(obj).toLowerCase() !== '[object object]'
583
+ return !Object.keys(isObj ? {} : obj).length
584
+ },
585
+
586
+ async handleExpectQuery(config) {
587
+ this.queryLoading = true
588
+
589
+ try {
590
+ if (this.$listeners.query) {
591
+ await this.validate()
592
+
593
+ let model
594
+
595
+ if (this.uploadKeys.size) {
596
+ model = this.convertModelToFormData(this.model)
597
+ config = {
598
+ headers: {
599
+ 'Content-Type': 'multipart/form-data'
600
+ },
601
+ ...config
602
+ }
603
+ } else {
604
+ model = JSON.parse(JSON.stringify(this.model))
605
+ }
606
+
607
+ await this.$listeners.query(model, config)
608
+ } else {
609
+ throw new Error(
610
+ 'must specify @query event when there is a query button'
611
+ )
612
+ }
613
+ } catch (err) {
614
+ console.error('form custom error -> handleExpectQuery:', err)
615
+ } finally {
616
+ this.queryLoading = false
617
+ }
618
+ },
619
+
620
+ convertModelToFormData(model) {
621
+ const fd = new FormData()
622
+ Object.entries(model).forEach(([key, value]) => {
623
+ fd.append(key, value instanceof window.FormData ? value.get(key) : value)
624
+ })
625
+ return fd
626
+ },
627
+
628
+ clearValidate() {
629
+ if (this.rules && this.$refs[this.formID]) {
630
+ this.$refs[this.formID] && this.$refs[this.formID].clearValidate()
631
+ }
632
+ },
633
+
634
+ resetFields() {
635
+ console.log('__log_formID', this.formID, this.$refs[this.formID])
636
+ this.$refs[this.formID] && this.$refs[this.formID].resetFields()
637
+ },
638
+
639
+ validate() {
640
+ if (this.rules && this.$refs[this.formID]) {
641
+ return this.$refs[this.formID].validate()
642
+ }
643
+
644
+ return Promise.resolve()
645
+ },
646
+
647
+ /**
648
+ * 生成formId
649
+ */
650
+ createFormId() {
651
+ return `formID-${Math.random()
652
+ .toString(36)
653
+ .slice(2)}`
654
+ }
655
+ }
656
+ }
657
+ </script>
658
+
659
+ <style lang="scss">
660
+ @import "index";
661
+ </style>