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,583 +1,583 @@
1
- <template>
2
- <div class="file-upload-table">
3
- <!-- 查看附件信息 -->
4
- <template v-if="readonly">
5
- <div class="p-t-s p-b-s">
6
- <div class="flex-box flex-v flex-lr">
7
- <div><slot name="title"></slot></div>
8
- <slot v-if="tableData.length" name="down-btn">
9
- <el-button size="mini" plain @click="downRows">批量下载</el-button>
10
- </slot>
11
- </div>
12
- </div>
13
-
14
- <el-table
15
- :data="tableData"
16
- :row-key="keys.rowKey"
17
- @selection-change="(selection) => (selectionList = selection)"
18
- >
19
- <slot name="selection-column"
20
- ><el-table-column type="selection" width="50" align="center" />
21
- </slot>
22
- <template v-if="dataPorp.slotHeader">
23
- <el-table-column
24
- v-for="item in dataPorp.slotHeader"
25
- :key="item"
26
- :label="item.label"
27
- :prop="item.prop"
28
- :align="item.align || 'center'"
29
- :width="item.width || 'auto'"
30
- :show-overflow-tooltip="item['show-overflow-tooltip']"
31
- />
32
- </template>
33
- <template v-else>
34
- <el-table-column label="附件类型" :prop="keys.type">
35
- <template slot="header" slot-scope="scope">
36
- <slot name="type-header" :column="scope.column">附件类型</slot>
37
- </template>
38
- <template slot-scope="{ row }">
39
- <slot name="type" :row="row">{{
40
- row[keys.type] | typeFiter(typeOptions)
41
- }}</slot>
42
- </template>
43
- </el-table-column>
44
- <el-table-column label="附件名称" :prop="keys.name">
45
- <template slot="header" slot-scope="scope">
46
- <slot name="name-header" :column="scope.column">附件名称</slot>
47
- </template>
48
- <template slot-scope="{ row }">
49
- <slot name="name" :row="row">{{ row[keys.name] }}</slot>
50
- </template>
51
- </el-table-column>
52
- <el-table-column
53
- label="上传时间"
54
- :prop="keys.time"
55
- width="170"
56
- align="left"
57
- >
58
- <template slot="header" slot-scope="scope">
59
- <slot name="time-header" :column="scope.column">上传时间</slot>
60
- </template>
61
- <template slot-scope="{ row }">
62
- <slot name="time" :row="row">{{ row[keys.time] }}</slot>
63
- </template>
64
- </el-table-column>
65
- <el-table-column label="上传人" :prop="keys.user">
66
- <template slot="header" slot-scope="scope">
67
- <slot name="user-header" :column="scope.column">上传人</slot>
68
- </template>
69
- <template slot-scope="{ row }">
70
- <slot name="user" :row="row">{{ row[keys.user] }}</slot>
71
- </template>
72
- </el-table-column>
73
- </template>
74
- <el-table-column label="操作" align="center" width="80" fixed="right">
75
- <template slot="header" slot-scope="scope">
76
- <slot name="handle-header" :column="scope.column">操作</slot>
77
- </template>
78
- <template slot-scope="{ row }">
79
- <slot name="handle" :row="row">
80
- <el-button
81
- type="text"
82
- icon="el-icon-view"
83
- @click="seeFile(row)"
84
- />
85
- <el-button
86
- type="text"
87
- icon="el-icon-download"
88
- :disabled="!row[keys.url] || row.url"
89
- @click="downFile(row)"
90
- />
91
- </slot>
92
- </template>
93
- </el-table-column>
94
- </el-table>
95
- </template>
96
- <!-- 上传附件 -->
97
- <template v-else>
98
- <div class="p-t-s p-b-s">
99
- <div class="flex-box flex-v flex-lr">
100
- <div><slot name="title"></slot></div>
101
- <div>
102
- <slot name="add-btn">
103
- <el-button type="primary" size="mini" @click="addRow"
104
- >新增</el-button
105
- >
106
- </slot>
107
- <slot v-if="showBatchUpload" name="batch-btn">
108
- <el-button size="mini" plain @click="visibleBatch = true"
109
- >批量上传</el-button
110
- >
111
- </slot>
112
- <slot v-if="tableData.length" name="down-btn">
113
- <el-button size="mini" plain @click="downRows">下载</el-button>
114
- </slot>
115
- <slot v-if="tableData.length" name="delete-btn">
116
- <el-button type="danger" plain size="mini" @click="deleteRows"
117
- >删除</el-button
118
- >
119
- </slot>
120
- </div>
121
- </div>
122
- </div>
123
-
124
- <el-table
125
- :data="tableData"
126
- :row-key="keys.rowKey"
127
- @selection-change="(selection) => (selectionList = selection)"
128
- >
129
- <slot name="selection-column"
130
- ><el-table-column type="selection" width="50" align="center" />
131
- </slot>
132
- <el-table-column label="附件类型" min-width="160">
133
- <template slot="header" slot-scope="scope">
134
- <slot name="type-header" :column="scope.column">附件类型</slot>
135
- </template>
136
- <template slot-scope="{ row }">
137
- <slot name="type" :row="row">
138
- <el-select
139
- v-model="row[keys.type]"
140
- :disabled="row['_typeDisabled']"
141
- placeholder="请选择"
142
- style="width: 100%"
143
- >
144
- <el-option
145
- v-for="item in typeOptions"
146
- :key="item.type"
147
- :disabled="item.disabled"
148
- :value="item.type"
149
- :label="item.label"
150
- />
151
- </el-select>
152
- </slot>
153
- </template>
154
- </el-table-column>
155
- <el-table-column label="附件名称" min-width="160">
156
- <template slot="header" slot-scope="scope">
157
- <slot name="name-header" :column="scope.column">附件名称</slot>
158
- </template>
159
- <template slot-scope="{ row }">
160
- <slot name="name" :row="row">
161
- <el-input v-model="row[keys.name]" placeholder="请输入" />
162
- </slot>
163
- </template>
164
- </el-table-column>
165
- <el-table-column label="附件上传" min-width="160">
166
- <template slot="header" slot-scope="scope">
167
- <slot name="upload-header" :column="scope.column">附件上传</slot>
168
- </template>
169
- <template slot-scope="{ row, $index }">
170
- <slot name="upload" :row="row" :$index="$index">
171
- <clUpload
172
- :ref="'upload' + $index"
173
- class="n20-upload-table-up"
174
- :file-name="row['_name'] || row[keys.name]"
175
- :data="row['_fileData']"
176
- :msg-type="null"
177
- :show-clear="false"
178
- :action="action"
179
- :headers="headers"
180
- :disabled="!row[keys.type]"
181
- :accept="row[keys.type] | acceptFilter(typeOptions, fileAccept)"
182
- :size="row[keys.type] | sizeFilter(typeOptions, fileSize)"
183
- :http-request="
184
- uploadHttpRequest
185
- ? (options) => uploadHttpRequest(options, row)
186
- : undefined
187
- "
188
- :before-upload="(file) => beforeUploadFn(file, row)"
189
- :on-progress="(event) => onProgressFn(event, row)"
190
- :on-success="
191
- (response, file, fileList) =>
192
- onSuccessFn(response, file, fileList, row)
193
- "
194
- :on-error="
195
- (err, file, fileList) =>
196
- errorFn(err, file, fileList, row, $index)
197
- "
198
- />
199
- </slot>
200
- </template>
201
- </el-table-column>
202
- <el-table-column
203
- label="上传时间"
204
- :prop="keys.time"
205
- width="170"
206
- align="left"
207
- >
208
- <template slot="header" slot-scope="scope">
209
- <slot name="time-header" :column="scope.column">上传时间</slot>
210
- </template>
211
- <template slot-scope="{ row }">
212
- <slot name="time" :row="row">{{ row[keys.time] }}</slot>
213
- </template>
214
- </el-table-column>
215
- <el-table-column label="上传人" :prop="keys.user" width="100">
216
- <template slot="header" slot-scope="scope">
217
- <slot name="user-header" :column="scope.column">上传人</slot>
218
- </template>
219
- <template slot-scope="{ row }">
220
- <slot name="user" :row="row">{{ row[keys.user] }}</slot>
221
- </template>
222
- </el-table-column>
223
- <el-table-column label="上传进度" width="220">
224
- <template slot="header" slot-scope="scope">
225
- <slot name="percent-header" :column="scope.column">上传进度</slot>
226
- </template>
227
- <template slot-scope="{ row, $index }">
228
- <slot name="percent" :row="row" :$index="$index">
229
- <div v-if="row['_percent'] >= 0" class="flex-box flex-v">
230
- <el-progress
231
- class="n20-upload-table-progress"
232
- :percentage="row['_percent']"
233
- :status="row['_status']"
234
- style="width: 140px"
235
- />
236
- <el-button
237
- v-if="row['_status'] === 'exception'"
238
- type="text"
239
- size="mini"
240
- style="width: 60px"
241
- @click="anewSubmitFn(row, $index)"
242
- >重新上传</el-button
243
- >
244
- <el-button
245
- v-else-if="row['_percent'] >= 0 && row['_percent'] < 100"
246
- type="text"
247
- size="mini"
248
- style="width: 60px"
249
- @click="abortFn(row, $index)"
250
- >取消</el-button
251
- >
252
- </div>
253
- </slot>
254
- </template>
255
- </el-table-column>
256
- <el-table-column label="操作" align="center" width="80" fixed="right">
257
- <template slot="header" slot-scope="scope">
258
- <slot name="handle-header" :column="scope.column">操作</slot>
259
- </template>
260
- <template slot-scope="{ row }">
261
- <slot name="handle" :row="row">
262
- <el-button
263
- type="text"
264
- icon="el-icon-view"
265
- :disabled="!row[keys.url]"
266
- @click="seeFile(row)"
267
- />
268
- </slot>
269
- </template>
270
- </el-table-column>
271
- </el-table>
272
- </template>
273
-
274
- <el-dialog
275
- v-drag
276
- class="p-a-0"
277
- title="附件预览"
278
- :visible.sync="visibleP"
279
- top="2vh"
280
- width="96%"
281
- append-to-body
282
- @close="closeSee"
283
- >
284
- <div
285
- v-if="imgType.test(previewName)"
286
- class="p-a flex-box flex-c flex-v"
287
- style="height: 82vh"
288
- >
289
- <img
290
- :src="previewUrl"
291
- :alt="previewName"
292
- style="max-width: 98%; max-height: 98%"
293
- />
294
- </div>
295
- <div v-else class="p-a" style="height: 82vh">
296
- <component
297
- :is="previewSameOrg ? 'object' : 'div'"
298
- :key="previewUrl"
299
- :data="previewUrl"
300
- style="width: 100%; height: 100%"
301
- >
302
- <div class="flex-column flex-c flex-v" style="height: 100%">
303
- <i
304
- class="el-icon-s-release"
305
- style="font-size: 60px; color: #999"
306
- ></i>
307
- <span style="margin-top: 16px">
308
- 不支持在线预览,请
309
- <a :href="previewUrl" :download="previewName || previewUrl"
310
- >下载</a
311
- >
312
- 到本地查看
313
- </span>
314
- </div>
315
- </component>
316
- </div>
317
- </el-dialog>
318
- <Dialog
319
- title="附件批量上传"
320
- :visible.sync="visibleBatch"
321
- top="5vh"
322
- width="692px"
323
- >
324
- <clUpload
325
- ref="upload-batch"
326
- class="n20-upload-drag"
327
- :msg-type="null"
328
- :show-clear="false"
329
- :drag="true"
330
- :auto-upload="false"
331
- :multiple="true"
332
- :action="action"
333
- :headers="headers"
334
- :accept="fileAccept"
335
- :http-request="uploadHttpRequest"
336
- :on-remove="(file) => $emit('on-remove', file)"
337
- :on-success="batchSuccess"
338
- >
339
- <template slot="trigger">
340
- <i class="drag-icon n20-icon-shangchuan"></i>
341
- <span class="drag-text">点击或将文件拖拽到这里上传</span>
342
- <span class="drag-tip">
343
- <slot>支持扩展名:.rar .zip .doc .docx .pdf .jpg...</slot>
344
- </span>
345
- </template>
346
- </clUpload>
347
- <div class="dialog-footer">
348
- <el-button type="primary" @click="batchUploadFn">确认</el-button>
349
- <el-button plain @click="visibleBatch = false">取消</el-button>
350
- </div>
351
- </Dialog>
352
- </div>
353
- </template>
354
-
355
- <script>
356
- import dayjs from 'dayjs'
357
- import axios from '../../utils/axios'
358
- import clUpload from '../Upload/index.vue'
359
- import Dialog from '../Dialog/index.vue'
360
- export default {
361
- name: 'FileUploadTable',
362
- components: {
363
- clUpload,
364
- Dialog
365
- },
366
- filters: {
367
- typeFiter(type, typeOptions) {
368
- return typeOptions.find((c) => c.type === type)?.label || ''
369
- },
370
- acceptFilter(type, typeOptions, fileAccept) {
371
- return typeOptions.find((c) => c.type === type)?.accept || fileAccept
372
- },
373
- sizeFilter(type, typeOptions, fileSize) {
374
- return typeOptions.find((c) => c.type === type)?.size || fileSize
375
- }
376
- },
377
- props: {
378
- readonly: {
379
- type: Boolean,
380
- default: false
381
- },
382
- action: {
383
- type: String,
384
- default: '/bems/1.0/attach'
385
- },
386
- headers: {
387
- type: Object,
388
- default: undefined
389
- },
390
- seePrefix: {
391
- type: String,
392
- default: undefined
393
- },
394
- seeTypes: {
395
- type: RegExp,
396
- default: () => /\.jpg|\.png|\.gif|\.svg|\.pdf$/i
397
- },
398
- tableData: {
399
- type: Array,
400
- default: () => []
401
- },
402
- dataPorp: {
403
- type: Object,
404
- default: () => ({})
405
- },
406
- showBatchUpload: {
407
- type: Boolean,
408
- default: false
409
- },
410
- uploadHttpRequest: {
411
- type: Function,
412
- default: undefined
413
- },
414
- getFileMethod: {
415
- type: Function,
416
- default: undefined
417
- }
418
- },
419
- data() {
420
- return {
421
- imgType: /\.jpg|\.png|\.gif|\.svg$/i,
422
- selectionList: [],
423
- fileAccept: this.dataPorp.fileAccept || undefined,
424
- fileSize: this.dataPorp.fileSize || undefined,
425
- typeOptions: this.dataPorp.typeOptions || [
426
- {
427
- type: '001',
428
- label: '信贷合同'
429
- },
430
- {
431
- type: '002',
432
- label: '贴现合同'
433
- },
434
- {
435
- type: '003',
436
- label: '其他合同'
437
- }
438
- ],
439
- keys: this.dataPorp.keys || {
440
- rowKey: 'id',
441
- type: 'type',
442
- name: 'name',
443
- url: 'url',
444
- time: 'time',
445
- user: 'user'
446
- },
447
- currFileList: [],
448
- visibleP: false,
449
- visibleBatch: false,
450
- previewUrl: undefined,
451
- previewName: undefined,
452
- previewSameOrg: false
453
- }
454
- },
455
- methods: {
456
- batchUploadFn() {
457
- let $uploadwrap = this.$refs['upload-batch']
458
- let $upload = $uploadwrap.$refs['upload']
459
- $upload.submit()
460
- },
461
- batchSuccess(response, file, fileList) {
462
- let row = {}
463
- this.tableData.splice(0, 0, row)
464
- this.$nextTick(() => {
465
- this.onSuccessFn(response, file, fileList, row)
466
- })
467
-
468
- if (fileList.every((f) => f.status === 'success')) {
469
- this.visibleBatch = false
470
- }
471
- },
472
- addRow() {
473
- this.$emit('add-row')
474
- },
475
- downRows() {
476
- this.$emit('down-rows', this.selectionList)
477
- },
478
- deleteRows() {
479
- this.$emit('delete-rows', this.selectionList)
480
- },
481
-
482
- async getFileInfo(row) {
483
- if (this.getFileMethod) {
484
- return this.getFileMethod(row)
485
- }
486
-
487
- let _url = row[this.keys.url]
488
- this.seePrefix && (_url = this.seePrefix + _url)
489
- if (_url) {
490
- let blob = await axios.get(_url, {}, { responseType: 'blob' })
491
- let url = URL.createObjectURL(blob)
492
- let name = blob.name
493
- let sameOrg = this.seeTypes.test(name) || this.seeTypes.test(_url)
494
- return {
495
- url,
496
- name,
497
- sameOrg
498
- }
499
- } else {
500
- return {}
501
- }
502
- },
503
- async downFile(row) {
504
- let { url, name } = await this.getFileInfo(row)
505
- if (url) {
506
- let aDom = document.createElement('a')
507
- aDom.href = url
508
- aDom.download = name
509
- aDom.click()
510
-
511
- this.$nextTick(() => {
512
- aDom = undefined
513
- url && URL.revokeObjectURL(url)
514
- })
515
- }
516
- },
517
- async seeFile(row) {
518
- let { url, name, sameOrg } = await this.getFileInfo(row)
519
- if (url) {
520
- this.previewSameOrg = sameOrg
521
- this.previewUrl = url
522
- this.previewName = name
523
- this.visibleP = true
524
- }
525
- },
526
- closeSee() {
527
- this.previewUrl && URL.revokeObjectURL(this.previewUrl)
528
- },
529
- beforeUploadFn(file, row) {
530
- this.$set(row, '_percent', 0)
531
- this.$set(row, '_status', undefined)
532
-
533
- this.$emit('before-upload', file, row)
534
- },
535
- onProgressFn({ percent }, row) {
536
- this.$set(row, '_percent', percent <= 99 ? Math.round(percent) : 99)
537
- },
538
- onSuccessFn(response, file, fileList, row) {
539
- this.$set(row, '_name', file.name)
540
- this.$set(row, '_percent', 100)
541
-
542
- row[this.keys.time] = dayjs().format('YYYY-MM-DD HH:mm:ss')
543
-
544
- row[this.keys.url] = response.data
545
- if (!row[this.keys.name]) {
546
- row[this.keys.name] = file.name
547
- }
548
- this.$set(row, '_status', 'success')
549
-
550
- this.$emit('on-success', file, row)
551
- },
552
- errorFn(err, file, fileList, row, $index) {
553
- this.$set(row, '_status', 'exception')
554
-
555
- let clUpload = this.$refs['upload' + $index]
556
- /* 重置文件状态,并加入文件队列 */
557
- file.status = 'ready'
558
- clUpload.fileList = [file]
559
-
560
- this.$emit('on-error', file, row)
561
- },
562
- abortFn(row, $index) {
563
- this.$set(row, '_status', 'exception')
564
-
565
- let clUpload = this.$refs['upload' + $index]
566
- let elUpload = clUpload.$refs['upload']
567
- let uploadFiles = elUpload.uploadFiles
568
-
569
- /* 重置文件状态,并加入文件队列 */
570
- let file = uploadFiles[uploadFiles.length - 1]
571
- file.status = 'ready'
572
- clUpload.fileList = [file]
573
-
574
- elUpload.abort()
575
- },
576
- anewSubmitFn(row, $index) {
577
- this.$set(row, '_status', 'success')
578
-
579
- this.$refs['upload' + $index]?.$refs['upload']?.submit()
580
- }
581
- }
582
- }
583
- </script>
1
+ <template>
2
+ <div class="file-upload-table">
3
+ <!-- 查看附件信息 -->
4
+ <template v-if="readonly">
5
+ <div class="p-t-s p-b-s">
6
+ <div class="flex-box flex-v flex-lr">
7
+ <div><slot name="title"></slot></div>
8
+ <slot v-if="tableData.length" name="down-btn">
9
+ <el-button size="mini" plain @click="downRows">批量下载</el-button>
10
+ </slot>
11
+ </div>
12
+ </div>
13
+
14
+ <el-table
15
+ :data="tableData"
16
+ :row-key="keys.rowKey"
17
+ @selection-change="(selection) => (selectionList = selection)"
18
+ >
19
+ <slot name="selection-column"
20
+ ><el-table-column type="selection" width="50" align="center" />
21
+ </slot>
22
+ <template v-if="dataPorp.slotHeader">
23
+ <el-table-column
24
+ v-for="item in dataPorp.slotHeader"
25
+ :key="item"
26
+ :label="item.label"
27
+ :prop="item.prop"
28
+ :align="item.align || 'center'"
29
+ :width="item.width || 'auto'"
30
+ :show-overflow-tooltip="item['show-overflow-tooltip']"
31
+ />
32
+ </template>
33
+ <template v-else>
34
+ <el-table-column label="附件类型" :prop="keys.type">
35
+ <template slot="header" slot-scope="scope">
36
+ <slot name="type-header" :column="scope.column">附件类型</slot>
37
+ </template>
38
+ <template slot-scope="{ row }">
39
+ <slot name="type" :row="row">{{
40
+ row[keys.type] | typeFiter(typeOptions)
41
+ }}</slot>
42
+ </template>
43
+ </el-table-column>
44
+ <el-table-column label="附件名称" :prop="keys.name">
45
+ <template slot="header" slot-scope="scope">
46
+ <slot name="name-header" :column="scope.column">附件名称</slot>
47
+ </template>
48
+ <template slot-scope="{ row }">
49
+ <slot name="name" :row="row">{{ row[keys.name] }}</slot>
50
+ </template>
51
+ </el-table-column>
52
+ <el-table-column
53
+ label="上传时间"
54
+ :prop="keys.time"
55
+ width="170"
56
+ align="left"
57
+ >
58
+ <template slot="header" slot-scope="scope">
59
+ <slot name="time-header" :column="scope.column">上传时间</slot>
60
+ </template>
61
+ <template slot-scope="{ row }">
62
+ <slot name="time" :row="row">{{ row[keys.time] }}</slot>
63
+ </template>
64
+ </el-table-column>
65
+ <el-table-column label="上传人" :prop="keys.user">
66
+ <template slot="header" slot-scope="scope">
67
+ <slot name="user-header" :column="scope.column">上传人</slot>
68
+ </template>
69
+ <template slot-scope="{ row }">
70
+ <slot name="user" :row="row">{{ row[keys.user] }}</slot>
71
+ </template>
72
+ </el-table-column>
73
+ </template>
74
+ <el-table-column label="操作" align="center" width="80" fixed="right">
75
+ <template slot="header" slot-scope="scope">
76
+ <slot name="handle-header" :column="scope.column">操作</slot>
77
+ </template>
78
+ <template slot-scope="{ row }">
79
+ <slot name="handle" :row="row">
80
+ <el-button
81
+ type="text"
82
+ icon="el-icon-view"
83
+ @click="seeFile(row)"
84
+ />
85
+ <el-button
86
+ type="text"
87
+ icon="el-icon-download"
88
+ :disabled="!row[keys.url] || row.url"
89
+ @click="downFile(row)"
90
+ />
91
+ </slot>
92
+ </template>
93
+ </el-table-column>
94
+ </el-table>
95
+ </template>
96
+ <!-- 上传附件 -->
97
+ <template v-else>
98
+ <div class="p-t-s p-b-s">
99
+ <div class="flex-box flex-v flex-lr">
100
+ <div><slot name="title"></slot></div>
101
+ <div>
102
+ <slot name="add-btn">
103
+ <el-button type="primary" size="mini" @click="addRow"
104
+ >新增</el-button
105
+ >
106
+ </slot>
107
+ <slot v-if="showBatchUpload" name="batch-btn">
108
+ <el-button size="mini" plain @click="visibleBatch = true"
109
+ >批量上传</el-button
110
+ >
111
+ </slot>
112
+ <slot v-if="tableData.length" name="down-btn">
113
+ <el-button size="mini" plain @click="downRows">下载</el-button>
114
+ </slot>
115
+ <slot v-if="tableData.length" name="delete-btn">
116
+ <el-button type="danger" plain size="mini" @click="deleteRows"
117
+ >删除</el-button
118
+ >
119
+ </slot>
120
+ </div>
121
+ </div>
122
+ </div>
123
+
124
+ <el-table
125
+ :data="tableData"
126
+ :row-key="keys.rowKey"
127
+ @selection-change="(selection) => (selectionList = selection)"
128
+ >
129
+ <slot name="selection-column"
130
+ ><el-table-column type="selection" width="50" align="center" />
131
+ </slot>
132
+ <el-table-column label="附件类型" min-width="160">
133
+ <template slot="header" slot-scope="scope">
134
+ <slot name="type-header" :column="scope.column">附件类型</slot>
135
+ </template>
136
+ <template slot-scope="{ row }">
137
+ <slot name="type" :row="row">
138
+ <el-select
139
+ v-model="row[keys.type]"
140
+ :disabled="row['_typeDisabled']"
141
+ placeholder="请选择"
142
+ style="width: 100%"
143
+ >
144
+ <el-option
145
+ v-for="item in typeOptions"
146
+ :key="item.type"
147
+ :disabled="item.disabled"
148
+ :value="item.type"
149
+ :label="item.label"
150
+ />
151
+ </el-select>
152
+ </slot>
153
+ </template>
154
+ </el-table-column>
155
+ <el-table-column label="附件名称" min-width="160">
156
+ <template slot="header" slot-scope="scope">
157
+ <slot name="name-header" :column="scope.column">附件名称</slot>
158
+ </template>
159
+ <template slot-scope="{ row }">
160
+ <slot name="name" :row="row">
161
+ <el-input v-model="row[keys.name]" placeholder="请输入" />
162
+ </slot>
163
+ </template>
164
+ </el-table-column>
165
+ <el-table-column label="附件上传" min-width="160">
166
+ <template slot="header" slot-scope="scope">
167
+ <slot name="upload-header" :column="scope.column">附件上传</slot>
168
+ </template>
169
+ <template slot-scope="{ row, $index }">
170
+ <slot name="upload" :row="row" :$index="$index">
171
+ <clUpload
172
+ :ref="'upload' + $index"
173
+ class="n20-upload-table-up"
174
+ :file-name="row['_name'] || row[keys.name]"
175
+ :data="row['_fileData']"
176
+ :msg-type="null"
177
+ :show-clear="false"
178
+ :action="action"
179
+ :headers="headers"
180
+ :disabled="!row[keys.type]"
181
+ :accept="row[keys.type] | acceptFilter(typeOptions, fileAccept)"
182
+ :size="row[keys.type] | sizeFilter(typeOptions, fileSize)"
183
+ :http-request="
184
+ uploadHttpRequest
185
+ ? (options) => uploadHttpRequest(options, row)
186
+ : undefined
187
+ "
188
+ :before-upload="(file) => beforeUploadFn(file, row)"
189
+ :on-progress="(event) => onProgressFn(event, row)"
190
+ :on-success="
191
+ (response, file, fileList) =>
192
+ onSuccessFn(response, file, fileList, row)
193
+ "
194
+ :on-error="
195
+ (err, file, fileList) =>
196
+ errorFn(err, file, fileList, row, $index)
197
+ "
198
+ />
199
+ </slot>
200
+ </template>
201
+ </el-table-column>
202
+ <el-table-column
203
+ label="上传时间"
204
+ :prop="keys.time"
205
+ width="170"
206
+ align="left"
207
+ >
208
+ <template slot="header" slot-scope="scope">
209
+ <slot name="time-header" :column="scope.column">上传时间</slot>
210
+ </template>
211
+ <template slot-scope="{ row }">
212
+ <slot name="time" :row="row">{{ row[keys.time] }}</slot>
213
+ </template>
214
+ </el-table-column>
215
+ <el-table-column label="上传人" :prop="keys.user" width="100">
216
+ <template slot="header" slot-scope="scope">
217
+ <slot name="user-header" :column="scope.column">上传人</slot>
218
+ </template>
219
+ <template slot-scope="{ row }">
220
+ <slot name="user" :row="row">{{ row[keys.user] }}</slot>
221
+ </template>
222
+ </el-table-column>
223
+ <el-table-column label="上传进度" width="220">
224
+ <template slot="header" slot-scope="scope">
225
+ <slot name="percent-header" :column="scope.column">上传进度</slot>
226
+ </template>
227
+ <template slot-scope="{ row, $index }">
228
+ <slot name="percent" :row="row" :$index="$index">
229
+ <div v-if="row['_percent'] >= 0" class="flex-box flex-v">
230
+ <el-progress
231
+ class="n20-upload-table-progress"
232
+ :percentage="row['_percent']"
233
+ :status="row['_status']"
234
+ style="width: 140px"
235
+ />
236
+ <el-button
237
+ v-if="row['_status'] === 'exception'"
238
+ type="text"
239
+ size="mini"
240
+ style="width: 60px"
241
+ @click="anewSubmitFn(row, $index)"
242
+ >重新上传</el-button
243
+ >
244
+ <el-button
245
+ v-else-if="row['_percent'] >= 0 && row['_percent'] < 100"
246
+ type="text"
247
+ size="mini"
248
+ style="width: 60px"
249
+ @click="abortFn(row, $index)"
250
+ >取消</el-button
251
+ >
252
+ </div>
253
+ </slot>
254
+ </template>
255
+ </el-table-column>
256
+ <el-table-column label="操作" align="center" width="80" fixed="right">
257
+ <template slot="header" slot-scope="scope">
258
+ <slot name="handle-header" :column="scope.column">操作</slot>
259
+ </template>
260
+ <template slot-scope="{ row }">
261
+ <slot name="handle" :row="row">
262
+ <el-button
263
+ type="text"
264
+ icon="el-icon-view"
265
+ :disabled="!row[keys.url]"
266
+ @click="seeFile(row)"
267
+ />
268
+ </slot>
269
+ </template>
270
+ </el-table-column>
271
+ </el-table>
272
+ </template>
273
+
274
+ <el-dialog
275
+ v-drag
276
+ class="p-a-0"
277
+ title="附件预览"
278
+ :visible.sync="visibleP"
279
+ top="2vh"
280
+ width="96%"
281
+ append-to-body
282
+ @close="closeSee"
283
+ >
284
+ <div
285
+ v-if="imgType.test(previewName)"
286
+ class="p-a flex-box flex-c flex-v"
287
+ style="height: 82vh"
288
+ >
289
+ <img
290
+ :src="previewUrl"
291
+ :alt="previewName"
292
+ style="max-width: 98%; max-height: 98%"
293
+ />
294
+ </div>
295
+ <div v-else class="p-a" style="height: 82vh">
296
+ <component
297
+ :is="previewSameOrg ? 'object' : 'div'"
298
+ :key="previewUrl"
299
+ :data="previewUrl"
300
+ style="width: 100%; height: 100%"
301
+ >
302
+ <div class="flex-column flex-c flex-v" style="height: 100%">
303
+ <i
304
+ class="el-icon-s-release"
305
+ style="font-size: 60px; color: #999"
306
+ ></i>
307
+ <span style="margin-top: 16px">
308
+ 不支持在线预览,请
309
+ <a :href="previewUrl" :download="previewName || previewUrl"
310
+ >下载</a
311
+ >
312
+ 到本地查看
313
+ </span>
314
+ </div>
315
+ </component>
316
+ </div>
317
+ </el-dialog>
318
+ <Dialog
319
+ title="附件批量上传"
320
+ :visible.sync="visibleBatch"
321
+ top="5vh"
322
+ width="692px"
323
+ >
324
+ <clUpload
325
+ ref="upload-batch"
326
+ class="n20-upload-drag"
327
+ :msg-type="null"
328
+ :show-clear="false"
329
+ :drag="true"
330
+ :auto-upload="false"
331
+ :multiple="true"
332
+ :action="action"
333
+ :headers="headers"
334
+ :accept="fileAccept"
335
+ :http-request="uploadHttpRequest"
336
+ :on-remove="(file) => $emit('on-remove', file)"
337
+ :on-success="batchSuccess"
338
+ >
339
+ <template slot="trigger">
340
+ <i class="drag-icon n20-icon-shangchuan"></i>
341
+ <span class="drag-text">点击或将文件拖拽到这里上传</span>
342
+ <span class="drag-tip">
343
+ <slot>支持扩展名:.rar .zip .doc .docx .pdf .jpg...</slot>
344
+ </span>
345
+ </template>
346
+ </clUpload>
347
+ <div class="dialog-footer">
348
+ <el-button type="primary" @click="batchUploadFn">确认</el-button>
349
+ <el-button plain @click="visibleBatch = false">取消</el-button>
350
+ </div>
351
+ </Dialog>
352
+ </div>
353
+ </template>
354
+
355
+ <script>
356
+ import dayjs from 'dayjs'
357
+ import axios from '../../utils/axios'
358
+ import clUpload from '../Upload/index.vue'
359
+ import Dialog from '../Dialog/index.vue'
360
+ export default {
361
+ name: 'FileUploadTable',
362
+ components: {
363
+ clUpload,
364
+ Dialog
365
+ },
366
+ filters: {
367
+ typeFiter(type, typeOptions) {
368
+ return typeOptions.find((c) => c.type === type)?.label || ''
369
+ },
370
+ acceptFilter(type, typeOptions, fileAccept) {
371
+ return typeOptions.find((c) => c.type === type)?.accept || fileAccept
372
+ },
373
+ sizeFilter(type, typeOptions, fileSize) {
374
+ return typeOptions.find((c) => c.type === type)?.size || fileSize
375
+ }
376
+ },
377
+ props: {
378
+ readonly: {
379
+ type: Boolean,
380
+ default: false
381
+ },
382
+ action: {
383
+ type: String,
384
+ default: '/bems/1.0/attach'
385
+ },
386
+ headers: {
387
+ type: Object,
388
+ default: undefined
389
+ },
390
+ seePrefix: {
391
+ type: String,
392
+ default: undefined
393
+ },
394
+ seeTypes: {
395
+ type: RegExp,
396
+ default: () => /\.jpg|\.png|\.gif|\.svg|\.pdf$/i
397
+ },
398
+ tableData: {
399
+ type: Array,
400
+ default: () => []
401
+ },
402
+ dataPorp: {
403
+ type: Object,
404
+ default: () => ({})
405
+ },
406
+ showBatchUpload: {
407
+ type: Boolean,
408
+ default: false
409
+ },
410
+ uploadHttpRequest: {
411
+ type: Function,
412
+ default: undefined
413
+ },
414
+ getFileMethod: {
415
+ type: Function,
416
+ default: undefined
417
+ }
418
+ },
419
+ data() {
420
+ return {
421
+ imgType: /\.jpg|\.png|\.gif|\.svg$/i,
422
+ selectionList: [],
423
+ fileAccept: this.dataPorp.fileAccept || undefined,
424
+ fileSize: this.dataPorp.fileSize || undefined,
425
+ typeOptions: this.dataPorp.typeOptions || [
426
+ {
427
+ type: '001',
428
+ label: '信贷合同'
429
+ },
430
+ {
431
+ type: '002',
432
+ label: '贴现合同'
433
+ },
434
+ {
435
+ type: '003',
436
+ label: '其他合同'
437
+ }
438
+ ],
439
+ keys: this.dataPorp.keys || {
440
+ rowKey: 'id',
441
+ type: 'type',
442
+ name: 'name',
443
+ url: 'url',
444
+ time: 'time',
445
+ user: 'user'
446
+ },
447
+ currFileList: [],
448
+ visibleP: false,
449
+ visibleBatch: false,
450
+ previewUrl: undefined,
451
+ previewName: undefined,
452
+ previewSameOrg: false
453
+ }
454
+ },
455
+ methods: {
456
+ batchUploadFn() {
457
+ let $uploadwrap = this.$refs['upload-batch']
458
+ let $upload = $uploadwrap.$refs['upload']
459
+ $upload.submit()
460
+ },
461
+ batchSuccess(response, file, fileList) {
462
+ let row = {}
463
+ this.tableData.splice(0, 0, row)
464
+ this.$nextTick(() => {
465
+ this.onSuccessFn(response, file, fileList, row)
466
+ })
467
+
468
+ if (fileList.every((f) => f.status === 'success')) {
469
+ this.visibleBatch = false
470
+ }
471
+ },
472
+ addRow() {
473
+ this.$emit('add-row')
474
+ },
475
+ downRows() {
476
+ this.$emit('down-rows', this.selectionList)
477
+ },
478
+ deleteRows() {
479
+ this.$emit('delete-rows', this.selectionList)
480
+ },
481
+
482
+ async getFileInfo(row) {
483
+ if (this.getFileMethod) {
484
+ return this.getFileMethod(row)
485
+ }
486
+
487
+ let _url = row[this.keys.url]
488
+ this.seePrefix && (_url = this.seePrefix + _url)
489
+ if (_url) {
490
+ let blob = await axios.get(_url, {}, { responseType: 'blob' })
491
+ let url = URL.createObjectURL(blob)
492
+ let name = blob.name
493
+ let sameOrg = this.seeTypes.test(name) || this.seeTypes.test(_url)
494
+ return {
495
+ url,
496
+ name,
497
+ sameOrg
498
+ }
499
+ } else {
500
+ return {}
501
+ }
502
+ },
503
+ async downFile(row) {
504
+ let { url, name } = await this.getFileInfo(row)
505
+ if (url) {
506
+ let aDom = document.createElement('a')
507
+ aDom.href = url
508
+ aDom.download = name
509
+ aDom.click()
510
+
511
+ this.$nextTick(() => {
512
+ aDom = undefined
513
+ url && URL.revokeObjectURL(url)
514
+ })
515
+ }
516
+ },
517
+ async seeFile(row) {
518
+ let { url, name, sameOrg } = await this.getFileInfo(row)
519
+ if (url) {
520
+ this.previewSameOrg = sameOrg
521
+ this.previewUrl = url
522
+ this.previewName = name
523
+ this.visibleP = true
524
+ }
525
+ },
526
+ closeSee() {
527
+ this.previewUrl && URL.revokeObjectURL(this.previewUrl)
528
+ },
529
+ beforeUploadFn(file, row) {
530
+ this.$set(row, '_percent', 0)
531
+ this.$set(row, '_status', undefined)
532
+
533
+ this.$emit('before-upload', file, row)
534
+ },
535
+ onProgressFn({ percent }, row) {
536
+ this.$set(row, '_percent', percent <= 99 ? Math.round(percent) : 99)
537
+ },
538
+ onSuccessFn(response, file, fileList, row) {
539
+ this.$set(row, '_name', file.name)
540
+ this.$set(row, '_percent', 100)
541
+
542
+ row[this.keys.time] = dayjs().format('YYYY-MM-DD HH:mm:ss')
543
+
544
+ row[this.keys.url] = response.data
545
+ if (!row[this.keys.name]) {
546
+ row[this.keys.name] = file.name
547
+ }
548
+ this.$set(row, '_status', 'success')
549
+
550
+ this.$emit('on-success', file, row)
551
+ },
552
+ errorFn(err, file, fileList, row, $index) {
553
+ this.$set(row, '_status', 'exception')
554
+
555
+ let clUpload = this.$refs['upload' + $index]
556
+ /* 重置文件状态,并加入文件队列 */
557
+ file.status = 'ready'
558
+ clUpload.fileList = [file]
559
+
560
+ this.$emit('on-error', file, row)
561
+ },
562
+ abortFn(row, $index) {
563
+ this.$set(row, '_status', 'exception')
564
+
565
+ let clUpload = this.$refs['upload' + $index]
566
+ let elUpload = clUpload.$refs['upload']
567
+ let uploadFiles = elUpload.uploadFiles
568
+
569
+ /* 重置文件状态,并加入文件队列 */
570
+ let file = uploadFiles[uploadFiles.length - 1]
571
+ file.status = 'ready'
572
+ clUpload.fileList = [file]
573
+
574
+ elUpload.abort()
575
+ },
576
+ anewSubmitFn(row, $index) {
577
+ this.$set(row, '_status', 'success')
578
+
579
+ this.$refs['upload' + $index]?.$refs['upload']?.submit()
580
+ }
581
+ }
582
+ }
583
+ </script>