n20-common-lib 1.3.26 → 1.3.29

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 (395) 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 +591 -591
  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 +330 -330
  154. package/nstc-g6/components/NstcUploadExcel/NstcUploadExcel.vue +145 -145
  155. package/nstc-g6/components/NstcWorkBench/NstcWorkBench.vue +176 -176
  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/parseTime.js +48 -48
  171. package/nstc-g6/utils/validate/index.js +6 -6
  172. package/nstc-g6/utils/vendor/Export2Excel.js +229 -229
  173. package/nstc-g6/utils/vendor/Export2Zip.js +24 -24
  174. package/nstc-g6/utils/vue-bus.js +4 -4
  175. package/package.json +116 -116
  176. package/src/_qiankun/index.js +113 -113
  177. package/src/_qiankun/postMessage.js +48 -48
  178. package/src/assets/css/_coreLib.scss +44 -44
  179. package/src/assets/css/alert.scss +31 -31
  180. package/src/assets/css/cl-anchor.scss +32 -32
  181. package/src/assets/css/cl-approve-card.scss +68 -68
  182. package/src/assets/css/cl-dialog.scss +113 -113
  183. package/src/assets/css/cl-drag-list.scss +24 -24
  184. package/src/assets/css/cl-empty.scss +10 -10
  185. package/src/assets/css/cl-expandable-pane.scss +37 -37
  186. package/src/assets/css/cl-expandable.scss +27 -27
  187. package/src/assets/css/cl-file-upload-table.scss +31 -31
  188. package/src/assets/css/cl-filter.scss +4 -4
  189. package/src/assets/css/cl-flow-step.scss +185 -185
  190. package/src/assets/css/cl-footer-box.scss +10 -10
  191. package/src/assets/css/cl-form-item.scss +710 -710
  192. package/src/assets/css/cl-general-card.scss +11 -11
  193. package/src/assets/css/cl-layout-aside.scss +92 -92
  194. package/src/assets/css/cl-layout-content.scss +16 -16
  195. package/src/assets/css/cl-layout-header.scss +89 -89
  196. package/src/assets/css/cl-layout-tabs.scss +87 -87
  197. package/src/assets/css/cl-layout.scss +97 -97
  198. package/src/assets/css/cl-login-temporary.scss +37 -37
  199. package/src/assets/css/cl-message.scss +159 -159
  200. package/src/assets/css/cl-more-tab.scss +98 -98
  201. package/src/assets/css/cl-nav-menu.scss +5 -5
  202. package/src/assets/css/cl-pagination.scss +130 -130
  203. package/src/assets/css/cl-secondary-tab.scss +53 -53
  204. package/src/assets/css/cl-showcolumn.scss +40 -40
  205. package/src/assets/css/cl-sifting.scss +51 -51
  206. package/src/assets/css/cl-statis.scss +54 -54
  207. package/src/assets/css/cl-step.scss +73 -73
  208. package/src/assets/css/cl-suspend.scss +19 -19
  209. package/src/assets/css/cl-tertiary-tab.scss +56 -56
  210. package/src/assets/css/cl-upload.scss +52 -52
  211. package/src/assets/css/cl-worn-pagination.scss +50 -50
  212. package/src/assets/css/el-button.scss +188 -188
  213. package/src/assets/css/el-table.scss +96 -96
  214. package/src/assets/css/element-variables.scss +1061 -1061
  215. package/src/assets/css/element.dev.scss +22 -22
  216. package/src/assets/css/font-icon.scss +26 -26
  217. package/src/assets/css/index.dev.scss +4 -4
  218. package/src/assets/css/index.scss +11 -11
  219. package/src/assets/css/normalize.scss +726 -726
  220. package/src/assets/css/plain-text.scss +36 -36
  221. package/src/assets/css/rootvar.scss +143 -143
  222. package/src/assets/css/select.scss +25 -25
  223. package/src/assets/css/title-pop.scss +23 -23
  224. package/src/assets/getJsonc.js +50 -50
  225. package/src/assets/iconFont/demo.css +539 -539
  226. package/src/assets/iconFont/demo_index.html +1614 -1614
  227. package/src/assets/iconFont/iconfont.css +263 -263
  228. package/src/assets/iconFont/iconfont.json +443 -443
  229. package/src/assets/realUrl.js +12 -12
  230. package/src/components/Anchor/AnchorItem.vue +29 -29
  231. package/src/components/Anchor/index.vue +185 -185
  232. package/src/components/ApprovalButtons/index.vue +240 -240
  233. package/src/components/ApprovalCard/index.vue +132 -132
  234. package/src/components/ApprovalRecord/approvalImg.vue +39 -39
  235. package/src/components/ApprovalRecord/flowDialog.vue +47 -47
  236. package/src/components/ApprovalRecord/index.vue +63 -63
  237. package/src/components/Button/button-group.vue +154 -154
  238. package/src/components/Button/icon-group-button.vue +63 -63
  239. package/src/components/Button/index.vue +56 -56
  240. package/src/components/CascaderArea/index.vue +103 -103
  241. package/src/components/ChildRange/index.vue +165 -165
  242. package/src/components/ChildRange/style.scss +34 -34
  243. package/src/components/ContentLoading/index.vue +41 -41
  244. package/src/components/ContentNull/index.vue +19 -19
  245. package/src/components/DatePicker/index.vue +27 -27
  246. package/src/components/DatePicker/por.vue +169 -169
  247. package/src/components/Descriptions/index.vue +42 -42
  248. package/src/components/Dialog/index.vue +26 -26
  249. package/src/components/Dialog/indexO.vue +116 -116
  250. package/src/components/DragList/index.vue +75 -75
  251. package/src/components/ECharts/define.js +74 -74
  252. package/src/components/ECharts/index.vue +168 -168
  253. package/src/components/ECharts/mixins/resize.js +23 -23
  254. package/src/components/Empty/img/400.svg +101 -101
  255. package/src/components/Empty/img/401.svg +101 -101
  256. package/src/components/Empty/img/403.svg +101 -101
  257. package/src/components/Empty/img/405.svg +101 -101
  258. package/src/components/Empty/img/901.svg +95 -95
  259. package/src/components/Empty/img/902.svg +95 -95
  260. package/src/components/Empty/img/903.svg +95 -95
  261. package/src/components/Empty/img/904.svg +95 -95
  262. package/src/components/Empty/img/905.svg +95 -95
  263. package/src/components/Empty/img/906.svg +95 -95
  264. package/src/components/Empty/img/907.svg +95 -95
  265. package/src/components/Empty/img/abnormal.svg +108 -108
  266. package/src/components/Empty/img/dispose.svg +71 -71
  267. package/src/components/Empty/img/empty.svg +57 -57
  268. package/src/components/Empty/img/general.svg +58 -58
  269. package/src/components/Empty/img/lock.svg +57 -57
  270. package/src/components/Empty/img/network.svg +59 -59
  271. package/src/components/Empty/img/relevant.svg +68 -68
  272. package/src/components/Empty/img/search.svg +72 -72
  273. package/src/components/Empty/index.vue +147 -147
  274. package/src/components/Expandable/index.vue +49 -49
  275. package/src/components/Expandable/main.vue +64 -64
  276. package/src/components/FileExportAsync/index.vue +191 -178
  277. package/src/components/FileImport/_index.vue +201 -201
  278. package/src/components/FileImport/index.vue +9 -9
  279. package/src/components/FileUploadTable/index.vue +562 -690
  280. package/src/components/Filters/index.vue +372 -372
  281. package/src/components/Filters/indexO.vue +104 -104
  282. package/src/components/FlowStep/index.vue +68 -68
  283. package/src/components/FooterBox/index.vue +21 -21
  284. package/src/components/GeneralCard/index.vue +15 -15
  285. package/src/components/InputNumber/index.vue +169 -169
  286. package/src/components/InputNumber/numberRange.vue +47 -47
  287. package/src/components/InputSearch/index.vue +75 -75
  288. package/src/components/Layout/AsideNav/index.vue +120 -120
  289. package/src/components/Layout/AsideNav/menuItem.vue +34 -34
  290. package/src/components/Layout/AsideNav/submenuTitle.vue +26 -26
  291. package/src/components/Layout/HeaderWrap/changePwd.vue +215 -215
  292. package/src/components/Layout/HeaderWrap/index.vue +401 -401
  293. package/src/components/Layout/HeaderWrap/noticePop.vue +316 -316
  294. package/src/components/Layout/SubContent/index.vue +127 -127
  295. package/src/components/Layout/TabsNav/index.vue +170 -170
  296. package/src/components/Layout/index.vue +518 -518
  297. package/src/components/Layout/utils.js +12 -12
  298. package/src/components/LoginTemporary/form.vue +575 -576
  299. package/src/components/LoginTemporary/index.vue +139 -139
  300. package/src/components/LoginTemporary/qrcode.vue +90 -90
  301. package/src/components/LoginTemporary/retrievePw.vue +372 -372
  302. package/src/components/LoginTemporary/utils.js +73 -73
  303. package/src/components/MicroApp/index.js +67 -67
  304. package/src/components/MicroFrame/index.vue +95 -95
  305. package/src/components/MoreTab/index.vue +232 -232
  306. package/src/components/NavMenu/index.vue +60 -60
  307. package/src/components/PageHeader/index.vue +35 -35
  308. package/src/components/PageHeader/style.scss +39 -39
  309. package/src/components/PageLayout/page.vue +15 -15
  310. package/src/components/Pagination/index.vue +165 -165
  311. package/src/components/Search/index.vue +485 -485
  312. package/src/components/Search/style.scss +93 -93
  313. package/src/components/SecondaryTab/index.vue +58 -58
  314. package/src/components/SelectLazy/index.vue +75 -75
  315. package/src/components/SelectTree/SelectTreeLazy.vue +241 -241
  316. package/src/components/SelectTree/index.vue +206 -206
  317. package/src/components/ShowColumn/index.vue +213 -213
  318. package/src/components/Sifting/index.vue +99 -99
  319. package/src/components/Stamp/index.vue +75 -75
  320. package/src/components/Statis/index.vue +111 -111
  321. package/src/components/Statis/statisItem.vue +60 -60
  322. package/src/components/Statis/statisPopover.vue +63 -63
  323. package/src/components/Step/index.vue +38 -38
  324. package/src/components/Suspend/index.vue +72 -72
  325. package/src/components/Table/ThSelectHeader.vue +127 -127
  326. package/src/components/Table/index.vue +261 -261
  327. package/src/components/Table/indexO.vue +149 -149
  328. package/src/components/Task/index.vue +26 -26
  329. package/src/components/TertiaryTab/index.vue +63 -63
  330. package/src/components/TimePicker/index.vue +28 -28
  331. package/src/components/Upload/index.vue +268 -262
  332. package/src/components/WornPagination/index.vue +73 -73
  333. package/src/directives/VClickOutside/index.js +19 -19
  334. package/src/directives/VHas/index.js +58 -58
  335. package/src/directives/VMove/index.js +42 -42
  336. package/src/directives/VTitle/index.js +101 -88
  337. package/src/index.js +254 -254
  338. package/src/plugins/CompatibleOld/index.js +57 -57
  339. package/src/plugins/Print/index.js +4 -4
  340. package/src/plugins/Print/print-js/.babelrc +12 -12
  341. package/src/plugins/Print/print-js/LICENSE +21 -21
  342. package/src/plugins/Print/print-js/README.md +98 -98
  343. package/src/plugins/Print/print-js/dist/print.css +96 -96
  344. package/src/plugins/Print/print-js/dist/print.js +990 -990
  345. package/src/plugins/Print/print-js/package.json +60 -60
  346. package/src/plugins/Print/print-js/src/index.d.ts +45 -45
  347. package/src/plugins/Print/print-js/src/index.js +10 -10
  348. package/src/plugins/Print/print-js/src/js/browser.js +33 -33
  349. package/src/plugins/Print/print-js/src/js/functions.js +103 -103
  350. package/src/plugins/Print/print-js/src/js/html.js +70 -70
  351. package/src/plugins/Print/print-js/src/js/image.js +48 -48
  352. package/src/plugins/Print/print-js/src/js/init.js +168 -168
  353. package/src/plugins/Print/print-js/src/js/json.js +109 -109
  354. package/src/plugins/Print/print-js/src/js/modal.js +62 -62
  355. package/src/plugins/Print/print-js/src/js/pdf.js +62 -62
  356. package/src/plugins/Print/print-js/src/js/print.js +102 -102
  357. package/src/plugins/Print/print-js/src/js/raw-html.js +15 -15
  358. package/src/plugins/Print/print-js/src/sass/index.scss +13 -13
  359. package/src/plugins/Print/print-js/src/sass/modules/_colors.scss +9 -9
  360. package/src/plugins/Print/print-js/src/sass/partials/_modal.scss +40 -40
  361. package/src/plugins/Print/print-js/src/sass/partials/_spinner.scss +45 -45
  362. package/src/plugins/Print/print.js +2 -2
  363. package/src/plugins/Print/print.scss +1 -1
  364. package/src/plugins/SetMenuTree/index.vue +41 -41
  365. package/src/plugins/SetMenuTree/logoIcon.vue +37 -37
  366. package/src/plugins/SetMenuTree/setmenutree.vue +427 -427
  367. package/src/plugins/SetMenuTree/utils.js +74 -74
  368. package/src/plugins/Sign/InfosecNetSignCNGAgent.min.js +2000 -2000
  369. package/src/plugins/Sign/bjca/XTXSAB.js +2395 -2395
  370. package/src/plugins/Sign/bjca/index.js +124 -119
  371. package/src/plugins/Sign/index.js +28 -28
  372. package/src/plugins/Sign/sign.js +64 -64
  373. package/src/plugins/setTabsForSub.js +2 -2
  374. package/src/utils/auth.js +53 -53
  375. package/src/utils/axios.js +203 -203
  376. package/src/utils/downloadBlob.js +19 -19
  377. package/src/utils/forEachs.js +16 -16
  378. package/src/utils/getScrollContainer.js +43 -43
  379. package/src/utils/i18n/cn2hk.json +1270 -1270
  380. package/src/utils/i18n/index.js +50 -50
  381. package/src/utils/list2tree.js +36 -36
  382. package/src/utils/mapper_aims.js +809 -809
  383. package/src/utils/msgboxPor.js +26 -26
  384. package/src/utils/print.js +161 -161
  385. package/src/utils/relaNo.js +72 -72
  386. package/src/utils/repairElementUI.js +95 -95
  387. package/src/utils/theme.config.js +22 -22
  388. package/src/utils/theme.js +31 -31
  389. package/src/utils/urlToGo.js +82 -82
  390. package/src/components/.DS_Store +0 -0
  391. package/src/components/Empty/.DS_Store +0 -0
  392. package/src/components/Empty/img/.DS_Store +0 -0
  393. package/src/components/Layout/.DS_Store +0 -0
  394. package/src/plugins/.DS_Store +0 -0
  395. package/src/plugins/Sign/.DS_Store +0 -0
