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,801 @@
1
+ <template>
2
+ <NstcDialog
3
+ v-model="_value"
4
+ :title="pageTitle"
5
+ :custom-class="cName"
6
+ :show-footer="false"
7
+ :width="dialogWidth"
8
+ >
9
+ <div :class="`${cName}-inner`">
10
+ <div :class="{ [`${cName}-left`]: true }">
11
+ <!-- 顶部标题以及全选按钮 -->
12
+ <div :class="`${cName}-inner-title`">
13
+ <div class="title-temp">
14
+ <span>{{ titleObj[type] }}</span>
15
+ <span>已选</span>
16
+ <span>{{ result.length || 0 }}</span>
17
+ </div>
18
+ <!-- <div class="choose-all" @click="chooseAllOrCancel">{{ isChkAll ? "取消全选": "全部选中" }}</div>-->
19
+ <div class="choose-all" @click="chooseAllOrCancel">全部选中</div>
20
+ </div>
21
+ <!-- checkBox -->
22
+ <div :class="`${cName}-inner-content`">
23
+ <div
24
+ v-for="(group, index) in options"
25
+ :key="index"
26
+ class="table-columns-set-group"
27
+ >
28
+ <div :class="`${cName}-group-name`">
29
+ {{ group.groupName }}
30
+ <!-- <i v-if="showCollapse" :class="['el-icon-arrow-up', 'arrow-up',arrowStates[index]?'arrow-down':'']" @click="upDown(index)"></i> -->
31
+ </div>
32
+ <CheckboxCustom
33
+ v-model="model[index]"
34
+ :class="[
35
+ arrowStates[index] ? 'arrowwz-change' : '',
36
+ 'show-group'
37
+ ]"
38
+ :options="group.children"
39
+ hover-show-title
40
+ @change="(_) => handleLeftChange(group.children)"
41
+ />
42
+ </div>
43
+ </div>
44
+ </div>
45
+ <!-- 右边排序部分 -->
46
+ <div
47
+ v-show="['set', 'export', 'condition'].includes(type)"
48
+ :class="`${cName}-right`"
49
+ >
50
+ <div :class="`${cName}-inner-title`">当前选定项</div>
51
+ <div ref="table_columns_set_result" :class="`${cName}-inner-content`">
52
+ <div
53
+ v-for="(item, index) in result"
54
+ :key="item.id"
55
+ :class="`${cName}-result-item`"
56
+ >
57
+ <span>{{ item.name }}</span>
58
+ <!-- <el-button
59
+ v-if="!item.isRequired"
60
+ type="text"
61
+ style="padding:0;"
62
+ icon="el-icon-close"
63
+ @click="handleDel(item, index)"
64
+ style="color:#007AFF"
65
+ /> -->
66
+ <div class="close">
67
+ <i class="el-icon-close" @click="handleDel(item, index)"></i>
68
+ </div>
69
+ </div>
70
+ </div>
71
+ </div>
72
+ </div>
73
+ <!-- 下面按钮部分 -->
74
+ <template slot="after">
75
+ <div slot="footer" class="dialog-footer">
76
+ <el-button
77
+ v-if="footerHandlers.confirm"
78
+ type="primary"
79
+ :class="footerHandlers.confirm.className || ''"
80
+ @click="handleConfirm"
81
+ >
82
+ {{ footerHandlers.confirm.text }}
83
+ </el-button>
84
+ <el-tooltip
85
+ class="item"
86
+ effect="dark"
87
+ content="重置本次操作"
88
+ placement="top-start"
89
+ >
90
+ <el-button
91
+ v-if="footerHandlers.cancel"
92
+ :class="footerHandlers.cancel.className || ''"
93
+ @click="handleReset"
94
+ >
95
+ {{ footerHandlers.cancel.text }}
96
+ </el-button>
97
+ </el-tooltip>
98
+ </div>
99
+ </template>
100
+ </NstcDialog>
101
+ </template>
102
+
103
+ <script>
104
+ import NstcDialog from '@/components/NstcG6Components/NstcDialog/NstcDialog'
105
+ import CheckboxCustom from '@/components/NstcG6Components/Form/CheckboxCustom'
106
+ import axios from '@/utils/axios'
107
+ import Sortable from 'sortablejs'
108
+
109
+ export default {
110
+ name: 'NstcTableSet',
111
+
112
+ components: {
113
+ NstcDialog,
114
+ CheckboxCustom
115
+ },
116
+
117
+ props: {
118
+ showCollapse: {
119
+ type: Boolean,
120
+ default: true
121
+ },
122
+ value: {
123
+ // 控制显示隐藏
124
+ type: Boolean,
125
+ default: false
126
+ },
127
+
128
+ type: {
129
+ // set - 列设置 export - 导出 condition - 筛选条件
130
+ type: String,
131
+ default: 'set'
132
+ },
133
+
134
+ exportExcelConfig: {
135
+ type: Object,
136
+ default: function () {
137
+ return {
138
+ url: '',
139
+ httpMethod: 'get',
140
+ formatData: (i) => {
141
+ return i
142
+ },
143
+ searchObj: {},
144
+ exportFileName: '导出'
145
+ }
146
+ }
147
+ },
148
+
149
+ title: {
150
+ type: String,
151
+ default: function () {
152
+ return '设置显示字段'
153
+ }
154
+ },
155
+
156
+ config: {
157
+ type: Object,
158
+ default: () => {
159
+ return {
160
+ pageUUID: '',
161
+ moduleNo: ''
162
+ }
163
+ }
164
+ }
165
+ },
166
+
167
+ data() {
168
+ return {
169
+ arrowStates: [],
170
+ hasInit: false,
171
+
172
+ footerHandlers: {
173
+ confirm: {
174
+ text: '确定',
175
+ className: {
176
+ 'nstc-g6-common-btn-1': true,
177
+ 'nstc-g6-common-btn-size-b': true
178
+ }
179
+ },
180
+ cancel: {
181
+ text: '重置',
182
+ className: {
183
+ 'nstc-g6-common-btn-1': true,
184
+ 'nstc-g6-common-btn-size-b': true
185
+ }
186
+ }
187
+ },
188
+
189
+ titleObj: {
190
+ set: '列设置',
191
+ export: '导出',
192
+ condition: '筛选'
193
+ },
194
+
195
+ options: [],
196
+ model: [],
197
+
198
+ result: [],
199
+ sortableInstance: null,
200
+ searchObj: {},
201
+ saveObj: {
202
+ userUnit: '',
203
+ userCondition: '',
204
+ pageUUID: '',
205
+ userId: '',
206
+ userExportUnit: ''
207
+ },
208
+ // 列表的
209
+ defaultSet: [],
210
+ cName: 'table-columns-global-set',
211
+
212
+ columns: [],
213
+
214
+ // 不能操作的选择项
215
+ isRequiredArr: [],
216
+
217
+ typeObj: {
218
+ set: 'userUnit',
219
+ export: 'userCondition',
220
+ condition: 'userExportUnit'
221
+ },
222
+
223
+ // 自定义表单和筛选的默认条件
224
+ defaultList: []
225
+ }
226
+ },
227
+
228
+ computed: {
229
+ _value: {
230
+ get() {
231
+ return this.value
232
+ },
233
+ set(val) {
234
+ this.$emit('input', val)
235
+ }
236
+ },
237
+ // 是否全选
238
+ isChkAll() {
239
+ let sum = 0
240
+ this.options.map((i) => {
241
+ i[`children`] && (sum += i[`children`].length)
242
+ })
243
+ return sum === this.result.length
244
+ },
245
+ // 页面名称
246
+ pageTitle() {
247
+ return this.titleObj[this.type]
248
+ },
249
+ dialogWidth() {
250
+ return '914px'
251
+ }
252
+ },
253
+
254
+ watch: {
255
+ value(val) {
256
+ // && !this[`hasInit_${this.type}`]
257
+ val && this.init()
258
+ }
259
+ },
260
+
261
+ methods: {
262
+ upDown(index) {
263
+ this.$set(this.arrowStates, index, !this.arrowStates[index])
264
+ },
265
+ /**
266
+ * 当左侧变化时, 左侧跟着变化
267
+ * options
268
+ * val
269
+ */
270
+ handleLeftChange(options) {
271
+ const resultIds = this.result.map((item) => item.id)
272
+ const leftCheckedArr = this.model.reduce(
273
+ (total, next) => [...total, ...next],
274
+ []
275
+ )
276
+
277
+ if (leftCheckedArr.length > resultIds.length) {
278
+ // 添加列
279
+ const id = leftCheckedArr.find((id) => !resultIds.includes(id))
280
+ const changeItem = options.find((item) => item.id === id)
281
+
282
+ this.result.push(changeItem)
283
+ } else {
284
+ // 删除列
285
+ const changeIndex = resultIds.findIndex(
286
+ (id) => !leftCheckedArr.includes(id)
287
+ )
288
+
289
+ this.result.splice(changeIndex, 1)
290
+ }
291
+ },
292
+
293
+ /**
294
+ * 左侧删除按钮
295
+ */
296
+ handleDel(item, index) {
297
+ this.result.splice(index, 1)
298
+
299
+ for (let i in this.model) {
300
+ const idx = this.model[i].findIndex((id) => id === item.id)
301
+
302
+ if (~idx) {
303
+ this.model[i].splice(idx, 1)
304
+ break
305
+ }
306
+ }
307
+ },
308
+
309
+ /**
310
+ * 保存自定义列
311
+ * @returns {Promise<void>}
312
+ */
313
+ async handleConfirm() {
314
+ if (['condition', 'set'].includes(this.type)) {
315
+ const k = this.type === 'set' ? 'userUnit' : 'userCondition'
316
+ if (this.result.length == 0) {
317
+ return this.$message.warning('至少勾选一个字段')
318
+ }
319
+ this.saveObj[k] = this.result.map((item) => item.id).join(',')
320
+ if (k == 'userUnit') {
321
+ this.saveObj['userCondition'] = null //防止设置自定义列或设置自定义筛选后,自定义列与自定义筛选相互影响
322
+ } else if (k == 'userCondition') {
323
+ this.saveObj['userUnit'] = null //防止设置自定义列或设置自定义筛选后,自定义列与自定义筛选相互影响
324
+ }
325
+ await axios
326
+ .put(`/bems/1.0/dynamicUnit/userUnit`, {
327
+ ...this.saveObj,
328
+ ...this.config
329
+ })
330
+ .then(() => {
331
+ this.$emit('update:defaultSet', this.result)
332
+ this.$emit('confirm', this.result)
333
+ this._value = false
334
+ // this.$message({
335
+ // type: 'success',
336
+ // message: '保存成功'
337
+ // })
338
+ // update Date
339
+ // this.init()
340
+ })
341
+ .catch((e) => {
342
+ this.$message({
343
+ type: 'error',
344
+ message: e.msg || '保存失败'
345
+ })
346
+ })
347
+ } else {
348
+ if (this.result.length == 0) {
349
+ return this.$message.warning('至少勾选一个字段')
350
+ }
351
+ await this.exportAction()
352
+ }
353
+ },
354
+
355
+ /**
356
+ * 重置选项
357
+ */
358
+ handleReset() {
359
+ this.init('reset')
360
+ },
361
+
362
+ handleDefaultSet(val) {
363
+ const ids = val.map((item) => item.id)
364
+
365
+ this.result = JSON.parse(JSON.stringify(val))
366
+ console.log('__log_result', this.result)
367
+ this.model = this.options.map((group) => {
368
+ let model = []
369
+
370
+ if (group.children) {
371
+ model = group.children
372
+ .map((item) => item.id)
373
+ .filter((id) => ids.includes(id))
374
+ }
375
+
376
+ return model
377
+ })
378
+ },
379
+
380
+ /**
381
+ * 初始化
382
+ * @param reset reset重置
383
+ * @returns {Promise<void>}
384
+ */
385
+ async init(reset) {
386
+ this.isRequiredArr = []
387
+ const { data } = await axios.get(`/bems/1.0/dynamicUnit`, this.config)
388
+ try {
389
+ // 全量的table列
390
+ let allUnit = []
391
+ if (this.type === 'set' || this.type === 'export') {
392
+ allUnit = JSON.parse(data[`allUnit`] || '[]')
393
+ } else if (this.type === 'condition') {
394
+ allUnit = JSON.parse(data[`allCondition`] || '[]')
395
+ }
396
+
397
+ // 用户默认选择的 userUnit
398
+ let key = ''
399
+ if (this.type === 'set') {
400
+ reset == 'reset' ? (data['userUnitList'] = data['userUnitList']) : ''
401
+ key = data[`userUnitList`] ? 'userUnitList' : 'defaultUnitList'
402
+ reset == 'reset' ? (key = 'userUnitList') : ''
403
+ this.defaultList = data[`defaultUnitList`]
404
+ } else if (this.type === 'condition') {
405
+ key = data[`userConditionList`]
406
+ ? 'userConditionList'
407
+ : 'defaultConditionList'
408
+ this.defaultList = data[`defaultConditionList`]
409
+ } else if (this.type === 'export') {
410
+ // 导出的字段在付款这边默认勾选是列显示的字段
411
+ key = data[`userUnitList`] ? 'userUnitList' : 'defaultUnitList'
412
+ reset == 'reset' ? (key = 'userUnitList') : ''
413
+ this.defaultList = data[`defaultUnitList`]
414
+ }
415
+ let userUnit = data[key]
416
+ console.log('__log_用户选择的', userUnit)
417
+
418
+ this.options = allUnit.map((group) => {
419
+ this.model.push([])
420
+
421
+ if (group.children) {
422
+ group.children = group.children.map((item) => {
423
+ !!item.isRequired && this.isRequiredArr.push(item.id)
424
+ return {
425
+ ...item,
426
+ label: item.name,
427
+ value: item.id,
428
+ disabled: false // 导出都可以勾选
429
+ }
430
+ })
431
+ }
432
+ this.arrowStates.push(false)
433
+ return group
434
+ })
435
+
436
+ this.handleDefaultSet(userUnit || [])
437
+
438
+ this.sortableInstance = new Sortable(
439
+ this.$refs[`table_columns_set_result`],
440
+ {
441
+ setData(dataTransfer) {
442
+ // to avoid Firefox bug
443
+ // Detail see : https://github.com/RubaXa/Sortable/issues/1012
444
+ dataTransfer.setData('Text', '')
445
+ },
446
+ onEnd: (evt) => {
447
+ const targetRow = this.result.splice(evt.oldIndex, 1)[0]
448
+
449
+ this.$nextTick(() => {
450
+ this.result.splice(evt.newIndex, 0, targetRow)
451
+ })
452
+ }
453
+ }
454
+ )
455
+ // type
456
+ this[`hasInit_${this.type}`] = true
457
+ //
458
+ } catch (e) {
459
+ console.log('__log_custom_column', e)
460
+ }
461
+ },
462
+
463
+ /**
464
+ * 全选 或 取消全选
465
+ */
466
+ chooseAllOrCancel() {
467
+ if (this.isChkAll) {
468
+ // this.model.map(i => {
469
+ // i.length = 0
470
+ // })
471
+ // this.handleDefaultSet([])
472
+ } else {
473
+ let arr = []
474
+ this.options.map((item, index) => {
475
+ if (item[`children`]) {
476
+ arr = arr.concat(item.children)
477
+ item.children.map((i) => {
478
+ !this.model[index].includes(i.id) && this.model[index].push(i.id)
479
+ })
480
+ }
481
+ })
482
+ this.handleDefaultSet(arr)
483
+ this.$forceUpdate()
484
+ console.log('__log_this.model', this.model)
485
+ }
486
+ },
487
+
488
+ /**
489
+ * 导出动作
490
+ */
491
+ async exportAction() {
492
+ // 导出默认10000
493
+ this.exportExcelConfig.searchObj[`page.size`] = 10000
494
+
495
+ let result = await axios({
496
+ url: this.exportExcelConfig.url,
497
+ method: this.exportExcelConfig.httpMethod,
498
+ [`${this.exportExcelConfig.httpMethod === 'get' ? 'params' : 'data'}`]:
499
+ this.exportExcelConfig.searchObj
500
+ })
501
+
502
+ this._value = false
503
+ console.log('返回结果', result)
504
+ result = result[`list`] || result
505
+
506
+ // 格式化导出数据
507
+ this.exportExcelConfig.formatData &&
508
+ (result = this.exportExcelConfig.formatData(result))
509
+
510
+ // 拼接导出结构
511
+ console.log('result', this.result)
512
+
513
+ this.excelExportAction(result)
514
+ },
515
+
516
+ /**
517
+ * 导出excel
518
+ * @param data 列表数据
519
+ */
520
+ excelExportAction(data) {
521
+ console.log('返回数据', data)
522
+ this.excelExportList = data
523
+ this.excelDownloadLoading = true
524
+ let that = this
525
+ import('@/utils/vendor/Export2Excel').then((excel) => {
526
+ const tHeader = this.result.map((i) => {
527
+ return i[`name`]
528
+ })
529
+ const keys = this.result.map((i) => {
530
+ return i[`id`]
531
+ })
532
+
533
+ // 格式化导出数据格式
534
+ const exportData = that.excelExportList.map((i) => {
535
+ const temp = []
536
+ keys.map((k) => {
537
+ temp.push(i[k])
538
+ })
539
+ return temp
540
+ })
541
+
542
+ console.log('___格式化数据', data, {
543
+ header: tHeader,
544
+ data: exportData,
545
+ filename: that.exportExcelConfig.exportFileName
546
+ })
547
+ let cellStyle = {}
548
+ if (that.exportExcelConfig.cellStyle) {
549
+ let cellStyleColName = this.result.filter(
550
+ (i) => that.exportExcelConfig.cellStyle[i.id]
551
+ )
552
+ let cellStyleMap = {}
553
+ cellStyleColName.forEach((i) => {
554
+ if (that.exportExcelConfig.cellStyle[i.id]) {
555
+ cellStyleMap[[i.name]] = that.exportExcelConfig.cellStyle[i.id]
556
+ }
557
+ })
558
+ let headerWs = excel.sheet_from_array_of_arrays([tHeader])
559
+ for (let colKey in headerWs) {
560
+ if (headerWs[colKey].v && cellStyleMap[headerWs[colKey].v]) {
561
+ let colName = colKey.slice(0, 1)
562
+ cellStyle[colName] = cellStyleMap[headerWs[colKey].v]
563
+ }
564
+ }
565
+ }
566
+
567
+ excel.export_json_to_excel(
568
+ {
569
+ header: tHeader,
570
+ data: exportData,
571
+ filename: that.exportExcelConfig.exportFileName,
572
+ merges: that.exportExcelConfig.merges
573
+ },
574
+ cellStyle
575
+ )
576
+ that.excelDownloadLoading = false
577
+ })
578
+ }
579
+ }
580
+ }
581
+ </script>
582
+
583
+ <style lang="scss">
584
+ .show-group {
585
+ max-height: 800px;
586
+ overflow: hidden;
587
+ transition: all 0.25s ease;
588
+ }
589
+
590
+ .arrowwz-change {
591
+ max-height: 0px;
592
+ }
593
+
594
+ .arrow-up {
595
+ font-size: 15px;
596
+ display: inline-block;
597
+ margin: 0px 3px;
598
+ cursor: pointer;
599
+ transition: all 0.25s linear;
600
+ }
601
+
602
+ .arrow-down {
603
+ transform: rotateZ(+90deg);
604
+ }
605
+
606
+ .export-excel {
607
+ .el-checkbox {
608
+ margin-right: 50px !important;
609
+ }
610
+
611
+ .el-checkbox:nth-child(5n) {
612
+ margin-right: 0;
613
+ }
614
+ }
615
+
616
+ // 导出模板
617
+
618
+ .table-columns-global-set {
619
+ &-group-name {
620
+ font-size: 14px;
621
+ color: #262d34;
622
+ }
623
+
624
+ .dialog-footer {
625
+ text-align: center;
626
+ }
627
+
628
+ // 弹框按钮样式
629
+ .nstc-dialog-footer-btn {
630
+ width: 90px;
631
+ height: 34px;
632
+ }
633
+
634
+ .nstc-dialog-footer-btn-clear {
635
+ margin-left: 15px;
636
+ }
637
+
638
+ padding: 15px 19px;
639
+
640
+ .el-dialog__header {
641
+ padding: 0 0 8px 0 !important;
642
+ text-align: left;
643
+
644
+ .el-icon-close {
645
+ transform: scale(1.4);
646
+ }
647
+ }
648
+
649
+ .el-dialog__body {
650
+ //border-top: 1px solid #dfe6ee;
651
+ padding: 15px 0;
652
+
653
+ .el-checkbox {
654
+ width: 15%;
655
+ margin-bottom: 20px;
656
+ }
657
+ }
658
+
659
+ .export-excel {
660
+ // border: none !important;
661
+ }
662
+
663
+ .el-checkbox__input {
664
+ transform: scale(1.2855);
665
+ }
666
+
667
+ .el-checkbox__label {
668
+ overflow: hidden;
669
+ vertical-align: middle;
670
+ text-overflow: ellipsis;
671
+ white-space: nowrap;
672
+ width: 100%;
673
+ }
674
+
675
+ .el-checkbox-group {
676
+ box-sizing: border-box;
677
+ padding-left: 2px;
678
+ margin-top: 12px;
679
+ }
680
+
681
+ &-inner {
682
+ display: flex;
683
+ height: 500px;
684
+
685
+ &-title {
686
+ padding: 0 10px 20px 0;
687
+ color: #8a8a8a;
688
+ display: flex;
689
+ justify-content: space-between;
690
+ font-weight: 700;
691
+
692
+ .title-temp {
693
+ span:nth-child(1) {
694
+ }
695
+
696
+ span:nth-child(2) {
697
+ color: #bac4cf;
698
+ font-size: 14px;
699
+ margin: 0 3px 0 13px;
700
+ }
701
+
702
+ span:nth-child(3) {
703
+ color: #007aff;
704
+ font-size: 14px;
705
+ }
706
+ }
707
+
708
+ .choose-all {
709
+ color: #007aff;
710
+ font-size: 14px;
711
+
712
+ &:hover {
713
+ cursor: pointer;
714
+ }
715
+ }
716
+ }
717
+
718
+ &-content {
719
+ flex: 1;
720
+ overflow-x: hidden;
721
+ overflow-y: auto;
722
+ }
723
+ }
724
+
725
+ &-left {
726
+ flex: 1;
727
+ border-right: 1px solid #dfe6ee;
728
+ }
729
+
730
+ &-right {
731
+ width: 180px;
732
+ padding-left: 10px;
733
+ margin: 0 0 0 10px;
734
+ }
735
+
736
+ &-left,
737
+ &-right {
738
+ display: flex;
739
+ flex-direction: column;
740
+ }
741
+
742
+ &-group {
743
+ & + & {
744
+ margin-top: 20px;
745
+ }
746
+
747
+ &-name {
748
+ color: #3d4a57;
749
+ font-weight: bold;
750
+ margin-bottom: 10px;
751
+ text-align: left;
752
+ }
753
+
754
+ .el-checkbox__label {
755
+ width: 92px;
756
+ white-space: nowrap;
757
+ overflow: hidden;
758
+ text-overflow: ellipsis;
759
+ vertical-align: middle;
760
+ line-height: 30px;
761
+ }
762
+ }
763
+
764
+ &-result-item {
765
+ padding: 9px 9px 0 0;
766
+ display: flex;
767
+ cursor: move;
768
+ align-items: center;
769
+ margin-right: 10px;
770
+
771
+ &:hover {
772
+ .close {
773
+ color: #007aff;
774
+ }
775
+ }
776
+
777
+ &:first-of-type {
778
+ margin-top: -7px;
779
+ }
780
+
781
+ & > span {
782
+ flex: 1;
783
+ overflow: hidden;
784
+ white-space: nowrap;
785
+ margin-right: 5px;
786
+ }
787
+
788
+ .el-button--mini {
789
+ padding: 0px;
790
+ }
791
+
792
+ .close {
793
+ z-index: 999;
794
+ }
795
+
796
+ .close:hover {
797
+ cursor: pointer;
798
+ }
799
+ }
800
+ }
801
+ </style>