n20-common-lib 1.2.46 → 1.3.2

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 (316) hide show
  1. package/package.json +17 -2
  2. package/src/assets/css/_coreLib.scss +1 -0
  3. package/src/assets/css/alert.scss +31 -0
  4. package/src/assets/css/cl-anchor.scss +18 -9
  5. package/src/assets/css/cl-approve-card.scss +12 -2
  6. package/src/assets/css/cl-dialog.scss +16 -1
  7. package/src/assets/css/cl-drag-list.scss +4 -2
  8. package/src/assets/css/cl-expandable-pane.scss +15 -3
  9. package/src/assets/css/cl-expandable.scss +5 -2
  10. package/src/assets/css/cl-file-upload-table.scss +22 -1
  11. package/src/assets/css/cl-form-item.scss +102 -8
  12. package/src/assets/css/cl-message.scss +87 -2
  13. package/src/assets/css/cl-pagination.scss +3 -1
  14. package/src/assets/css/cl-showcolumn.scss +18 -1
  15. package/src/assets/css/cl-statis.scss +14 -1
  16. package/src/assets/css/cl-tertiary-tab.scss +4 -2
  17. package/src/assets/css/cl-upload.scss +7 -0
  18. package/src/assets/css/el-button.scss +24 -9
  19. package/src/assets/css/el-table.scss +18 -0
  20. package/src/assets/css/element.dev.scss +1 -0
  21. package/src/assets/css/font-icon.scss +0 -1
  22. package/src/assets/css/normalize.scss +6 -6
  23. package/src/assets/css/plain-text.scss +138 -0
  24. package/src/assets/css/title-pop.scss +20 -1
  25. package/src/assets/svg/404.svg +1 -0
  26. package/src/assets/svg/addFile.svg +32 -0
  27. package/src/assets/svg/bug.svg +1 -0
  28. package/src/assets/svg/chart.svg +1 -0
  29. package/src/assets/svg/clipboard.svg +1 -0
  30. package/src/assets/svg/component.svg +1 -0
  31. package/src/assets/svg/dashboard.svg +1 -0
  32. package/src/assets/svg/deleteFile.svg +28 -0
  33. package/src/assets/svg/documentation.svg +1 -0
  34. package/src/assets/svg/drag.svg +1 -0
  35. package/src/assets/svg/edit.svg +1 -0
  36. package/src/assets/svg/education.svg +1 -0
  37. package/src/assets/svg/email.svg +1 -0
  38. package/src/assets/svg/example.svg +1 -0
  39. package/src/assets/svg/excel.svg +1 -0
  40. package/src/assets/svg/exit-fullscreen.svg +1 -0
  41. package/src/assets/svg/eye-open.svg +1 -0
  42. package/src/assets/svg/eye.svg +1 -0
  43. package/src/assets/svg/favorite.svg +1 -0
  44. package/src/assets/svg/favorite_active.svg +1 -0
  45. package/src/assets/svg/favorite_x400.svg +1 -0
  46. package/src/assets/svg/favorite_x400_active.svg +1 -0
  47. package/src/assets/svg/favorite_x400_blank.svg +1 -0
  48. package/src/assets/svg/filter.svg +16 -0
  49. package/src/assets/svg/filter@2x.png +0 -0
  50. package/src/assets/svg/filterActive.svg +16 -0
  51. package/src/assets/svg/filterClose@2x.png +0 -0
  52. package/src/assets/svg/form.svg +1 -0
  53. package/src/assets/svg/fullscreen.svg +1 -0
  54. package/src/assets/svg/guide.svg +1 -0
  55. package/src/assets/svg/hourglass.svg +19 -0
  56. package/src/assets/svg/icon.svg +1 -0
  57. package/src/assets/svg/international.svg +1 -0
  58. package/src/assets/svg/language.svg +1 -0
  59. package/src/assets/svg/left-dis.svg +1 -0
  60. package/src/assets/svg/left.svg +1 -0
  61. package/src/assets/svg/link.svg +1 -0
  62. package/src/assets/svg/list.svg +1 -0
  63. package/src/assets/svg/lock.svg +1 -0
  64. package/src/assets/svg/message-t.svg +1 -0
  65. package/src/assets/svg/money.svg +1 -0
  66. package/src/assets/svg/money3.svg +1 -0
  67. package/src/assets/svg/money4.svg +1 -0
  68. package/src/assets/svg/moneyTwo.svg +1 -0
  69. package/src/assets/svg/msg_white.svg +1 -0
  70. package/src/assets/svg/nested.svg +1 -0
  71. package/src/assets/svg/newsearch.svg +19 -0
  72. package/src/assets/svg/password.svg +1 -0
  73. package/src/assets/svg/pdf.svg +1 -0
  74. package/src/assets/svg/people.svg +1 -0
  75. package/src/assets/svg/peoples.svg +1 -0
  76. package/src/assets/svg/phone.svg +1 -0
  77. package/src/assets/svg/phone_msg.svg +1 -0
  78. package/src/assets/svg/qq.svg +1 -0
  79. package/src/assets/svg/right-dis.svg +1 -0
  80. package/src/assets/svg/right.svg +1 -0
  81. package/src/assets/svg/search.svg +1 -0
  82. package/src/assets/svg/searchActive.svg +19 -0
  83. package/src/assets/svg/shopping.svg +1 -0
  84. package/src/assets/svg/size.svg +1 -0
  85. package/src/assets/svg/skill.svg +1 -0
  86. package/src/assets/svg/star.svg +1 -0
  87. package/src/assets/svg/steam.svg +1 -0
  88. package/src/assets/svg/tab.svg +1 -0
  89. package/src/assets/svg/table.svg +1 -0
  90. package/src/assets/svg/theme.svg +1 -0
  91. package/src/assets/svg/tree-table.svg +1 -0
  92. package/src/assets/svg/tree.svg +1 -0
  93. package/src/assets/svg/user.svg +1 -0
  94. package/src/assets/svg/wechat.svg +1 -0
  95. package/src/assets/svg/z-left-2-dis.svg +1 -0
  96. package/src/assets/svg/z-left-2.svg +1 -0
  97. package/src/assets/svg/z-right-2-dis.svg +1 -0
  98. package/src/assets/svg/z-right-2.svg +1 -0
  99. package/src/assets/svg/z-right.svg +1 -0
  100. package/src/assets/svg/zip.svg +1 -0
  101. package/src/components/ApprovalButtons/index.vue +16 -9
  102. package/src/components/ApprovalCard/index.vue +18 -14
  103. package/src/components/Button/button-group.vue +52 -48
  104. package/src/components/Button/icon-group-button.vue +2 -0
  105. package/src/components/ChildRange/index.vue +202 -0
  106. package/src/components/ECharts/define.js +74 -0
  107. package/src/components/ECharts/index.vue +163 -0
  108. package/src/components/ECharts/mixins/resize.js +56 -0
  109. package/src/components/Empty/img/400.svg +102 -0
  110. package/src/components/Empty/img/401.svg +102 -0
  111. package/src/components/Empty/img/403.svg +102 -0
  112. package/src/components/Empty/img/405.svg +102 -0
  113. package/src/components/Empty/img/901.svg +96 -0
  114. package/src/components/Empty/img/902.svg +96 -0
  115. package/src/components/Empty/img/903.svg +96 -0
  116. package/src/components/Empty/img/904.svg +96 -0
  117. package/src/components/Empty/img/905.svg +96 -0
  118. package/src/components/Empty/img/906.svg +96 -0
  119. package/src/components/Empty/img/907.svg +96 -0
  120. package/src/components/Empty/index.vue +55 -0
  121. package/src/components/Expandable/main.vue +4 -1
  122. package/src/components/FileImport/index.vue +201 -0
  123. package/src/components/FileUploadTable/index.vue +15 -10
  124. package/src/components/Filters/index.vue +2 -2
  125. package/src/components/Filters/indexO.vue +1 -1
  126. package/src/components/InputSearch/index.vue +1 -1
  127. package/src/components/LoginTemporary/index.vue +3 -3
  128. package/src/components/NstcG6Components/Calendar/index.js +8 -0
  129. package/src/components/NstcG6Components/Calendar/src/basic/month-table.vue +129 -0
  130. package/src/components/NstcG6Components/Calendar/src/basic/year-table.vue +126 -0
  131. package/src/components/NstcG6Components/Calendar/src/main.vue +442 -0
  132. package/src/components/NstcG6Components/DialogForm/index.js +8 -0
  133. package/src/components/NstcG6Components/DialogForm/src/demo/index.vue +56 -0
  134. package/src/components/NstcG6Components/DialogForm/src/main.vue +189 -0
  135. package/src/components/NstcG6Components/Form/A_DEMO/component/originalForm.vue +281 -0
  136. package/src/components/NstcG6Components/Form/A_DEMO/config/config_3.js +1222 -0
  137. package/src/components/NstcG6Components/Form/A_DEMO/index.vue +803 -0
  138. package/src/components/NstcG6Components/Form/AutocompleteCustom/index.vue +72 -0
  139. package/src/components/NstcG6Components/Form/BusinessSpecific/InputMultiple.vue +191 -0
  140. package/src/components/NstcG6Components/Form/BusinessSpecific/InputWithUnit.vue +128 -0
  141. package/src/components/NstcG6Components/Form/BusinessSpecific/SelectTreeDialog.vue +233 -0
  142. package/src/components/NstcG6Components/Form/BusinessSpecific/readme.md +7 -0
  143. package/src/components/NstcG6Components/Form/CascaderCustom/index.vue +101 -0
  144. package/src/components/NstcG6Components/Form/CheckboxCustom/index.vue +84 -0
  145. package/src/components/NstcG6Components/Form/Component.vue +661 -0
  146. package/src/components/NstcG6Components/Form/ComponentSecond.vue +650 -0
  147. package/src/components/NstcG6Components/Form/DatepickerCustom/index.vue +130 -0
  148. package/src/components/NstcG6Components/Form/InputAndDialog/index.js +15 -0
  149. package/src/components/NstcG6Components/Form/InputAndDialog/src/main.vue +395 -0
  150. package/src/components/NstcG6Components/Form/InputCustom/demo/index.vue +65 -0
  151. package/src/components/NstcG6Components/Form/InputCustom/index.vue +307 -0
  152. package/src/components/NstcG6Components/Form/IntervalinputCustom/demo/index.vue +31 -0
  153. package/src/components/NstcG6Components/Form/IntervalinputCustom/index.vue +118 -0
  154. package/src/components/NstcG6Components/Form/Item.vue +330 -0
  155. package/src/components/NstcG6Components/Form/ItemSecond.vue +269 -0
  156. package/src/components/NstcG6Components/Form/List.vue +146 -0
  157. package/src/components/NstcG6Components/Form/ListSecond.vue +130 -0
  158. package/src/components/NstcG6Components/Form/RadioCustom/index.vue +73 -0
  159. package/src/components/NstcG6Components/Form/SelectAccount/index.js +15 -0
  160. package/src/components/NstcG6Components/Form/SelectAccount/src/demo/index.vue +58 -0
  161. package/src/components/NstcG6Components/Form/SelectAccount/src/main.vue +283 -0
  162. package/src/components/NstcG6Components/Form/SelectAndDialog/index.js +15 -0
  163. package/src/components/NstcG6Components/Form/SelectAndDialog/src/main.vue +384 -0
  164. package/src/components/NstcG6Components/Form/SelectCashFlow/index.js +15 -0
  165. package/src/components/NstcG6Components/Form/SelectCashFlow/src/demo/index.vue +42 -0
  166. package/src/components/NstcG6Components/Form/SelectCashFlow/src/main.vue +126 -0
  167. package/src/components/NstcG6Components/Form/SelectCustom/demo/index.vue +82 -0
  168. package/src/components/NstcG6Components/Form/SelectCustom/index.vue +488 -0
  169. package/src/components/NstcG6Components/Form/SelectSubject/index.js +15 -0
  170. package/src/components/NstcG6Components/Form/SelectSubject/src/demo/index.vue +85 -0
  171. package/src/components/NstcG6Components/Form/SelectSubject/src/main.vue +182 -0
  172. package/src/components/NstcG6Components/Form/SelectindialogCustom/demo/index.vue +188 -0
  173. package/src/components/NstcG6Components/Form/SelectindialogCustom/index.vue +650 -0
  174. package/src/components/NstcG6Components/Form/SelectindialogCustom/install.js +7 -0
  175. package/src/components/NstcG6Components/Form/TableRadioCustom/demo/index.vue +53 -0
  176. package/src/components/NstcG6Components/Form/TableRadioCustom/index.vue +183 -0
  177. package/src/components/NstcG6Components/Form/TextCustom/index.vue +38 -0
  178. package/src/components/NstcG6Components/Form/UploadCustom/demo/index.vue +31 -0
  179. package/src/components/NstcG6Components/Form/UploadCustom/iconxitongshezhi-yichu.png +0 -0
  180. package/src/components/NstcG6Components/Form/UploadCustom/index.vue +506 -0
  181. package/src/components/NstcG6Components/Form/configs.js +191 -0
  182. package/src/components/NstcG6Components/Form/configsSecond.js +161 -0
  183. package/src/components/NstcG6Components/Form/index.js +8 -0
  184. package/src/components/NstcG6Components/Form/index.scss +29 -0
  185. package/src/components/NstcG6Components/Form/payeePersonSelect/index.js +15 -0
  186. package/src/components/NstcG6Components/Form/payeePersonSelect/src/demo/index.vue +164 -0
  187. package/src/components/NstcG6Components/Form/payeePersonSelect/src/main.vue +185 -0
  188. package/src/components/NstcG6Components/Form/readme.txt +4 -0
  189. package/src/components/NstcG6Components/FormGroup/index.js +8 -0
  190. package/src/components/NstcG6Components/FormGroup/src/demo/config.js +23 -0
  191. package/src/components/NstcG6Components/FormGroup/src/demo/index.vue +85 -0
  192. package/src/components/NstcG6Components/FormGroup/src/main.vue +639 -0
  193. package/src/components/NstcG6Components/FormGroup/src/validate.js +23 -0
  194. package/src/components/NstcG6Components/InputTag/InputTag.vue +270 -0
  195. package/src/components/NstcG6Components/NstcApprovel/NstcApprovel.vue +25 -0
  196. package/src/components/NstcG6Components/NstcBackToTop/NstcBackToTop.vue +150 -0
  197. package/src/components/NstcG6Components/NstcBranchLazyLoad/NstcBranchLazyLoad.vue +119 -0
  198. package/src/components/NstcG6Components/NstcCharts/NstcCharts.vue +162 -0
  199. package/src/components/NstcG6Components/NstcCharts/define.js +74 -0
  200. package/src/components/NstcG6Components/NstcCharts/mixins/resize.js +56 -0
  201. package/src/components/NstcG6Components/NstcConfirm/NstcConfirm.vue +153 -0
  202. package/src/components/NstcG6Components/NstcConfirm/index.js +25 -0
  203. package/src/components/NstcG6Components/NstcDialog/NstcDialog.vue +185 -0
  204. package/src/components/NstcG6Components/NstcDialogForm/NstcDialogForm.vue +176 -0
  205. package/src/components/NstcG6Components/NstcDialogTable/NstcDialogTable.vue +282 -0
  206. package/src/components/NstcG6Components/NstcDropdown/NstcDropdown.vue +52 -0
  207. package/src/components/NstcG6Components/NstcDropdownTree/NstcDropdownTree.vue +392 -0
  208. package/src/components/NstcG6Components/NstcElectronicFile/NstcElectronicFile.vue +591 -0
  209. package/src/components/NstcG6Components/NstcExcelCustomImport/NstcExcelCustomImport.vue +475 -0
  210. package/src/components/NstcG6Components/NstcExcelCustomImport/img/upload@2x.png +0 -0
  211. package/src/components/NstcG6Components/NstcExcelExport/NstcExcelExport.vue +145 -0
  212. package/src/components/NstcG6Components/NstcExcelImport/NstcExcelImport.vue +1051 -0
  213. package/src/components/NstcG6Components/NstcExcelImport/img/upload@2x.png +0 -0
  214. package/src/components/NstcG6Components/NstcExcelImportN/NstcExcelImportN.vue +1168 -0
  215. package/src/components/NstcG6Components/NstcExpandCollapse/NstcExpandCollapse.vue +130 -0
  216. package/src/components/NstcG6Components/NstcExpandCollapse/index.scss +77 -0
  217. package/src/components/NstcG6Components/NstcFileUpload/NstcFileUpload.vue +1011 -0
  218. package/src/components/NstcG6Components/NstcFileUpload/img/addFile.svg +32 -0
  219. package/src/components/NstcG6Components/NstcFileUpload/img/delete.svg +24 -0
  220. package/src/components/NstcG6Components/NstcFileUpload/img/deleteFile.svg +28 -0
  221. package/src/components/NstcG6Components/NstcFileUpload/img/download.svg +24 -0
  222. package/src/components/NstcG6Components/NstcFileUpload/img/inputUpload.svg +30 -0
  223. package/src/components/NstcG6Components/NstcFileUpload/img/look-diabled.svg +24 -0
  224. package/src/components/NstcG6Components/NstcFileUpload/img/look.svg +24 -0
  225. package/src/components/NstcG6Components/NstcForm/A_DEMO/component/originalForm.vue +281 -0
  226. package/src/components/NstcG6Components/NstcForm/A_DEMO/config/config_3.js +1222 -0
  227. package/src/components/NstcG6Components/NstcForm/A_DEMO/index.vue +796 -0
  228. package/src/components/NstcG6Components/NstcForm/AutocompleteCustom/index.vue +68 -0
  229. package/src/components/NstcG6Components/NstcForm/BusinessSpecific/InputMultiple.vue +191 -0
  230. package/src/components/NstcG6Components/NstcForm/BusinessSpecific/InputWithUnit.vue +128 -0
  231. package/src/components/NstcG6Components/NstcForm/BusinessSpecific/SelectTreeDialog.vue +233 -0
  232. package/src/components/NstcG6Components/NstcForm/BusinessSpecific/readme.md +7 -0
  233. package/src/components/NstcG6Components/NstcForm/CascaderCustom/index.vue +101 -0
  234. package/src/components/NstcG6Components/NstcForm/CheckboxCustom/index.vue +84 -0
  235. package/src/components/NstcG6Components/NstcForm/Component.vue +684 -0
  236. package/src/components/NstcG6Components/NstcForm/ComponentSecond.vue +650 -0
  237. package/src/components/NstcG6Components/NstcForm/DatepickerCustom/index.vue +130 -0
  238. package/src/components/NstcG6Components/NstcForm/InputAndDialog/NstcInputAndDialog.vue +389 -0
  239. package/src/components/NstcG6Components/NstcForm/InputCustom/index.vue +314 -0
  240. package/src/components/NstcG6Components/NstcForm/IntervalInputCustom/index.vue +116 -0
  241. package/src/components/NstcG6Components/NstcForm/Item.vue +327 -0
  242. package/src/components/NstcG6Components/NstcForm/ItemSecond.vue +269 -0
  243. package/src/components/NstcG6Components/NstcForm/List.vue +146 -0
  244. package/src/components/NstcG6Components/NstcForm/ListSecond.vue +130 -0
  245. package/src/components/NstcG6Components/NstcForm/RadioCustom/index.vue +73 -0
  246. package/src/components/NstcG6Components/NstcForm/SelectAccount/NstcSelectAccount.vue +334 -0
  247. package/src/components/NstcG6Components/NstcForm/SelectAndDialog/NstcSelectAndDialog.vue +382 -0
  248. package/src/components/NstcG6Components/NstcForm/SelectCashFlow/NstcSelectCashFlow.vue +123 -0
  249. package/src/components/NstcG6Components/NstcForm/SelectCustom/index.vue +460 -0
  250. package/src/components/NstcG6Components/NstcForm/SelectSubject/NstcSelectSubject.vue +185 -0
  251. package/src/components/NstcG6Components/NstcForm/SelectindialogCustom/index.vue +650 -0
  252. package/src/components/NstcG6Components/NstcForm/TableRadioCustom/index.vue +183 -0
  253. package/src/components/NstcG6Components/NstcForm/TextCustom/index.vue +38 -0
  254. package/src/components/NstcG6Components/NstcForm/UploadCustom/iconxitongshezhi-yichu.png +0 -0
  255. package/src/components/NstcG6Components/NstcForm/UploadCustom/index.vue +483 -0
  256. package/src/components/NstcG6Components/NstcForm/configs.js +191 -0
  257. package/src/components/NstcG6Components/NstcForm/configsSecond.js +161 -0
  258. package/src/components/NstcG6Components/NstcForm/index.js +8 -0
  259. package/src/components/NstcG6Components/NstcForm/index.scss +29 -0
  260. package/src/components/NstcG6Components/NstcForm/payeePersonSelect/NstcPayeePerson.vue +188 -0
  261. package/src/components/NstcG6Components/NstcForm/readme.txt +4 -0
  262. package/src/components/NstcG6Components/NstcPagination/NstcPagination.vue +430 -0
  263. package/src/components/NstcG6Components/NstcPagination/setPageNum.png +0 -0
  264. package/src/components/NstcG6Components/NstcPagination/setpagedefault.png +0 -0
  265. package/src/components/NstcG6Components/NstcScreenFull/NstcScreenFull.vue +70 -0
  266. package/src/components/NstcG6Components/NstcSelectTree/NstcSelectTree.vue +729 -0
  267. package/src/components/NstcG6Components/NstcSelectTreeList/NstcSelectTreeList.vue +676 -0
  268. package/src/components/NstcG6Components/NstcSticky/NstcSticky.vue +97 -0
  269. package/src/components/NstcG6Components/NstcSvgIcon/NstcSvgIcon.vue +77 -0
  270. package/src/components/NstcG6Components/NstcTab/NstcTab.vue +80 -0
  271. package/src/components/NstcG6Components/NstcTabWithBadge/NstcTabWithBadge.vue +45 -0
  272. package/src/components/NstcG6Components/NstcTabWithBadge/index.scss +31 -0
  273. package/src/components/NstcG6Components/NstcTable/ElTableColumnCustom/index.vue +292 -0
  274. package/src/components/NstcG6Components/NstcTable/NstcTable.vue +460 -0
  275. package/src/components/NstcG6Components/NstcTableSet/NstcTableSet.vue +801 -0
  276. package/src/components/NstcG6Components/NstcThemePicker/NstcThemePicker.vue +186 -0
  277. package/src/components/NstcG6Components/NstcUploadCustomExcel/NstcUploadCustomExcel.vue +330 -0
  278. package/src/components/NstcG6Components/NstcUploadExcel/NstcUploadExcel.vue +145 -0
  279. package/src/components/NstcG6Components/NstcWorkBench/NstcWorkBench.vue +167 -0
  280. package/src/components/NstcG6Components/Search/NstcSearch.vue +591 -0
  281. package/src/components/NstcG6Components/Search/src/demo/index copy.vue +101 -0
  282. package/src/components/NstcG6Components/Search/src/demo/index.vue +103 -0
  283. package/src/components/NstcG6Components/Search/src/main copy.vue +607 -0
  284. package/src/components/NstcG6Components/approvelTwo/main.vue +220 -0
  285. package/src/components/NstcG6Components/approvelTwo/progress.vue +154 -0
  286. package/src/components/PageHeader/index.vue +80 -0
  287. package/src/components/PlainText/PlainTextItem.vue +17 -0
  288. package/src/components/PlainText/index.vue +12 -0
  289. package/src/components/Search/index.vue +593 -0
  290. package/src/components/SelectTree/index.vue +1 -0
  291. package/src/components/ShowColumn/index.vue +1 -1
  292. package/src/components/Stamp/images/accounts.png +0 -0
  293. package/src/components/Stamp/images/cancellation.png +0 -0
  294. package/src/components/Stamp/images/clinch.png +0 -0
  295. package/src/components/Stamp/images/conclude.png +0 -0
  296. package/src/components/Stamp/images/efficacy.png +0 -0
  297. package/src/components/Stamp/images/termination.png +0 -0
  298. package/src/components/Stamp/index.vue +75 -0
  299. package/src/components/Statis/statisPopover.vue +1 -0
  300. package/src/components/Table/ThSelectHeader.vue +133 -0
  301. package/src/components/Table/index.vue +53 -3
  302. package/src/components/Upload/index.vue +6 -2
  303. package/src/directives/VCopy/index.js +60 -0
  304. package/src/directives/VNstcNumber/index.js +14 -0
  305. package/src/directives/VNstcNumber/temp.js +446 -0
  306. package/src/index.js +28 -1
  307. package/src/utils/dateAndValidator.js +629 -0
  308. package/src/utils/debounce.js +40 -0
  309. package/src/utils/mapper_aims.js +810 -0
  310. package/src/utils/parseTime.js +48 -0
  311. package/src/utils/validate/index.js +7 -0
  312. package/src/utils/vendor/Export2Excel.js +229 -0
  313. package/src/utils/vendor/Export2Zip.js +24 -0
  314. package/src/utils/vue-bus.js +5 -0
  315. package/style/index.css +1 -1
  316. package/style/index.css.map +1 -1
