n20-common-lib 1.3.9 → 1.3.12

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 (287) hide show
  1. package/nstc-g6/assets/svg/404.svg +1 -0
  2. package/nstc-g6/assets/svg/addFile.svg +32 -0
  3. package/nstc-g6/assets/svg/bug.svg +1 -0
  4. package/nstc-g6/assets/svg/chart.svg +1 -0
  5. package/nstc-g6/assets/svg/clipboard.svg +1 -0
  6. package/nstc-g6/assets/svg/component.svg +1 -0
  7. package/nstc-g6/assets/svg/dashboard.svg +1 -0
  8. package/nstc-g6/assets/svg/deleteFile.svg +28 -0
  9. package/nstc-g6/assets/svg/documentation.svg +1 -0
  10. package/nstc-g6/assets/svg/drag.svg +1 -0
  11. package/nstc-g6/assets/svg/edit.svg +1 -0
  12. package/nstc-g6/assets/svg/education.svg +1 -0
  13. package/nstc-g6/assets/svg/email.svg +1 -0
  14. package/nstc-g6/assets/svg/example.svg +1 -0
  15. package/nstc-g6/assets/svg/excel.svg +1 -0
  16. package/nstc-g6/assets/svg/exit-fullscreen.svg +1 -0
  17. package/nstc-g6/assets/svg/eye-open.svg +1 -0
  18. package/nstc-g6/assets/svg/eye.svg +1 -0
  19. package/nstc-g6/assets/svg/favorite.svg +1 -0
  20. package/nstc-g6/assets/svg/favorite_active.svg +1 -0
  21. package/nstc-g6/assets/svg/favorite_x400.svg +1 -0
  22. package/nstc-g6/assets/svg/favorite_x400_active.svg +1 -0
  23. package/nstc-g6/assets/svg/favorite_x400_blank.svg +1 -0
  24. package/nstc-g6/assets/svg/filter.svg +16 -0
  25. package/nstc-g6/assets/svg/filter@2x.png +0 -0
  26. package/nstc-g6/assets/svg/filterActive.svg +16 -0
  27. package/nstc-g6/assets/svg/filterClose@2x.png +0 -0
  28. package/nstc-g6/assets/svg/form.svg +1 -0
  29. package/nstc-g6/assets/svg/fullscreen.svg +1 -0
  30. package/nstc-g6/assets/svg/guide.svg +1 -0
  31. package/nstc-g6/assets/svg/hourglass.svg +19 -0
  32. package/nstc-g6/assets/svg/icon.svg +1 -0
  33. package/nstc-g6/assets/svg/international.svg +1 -0
  34. package/nstc-g6/assets/svg/language.svg +1 -0
  35. package/nstc-g6/assets/svg/left-dis.svg +1 -0
  36. package/nstc-g6/assets/svg/left.svg +1 -0
  37. package/nstc-g6/assets/svg/link.svg +1 -0
  38. package/nstc-g6/assets/svg/list.svg +1 -0
  39. package/nstc-g6/assets/svg/lock.svg +1 -0
  40. package/nstc-g6/assets/svg/message-t.svg +1 -0
  41. package/nstc-g6/assets/svg/money.svg +1 -0
  42. package/nstc-g6/assets/svg/money3.svg +1 -0
  43. package/nstc-g6/assets/svg/money4.svg +1 -0
  44. package/nstc-g6/assets/svg/moneyTwo.svg +1 -0
  45. package/nstc-g6/assets/svg/msg_white.svg +1 -0
  46. package/nstc-g6/assets/svg/nested.svg +1 -0
  47. package/nstc-g6/assets/svg/newsearch.svg +19 -0
  48. package/nstc-g6/assets/svg/password.svg +1 -0
  49. package/nstc-g6/assets/svg/pdf.svg +1 -0
  50. package/nstc-g6/assets/svg/people.svg +1 -0
  51. package/nstc-g6/assets/svg/peoples.svg +1 -0
  52. package/nstc-g6/assets/svg/phone.svg +1 -0
  53. package/nstc-g6/assets/svg/phone_msg.svg +1 -0
  54. package/nstc-g6/assets/svg/qq.svg +1 -0
  55. package/nstc-g6/assets/svg/right-dis.svg +1 -0
  56. package/nstc-g6/assets/svg/right.svg +1 -0
  57. package/nstc-g6/assets/svg/search.svg +1 -0
  58. package/nstc-g6/assets/svg/searchActive.svg +19 -0
  59. package/nstc-g6/assets/svg/shopping.svg +1 -0
  60. package/nstc-g6/assets/svg/size.svg +1 -0
  61. package/nstc-g6/assets/svg/skill.svg +1 -0
  62. package/nstc-g6/assets/svg/star.svg +1 -0
  63. package/nstc-g6/assets/svg/steam.svg +1 -0
  64. package/nstc-g6/assets/svg/tab.svg +1 -0
  65. package/nstc-g6/assets/svg/table.svg +1 -0
  66. package/nstc-g6/assets/svg/theme.svg +1 -0
  67. package/nstc-g6/assets/svg/tree-table.svg +1 -0
  68. package/nstc-g6/assets/svg/tree.svg +1 -0
  69. package/nstc-g6/assets/svg/user.svg +1 -0
  70. package/nstc-g6/assets/svg/wechat.svg +1 -0
  71. package/nstc-g6/assets/svg/z-left-2-dis.svg +1 -0
  72. package/nstc-g6/assets/svg/z-left-2.svg +1 -0
  73. package/nstc-g6/assets/svg/z-right-2-dis.svg +1 -0
  74. package/nstc-g6/assets/svg/z-right-2.svg +1 -0
  75. package/nstc-g6/assets/svg/z-right.svg +1 -0
  76. package/nstc-g6/assets/svg/zip.svg +1 -0
  77. package/nstc-g6/components/Calendar/index.js +8 -0
  78. package/nstc-g6/components/Calendar/src/basic/month-table.vue +129 -0
  79. package/nstc-g6/components/Calendar/src/basic/year-table.vue +126 -0
  80. package/nstc-g6/components/Calendar/src/main.vue +442 -0
  81. package/nstc-g6/components/DialogForm/index.js +8 -0
  82. package/nstc-g6/components/DialogForm/src/demo/index.vue +56 -0
  83. package/nstc-g6/components/DialogForm/src/main.vue +189 -0
  84. package/nstc-g6/components/Form/A_DEMO/component/originalForm.vue +281 -0
  85. package/nstc-g6/components/Form/A_DEMO/config/config_3.js +1222 -0
  86. package/nstc-g6/components/Form/A_DEMO/index.vue +803 -0
  87. package/nstc-g6/components/Form/AutocompleteCustom/index.vue +72 -0
  88. package/nstc-g6/components/Form/BusinessSpecific/InputMultiple.vue +191 -0
  89. package/nstc-g6/components/Form/BusinessSpecific/InputWithUnit.vue +128 -0
  90. package/nstc-g6/components/Form/BusinessSpecific/SelectTreeDialog.vue +233 -0
  91. package/nstc-g6/components/Form/BusinessSpecific/readme.md +7 -0
  92. package/nstc-g6/components/Form/CascaderCustom/index.vue +101 -0
  93. package/nstc-g6/components/Form/CheckboxCustom/index.vue +84 -0
  94. package/nstc-g6/components/Form/Component.vue +661 -0
  95. package/nstc-g6/components/Form/ComponentSecond.vue +650 -0
  96. package/nstc-g6/components/Form/DatepickerCustom/index.vue +130 -0
  97. package/nstc-g6/components/Form/InputAndDialog/index.js +15 -0
  98. package/nstc-g6/components/Form/InputAndDialog/src/main.vue +395 -0
  99. package/nstc-g6/components/Form/InputCustom/demo/index.vue +65 -0
  100. package/nstc-g6/components/Form/InputCustom/index.vue +307 -0
  101. package/nstc-g6/components/Form/IntervalinputCustom/demo/index.vue +31 -0
  102. package/nstc-g6/components/Form/IntervalinputCustom/index.vue +118 -0
  103. package/nstc-g6/components/Form/Item.vue +330 -0
  104. package/nstc-g6/components/Form/ItemSecond.vue +269 -0
  105. package/nstc-g6/components/Form/List.vue +146 -0
  106. package/nstc-g6/components/Form/ListSecond.vue +130 -0
  107. package/nstc-g6/components/Form/RadioCustom/index.vue +73 -0
  108. package/nstc-g6/components/Form/SelectAccount/index.js +15 -0
  109. package/nstc-g6/components/Form/SelectAccount/src/demo/index.vue +58 -0
  110. package/nstc-g6/components/Form/SelectAccount/src/main.vue +283 -0
  111. package/nstc-g6/components/Form/SelectAndDialog/index.js +15 -0
  112. package/nstc-g6/components/Form/SelectAndDialog/src/main.vue +384 -0
  113. package/nstc-g6/components/Form/SelectCashFlow/index.js +15 -0
  114. package/nstc-g6/components/Form/SelectCashFlow/src/demo/index.vue +42 -0
  115. package/nstc-g6/components/Form/SelectCashFlow/src/main.vue +126 -0
  116. package/nstc-g6/components/Form/SelectCustom/demo/index.vue +82 -0
  117. package/nstc-g6/components/Form/SelectCustom/index.vue +488 -0
  118. package/nstc-g6/components/Form/SelectSubject/index.js +15 -0
  119. package/nstc-g6/components/Form/SelectSubject/src/demo/index.vue +85 -0
  120. package/nstc-g6/components/Form/SelectSubject/src/main.vue +182 -0
  121. package/nstc-g6/components/Form/SelectindialogCustom/demo/index.vue +188 -0
  122. package/nstc-g6/components/Form/SelectindialogCustom/index.vue +650 -0
  123. package/nstc-g6/components/Form/SelectindialogCustom/install.js +7 -0
  124. package/nstc-g6/components/Form/TableRadioCustom/demo/index.vue +53 -0
  125. package/nstc-g6/components/Form/TableRadioCustom/index.vue +183 -0
  126. package/nstc-g6/components/Form/TextCustom/index.vue +38 -0
  127. package/nstc-g6/components/Form/UploadCustom/demo/index.vue +31 -0
  128. package/nstc-g6/components/Form/UploadCustom/iconxitongshezhi-yichu.png +0 -0
  129. package/nstc-g6/components/Form/UploadCustom/index.vue +506 -0
  130. package/nstc-g6/components/Form/configs.js +191 -0
  131. package/nstc-g6/components/Form/configsSecond.js +161 -0
  132. package/nstc-g6/components/Form/index.js +8 -0
  133. package/nstc-g6/components/Form/index.scss +29 -0
  134. package/nstc-g6/components/Form/payeePersonSelect/index.js +15 -0
  135. package/nstc-g6/components/Form/payeePersonSelect/src/demo/index.vue +164 -0
  136. package/nstc-g6/components/Form/payeePersonSelect/src/main.vue +185 -0
  137. package/nstc-g6/components/Form/readme.txt +4 -0
  138. package/nstc-g6/components/FormGroup/index.js +8 -0
  139. package/nstc-g6/components/FormGroup/src/demo/config.js +23 -0
  140. package/nstc-g6/components/FormGroup/src/demo/index.vue +85 -0
  141. package/nstc-g6/components/FormGroup/src/main.vue +639 -0
  142. package/nstc-g6/components/FormGroup/src/validate.js +23 -0
  143. package/nstc-g6/components/InputTag/InputTag.vue +270 -0
  144. package/nstc-g6/components/NstcApprovel/NstcApprovel.vue +24 -0
  145. package/nstc-g6/components/NstcBackToTop/NstcBackToTop.vue +150 -0
  146. package/nstc-g6/components/NstcBranchLazyLoad/NstcBranchLazyLoad.vue +123 -0
  147. package/nstc-g6/components/NstcCharts/NstcCharts.vue +162 -0
  148. package/nstc-g6/components/NstcCharts/define.js +74 -0
  149. package/nstc-g6/components/NstcCharts/mixins/resize.js +56 -0
  150. package/nstc-g6/components/NstcConfirm/NstcConfirm.vue +152 -0
  151. package/nstc-g6/components/NstcConfirm/index.js +25 -0
  152. package/nstc-g6/components/NstcDialog/NstcDialog.vue +185 -0
  153. package/nstc-g6/components/NstcDialogForm/NstcDialogForm.vue +176 -0
  154. package/nstc-g6/components/NstcDialogTable/NstcDialogTable.vue +280 -0
  155. package/nstc-g6/components/NstcDropdown/NstcDropdown.vue +52 -0
  156. package/nstc-g6/components/NstcDropdownTree/NstcDropdownTree.vue +396 -0
  157. package/nstc-g6/components/NstcElectronicFile/NstcElectronicFile.vue +591 -0
  158. package/nstc-g6/components/NstcExcelCustomImport/NstcExcelCustomImport.vue +475 -0
  159. package/nstc-g6/components/NstcExcelCustomImport/img/upload@2x.png +0 -0
  160. package/nstc-g6/components/NstcExcelExport/NstcExcelExport.vue +145 -0
  161. package/nstc-g6/components/NstcExcelImport/NstcExcelImport.vue +1074 -0
  162. package/nstc-g6/components/NstcExcelImport/img/upload@2x.png +0 -0
  163. package/nstc-g6/components/NstcExcelImportN/NstcExcelImportN.vue +1166 -0
  164. package/nstc-g6/components/NstcExpandCollapse/NstcExpandCollapse.vue +130 -0
  165. package/nstc-g6/components/NstcExpandCollapse/index.scss +77 -0
  166. package/nstc-g6/components/NstcFileUpload/NstcFileUpload.vue +989 -0
  167. package/nstc-g6/components/NstcFileUpload/img/addFile.svg +32 -0
  168. package/nstc-g6/components/NstcFileUpload/img/delete.svg +24 -0
  169. package/nstc-g6/components/NstcFileUpload/img/deleteFile.svg +28 -0
  170. package/nstc-g6/components/NstcFileUpload/img/download.svg +24 -0
  171. package/nstc-g6/components/NstcFileUpload/img/inputUpload.svg +30 -0
  172. package/nstc-g6/components/NstcFileUpload/img/look-diabled.svg +24 -0
  173. package/nstc-g6/components/NstcFileUpload/img/look.svg +24 -0
  174. package/nstc-g6/components/NstcForm/A_DEMO/component/originalForm.vue +281 -0
  175. package/nstc-g6/components/NstcForm/A_DEMO/config/config_3.js +1222 -0
  176. package/nstc-g6/components/NstcForm/A_DEMO/index.vue +796 -0
  177. package/nstc-g6/components/NstcForm/AutocompleteCustom/index.vue +68 -0
  178. package/nstc-g6/components/NstcForm/BusinessSpecific/InputMultiple.vue +189 -0
  179. package/nstc-g6/components/NstcForm/BusinessSpecific/InputWithUnit.vue +128 -0
  180. package/nstc-g6/components/NstcForm/BusinessSpecific/SelectTreeDialog.vue +233 -0
  181. package/nstc-g6/components/NstcForm/BusinessSpecific/readme.md +7 -0
  182. package/nstc-g6/components/NstcForm/CascaderCustom/index.vue +101 -0
  183. package/nstc-g6/components/NstcForm/CheckboxCustom/index.vue +84 -0
  184. package/nstc-g6/components/NstcForm/Component.vue +684 -0
  185. package/nstc-g6/components/NstcForm/ComponentSecond.vue +650 -0
  186. package/nstc-g6/components/NstcForm/DatepickerCustom/index.vue +130 -0
  187. package/nstc-g6/components/NstcForm/InputAndDialog/NstcInputAndDialog.vue +389 -0
  188. package/nstc-g6/components/NstcForm/InputCustom/index.vue +314 -0
  189. package/nstc-g6/components/NstcForm/IntervalInputCustom/index.vue +116 -0
  190. package/nstc-g6/components/NstcForm/Item.vue +327 -0
  191. package/nstc-g6/components/NstcForm/ItemSecond.vue +269 -0
  192. package/nstc-g6/components/NstcForm/List.vue +146 -0
  193. package/nstc-g6/components/NstcForm/ListSecond.vue +130 -0
  194. package/nstc-g6/components/NstcForm/RadioCustom/index.vue +73 -0
  195. package/nstc-g6/components/NstcForm/SelectAccount/NstcSelectAccount.vue +334 -0
  196. package/nstc-g6/components/NstcForm/SelectAndDialog/NstcSelectAndDialog.vue +377 -0
  197. package/nstc-g6/components/NstcForm/SelectCashFlow/NstcSelectCashFlow.vue +123 -0
  198. package/nstc-g6/components/NstcForm/SelectCustom/index.vue +460 -0
  199. package/nstc-g6/components/NstcForm/SelectSubject/NstcSelectSubject.vue +185 -0
  200. package/nstc-g6/components/NstcForm/SelectindialogCustom/index.vue +648 -0
  201. package/nstc-g6/components/NstcForm/TableRadioCustom/index.vue +183 -0
  202. package/nstc-g6/components/NstcForm/TextCustom/index.vue +38 -0
  203. package/nstc-g6/components/NstcForm/UploadCustom/iconxitongshezhi-yichu.png +0 -0
  204. package/nstc-g6/components/NstcForm/UploadCustom/index.vue +500 -0
  205. package/nstc-g6/components/NstcForm/configs.js +191 -0
  206. package/nstc-g6/components/NstcForm/configsSecond.js +161 -0
  207. package/nstc-g6/components/NstcForm/index.js +8 -0
  208. package/nstc-g6/components/NstcForm/index.scss +29 -0
  209. package/nstc-g6/components/NstcForm/payeePersonSelect/NstcPayeePerson.vue +188 -0
  210. package/nstc-g6/components/NstcForm/readme.txt +4 -0
  211. package/nstc-g6/components/NstcPagination/NstcPagination.vue +428 -0
  212. package/nstc-g6/components/NstcPagination/setPageNum.png +0 -0
  213. package/nstc-g6/components/NstcPagination/setpagedefault.png +0 -0
  214. package/nstc-g6/components/NstcScreenFull/NstcScreenFull.vue +70 -0
  215. package/nstc-g6/components/NstcSelectTree/NstcSelectTree.vue +729 -0
  216. package/nstc-g6/components/NstcSelectTreeList/NstcSelectTreeList.vue +676 -0
  217. package/nstc-g6/components/NstcSticky/NstcSticky.vue +97 -0
  218. package/nstc-g6/components/NstcSvgIcon/NstcSvgIcon.vue +72 -0
  219. package/nstc-g6/components/NstcTab/NstcTab.vue +80 -0
  220. package/nstc-g6/components/NstcTabWithBadge/NstcTabWithBadge.vue +45 -0
  221. package/nstc-g6/components/NstcTabWithBadge/index.scss +31 -0
  222. package/nstc-g6/components/NstcTable/ElTableColumnCustom/index.vue +292 -0
  223. package/nstc-g6/components/NstcTable/NstcTable.vue +460 -0
  224. package/nstc-g6/components/NstcTableSet/NstcTableSet.vue +801 -0
  225. package/nstc-g6/components/NstcThemePicker/NstcThemePicker.vue +186 -0
  226. package/nstc-g6/components/NstcUploadCustomExcel/NstcUploadCustomExcel.vue +330 -0
  227. package/nstc-g6/components/NstcUploadExcel/NstcUploadExcel.vue +145 -0
  228. package/nstc-g6/components/NstcWorkBench/NstcWorkBench.vue +176 -0
  229. package/nstc-g6/components/Search/NstcSearch.vue +583 -0
  230. package/nstc-g6/components/Search/src/demo/index copy.vue +101 -0
  231. package/nstc-g6/components/Search/src/demo/index.vue +103 -0
  232. package/nstc-g6/components/Search/src/main copy.vue +607 -0
  233. package/nstc-g6/components/approvelTwo/main.vue +220 -0
  234. package/nstc-g6/components/approvelTwo/progress.vue +154 -0
  235. package/nstc-g6/directives/VCopy/index.js +60 -0
  236. package/nstc-g6/directives/VNstcNumber/index.js +14 -0
  237. package/nstc-g6/directives/VNstcNumber/temp.js +446 -0
  238. package/nstc-g6/index.js +193 -0
  239. package/nstc-g6/utils/auth.js +2 -0
  240. package/nstc-g6/utils/axios.js +2 -0
  241. package/nstc-g6/utils/dateAndValidator.js +649 -0
  242. package/nstc-g6/utils/debounce.js +40 -0
  243. package/nstc-g6/utils/parseTime.js +48 -0
  244. package/nstc-g6/utils/validate/index.js +7 -0
  245. package/nstc-g6/utils/vendor/Export2Excel.js +229 -0
  246. package/nstc-g6/utils/vendor/Export2Zip.js +24 -0
  247. package/nstc-g6/utils/vue-bus.js +5 -0
  248. package/package.json +9 -2
  249. package/src/assets/css/_coreLib.scss +9 -1
  250. package/src/assets/css/element-variables.scss +1 -1
  251. package/src/components/ChildRange/index.vue +2 -37
  252. package/src/components/ChildRange/style.scss +34 -0
  253. package/src/components/FileImport/index.vue +3 -1
  254. package/src/components/PageHeader/index.vue +2 -44
  255. package/src/components/PageHeader/style.scss +39 -0
  256. package/src/components/Search/index.vue +1 -97
  257. package/src/components/Search/style.scss +93 -0
  258. package/src/components/Table/ThSelectHeader.vue +2 -11
  259. package/src/components/Table/index.vue +4 -2
  260. package/src/directives/VTitle/index.js +14 -17
  261. package/style/css/normalize.scss +6 -6
  262. package/style/index.css +3 -3
  263. package/style/index.css.map +1 -1
  264. package/style/server-config.jsonc +527 -410
  265. package/treme/blue.css +3 -0
  266. package/treme/blue.umd.min.js +1 -0
  267. package/treme/css/normalize.scss +726 -0
  268. package/treme/fonts/element-icons.535877f5.woff +0 -0
  269. package/treme/fonts/element-icons.732389de.ttf +0 -0
  270. package/treme/fonts/iconfont.022f36c4.woff2 +0 -0
  271. package/treme/fonts/iconfont.4a1b2c93.woff +0 -0
  272. package/treme/fonts/iconfont.a9febaa2.ttf +0 -0
  273. package/treme/green.css +3 -0
  274. package/treme/green.umd.min.js +1 -0
  275. package/treme/lightBlue.css +3 -0
  276. package/treme/lightBlue.umd.min.js +1 -0
  277. package/treme/orange.css +3 -0
  278. package/treme/orange.umd.min.js +1 -0
  279. package/treme/pageDemo/demo-1.vue +131 -0
  280. package/treme/pageDemo/demo-2.vue +35 -0
  281. package/treme/pageDemo/demo-3.vue +22 -0
  282. package/treme/pageDemo/seeCode.js +20 -0
  283. package/treme/red.css +3 -0
  284. package/treme/red.umd.min.js +1 -0
  285. package/treme/server-config.jsonc +723 -0
  286. package/treme/yellow.css +3 -0
  287. package/treme/yellow.umd.min.js +1 -0