@@ -1,690 +1,562 @@
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
- <el-table-column label="附件类型" :prop="keys.type">
23
- <template slot="header" slot-scope="scope">
24
- <slot name="type-header" :column="scope.column">附件类型</slot>
25
- </template>
26
- <template slot-scope="{ row }">
27
- <slot name="type" :row="row">{{
28
- row[keys.type] | typeFiter(typeOptions)
29
- }}</slot>
30
- </template>
31
- </el-table-column>
32
- <el-table-column label="附件名称" :prop="keys.name">
33
- <template slot="header" slot-scope="scope">
34
- <slot name="name-header" :column="scope.column">附件名称</slot>
35
- </template>
36
- <template slot-scope="{ row }">
37
- <slot name="name" :row="row">{{ row[keys.name] }}</slot>
38
- </template>
39
- </el-table-column>
40
- <el-table-column
41
- label="上传时间"
42
- :prop="keys.time"
43
- width="170"
44
- align="left"
45
- >
46
- <template slot="header" slot-scope="scope">
47
- <slot name="time-header" :column="scope.column">上传时间</slot>
48
- </template>
49
- <template slot-scope="{ row }">
50
- <slot name="time" :row="row">{{ row[keys.time] }}</slot>
51
- </template>
52
- </el-table-column>
53
- <el-table-column label="上传人" :prop="keys.user">
54
- <template slot="header" slot-scope="scope">
55
- <slot name="user-header" :column="scope.column">上传人</slot>
56
- </template>
57
- <template slot-scope="{ row }">
58
- <slot name="user" :row="row">{{ row[keys.user] }}</slot>
59
- </template>
60
- </el-table-column>
61
- <el-table-column label="操作" align="center" width="80">
62
- <template slot="header" slot-scope="scope">
63
- <slot name="handle-header" :column="scope.column">操作</slot>
64
- </template>
65
- <template slot-scope="{ row }">
66
- <slot name="handle" :row="row">
67
- <el-button
68
- type="text"
69
- icon="el-icon-view"
70
- @click="seeFile(row)"
71
- />
72
- <el-button
73
- type="text"
74
- icon="el-icon-download"
75
- :disabled="!row[keys.url]"
76
- @click="downFile(row)"
77
- />
78
- </slot>
79
- </template>
80
- </el-table-column>
81
- </el-table>
82
- </template>
83
- <!-- 上传附件 -->
84
- <template v-else>
85
- <div class="p-t-s p-b-s">
86
- <div class="flex-box flex-v flex-lr">
87
- <div><slot name="title"></slot></div>
88
- <div>
89
- <slot name="add-btn">
90
- <el-button type="primary" size="mini" @click="addRow"
91
- >新增</el-button
92
- >
93
- </slot>
94
- <slot name="batch-btn">
95
- <el-button size="mini" plain @click="handleUploadDialog"
96
- >批量上传</el-button
97
- >
98
- </slot>
99
- <slot v-if="tableData.length" name="down-btn">
100
- <el-button size="mini" plain @click="downRows">下载</el-button>
101
- </slot>
102
- <slot v-if="tableData.length" name="delete-btn">
103
- <el-button type="danger" plain size="mini" @click="deleteRows"
104
- >删除</el-button
105
- >
106
- </slot>
107
- </div>
108
- </div>
109
- </div>
110
-
111
- <el-table
112
- :data="tableData"
113
- :row-key="keys.rowKey"
114
- @selection-change="(selection) => (selectionList = selection)"
115
- >
116
- <slot name="selection-column"
117
- ><el-table-column type="selection" width="50" align="center" />
118
- </slot>
119
- <el-table-column label="附件类型" min-width="160">
120
- <template slot="header" slot-scope="scope">
121
- <slot name="type-header" :column="scope.column">附件类型</slot>
122
- </template>
123
- <template slot-scope="{ row }">
124
- <slot name="type" :row="row">
125
- <el-select
126
- v-model="row[keys.type]"
127
- :disabled="row['_typeDisabled']"
128
- placeholder="请选择"
129
- style="width: 100%"
130
- >
131
- <el-option
132
- v-for="item in typeOptions"
133
- :key="item.type"
134
- :disabled="item.disabled"
135
- :value="item.type"
136
- :label="item.label"
137
- />
138
- </el-select>
139
- </slot>
140
- </template>
141
- </el-table-column>
142
- <el-table-column label="附件名称" min-width="160">
143
- <template slot="header" slot-scope="scope">
144
- <slot name="name-header" :column="scope.column">附件名称</slot>
145
- </template>
146
- <template slot-scope="{ row }">
147
- <slot name="name" :row="row">
148
- <el-input v-model="row[keys.name]" placeholder="请输入" />
149
- </slot>
150
- </template>
151
- </el-table-column>
152
- <el-table-column label="附件上传" min-width="160">
153
- <template slot="header" slot-scope="scope">
154
- <slot name="upload-header" :column="scope.column">附件上传</slot>
155
- </template>
156
- <template slot-scope="{ row, $index }">
157
- <slot name="upload" :row="row" :$index="$index">
158
- <clUpload
159
- :ref="'upload' + $index"
160
- class="n20-upload-table-up"
161
- :file-name="row['_name'] || row[keys.name]"
162
- :data="row['_fileData']"
163
- :msg-type="null"
164
- :show-clear="false"
165
- :action="action"
166
- :headers="headers"
167
- :disabled="!row[keys.type]"
168
- :accept="row[keys.type] | acceptFilter(typeOptions, fileAccept)"
169
- :size="row[keys.type] | sizeFilter(typeOptions, fileSize)"
170
- :before-upload="(file) => beforeUploadFn(file, row)"
171
- :on-progress="(event) => onProgressFn(event, row)"
172
- :on-success="
173
- (response, file, fileList) =>
174
- onSuccessFn(response, file, fileList, row)
175
- "
176
- :on-error="
177
- (err, file, fileList) =>
178
- errorFn(err, file, fileList, row, $index)
179
- "
180
- />
181
- </slot>
182
- </template>
183
- </el-table-column>
184
- <el-table-column
185
- label="上传时间"
186
- :prop="keys.time"
187
- width="170"
188
- align="left"
189
- >
190
- <template slot="header" slot-scope="scope">
191
- <slot name="time-header" :column="scope.column">上传时间</slot>
192
- </template>
193
- <template slot-scope="{ row }">
194
- <slot name="time" :row="row">{{ row[keys.time] }}</slot>
195
- </template>
196
- </el-table-column>
197
- <el-table-column label="上传人" :prop="keys.user" width="100">
198
- <template slot="header" slot-scope="scope">
199
- <slot name="user-header" :column="scope.column">上传人</slot>
200
- </template>
201
- <template slot-scope="{ row }">
202
- <slot name="user" :row="row">{{ row[keys.user] }}</slot>
203
- </template>
204
- </el-table-column>
205
- <el-table-column label="上传进度" width="220">
206
- <template slot="header" slot-scope="scope">
207
- <slot name="percent-header" :column="scope.column">上传进度</slot>
208
- </template>
209
- <template slot-scope="{ row, $index }">
210
- <slot name="percent" :row="row" :$index="$index">
211
- <div v-if="row['_percent'] >= 0" class="flex-box flex-v">
212
- <el-progress
213
- class="n20-upload-table-progress"
214
- :percentage="row['_percent']"
215
- :status="row['_status']"
216
- style="width: 140px"
217
- />
218
- <el-button
219
- v-if="row['_status'] === 'exception'"
220
- type="text"
221
- size="mini"
222
- style="width: 60px"
223
- @click="anewSubmitFn(row, $index)"
224
- >重新上传</el-button
225
- >
226
- <el-button
227
- v-else-if="row['_percent'] >= 0 && row['_percent'] < 100"
228
- type="text"
229
- size="mini"
230
- style="width: 60px"
231
- @click="abortFn(row, $index)"
232
- >取消</el-button
233
- >
234
- </div>
235
- </slot>
236
- </template>
237
- </el-table-column>
238
- <el-table-column label="操作" align="center" width="80">
239
- <template slot="header" slot-scope="scope">
240
- <slot name="handle-header" :column="scope.column">操作</slot>
241
- </template>
242
- <template slot-scope="{ row }">
243
- <slot name="handle" :row="row">
244
- <el-button
245
- type="text"
246
- icon="el-icon-view"
247
- :disabled="!row[keys.url]"
248
- @click="seeFile(row)"
249
- />
250
- </slot>
251
- </template>
252
- </el-table-column>
253
- </el-table>
254
- </template>
255
-
256
- <el-dialog
257
- v-drag
258
- class="p-a-0"
259
- title="附件预览"
260
- :visible.sync="visibleP"
261
- top="2vh"
262
- width="96%"
263
- append-to-body
264
- @close="closeSee"
265
- >
266
- <div
267
- v-if="imgType.test(previewName)"
268
- class="p-a flex-box flex-c flex-v"
269
- style="height: 82vh"
270
- >
271
- <img
272
- :src="previewUrl"
273
- :alt="previewName"
274
- style="max-width: 98%; max-height: 98%"
275
- />
276
- </div>
277
- <div v-else class="p-a" style="height: 82vh">
278
- <component
279
- :is="previewSameOrg ? 'object' : 'div'"
280
- :key="previewUrl"
281
- :data="previewUrl"
282
- style="width: 100%; height: 100%"
283
- >
284
- <div class="flex-column flex-c flex-v" style="height: 100%">
285
- <i
286
- class="el-icon-s-release"
287
- style="font-size: 60px; color: #999"
288
- ></i>
289
- <span style="margin-top: 16px">
290
- 不支持在线预览,请
291
- <a :href="previewUrl" :download="previewName || previewUrl"
292
- >下载</a
293
- >
294
- 到本地查看
295
- </span>
296
- </div>
297
- </component>
298
- </div>
299
- </el-dialog>
300
- <Dialog
301
- title="附件批量上传"
302
- :visible.sync="visibleBatch"
303
- top="5vh"
304
- width="60%"
305
- >
306
- <cl-upload
307
- class="n20-upload-drag"
308
- :drag="true"
309
- action="no"
310
- :auto-upload="false"
311
- :multiple="true"
312
- :limit="10"
313
- :on-remove="onRemove"
314
- :on-change="onChange"
315
- :on-success="onSuccess"
316
- :http-request="customUpload"
317
- accept=".rar,.zip,.doc,.docx,.pdf,image/*"
318
- >
319
- <template slot="trigger">
320
- <i class="drag-icon n20-icon-shangchuan"></i>
321
- <span class="drag-text">点击或将文件拖拽到这里上传</span>
322
- <span class="drag-tip">
323
- <slot>支持扩展名:.rar .zip .doc .docx .pdf .jpg...</slot>
324
- </span>
325
- </template>
326
- </cl-upload>
327
- <div class="dialog-footer">
328
- <el-button type="primary" @click="customUpload">确认</el-button>
329
- <el-button plain @click="visibleBatch = false">取消</el-button>
330
- </div>
331
- </Dialog>
332
- </div>
333
- </template>
334
-
335
- <script>
336
- import dayjs from 'dayjs'
337
- import axios from '../../utils/axios'
338
- import clUpload from '../Upload/index.vue'
339
- import Dialog from '../Dialog/index.vue'
340
- export default {
341
- name: 'FileUploadTable',
342
- components: {
343
- clUpload,
344
- Dialog
345
- },
346
- filters: {
347
- typeFiter(type, typeOptions) {
348
- return typeOptions.find((c) => c.type === type)?.label || ''
349
- },
350
- acceptFilter(type, typeOptions, fileAccept) {
351
- return typeOptions.find((c) => c.type === type)?.accept || fileAccept
352
- },
353
- sizeFilter(type, typeOptions, fileSize) {
354
- return typeOptions.find((c) => c.type === type)?.size || fileSize
355
- }
356
- },
357
- props: {
358
- readonly: {
359
- type: Boolean,
360
- default: false
361
- },
362
- action: {
363
- type: String,
364
- default: '/bems/1.0/attach'
365
- },
366
- headers: {
367
- type: Object,
368
- default: undefined
369
- },
370
- actionBatch: {
371
- type: String,
372
- default: '/api/neams/eamsbaserecord/save'
373
- },
374
- seePrefix: {
375
- type: String,
376
- default: undefined
377
- },
378
- seeTypes: {
379
- type: RegExp,
380
- default: () => /\.jpg|\.png|\.gif|\.svg|\.pdf$/i
381
- },
382
- uploadParams: {
383
- type: Object,
384
- default: () => ({})
385
- },
386
- tableData: {
387
- type: Array,
388
- default: () => []
389
- },
390
- dataPorp: {
391
- type: Object,
392
- default: () => ({})
393
- }
394
- },
395
- data() {
396
- return {
397
- imgType: /\.jpg|\.png|\.gif|\.svg$/i,
398
- selectionList: [],
399
- fileAccept: this.dataPorp.fileAccept || undefined,
400
- fileSize: this.dataPorp.fileSize || undefined,
401
- typeOptions: this.dataPorp.typeOptions || [
402
- {
403
- type: '001',
404
- label: '信贷合同'
405
- },
406
- {
407
- type: '002',
408
- label: '贴现合同'
409
- },
410
- {
411
- type: '003',
412
- label: '其他合同'
413
- }
414
- ],
415
- batchData: {},
416
- keys: this.dataPorp.keys || {
417
- rowKey: 'id',
418
- type: 'type',
419
- name: 'name',
420
- url: 'url',
421
- time: 'time',
422
- user: 'user'
423
- },
424
- currFileList: [],
425
- visibleP: false,
426
- visibleBatch: false,
427
- previewUrl: undefined,
428
- previewName: undefined,
429
- previewSameOrg: false
430
- }
431
- },
432
- methods: {
433
- addRow() {
434
- this.$emit('add-row')
435
- },
436
- handleUploadDialog() {
437
- this.visibleBatch = true
438
- },
439
- async customUpload() {
440
- let { code, data } = await axios({
441
- headers: {
442
- 'Content-Type': 'multipart/form-data'
443
- },
444
- url: `/api/neams/eamsbaserecord/save`,
445
- method: 'POST',
446
- data: this.batchData
447
- })
448
-
449
- if (code === 200) {
450
- if (data.length > 0) {
451
- let flieList = data.map((item) => {
452
- var keys = Object.keys(item)[0]
453
- let row = JSON.parse(item[keys])
454
- var d = new Date(row.uploadtime)
455
- return {
456
- name: row.recordname,
457
- time: this.TimeDate(d),
458
- user: row.creator,
459
- archiveId: row.beid,
460
- type: row.attno
461
- }
462
- })
463
-
464
- this.tableData = this.tableData.concat(flieList)
465
- this.visibleBatch = false
466
- this.currFileList = []
467
- }
468
- }
469
- },
470
- onRemove(file, filelist) {
471
- this.currFileList = filelist
472
- let params = this.uploadParams
473
- let data = new FormData()
474
- let dataArray = []
475
- console.log(this.currFileList, 999)
476
- this.currFileList.forEach((item) => {
477
- data.append('file', item.raw)
478
- let attno = null
479
- dataArray.push({
480
- ...params,
481
- recordname: item.name,
482
- fileSize: item.size,
483
- memo: item.name,
484
- attno
485
- })
486
- })
487
- data.append('data', JSON.stringify(dataArray))
488
- //档案生效时间-截止时间
489
- data.append('date', `${this.getFormatDate()},2099-12-31 23:59:59`)
490
- this.batchData = data
491
- },
492
- onChange(file, filelist) {
493
- this.currFileList = filelist
494
- let params = this.uploadParams
495
- let data = new FormData()
496
- let dataArray = []
497
- console.log(this.currFileList, 999)
498
- this.currFileList.forEach((item) => {
499
- data.append('file', item.raw)
500
- let attno = null
501
- dataArray.push({
502
- ...params,
503
- recordname: item.name,
504
- fileSize: item.size,
505
- memo: item.name,
506
- attno
507
- })
508
- })
509
- data.append('data', JSON.stringify(dataArray))
510
- //档案生效时间-截止时间
511
- data.append('date', `${this.getFormatDate()},2099-12-31 23:59:59`)
512
- this.batchData = data
513
- },
514
- downRows() {
515
- this.$emit('down-rows', this.selectionList)
516
- },
517
- deleteRows() {
518
- this.$emit('delete-rows', this.selectionList)
519
- },
520
-
521
- async getFileInfo(row) {
522
- let _url = row[this.keys.url]
523
- this.seePrefix && (_url = this.seePrefix + _url)
524
- if (_url) {
525
- let blob = await axios.get(_url, {}, { responseType: 'blob' })
526
- let url = URL.createObjectURL(blob)
527
- let name = blob.name
528
- let sameOrg = this.seeTypes.test(name) || this.seeTypes.test(_url)
529
- return {
530
- url,
531
- name,
532
- sameOrg
533
- }
534
- } else {
535
- return {}
536
- }
537
- },
538
- getFormatDate() {
539
- let date = new Date()
540
- let month = date.getMonth() + 1
541
- let strDate = date.getDate()
542
- let getHours = date.getHours()
543
- let getMinutes = date.getMinutes()
544
- let getSeconds = date.getSeconds()
545
- if (month >= 1 && month <= 9) {
546
- month = '0' + month
547
- }
548
- if (strDate >= 0 && strDate <= 9) {
549
- strDate = '0' + strDate
550
- }
551
- if (getHours >= 0 && getHours <= 9) {
552
- getHours = '0' + getHours
553
- }
554
- if (getMinutes >= 0 && getMinutes <= 9) {
555
- getMinutes = '0' + getMinutes
556
- }
557
- if (getSeconds >= 0 && getSeconds <= 9) {
558
- getSeconds = '0' + getSeconds
559
- }
560
- return (
561
- date.getFullYear() +
562
- '-' +
563
- month +
564
- '-' +
565
- strDate +
566
- ' ' +
567
- getHours +
568
- ':' +
569
- getMinutes +
570
- ':' +
571
- getSeconds
572
- )
573
- },
574
- TimeDate(now) {
575
- var year = now.getFullYear()
576
- var month = now.getMonth() + 1
577
- var date = now.getDate()
578
- var hour = now.getHours()
579
- var minute = now.getMinutes()
580
- var second = now.getSeconds()
581
- if (month < 10) {
582
- month = '0' + month
583
- }
584
- if (date < 10) {
585
- date = '0' + date
586
- }
587
- if (hour < 10) {
588
- hour = '0' + hour
589
- }
590
- if (minute < 10) {
591
- minute = '0' + minute
592
- }
593
- if (second < 10) {
594
- second = '0' + second
595
- }
596
- return (
597
- year +
598
- '-' +
599
- month +
600
- '-' +
601
- date +
602
- ' ' +
603
- hour +
604
- ':' +
605
- minute +
606
- ':' +
607
- second
608
- )
609
- },
610
- async downFile(row) {
611
- let { url, name } = await this.getFileInfo(row)
612
- if (url) {
613
- let aDom = document.createElement('a')
614
- aDom.href = url
615
- aDom.download = name
616
- aDom.click()
617
-
618
- this.$nextTick(() => {
619
- aDom = undefined
620
- url && URL.revokeObjectURL(url)
621
- })
622
- }
623
- },
624
- async seeFile(row) {
625
- let { url, name, sameOrg } = await this.getFileInfo(row)
626
- if (url) {
627
- this.previewSameOrg = sameOrg
628
- this.previewUrl = url
629
- this.previewName = name
630
- this.visibleP = true
631
- }
632
- },
633
- closeSee() {
634
- this.previewUrl && URL.revokeObjectURL(this.previewUrl)
635
- },
636
- beforeUploadFn(file, row) {
637
- this.$set(row, '_percent', 0)
638
- this.$set(row, '_status', undefined)
639
-
640
- this.$emit('before-upload', file, row)
641
- },
642
- onProgressFn({ percent }, row) {
643
- this.$set(row, '_percent', percent <= 99 ? Math.round(percent) : 99)
644
- },
645
- onSuccessFn(response, file, fileList, row) {
646
- this.$set(row, '_name', file.name)
647
- this.$set(row, '_percent', 100)
648
-
649
- row[this.keys.time] = dayjs().format('YYYY-MM-DD HH:mm:ss')
650
-
651
- row[this.keys.url] = response.data
652
- if (!row[this.keys.name]) {
653
- row[this.keys.name] = file.name
654
- }
655
- this.$set(row, '_status', 'success')
656
-
657
- this.$emit('on-success', file, row)
658
- },
659
- errorFn(err, file, fileList, row, $index) {
660
- this.$set(row, '_status', 'exception')
661
-
662
- let clUpload = this.$refs['upload' + $index]
663
- /* 重置文件状态,并加入文件队列 */
664
- file.status = 'ready'
665
- clUpload.fileList = [file]
666
-
667
- this.$emit('on-error', file, row)
668
- },
669
- abortFn(row, $index) {
670
- this.$set(row, '_status', 'exception')
671
-
672
- let clUpload = this.$refs['upload' + $index]
673
- let elUpload = clUpload.$refs['upload']
674
- let uploadFiles = elUpload.uploadFiles
675
-
676
- /* 重置文件状态,并加入文件队列 */
677
- let file = uploadFiles[uploadFiles.length - 1]
678
- file.status = 'ready'
679
- clUpload.fileList = [file]
680
-
681
- elUpload.abort()
682
- },
683
- anewSubmitFn(row, $index) {
684
- this.$set(row, '_status', 'success')
685
-
686
- this.$refs['upload' + $index]?.$refs['upload']?.submit()
687
- }
688
- }
689
- }
690
- </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
+ <el-table-column label="附件类型" :prop="keys.type">
23
+ <template slot="header" slot-scope="scope">
24
+ <slot name="type-header" :column="scope.column">附件类型</slot>
25
+ </template>
26
+ <template slot-scope="{ row }">
27
+ <slot name="type" :row="row">{{
28
+ row[keys.type] | typeFiter(typeOptions)
29
+ }}</slot>
30
+ </template>
31
+ </el-table-column>
32
+ <el-table-column label="附件名称" :prop="keys.name">
33
+ <template slot="header" slot-scope="scope">
34
+ <slot name="name-header" :column="scope.column">附件名称</slot>
35
+ </template>
36
+ <template slot-scope="{ row }">
37
+ <slot name="name" :row="row">{{ row[keys.name] }}</slot>
38
+ </template>
39
+ </el-table-column>
40
+ <el-table-column
41
+ label="上传时间"
42
+ :prop="keys.time"
43
+ width="170"
44
+ align="left"
45
+ >
46
+ <template slot="header" slot-scope="scope">
47
+ <slot name="time-header" :column="scope.column">上传时间</slot>
48
+ </template>
49
+ <template slot-scope="{ row }">
50
+ <slot name="time" :row="row">{{ row[keys.time] }}</slot>
51
+ </template>
52
+ </el-table-column>
53
+ <el-table-column label="上传人" :prop="keys.user">
54
+ <template slot="header" slot-scope="scope">
55
+ <slot name="user-header" :column="scope.column">上传人</slot>
56
+ </template>
57
+ <template slot-scope="{ row }">
58
+ <slot name="user" :row="row">{{ row[keys.user] }}</slot>
59
+ </template>
60
+ </el-table-column>
61
+ <el-table-column label="操作" align="center" width="80" fixed="right">
62
+ <template slot="header" slot-scope="scope">
63
+ <slot name="handle-header" :column="scope.column">操作</slot>
64
+ </template>
65
+ <template slot-scope="{ row }">
66
+ <slot name="handle" :row="row">
67
+ <el-button
68
+ type="text"
69
+ icon="el-icon-view"
70
+ @click="seeFile(row)"
71
+ />
72
+ <el-button
73
+ type="text"
74
+ icon="el-icon-download"
75
+ :disabled="!row[keys.url]"
76
+ @click="downFile(row)"
77
+ />
78
+ </slot>
79
+ </template>
80
+ </el-table-column>
81
+ </el-table>
82
+ </template>
83
+ <!-- 上传附件 -->
84
+ <template v-else>
85
+ <div class="p-t-s p-b-s">
86
+ <div class="flex-box flex-v flex-lr">
87
+ <div><slot name="title"></slot></div>
88
+ <div>
89
+ <slot name="add-btn">
90
+ <el-button type="primary" size="mini" @click="addRow"
91
+ >新增</el-button
92
+ >
93
+ </slot>
94
+ <slot v-if="showBatchUpload" name="batch-btn">
95
+ <el-button size="mini" plain @click="visibleBatch = true"
96
+ >批量上传</el-button
97
+ >
98
+ </slot>
99
+ <slot v-if="tableData.length" name="down-btn">
100
+ <el-button size="mini" plain @click="downRows">下载</el-button>
101
+ </slot>
102
+ <slot v-if="tableData.length" name="delete-btn">
103
+ <el-button type="danger" plain size="mini" @click="deleteRows"
104
+ >删除</el-button
105
+ >
106
+ </slot>
107
+ </div>
108
+ </div>
109
+ </div>
110
+
111
+ <el-table
112
+ :data="tableData"
113
+ :row-key="keys.rowKey"
114
+ @selection-change="(selection) => (selectionList = selection)"
115
+ >
116
+ <slot name="selection-column"
117
+ ><el-table-column type="selection" width="50" align="center" />
118
+ </slot>
119
+ <el-table-column label="附件类型" min-width="160">
120
+ <template slot="header" slot-scope="scope">
121
+ <slot name="type-header" :column="scope.column">附件类型</slot>
122
+ </template>
123
+ <template slot-scope="{ row }">
124
+ <slot name="type" :row="row">
125
+ <el-select
126
+ v-model="row[keys.type]"
127
+ :disabled="row['_typeDisabled']"
128
+ placeholder="请选择"
129
+ style="width: 100%"
130
+ >
131
+ <el-option
132
+ v-for="item in typeOptions"
133
+ :key="item.type"
134
+ :disabled="item.disabled"
135
+ :value="item.type"
136
+ :label="item.label"
137
+ />
138
+ </el-select>
139
+ </slot>
140
+ </template>
141
+ </el-table-column>
142
+ <el-table-column label="附件名称" min-width="160">
143
+ <template slot="header" slot-scope="scope">
144
+ <slot name="name-header" :column="scope.column">附件名称</slot>
145
+ </template>
146
+ <template slot-scope="{ row }">
147
+ <slot name="name" :row="row">
148
+ <el-input v-model="row[keys.name]" placeholder="请输入" />
149
+ </slot>
150
+ </template>
151
+ </el-table-column>
152
+ <el-table-column label="附件上传" min-width="160">
153
+ <template slot="header" slot-scope="scope">
154
+ <slot name="upload-header" :column="scope.column">附件上传</slot>
155
+ </template>
156
+ <template slot-scope="{ row, $index }">
157
+ <slot name="upload" :row="row" :$index="$index">
158
+ <clUpload
159
+ :ref="'upload' + $index"
160
+ class="n20-upload-table-up"
161
+ :file-name="row['_name'] || row[keys.name]"
162
+ :data="row['_fileData']"
163
+ :msg-type="null"
164
+ :show-clear="false"
165
+ :action="action"
166
+ :headers="headers"
167
+ :disabled="!row[keys.type]"
168
+ :accept="row[keys.type] | acceptFilter(typeOptions, fileAccept)"
169
+ :size="row[keys.type] | sizeFilter(typeOptions, fileSize)"
170
+ :http-request="
171
+ uploadHttpRequest
172
+ ? (options) => uploadHttpRequest(options, row)
173
+ : undefined
174
+ "
175
+ :before-upload="(file) => beforeUploadFn(file, row)"
176
+ :on-progress="(event) => onProgressFn(event, row)"
177
+ :on-success="
178
+ (response, file, fileList) =>
179
+ onSuccessFn(response, file, fileList, row)
180
+ "
181
+ :on-error="
182
+ (err, file, fileList) =>
183
+ errorFn(err, file, fileList, row, $index)
184
+ "
185
+ />
186
+ </slot>
187
+ </template>
188
+ </el-table-column>
189
+ <el-table-column
190
+ label="上传时间"
191
+ :prop="keys.time"
192
+ width="170"
193
+ align="left"
194
+ >
195
+ <template slot="header" slot-scope="scope">
196
+ <slot name="time-header" :column="scope.column">上传时间</slot>
197
+ </template>
198
+ <template slot-scope="{ row }">
199
+ <slot name="time" :row="row">{{ row[keys.time] }}</slot>
200
+ </template>
201
+ </el-table-column>
202
+ <el-table-column label="上传人" :prop="keys.user" width="100">
203
+ <template slot="header" slot-scope="scope">
204
+ <slot name="user-header" :column="scope.column">上传人</slot>
205
+ </template>
206
+ <template slot-scope="{ row }">
207
+ <slot name="user" :row="row">{{ row[keys.user] }}</slot>
208
+ </template>
209
+ </el-table-column>
210
+ <el-table-column label="上传进度" width="220">
211
+ <template slot="header" slot-scope="scope">
212
+ <slot name="percent-header" :column="scope.column">上传进度</slot>
213
+ </template>
214
+ <template slot-scope="{ row, $index }">
215
+ <slot name="percent" :row="row" :$index="$index">
216
+ <div v-if="row['_percent'] >= 0" class="flex-box flex-v">
217
+ <el-progress
218
+ class="n20-upload-table-progress"
219
+ :percentage="row['_percent']"
220
+ :status="row['_status']"
221
+ style="width: 140px"
222
+ />
223
+ <el-button
224
+ v-if="row['_status'] === 'exception'"
225
+ type="text"
226
+ size="mini"
227
+ style="width: 60px"
228
+ @click="anewSubmitFn(row, $index)"
229
+ >重新上传</el-button
230
+ >
231
+ <el-button
232
+ v-else-if="row['_percent'] >= 0 && row['_percent'] < 100"
233
+ type="text"
234
+ size="mini"
235
+ style="width: 60px"
236
+ @click="abortFn(row, $index)"
237
+ >取消</el-button
238
+ >
239
+ </div>
240
+ </slot>
241
+ </template>
242
+ </el-table-column>
243
+ <el-table-column label="操作" align="center" width="80" fixed="right">
244
+ <template slot="header" slot-scope="scope">
245
+ <slot name="handle-header" :column="scope.column">操作</slot>
246
+ </template>
247
+ <template slot-scope="{ row }">
248
+ <slot name="handle" :row="row">
249
+ <el-button
250
+ type="text"
251
+ icon="el-icon-view"
252
+ :disabled="!row[keys.url]"
253
+ @click="seeFile(row)"
254
+ />
255
+ </slot>
256
+ </template>
257
+ </el-table-column>
258
+ </el-table>
259
+ </template>
260
+
261
+ <el-dialog
262
+ v-drag
263
+ class="p-a-0"
264
+ title="附件预览"
265
+ :visible.sync="visibleP"
266
+ top="2vh"
267
+ width="96%"
268
+ append-to-body
269
+ @close="closeSee"
270
+ >
271
+ <div
272
+ v-if="imgType.test(previewName)"
273
+ class="p-a flex-box flex-c flex-v"
274
+ style="height: 82vh"
275
+ >
276
+ <img
277
+ :src="previewUrl"
278
+ :alt="previewName"
279
+ style="max-width: 98%; max-height: 98%"
280
+ />
281
+ </div>
282
+ <div v-else class="p-a" style="height: 82vh">
283
+ <component
284
+ :is="previewSameOrg ? 'object' : 'div'"
285
+ :key="previewUrl"
286
+ :data="previewUrl"
287
+ style="width: 100%; height: 100%"
288
+ >
289
+ <div class="flex-column flex-c flex-v" style="height: 100%">
290
+ <i
291
+ class="el-icon-s-release"
292
+ style="font-size: 60px; color: #999"
293
+ ></i>
294
+ <span style="margin-top: 16px">
295
+ 不支持在线预览,请
296
+ <a :href="previewUrl" :download="previewName || previewUrl"
297
+ >下载</a
298
+ >
299
+ 到本地查看
300
+ </span>
301
+ </div>
302
+ </component>
303
+ </div>
304
+ </el-dialog>
305
+ <Dialog
306
+ title="附件批量上传"
307
+ :visible.sync="visibleBatch"
308
+ top="5vh"
309
+ width="692px"
310
+ >
311
+ <clUpload
312
+ ref="upload-batch"
313
+ class="n20-upload-drag"
314
+ :msg-type="null"
315
+ :show-clear="false"
316
+ :drag="true"
317
+ :auto-upload="false"
318
+ :multiple="true"
319
+ :action="action"
320
+ :headers="headers"
321
+ :accept="fileAccept"
322
+ :http-request="uploadHttpRequest"
323
+ :on-remove="(file) => $emit('on-remove', file)"
324
+ :on-success="batchSuccess"
325
+ >
326
+ <template slot="trigger">
327
+ <i class="drag-icon n20-icon-shangchuan"></i>
328
+ <span class="drag-text">点击或将文件拖拽到这里上传</span>
329
+ <span class="drag-tip">
330
+ <slot>支持扩展名:.rar .zip .doc .docx .pdf .jpg...</slot>
331
+ </span>
332
+ </template>
333
+ </clUpload>
334
+ <div class="dialog-footer">
335
+ <el-button type="primary" @click="batchUploadFn">确认</el-button>
336
+ <el-button plain @click="visibleBatch = false">取消</el-button>
337
+ </div>
338
+ </Dialog>
339
+ </div>
340
+ </template>
341
+
342
+ <script>
343
+ import dayjs from 'dayjs'
344
+ import axios from '../../utils/axios'
345
+ import clUpload from '../Upload/index.vue'
346
+ import Dialog from '../Dialog/index.vue'
347
+ export default {
348
+ name: 'FileUploadTable',
349
+ components: {
350
+ clUpload,
351
+ Dialog
352
+ },
353
+ filters: {
354
+ typeFiter(type, typeOptions) {
355
+ return typeOptions.find((c) => c.type === type)?.label || ''
356
+ },
357
+ acceptFilter(type, typeOptions, fileAccept) {
358
+ return typeOptions.find((c) => c.type === type)?.accept || fileAccept
359
+ },
360
+ sizeFilter(type, typeOptions, fileSize) {
361
+ return typeOptions.find((c) => c.type === type)?.size || fileSize
362
+ }
363
+ },
364
+ props: {
365
+ readonly: {
366
+ type: Boolean,
367
+ default: false
368
+ },
369
+ action: {
370
+ type: String,
371
+ default: '/bems/1.0/attach'
372
+ },
373
+ headers: {
374
+ type: Object,
375
+ default: undefined
376
+ },
377
+ seePrefix: {
378
+ type: String,
379
+ default: undefined
380
+ },
381
+ seeTypes: {
382
+ type: RegExp,
383
+ default: () => /\.jpg|\.png|\.gif|\.svg|\.pdf$/i
384
+ },
385
+ tableData: {
386
+ type: Array,
387
+ default: () => []
388
+ },
389
+ dataPorp: {
390
+ type: Object,
391
+ default: () => ({})
392
+ },
393
+ showBatchUpload: {
394
+ type: Boolean,
395
+ default: false
396
+ },
397
+ uploadHttpRequest: {
398
+ type: Function,
399
+ default: undefined
400
+ }
401
+ },
402
+ data() {
403
+ return {
404
+ imgType: /\.jpg|\.png|\.gif|\.svg$/i,
405
+ selectionList: [],
406
+ fileAccept: this.dataPorp.fileAccept || undefined,
407
+ fileSize: this.dataPorp.fileSize || undefined,
408
+ typeOptions: this.dataPorp.typeOptions || [
409
+ {
410
+ type: '001',
411
+ label: '信贷合同'
412
+ },
413
+ {
414
+ type: '002',
415
+ label: '贴现合同'
416
+ },
417
+ {
418
+ type: '003',
419
+ label: '其他合同'
420
+ }
421
+ ],
422
+ keys: this.dataPorp.keys || {
423
+ rowKey: 'id',
424
+ type: 'type',
425
+ name: 'name',
426
+ url: 'url',
427
+ time: 'time',
428
+ user: 'user'
429
+ },
430
+ currFileList: [],
431
+ visibleP: false,
432
+ visibleBatch: false,
433
+ previewUrl: undefined,
434
+ previewName: undefined,
435
+ previewSameOrg: false
436
+ }
437
+ },
438
+ methods: {
439
+ batchUploadFn() {
440
+ let $uploadwrap = this.$refs['upload-batch']
441
+ let $upload = $uploadwrap.$refs['upload']
442
+ $upload.submit()
443
+ },
444
+ batchSuccess(response, file, fileList) {
445
+ let row = {}
446
+ this.tableData.splice(0, 0, row)
447
+ this.$nextTick(() => {
448
+ this.onSuccessFn(response, file, fileList, row)
449
+ })
450
+
451
+ if (fileList.every((f) => f.status === 'success')) {
452
+ this.visibleBatch = false
453
+ }
454
+ },
455
+ addRow() {
456
+ this.$emit('add-row')
457
+ },
458
+ downRows() {
459
+ this.$emit('down-rows', this.selectionList)
460
+ },
461
+ deleteRows() {
462
+ this.$emit('delete-rows', this.selectionList)
463
+ },
464
+
465
+ async getFileInfo(row) {
466
+ let _url = row[this.keys.url]
467
+ this.seePrefix && (_url = this.seePrefix + _url)
468
+ if (_url) {
469
+ let blob = await axios.get(_url, {}, { responseType: 'blob' })
470
+ let url = URL.createObjectURL(blob)
471
+ let name = blob.name
472
+ let sameOrg = this.seeTypes.test(name) || this.seeTypes.test(_url)
473
+ return {
474
+ url,
475
+ name,
476
+ sameOrg
477
+ }
478
+ } else {
479
+ return {}
480
+ }
481
+ },
482
+ async downFile(row) {
483
+ let { url, name } = await this.getFileInfo(row)
484
+ if (url) {
485
+ let aDom = document.createElement('a')
486
+ aDom.href = url
487
+ aDom.download = name
488
+ aDom.click()
489
+
490
+ this.$nextTick(() => {
491
+ aDom = undefined
492
+ url && URL.revokeObjectURL(url)
493
+ })
494
+ }
495
+ },
496
+ async seeFile(row) {
497
+ let { url, name, sameOrg } = await this.getFileInfo(row)
498
+ if (url) {
499
+ this.previewSameOrg = sameOrg
500
+ this.previewUrl = url
501
+ this.previewName = name
502
+ this.visibleP = true
503
+ }
504
+ },
505
+ closeSee() {
506
+ this.previewUrl && URL.revokeObjectURL(this.previewUrl)
507
+ },
508
+ beforeUploadFn(file, row) {
509
+ this.$set(row, '_percent', 0)
510
+ this.$set(row, '_status', undefined)
511
+
512
+ this.$emit('before-upload', file, row)
513
+ },
514
+ onProgressFn({ percent }, row) {
515
+ this.$set(row, '_percent', percent <= 99 ? Math.round(percent) : 99)
516
+ },
517
+ onSuccessFn(response, file, fileList, row) {
518
+ this.$set(row, '_name', file.name)
519
+ this.$set(row, '_percent', 100)
520
+
521
+ row[this.keys.time] = dayjs().format('YYYY-MM-DD HH:mm:ss')
522
+
523
+ row[this.keys.url] = response.data
524
+ if (!row[this.keys.name]) {
525
+ row[this.keys.name] = file.name
526
+ }
527
+ this.$set(row, '_status', 'success')
528
+
529
+ this.$emit('on-success', file, row)
530
+ },
531
+ errorFn(err, file, fileList, row, $index) {
532
+ this.$set(row, '_status', 'exception')
533
+
534
+ let clUpload = this.$refs['upload' + $index]
535
+ /* 重置文件状态,并加入文件队列 */
536
+ file.status = 'ready'
537
+ clUpload.fileList = [file]
538
+
539
+ this.$emit('on-error', file, row)
540
+ },
541
+ abortFn(row, $index) {
542
+ this.$set(row, '_status', 'exception')
543
+
544
+ let clUpload = this.$refs['upload' + $index]
545
+ let elUpload = clUpload.$refs['upload']
546
+ let uploadFiles = elUpload.uploadFiles
547
+
548
+ /* 重置文件状态,并加入文件队列 */
549
+ let file = uploadFiles[uploadFiles.length - 1]
550
+ file.status = 'ready'
551
+ clUpload.fileList = [file]
552
+
553
+ elUpload.abort()
554
+ },
555
+ anewSubmitFn(row, $index) {
556
+ this.$set(row, '_status', 'success')
557
+
558
+ this.$refs['upload' + $index]?.$refs['upload']?.submit()
559
+ }
560
+ }
561
+ }
562
+ </script>