@@ -0,0 +1,475 @@
1
+ <!--
2
+ 功能: excel自定义导入功能
3
+ 作者: nstc
4
+ 创建时间: 2021-02-05
5
+ -->
6
+ <template>
7
+ <div>
8
+ <NstcDialog
9
+ v-model="_value"
10
+ :title="title"
11
+ :width="width"
12
+ append-to-body
13
+ v-bind="$attrs"
14
+ v-on="$listeners"
15
+ @cancel="resetAction"
16
+ :footer-handlers="footerHandlers"
17
+ >
18
+ <div class="nstc-common-excel-import">
19
+ <div class="nstc-common-excel-import-tips-box">
20
+ <el-row :gutter="10">
21
+ <el-col style="width: 75px; text-align: right">
22
+ <span class="tips-box-text">导入说明:</span>
23
+ </el-col>
24
+ <el-col :span="18">
25
+ <div v-for="(item, index) in tips" :key="index" class="tips-item">
26
+ <span v-if="tips.length !== 1">{{ index + 1 }}. </span>
27
+ <span>{{ item.text }}</span>
28
+ </div>
29
+ </el-col>
30
+ </el-row>
31
+ </div>
32
+ <slot />
33
+
34
+ <el-form :label-width="labelWidth">
35
+ <el-form-item label="上传">
36
+ <div class="excel-unload-input" @click="uploadChooseFile">
37
+ <div
38
+ :class="{
39
+ placeholder: true,
40
+ 'placeholder-has-file': placeholderHasFile,
41
+ }"
42
+ >
43
+ {{ placeholderText || '请选择' }}
44
+ </div>
45
+ <img class="excel-unload-input-img" :src="uploadImg" alt="" />
46
+ </div>
47
+ <el-button
48
+ type="primary"
49
+ class="nstc-g6-common-btn-1 nstc-g6-common-btn-size-s"
50
+ @click="handleConfirmImportExcel"
51
+ :disabled="
52
+ excelData.tableData.length === 0 || confirmDisabledFlag
53
+ "
54
+ >导入</el-button
55
+ >
56
+ <el-button
57
+ type="text"
58
+ style="margin-left: 20px"
59
+ @click="downloadTemplate"
60
+ :disabled="!templateUrl"
61
+ >导入模板下载</el-button
62
+ >
63
+ </el-form-item>
64
+ </el-form>
65
+
66
+ <div v-show="statisticsFlag" class="excel-upload-result-box">
67
+ <div class="excel-upload-result-box-head">结果统计</div>
68
+ <div class="excel-upload-result-box-content">
69
+ <span>结果统计 {{ validateResult.totalNum }} 条记录, </span>
70
+ <span>其中有效数据记录{{ validateResult.successNum }} 条, </span>
71
+ <span
72
+ >其中无效数据记录
73
+ <span class="nstc-import-error-num">{{
74
+ validateResult.errorList.length
75
+ }}</span>
76
+ 条。</span
77
+ >
78
+ </div>
79
+ </div>
80
+
81
+ <NstcUploadCustomExcel
82
+ v-if="value"
83
+ ref="nstc-unload-excel-box"
84
+ v-show="percentage !== 100"
85
+ class="upload-excel-box"
86
+ :before-upload="beforeUpload"
87
+ :on-success="handleSuccess"
88
+ ></NstcUploadCustomExcel>
89
+
90
+ <div v-show="hasErrorFlag" class="fail-excel-import-box">
91
+ <div class="fail-excel-import-box-title">无效数据情况统计</div>
92
+ <NstcTable
93
+ :columns="columnsListTemp"
94
+ :data="errorListTemp"
95
+ :show-pagination="false"
96
+ :show-overflow-tooltip="true"
97
+ ></NstcTable>
98
+ </div>
99
+
100
+ <div v-show="hasErrorFlag" class="end-tips">
101
+ 上述数据输入有误,请修改导入文件中相关信息!
102
+ </div>
103
+ </div>
104
+ </NstcDialog>
105
+ </div>
106
+ </template>
107
+
108
+ <script>
109
+ import NstcUploadCustomExcel from "../NstcUploadCustomExcel/NstcUploadCustomExcel";
110
+ import NstcDialog from "../NstcDialog/NstcDialog";
111
+ import NstcTable from "../NstcTable/NstcTable";
112
+ import uploadImg from "./img/upload@2x.png";
113
+ export default {
114
+ name: "NstcExcelCustomImport",
115
+
116
+ components: {
117
+ NstcUploadCustomExcel,
118
+ NstcDialog,
119
+ NstcTable,
120
+ },
121
+ props: {
122
+ //弹框是否显示 默认:false
123
+ value: {
124
+ type: Boolean,
125
+ default: false,
126
+ },
127
+ //导入说明文本
128
+ tips: {
129
+ type: Array,
130
+ default: () => {
131
+ return [];
132
+ },
133
+ },
134
+ //表单域标签的宽度
135
+ labelWidth: {
136
+ type: String,
137
+ default: "",
138
+ },
139
+ //文件下载的模板url
140
+ templateUrl: {
141
+ type: String,
142
+ default: "",
143
+ },
144
+ //操作框的主标题
145
+ title: {
146
+ type: String,
147
+ default: function () {
148
+ return "导入";
149
+ },
150
+ },
151
+ //是否重置
152
+ reset: {
153
+ type: Boolean,
154
+ default: false,
155
+ },
156
+ //底部按钮信息
157
+ footerHandlers: {
158
+ type: Object,
159
+ default: function () {
160
+ return {
161
+ // cancel: {
162
+ // text: '取消'
163
+ // },
164
+ // confirm: {
165
+ // text: '导入'
166
+ // }
167
+ };
168
+ },
169
+ },
170
+ //账户明细自定义导入标识
171
+ flag: {
172
+ type: Boolean,
173
+ default: false,
174
+ },
175
+ // 自动上传校验
176
+ callback: {
177
+ type: Function,
178
+ default: () => {},
179
+ },
180
+ // mapper: {
181
+ // type: Object,
182
+ // default: () => {}
183
+ // },
184
+ //导入请求
185
+ handleConfirm: {
186
+ type: Function,
187
+ default: () => {},
188
+ },
189
+
190
+ // 校验结果
191
+ validateResult: {
192
+ type: Object,
193
+ default: () => {
194
+ return {
195
+ totalNum: 0,
196
+ successNum: 0,
197
+ columnsList: [],
198
+ errorList: [],
199
+ };
200
+ },
201
+ },
202
+ width:{
203
+ type:[String,Number],
204
+ default:'1200px'
205
+ }
206
+ },
207
+ mounted() {
208
+ this.placeholderText= ''
209
+ // chrome and ie
210
+ window.addEventListener("mousewheel", this.handleScroll(), false);
211
+ // firefox
212
+ window.addEventListener("DOMMouseScroll", this.handleScroll(), false);
213
+ },
214
+ data() {
215
+ return {
216
+ uploadImg,
217
+ excelData: {
218
+ // tableHeader: [],
219
+ tableData: [],
220
+ },
221
+ placeholderHasFile: false,
222
+ progressStatus: "",
223
+ percentage: 0,
224
+ percentageFlag: false,
225
+ fileName: "",
226
+ drawerFlag: false,
227
+ dialogVisible: false,
228
+ tipsText: "导入说明",
229
+ totalNum: 0,
230
+ successNum: 0,
231
+ failNum: 0,
232
+ placeholderText: "",
233
+ columnsFailResult: [],
234
+ tableDataFailResult: [],
235
+ columnsListTemp: [],
236
+ errorListTemp: [],
237
+ successFlag: false,
238
+ statisticsFlag: false,
239
+ confirmDisabledFlag: true,
240
+ isShow: false,
241
+ };
242
+ },
243
+ watch: {
244
+ value:{
245
+ handler(newValue){
246
+ if (!newValue) {
247
+ this.resetAction()
248
+ }
249
+ }
250
+ },
251
+ validateResult: {
252
+ handler(newValue, oldValue) {
253
+ // console.log("值更新了", newValue, oldValue);
254
+ oldValue.columnsList.length && (this.statisticsFlag = true);
255
+
256
+ // 获取每行字符的最大长度
257
+ const lengthObj = {};
258
+ newValue.errorList.map((item) => {
259
+ // console.log("keys", Object.keys(item));
260
+ const keys = oldValue.columnsList.map((i) => {
261
+ return i["prop"];
262
+ });
263
+ keys.map((k, i) => {
264
+ // console.log("计算的长度", item[k]);
265
+ if (item[k] && (!lengthObj[i] || lengthObj[i] < item[k].length)) {
266
+ lengthObj[i] = item[k].length;
267
+ }
268
+ });
269
+ });
270
+
271
+ // 更新column
272
+ this.columnsListTemp = oldValue.columnsList.map((i, index) => {
273
+ // console.log('iiiiiii', i, i.errorList)
274
+ return {
275
+ ...i,
276
+ width: 16 * lengthObj[index] + 40,
277
+ component: {
278
+ template: `<div v-html="scope.row['${i.prop}']"></div>`,
279
+ },
280
+ };
281
+ });
282
+
283
+
284
+ // 更新errorList的tableData
285
+ this.errorListTemp.length = 0;
286
+ newValue.errorList.map((i) => {
287
+ const temp = {};
288
+ Object.keys(i).map((k) => {
289
+ if (i.errorList && i.errorList.includes(k)) {
290
+ temp[
291
+ k
292
+ ] = `<div class="nstc-g6-common-color-danger">${i[k]}</div>`;
293
+ } else {
294
+ temp[k] = i[k];
295
+ }
296
+ });
297
+ this.errorListTemp.push(temp);
298
+ // console.log("表格数据", this.errorListTemp);
299
+ });
300
+
301
+ this.successFlag =
302
+ this.validateResult.successNum !== 0 &&
303
+ this.validateResult.successNum === this.validateResult.totalNum;
304
+
305
+ // this.footerHandlers.confirm.disabled = !this.successFlag
306
+ this.confirmDisabledFlag = !this.successFlag;
307
+
308
+ // nstc-g6-common-color-danger
309
+ // this.columnsList && this.columnsList.map(i => {
310
+ // console.log(i)
311
+ // })
312
+ },
313
+ deep: true,
314
+ },
315
+ columnsList: {
316
+ handler(newValue, oldValue) {
317
+ console.log("值更新了", newValue, oldValue);
318
+
319
+ // console.log("123123123", this.columnsListTemp);
320
+ },
321
+ },
322
+ reset(val) {
323
+ val && this.resetAction();
324
+ },
325
+ },
326
+ computed: {
327
+ _value: {
328
+ get() {
329
+ return this.value;
330
+ },
331
+ set(val) {
332
+ this.$emit("input", val);
333
+ },
334
+ },
335
+ hasErrorFlag() {
336
+ return (
337
+ this.validateResult.errorList &&
338
+ this.validateResult.errorList.length > 0
339
+ );
340
+ },
341
+ },
342
+ created() {
343
+ console.log(
344
+ "批量导入的国际化",
345
+ "上述数据输入有误,请修改导入文件中相关信息!"
346
+ );
347
+ },
348
+ methods: {
349
+ beforeUpload(file) {
350
+ this.percentage = 0;
351
+ this.progressStatus = "";
352
+ this.percentageFlag = true;
353
+ this.fileName = file.name;
354
+ this.placeholderText = this.fileName;
355
+ this.placeholderHasFile = true;
356
+ return true;
357
+ },
358
+ // header
359
+ handleSuccess(results,tableList) {
360
+ this.percentage = 100;
361
+ this.progressStatus = "success";
362
+ this.validateResult.columnsList = tableList
363
+
364
+
365
+
366
+ this.excelData.tableData = results;
367
+
368
+ // 自动上传校验or模板上传
369
+ this.flag ? this.callback(results) : this.callback(this.excelData);
370
+ },
371
+
372
+ async handleConfirmImportExcel() {
373
+ (await this.flag)
374
+ ? this.handleConfirm()
375
+ : this.handleConfirm(this.excelData);
376
+ // try {
377
+ // await this.callback(this.excelData)
378
+ // } catch (err) {
379
+ // return Promise.reject(err)
380
+ // }
381
+ },
382
+
383
+ // 下载文件
384
+ downloadTemplate() {
385
+ const aEl = document.createElement("a");
386
+ aEl.setAttribute("href", this.templateUrl);
387
+ aEl.target = "_blank";
388
+ // aEl.download = this.templateUrl
389
+ aEl.click();
390
+ },
391
+
392
+ resetAction(flag) {
393
+ // 文件
394
+ this.excelData = {
395
+ // tableHeader: [],
396
+ tableData: [],
397
+ };
398
+ // 不改变原来数据结构
399
+ this.validateResult.totalNum = null;
400
+ this.validateResult.successNum = null;
401
+ this.validateResult.columnsList = [];
402
+ this.validateResult.errorList = [];
403
+
404
+ this.successFlag = false;
405
+ // this.footerHandlers.confirm.disabled = true
406
+ this.confirmDisabledFlag = true;
407
+ this.percentageFlag = false;
408
+ this.fileName = "";
409
+ this.percentage = 0;
410
+ this.reset = false;
411
+ this.statisticsFlag = false;
412
+ this.placeholderHasFile = false;
413
+ this.placeholderText = '请选择';
414
+ console.log("执行了弹框关闭事件");
415
+ ![`delete`].includes(flag) && (this._value = false);
416
+ this.$nextTick(() => {
417
+ this.$forceUpdate();
418
+ });
419
+ },
420
+
421
+ /**
422
+ * 选择文件
423
+ */
424
+ uploadChooseFile() {
425
+ this.$refs[`nstc-unload-excel-box`].handleUpload();
426
+ },
427
+ handleScroll(e) {
428
+ let direction = e ? (e.deltaY > 0 ? "down" : "up") : ""; // 该语句可以用来判断滚轮是向上滑动还是向下
429
+ if (document.getElementsByTagName("li").length == 1) {
430
+ //此处决定无论一次滚轮滚动的距离是多少,此事件
431
+ //都得等上次滚动结束,才会执行本次
432
+ this.isShow = false;
433
+ setTimeout(() => {
434
+ this.isShow = true;
435
+ ++this.nowIndex;
436
+ if (this.nowIndex == 3) {
437
+ this.nowIndex = 0;
438
+ }
439
+ }, 10);
440
+ }
441
+ console.log(direction);
442
+ },
443
+ },
444
+ };
445
+ </script>
446
+
447
+ <style lang="scss">
448
+
449
+ .nstc-import-error-num {
450
+ color: #fb5555;
451
+ }
452
+ .excel-unload-input {
453
+ position: relative;
454
+ overflow: hidden;
455
+ }
456
+ .placeholder-has-file {
457
+ color: #242424 !important;
458
+ height: 35px;
459
+ width: 999px;
460
+ position: absolute;
461
+ top: -1px;
462
+ left: 10px;
463
+ }
464
+ .excel-unload-input-img {
465
+ position: absolute;
466
+ right: 10px;
467
+ top: 8px;
468
+ }
469
+ // .dialog-footer {
470
+ // position: absolute;
471
+ // top: 170px;
472
+ // left: 380px;
473
+ // }
474
+ </style>
475
+
@@ -0,0 +1,145 @@
1
+ <template>
2
+ <div class="nstc-excel-export-box">
3
+ <slot />
4
+ </div>
5
+ </template>
6
+
7
+ <script>
8
+ import * as Export2Excel from "@/utils/vendor/Export2Excel";
9
+ export default {
10
+ name: "NstcExcelExport",
11
+ props: {
12
+ data: {
13
+ type: Object,
14
+ default: function () {
15
+ return {
16
+ childKey: "", //指定childKey时,会更具childKey递归取数据
17
+ head: [], //表头数据,未指定childKey时,必须传字符串数组,指定childKey时,表头为对象数组,{key:'key',value:'value'},方便表格行取对应数据
18
+ data: [], //行数据,未指定childKey时,必须传与表头对应的字符串数组,指定childKey时,传与表头对应的对象数组
19
+ fileName: "列表",
20
+ };
21
+ },
22
+ },
23
+ // 导入执行动作
24
+ executeExportFlag: {
25
+ type: [Number, String],
26
+ default: () => {
27
+ return "";
28
+ },
29
+ },
30
+ // 单元格样式
31
+ cellStyle: {
32
+ type: Object,
33
+ default: () => {
34
+ return {};
35
+ },
36
+ },
37
+ merges: {
38
+ type: Array,
39
+ default: () => {
40
+ return [];
41
+ },
42
+ },
43
+ },
44
+ watch: {
45
+ executeExportFlag(newValue) {
46
+ if (newValue) {
47
+ this.excelExportAction();
48
+ }
49
+ },
50
+ },
51
+ data() {
52
+ return {};
53
+ },
54
+ methods: {
55
+ /**
56
+ * 扁平化数据
57
+ * @param item 当前数据
58
+ * @param dataTemp 新组装的数据容器
59
+ * @param level 当前数据在当前行的等级
60
+ * @param str 子节点需要拼接的字符串
61
+ * @param childKey 子节点的key
62
+ */
63
+ flatChild(item, dataTemp, level, str, childKey) {
64
+ let subStr = "";
65
+ for (var i = 0; i < level; i++) {
66
+ subStr += str;
67
+ }
68
+ item[this.data.head[0].key] = subStr + item[this.data.head[0].key];
69
+ dataTemp.push(item);
70
+ level++;
71
+ // eslint-disable-next-line no-debugger
72
+ if (item[childKey] && item[childKey].length > 0) {
73
+ item[childKey].forEach((child) => {
74
+ this.flatChild(child, dataTemp, level, str, childKey);
75
+ });
76
+ }
77
+ },
78
+ /**
79
+ * 导出动作
80
+ */
81
+ excelExportAction() {
82
+ this.excelDownloadLoading = true;
83
+ let that = this;
84
+ if (this.data.head.length < 1 || this.data.data.length < 1) {
85
+ this.$message({
86
+ type: "warning",
87
+ message: "表格数据不足!",
88
+ });
89
+ return;
90
+ }
91
+ // console.log('Export2Excel', import('@/utils/vendor/Export2Excel'))
92
+ // import('@/utils/vendor/Export2Excel').then(excel => {
93
+
94
+ // excel.export_json_to_excel({
95
+ // header: that.data.head,
96
+ // data: that.data.data,
97
+ // filename: that.data.fileName
98
+ // })
99
+ // that.excelDownloadLoading = false
100
+ // })
101
+ let str = " "; //子节点添加的符号
102
+ let level = 0; //当前行的等级
103
+ let dataTemp = []; //暂存扁平化数据
104
+ if (this.data.childKey) {
105
+ this.data.data.forEach((item) => {
106
+ level = 0;
107
+ this.flatChild(item, dataTemp, level, str, this.data.childKey);
108
+ });
109
+
110
+ //扁平化数据转化为表数据
111
+ dataTemp = dataTemp.map((d) => {
112
+ let temp = [];
113
+ this.data.head.forEach((h) => {
114
+ temp.push(d[h.key]);
115
+ });
116
+ return temp;
117
+ });
118
+ // eslint-disable-next-line no-debugger
119
+ // debugger;
120
+
121
+ //重置表数据为转化后的数据
122
+ this.data.head = this.data.head.map((item) => item.value);
123
+ this.data.data = dataTemp;
124
+ }
125
+
126
+ Export2Excel.export_json_to_excel(
127
+ {
128
+ header: that.data.head,
129
+ data: that.data.data,
130
+ filename: that.data.fileName,
131
+ merges: this.merges
132
+ },
133
+ this.cellStyle
134
+ );
135
+ that.excelDownloadLoading = false;
136
+ },
137
+ },
138
+ };
139
+ </script>
140
+
141
+ <style lang="scss">
142
+ .nstc-excel-export-box {
143
+ display: inline-block;
144
+ }
145
+ </style>