@@ -0,0 +1,183 @@
1
+ <template>
2
+ <div :key="key">
3
+ <!-- <el-button type="primary" @click="handle">清空</el-button> -->
4
+ <ElTableCustom
5
+ ref="tableSelect"
6
+ max-height="500"
7
+ :data="data"
8
+ :columns="_columns"
9
+ :show-pagination="showPagination"
10
+ :pagination.sync="_pagination"
11
+ @selection-change="handleSelectionChange"
12
+ @pagination-change="val => $emit('pagination-change', val)"
13
+ >
14
+ <template v-if="!multiple" v-slot:before>
15
+ <el-table-column
16
+ :width="45"
17
+ align="center"
18
+ header-align="center"
19
+ >
20
+ <template v-slot="{ row, $index }">
21
+ <el-radio
22
+ v-model="_value"
23
+ :label="$index"
24
+ :disabled="row.disabled"
25
+ >{{ '' }}</el-radio>
26
+ </template>
27
+ </el-table-column>
28
+ </template>
29
+ </ElTableCustom>
30
+ </div>
31
+ </template>
32
+
33
+ <script>
34
+ import ElTableCustom from '../../NstcTable/NstcTable'
35
+
36
+ export default {
37
+ name: 'TableRadioCustom',
38
+
39
+ components: {
40
+ ElTableCustom
41
+ },
42
+
43
+ props: {
44
+ // 双向绑定值,单选时为{ [valueKey]: 'xxx', [labelKey]: 'xxx' },多选时为[{ [valueKey]: 'xxx', [labelKey]: 'xxx' }, { [valueKey]: 'xxx', [labelKey]: 'xxx' },...]
45
+ value: {
46
+ type: [Object, Array],
47
+ default: null
48
+ },
49
+
50
+ // 双向绑定值的valueKey,需对应到表格行数据的某个属性
51
+ valueKey: {
52
+ type: String,
53
+ default: 'key'
54
+ },
55
+
56
+ // 双向绑定值的labelKey,需对应到表格行数据的某个属性
57
+ labelKey: {
58
+ type: String,
59
+ default: 'name'
60
+ },
61
+
62
+ // 是否多选
63
+ multiple: {
64
+ type: Boolean,
65
+ default: false
66
+ },
67
+
68
+ // 列配置
69
+ columns: {
70
+ type: Array,
71
+ default: () => []
72
+ },
73
+
74
+ // 表格数据
75
+ data: {
76
+ type: Array,
77
+ default: () => []
78
+ },
79
+
80
+ // 分页器是否展示
81
+ showPagination: {
82
+ default: true,
83
+ type: Boolean
84
+ },
85
+
86
+ // 分页器
87
+ pagination: {
88
+ type: Object,
89
+ default: () => {
90
+ return {
91
+ page: 1,
92
+ limit: 20,
93
+ total: 0
94
+ }
95
+ }
96
+ }
97
+ },
98
+
99
+ data() {
100
+ return {
101
+ key: `TableRadioCustomID-${Math.random()
102
+ .toString(36)
103
+ .slice(2)}`
104
+ }
105
+ },
106
+
107
+ computed: {
108
+ _value: {
109
+ get() {
110
+ return this.data.findIndex(row => this.value && row[this.valueKey] === this.value[this.valueKey])
111
+ },
112
+ set(val) {
113
+ const row = this.data[val]
114
+ const res = {
115
+ ...row,
116
+ [this.valueKey]: row[this.valueKey],
117
+ [this.labelKey]: row[this.labelKey]
118
+ }
119
+
120
+ this.$emit('input', res)
121
+ this.$emit('change', res)
122
+ }
123
+ },
124
+
125
+ _columns() {
126
+ return this.multiple
127
+ ? [
128
+ {
129
+ type: 'selection',
130
+ width: 35
131
+ },
132
+ ...this.columns
133
+ ]
134
+ : this.columns
135
+ },
136
+
137
+ _pagination: {
138
+ get() {
139
+ return this.pagination
140
+ },
141
+ set(val) {
142
+ this.$emit('update:pagination', val)
143
+ }
144
+ }
145
+ },
146
+
147
+ watch: {
148
+ data: {
149
+ immediate: false,
150
+ handler(val) {
151
+ this.$nextTick(() => {
152
+ this.multiple && this.setSelectedRow(val)
153
+ })
154
+ }
155
+ }
156
+ },
157
+
158
+ methods: {
159
+ setSelectedRow(data) {
160
+ this.value && this.value.forEach((item) => {
161
+ const index = data.findIndex(row => row[this.valueKey] === item[this.valueKey])
162
+
163
+ this.$refs.tableSelect.$refs.elTable.toggleRowSelection(data[index], true)
164
+ })
165
+ },
166
+
167
+ handleSelectionChange(val) {
168
+ const res = val.map(item => ({
169
+ ...item,
170
+ [this.valueKey]: item[this.valueKey],
171
+ [this.labelKey]: item[this.labelKey]
172
+ }))
173
+
174
+ // this.$emit('input', res)
175
+ this.$emit('multiple-change', res)
176
+ }
177
+
178
+ // handle() {
179
+ // console.log(this._value = null)
180
+ // }
181
+ }
182
+ }
183
+ </script>
@@ -0,0 +1,38 @@
1
+ <template>
2
+ <span class="text-custom" :style="{width:parseFloat(width) + 'px'}">{{ getValue(value) }}</span>
3
+ </template>
4
+
5
+ <script>
6
+ export default {
7
+ name: 'TextCustom',
8
+
9
+ props: {
10
+ value: {
11
+ type: [String, Number, Array],
12
+ default: ''
13
+ },
14
+
15
+ width: {
16
+ type: [String, Number, Array],
17
+ default: 264
18
+ }
19
+ },
20
+
21
+ methods: {
22
+ getValue(value) {
23
+ if(value instanceof Array) {
24
+ return value.toString().replace(/,/g, '')
25
+ } else {
26
+ return value
27
+ }
28
+ }
29
+ }
30
+ }
31
+ </script>
32
+
33
+ <style>
34
+ .text-custom {
35
+ display: inline-block;
36
+ word-break: break-all;
37
+ }
38
+ </style>
@@ -0,0 +1,500 @@
1
+ <template>
2
+ <div
3
+ :key="key"
4
+ :class="[
5
+ 'upload-custom',
6
+ { 'is-multiple': multiple || valueClassification.img.length }
7
+ ]"
8
+ :style="{ width: `${_width}px` }"
9
+ >
10
+ <input
11
+ v-if="isChoosing"
12
+ ref="fileInput"
13
+ type="file"
14
+ :multiple="multiple"
15
+ @change="handleFileChange"
16
+ />
17
+ <el-button
18
+ v-if="!isView"
19
+ :loading="loading"
20
+ :icon="_icon"
21
+ :disabled="_disabled"
22
+ class="button-cancel"
23
+ @click="chooseFile"
24
+ >
25
+ <span>{{ text }}</span>
26
+ </el-button>
27
+
28
+ <template v-if="showFile">
29
+ <template v-if="!multiple && valueClassification.other.length">
30
+ <div v-if="fileName" class="upload-file-name" :title="fileName">
31
+ {{ fileName }}
32
+ </div>
33
+ <el-button
34
+ v-if="fileName"
35
+ class="upload-file-delete"
36
+ type="text"
37
+ @click="handleClickFileBtn"
38
+ >
39
+ {{ fileBtnName }}
40
+ </el-button>
41
+ </template>
42
+ <template v-else>
43
+ <div class="upload-file-other">
44
+ <div
45
+ v-for="(item, index) in valueClassification.other"
46
+ :key="index"
47
+ class="upload-file-other-item"
48
+ >
49
+ <div class="upload-file-name" :title="item.fileName">
50
+ {{ item.fileName }}
51
+ </div>
52
+ <el-button
53
+ class="upload-file-other-delete"
54
+ type="text"
55
+ @click="handleClickFileBtn(item)"
56
+ >
57
+ {{ fileBtnName }}
58
+ </el-button>
59
+ </div>
60
+ </div>
61
+ <div class="upload-file-img">
62
+ <div
63
+ v-for="(item, index) in valueClassification.img"
64
+ :key="index"
65
+ class="upload-file-img-item"
66
+ >
67
+ <el-image
68
+ :src="item.fileUrl"
69
+ :preview-src-list="getPreviewSrcList(index)"
70
+ />
71
+ <img
72
+ v-if="!isView"
73
+ :src="closeImg"
74
+ alt="#"
75
+ @click="handleDelete(item)"
76
+ />
77
+ </div>
78
+ </div>
79
+ </template>
80
+ </template>
81
+ </div>
82
+ </template>
83
+
84
+ <script>
85
+ import closeImg from './iconxitongshezhi-yichu.png'
86
+
87
+ import axios from '../../../../src/utils/axios'
88
+ // import OSS from 'ali-oss'
89
+
90
+ export default {
91
+ name: 'UploadCustom',
92
+
93
+ inheritAttrs: false,
94
+
95
+ props: {
96
+ text: {
97
+ type: String,
98
+ default: function () {
99
+ return '请选择附件'
100
+ }
101
+ },
102
+
103
+ icon: {
104
+ type: String,
105
+ default: undefined
106
+ },
107
+
108
+ value: {
109
+ // 值格式为单选{ fileName,fileUrl }/{ fileName,file },或者多选[{ fileName,fileUrl }]/[{ fileName,file }]
110
+ type: [Object, Array],
111
+ default: null
112
+ },
113
+
114
+ valueIsFileUrl: {
115
+ // true时,值返回格式为{ fileName,fileUrl };false时,值返回格式为{ fileName,file }(file为文件类型)
116
+ type: Boolean,
117
+ default: false
118
+ },
119
+
120
+ url: {
121
+ // 上传到自定义服务器的url
122
+ type: String,
123
+ default: null
124
+ },
125
+
126
+ disabled: {
127
+ // 是否禁用
128
+ type: Boolean,
129
+ default: false
130
+ },
131
+
132
+ showFile: {
133
+ // 是否展示长传结果
134
+ type: Boolean,
135
+ default: true
136
+ },
137
+
138
+ validator: {
139
+ // 上传前的验证,参数为typeCode(文件头前8位,用于检测文件真实格式), raw(文件buffer对象)
140
+ type: Function,
141
+ default: null
142
+ },
143
+
144
+ beforeChooseFile: {
145
+ // 选择文件前的前置函数
146
+ type: Function,
147
+ default: null
148
+ },
149
+
150
+ width: {
151
+ type: [String, Number],
152
+ default: undefined
153
+ },
154
+
155
+ max: {
156
+ // 多选时,最大上传文件个数
157
+ type: Number,
158
+ default: 5
159
+ },
160
+
161
+ multiple: {
162
+ // 是否支持多选
163
+ type: Boolean,
164
+ default: false
165
+ },
166
+
167
+ isView: {
168
+ // 是否仅查看
169
+ type: Boolean,
170
+ default: false
171
+ },
172
+
173
+ storeAsPrefix: {
174
+ // ali-oss上传路径前缀
175
+ type: String,
176
+ default: ''
177
+ }
178
+ },
179
+
180
+ data() {
181
+ return {
182
+ key: `UploadCustomID-${Math.random().toString(36).slice(2)}`,
183
+
184
+ loading: false,
185
+ isChoosing: false,
186
+ revokeObjectURL: [],
187
+ closeImg
188
+ }
189
+ },
190
+
191
+ computed: {
192
+ _value: {
193
+ get() {
194
+ return this.value
195
+ },
196
+ set(val) {
197
+ this.$emit('input', val)
198
+ this.$emit('change', val)
199
+ }
200
+ },
201
+
202
+ fileName() {
203
+ return !this.multiple && this._value && this._value.fileName
204
+ ? this._value.fileName
205
+ : ''
206
+ },
207
+
208
+ _width() {
209
+ return this.width ? (this.width + '').replace(/px/, '') : undefined
210
+ },
211
+
212
+ _icon() {
213
+ return this.icon ? this.icon : undefined
214
+ },
215
+
216
+ _disabled() {
217
+ return (
218
+ this.disabled ||
219
+ (Array.isArray(this._value) && this._value.length >= this.max)
220
+ )
221
+ },
222
+
223
+ valueClassification() {
224
+ const _value = this.multiple
225
+ ? this._value
226
+ : this._value
227
+ ? [this._value]
228
+ : []
229
+ const reg = /\.(png|jpg|gif|jpeg)$/
230
+
231
+ return _value.reduce(
232
+ (prev, file, index) => {
233
+ if (reg.test(file.fileName)) {
234
+ let fileUrl = ''
235
+
236
+ if (file.fileUrl) {
237
+ fileUrl = file.fileUrl
238
+ } else {
239
+ fileUrl = window.URL.createObjectURL(file.file)
240
+ this.revokeObjectURL.push(fileUrl)
241
+ }
242
+
243
+ prev.img.push({
244
+ fileUrl,
245
+ index,
246
+ ...file
247
+ })
248
+ } else {
249
+ prev.other.push({
250
+ ...file,
251
+ index
252
+ })
253
+ }
254
+
255
+ return prev
256
+ },
257
+ { img: [], other: [] }
258
+ )
259
+ },
260
+
261
+ getPreviewSrcList() {
262
+ return (index) => {
263
+ const imgUrls = this.valueClassification.img.map((item) => item.fileUrl)
264
+
265
+ return imgUrls.slice(index).concat(imgUrls.slice(0, index))
266
+ }
267
+ },
268
+
269
+ fileBtnName() {
270
+ return this.isView ? '下载' : '删除'
271
+ }
272
+ },
273
+
274
+ beforeDestroy() {
275
+ this.revokeObjectURL.forEach((fileUrl) =>
276
+ window.URL.revokeObjectURL(fileUrl)
277
+ )
278
+ },
279
+
280
+ methods: {
281
+ async chooseFile() {
282
+ try {
283
+ this.isChoosing = true
284
+ this.beforeChooseFile && (await this.beforeChooseFile())
285
+
286
+ await this.$nextTick()
287
+
288
+ this.$refs.fileInput.click()
289
+ } catch (err) {
290
+ console.error(err)
291
+ // this.$$message(err)
292
+ }
293
+ },
294
+
295
+ async handleFileChange(e) {
296
+ this.loading = true
297
+ this.isChoosing = false
298
+
299
+ try {
300
+ const files = Array.from(e.target.files)
301
+
302
+ await this.fileMaxCheck(files)
303
+ await Promise.all(files.map((file) => this.fileTypeCheck(file)))
304
+
305
+ const value = await Promise.all(
306
+ files.map((file) => this.singleFileUpload(file))
307
+ )
308
+
309
+ this._value = this.multiple ? [...this._value, ...value] : value[0]
310
+ } catch (err) {
311
+ // this.$$message(err.reason || '上传失败')
312
+ }
313
+
314
+ this.loading = false
315
+ },
316
+
317
+ async singleFileUpload(file) {
318
+ try {
319
+ const fileName = file.name
320
+
321
+ if (this.valueIsFileUrl) {
322
+ let fileUrl = ''
323
+
324
+ if (this.url) {
325
+ const fd = new FormData()
326
+
327
+ fd.append('file', file)
328
+
329
+ fileUrl = await axios.post(this.url, fd, {
330
+ headers: {
331
+ 'Content-Type': 'multipart/form-data'
332
+ }
333
+ })
334
+ } else {
335
+ }
336
+
337
+ return {
338
+ fileUrl,
339
+ fileName
340
+ }
341
+ }
342
+
343
+ return {
344
+ file,
345
+ fileName
346
+ }
347
+ } catch (err) {
348
+ return Promise.reject(err)
349
+ }
350
+ },
351
+
352
+ handleClickFileBtn(item) {
353
+ if (this.isView) {
354
+ window.open(item.fileUrl)
355
+ } else {
356
+ this.handleDelete(item)
357
+ }
358
+ },
359
+
360
+ handleDelete(item) {
361
+ if (this.multiple) {
362
+ this._value.splice(item.index, 1)
363
+ } else {
364
+ this._value = null
365
+ }
366
+ },
367
+
368
+ fileTypeCheck(raw) {
369
+ const _this = this
370
+
371
+ return new Promise((resolve, reject) => {
372
+ const reader = new FileReader()
373
+
374
+ reader.onload = async function (r) {
375
+ try {
376
+ const buffer = r.target.result
377
+ const dataview = new DataView(buffer)
378
+ const ints = new Uint16Array(buffer.byteLength)
379
+
380
+ for (let i = 0; i < 4; i++) {
381
+ ints[i] = dataview.getUint8(i)
382
+ }
383
+
384
+ const typeCode = ints
385
+ .reduce((acc, val) => acc + val.toString(16), '')
386
+ .slice(0, 8)
387
+ .toLowerCase()
388
+
389
+ if (typeof _this.validator === 'function') {
390
+ await _this.validator(typeCode, raw)
391
+ }
392
+
393
+ resolve()
394
+ } catch (err) {
395
+ reject(err)
396
+ }
397
+ }
398
+
399
+ reader.readAsArrayBuffer(raw)
400
+ })
401
+ },
402
+
403
+ fileMaxCheck(files) {
404
+ return new Promise((resolve, reject) => {
405
+ if (this.multiple && files.length + this._value.length > this.max) {
406
+ reject({ reason: `最多上传文件数:${this.max}` })
407
+ }
408
+
409
+ resolve()
410
+ })
411
+ }
412
+ }
413
+ }
414
+ </script>
415
+
416
+ <style lang="scss">
417
+ .upload-custom {
418
+ display: inline-flex;
419
+ align-items: center;
420
+ position: relative;
421
+ padding-right: 32px;
422
+ &.is-multiple {
423
+ display: inline-block;
424
+ }
425
+
426
+ .button-cancel {
427
+ flex: none;
428
+ width: auto;
429
+ display: inline-flex;
430
+ align-items: center;
431
+ i {
432
+ margin-right: 6px;
433
+ font-size: 9px;
434
+ }
435
+ }
436
+
437
+ input {
438
+ display: none;
439
+ }
440
+
441
+ .upload-file {
442
+ &-name {
443
+ font-size: 14px;
444
+ padding-left: 10px;
445
+ flex: auto;
446
+ overflow: hidden;
447
+ white-space: nowrap;
448
+ text-overflow: ellipsis;
449
+ }
450
+
451
+ &-delete {
452
+ position: absolute;
453
+ top: 9px;
454
+ right: 0;
455
+ }
456
+
457
+ &-other {
458
+ display: flex;
459
+ flex-wrap: wrap;
460
+ margin-top: 5px;
461
+ &-item {
462
+ flex: none;
463
+ display: flex;
464
+ align-items: center;
465
+ margin-right: 40px;
466
+ .upload-file-name {
467
+ padding-left: 0;
468
+ padding-right: 10px;
469
+ }
470
+ }
471
+ }
472
+
473
+ &-img {
474
+ display: flex;
475
+ margin-top: 5px;
476
+ flex-wrap: wrap;
477
+ &-item {
478
+ flex: none;
479
+ margin-right: 10px;
480
+ position: relative;
481
+ .el-image {
482
+ width: 72px;
483
+ height: 72px;
484
+ background-color: #fff;
485
+ border-radius: 2px;
486
+ border: #cfd8e6;
487
+ }
488
+ & > img {
489
+ position: absolute;
490
+ right: 0;
491
+ top: 0;
492
+ width: 16px;
493
+ height: 16px;
494
+ cursor: pointer;
495
+ }
496
+ }
497
+ }
498
+ }
499
+ }
500
+ </style>