ai.touchui-vue 1.30.2 → 1.30.4

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 (786) hide show
  1. package/README.md +21 -21
  2. package/lib/affix.js +2 -2
  3. package/lib/ai.touchui-vue.common.js +2393 -2382
  4. package/lib/align.js +2 -2
  5. package/lib/animation.js +2 -2
  6. package/lib/article.js +2 -2
  7. package/lib/box.js +2 -2
  8. package/lib/button.js +2 -2
  9. package/lib/calendar.js +2 -2
  10. package/lib/card-item.js +2 -2
  11. package/lib/card.js +2 -2
  12. package/lib/cascader.js +2 -2
  13. package/lib/center-scroll.js +2 -2
  14. package/lib/chat.js +7 -7
  15. package/lib/checkbox.js +2 -2
  16. package/lib/checkboxes.js +2 -2
  17. package/lib/collapse.js +8 -7
  18. package/lib/color.js +7 -7
  19. package/lib/countdown.js +2 -2
  20. package/lib/date-picker.js +30 -12
  21. package/lib/date-range.js +13 -14
  22. package/lib/dialog.js +2 -2
  23. package/lib/dis.js +2 -2
  24. package/lib/ellipsis.js +2 -2
  25. package/lib/emote.js +2 -2
  26. package/lib/export.js +5 -5
  27. package/lib/filter.js +2 -2
  28. package/lib/fix.js +2 -2
  29. package/lib/float.js +2 -2
  30. package/lib/flow.js +4 -4
  31. package/lib/form.js +2 -2
  32. package/lib/grid.js +2 -2
  33. package/lib/guider.js +2 -2
  34. package/lib/header.js +2 -2
  35. package/lib/hide.js +2 -2
  36. package/lib/icon.js +2 -2
  37. package/lib/import.js +2 -2
  38. package/lib/index.js +1 -1
  39. package/lib/index.js.LICENSE.txt +4 -0
  40. package/lib/input.js +2 -2
  41. package/lib/ip.js +2 -2
  42. package/lib/line.js +2 -2
  43. package/lib/loading.js +2 -2
  44. package/lib/locale/format.js +10 -10
  45. package/lib/longtap.js +2 -2
  46. package/lib/menu-icon.js +548 -547
  47. package/lib/message.js +2 -2
  48. package/lib/mixins/migrating.js +20 -20
  49. package/lib/mixins/transition.js +14 -14
  50. package/lib/msg.js +2 -2
  51. package/lib/org.js +10 -9
  52. package/lib/padding.js +2 -2
  53. package/lib/page.js +8 -7
  54. package/lib/param.js +2 -2
  55. package/lib/pic.js +2 -2
  56. package/lib/popup.js +2 -2
  57. package/lib/progress.js +2 -2
  58. package/lib/range.js +5 -5
  59. package/lib/rate.js +2 -2
  60. package/lib/reverser.js +2 -2
  61. package/lib/scroll.js +2 -2
  62. package/lib/segment.js +2 -2
  63. package/lib/select.js +2 -2
  64. package/lib/size.js +2 -2
  65. package/lib/skeleton.js +2 -2
  66. package/lib/slide.js +2 -2
  67. package/lib/space.js +2 -2
  68. package/lib/static/{net-mix.293a4b6.svg → net-mix.dc6e414.svg} +7 -7
  69. package/lib/step.js +2 -2
  70. package/lib/submit.js +2 -2
  71. package/lib/switch.js +2 -2
  72. package/lib/tab.js +2 -2
  73. package/lib/table.js +736 -742
  74. package/lib/tag.js +2 -2
  75. package/lib/timeline.js +2 -2
  76. package/lib/tip.js +2 -2
  77. package/lib/tooltip.js +2 -2
  78. package/lib/transfer.js +2 -2
  79. package/lib/tree.js +2 -2
  80. package/lib/upload.js +2 -2
  81. package/lib/utils/clickoutside.js +11 -11
  82. package/lib/utils/dom.js +13 -13
  83. package/lib/utils/filetransfer.js +4 -4
  84. package/lib/utils/jsencrypt/JSEncrypt.js +77 -77
  85. package/lib/utils/jsencrypt/JSEncryptRSAKey.js +115 -115
  86. package/lib/utils/jsencrypt/jselib/asn1js/asn1.js +4 -4
  87. package/lib/utils/jsencrypt/jselib/jsrsasign/asn1-1.0.js +734 -734
  88. package/lib/utils/jsencrypt/jselib/jsrsasign/yahoo.js +22 -22
  89. package/lib/utils/jsencrypt.js +260 -260
  90. package/lib/utils/md5.js +3 -3
  91. package/lib/utils/mime.js +2 -2
  92. package/lib/utils/ratio.js +54 -53
  93. package/lib/utils/sign.js +12 -12
  94. package/lib/utils/util.js +3 -3
  95. package/lib/utils/validate.js +11 -11
  96. package/package.json +160 -159
  97. package/packages/affix/index.js +8 -8
  98. package/packages/affix/src/affix.vue +139 -139
  99. package/packages/align/index.js +8 -8
  100. package/packages/align/src/directive.js +29 -29
  101. package/packages/animation/index.js +8 -8
  102. package/packages/animation/src/animation.vue +68 -68
  103. package/packages/article/index.js +8 -8
  104. package/packages/article/src/article.vue +23 -23
  105. package/packages/box/index.js +8 -8
  106. package/packages/box/src/box.vue +170 -170
  107. package/packages/button/index.js +8 -8
  108. package/packages/button/src/button.vue +162 -162
  109. package/packages/calendar/index.js +8 -8
  110. package/packages/calendar/src/calendar.vue +1142 -1142
  111. package/packages/card/index.js +10 -10
  112. package/packages/card/src/card-item.vue +92 -92
  113. package/packages/card/src/card.vue +175 -175
  114. package/packages/card-item/index.js +8 -8
  115. package/packages/cascader/index.js +8 -8
  116. package/packages/cascader/src/cascader.vue +814 -814
  117. package/packages/center-scroll/index.js +8 -8
  118. package/packages/center-scroll/src/center-scroll.vue +147 -147
  119. package/packages/chat/index.js +12 -12
  120. package/packages/chat/src/chat.vue +116 -116
  121. package/packages/checkbox/index.js +8 -8
  122. package/packages/checkbox/src/checkbox.vue +262 -262
  123. package/packages/checkboxes/index.js +8 -8
  124. package/packages/checkboxes/src/checkboxes.vue +97 -97
  125. package/packages/collapse/index.js +10 -10
  126. package/packages/collapse/src/collapse-item.vue +188 -188
  127. package/packages/collapse/src/collapse.vue +100 -100
  128. package/packages/color/index.js +8 -8
  129. package/packages/color/src/directive.js +42 -42
  130. package/packages/countdown/index.js +8 -8
  131. package/packages/countdown/src/countdown.vue +128 -128
  132. package/packages/date-picker/index.js +8 -8
  133. package/packages/date-picker/src/date-picker.vue +436 -432
  134. package/packages/date-picker/src/picker.vue +342 -342
  135. package/packages/date-range/index.js +8 -8
  136. package/packages/date-range/src/date-range.vue +384 -384
  137. package/packages/dialog/index.js +8 -8
  138. package/packages/dialog/src/dialog.vue +287 -287
  139. package/packages/dis/index.js +8 -8
  140. package/packages/dis/src/directive.js +42 -42
  141. package/packages/ellipsis/index.js +8 -8
  142. package/packages/ellipsis/src/ellipsis.vue +306 -306
  143. package/packages/emote/index.js +8 -8
  144. package/packages/emote/src/emote.vue +38 -38
  145. package/packages/export/index.js +8 -8
  146. package/packages/export/src/ajax.js +73 -73
  147. package/packages/export/src/export.vue +289 -289
  148. package/packages/filter/index.js +8 -8
  149. package/packages/filter/src/filter.vue +245 -245
  150. package/packages/fix/index.js +8 -8
  151. package/packages/fix/src/fix.vue +221 -221
  152. package/packages/float/index.js +16 -16
  153. package/packages/float/src/directive.js +20 -20
  154. package/packages/float/src/main.vue +642 -642
  155. package/packages/float/src/trigger.vue +31 -31
  156. package/packages/flow/index.js +8 -8
  157. package/packages/flow/src/flow.vue +234 -234
  158. package/packages/flow/src/flowItem.vue +61 -61
  159. package/packages/flow/src/flowLine.vue +168 -168
  160. package/packages/form/index.js +10 -10
  161. package/packages/form/src/form-item.vue +96 -96
  162. package/packages/form/src/form.vue +184 -184
  163. package/packages/grid/index.js +10 -10
  164. package/packages/grid/src/grid-item.vue +65 -65
  165. package/packages/grid/src/grid.vue +190 -190
  166. package/packages/grid-item/index.js +8 -8
  167. package/packages/guider/index.js +8 -8
  168. package/packages/guider/src/guider.vue +168 -168
  169. package/packages/header/index.js +8 -8
  170. package/packages/header/src/header.vue +111 -111
  171. package/packages/hide/index.js +8 -8
  172. package/packages/hide/src/directive.js +57 -57
  173. package/packages/icon/index.js +8 -8
  174. package/packages/icon/src/icon.vue +79 -79
  175. package/packages/import/index.js +8 -8
  176. package/packages/import/src/import.vue +279 -279
  177. package/packages/input/index.js +8 -8
  178. package/packages/input/src/calcTextareaHeight.js +104 -104
  179. package/packages/input/src/input.vue +653 -653
  180. package/packages/ip/index.js +8 -8
  181. package/packages/ip/src/ip.vue +143 -143
  182. package/packages/line/index.js +8 -8
  183. package/packages/line/src/line.vue +29 -29
  184. package/packages/loading/index.js +8 -8
  185. package/packages/loading/src/loading.js +58 -58
  186. package/packages/longtap/index.js +8 -8
  187. package/packages/longtap/src/longtap.js +95 -95
  188. package/packages/menu-icon/index.js +8 -8
  189. package/packages/menu-icon/src/menu-icon.vue +206 -206
  190. package/packages/message/index.js +8 -8
  191. package/packages/message/src/message.vue +9 -9
  192. package/packages/msg/index.js +8 -8
  193. package/packages/msg/src/msg.vue +227 -227
  194. package/packages/org/index.js +8 -8
  195. package/packages/org/src/org.vue +113 -113
  196. package/packages/org/src/orgItem.vue +63 -63
  197. package/packages/padding/index.js +8 -8
  198. package/packages/padding/src/padding.vue +105 -105
  199. package/packages/page/index.js +8 -8
  200. package/packages/page/src/page.vue +297 -297
  201. package/packages/param/index.js +8 -8
  202. package/packages/param/src/param.vue +226 -226
  203. package/packages/pic/index.js +8 -8
  204. package/packages/pic/src/pic-viewer.vue +331 -331
  205. package/packages/pic/src/pic.vue +144 -144
  206. package/packages/popup/index.js +12 -12
  207. package/packages/popup/src/popup-group.vue +47 -47
  208. package/packages/popup/src/popup-item.vue +163 -163
  209. package/packages/popup/src/popup.vue +350 -350
  210. package/packages/progress/index.js +8 -8
  211. package/packages/progress/src/progress.vue +306 -306
  212. package/packages/range/index.js +8 -8
  213. package/packages/range/src/range.vue +612 -612
  214. package/packages/rate/index.js +8 -8
  215. package/packages/rate/src/rate.vue +129 -129
  216. package/packages/reverser/index.js +8 -8
  217. package/packages/reverser/src/reverser.vue +49 -49
  218. package/packages/scroll/index.js +12 -12
  219. package/packages/scroll/src/scroll-point.vue +24 -24
  220. package/packages/scroll/src/scroll-sticky.vue +60 -60
  221. package/packages/scroll/src/scroll.vue +381 -381
  222. package/packages/segment/index.js +8 -8
  223. package/packages/segment/src/segment.vue +618 -618
  224. package/packages/select/index.js +8 -8
  225. package/packages/select/src/select.vue +1445 -1445
  226. package/packages/size/index.js +8 -8
  227. package/packages/size/src/directive.js +33 -33
  228. package/packages/skeleton/index.js +8 -8
  229. package/packages/skeleton/src/skeleton.vue +179 -179
  230. package/packages/slide/index.js +8 -8
  231. package/packages/slide/src/slide.vue +147 -147
  232. package/packages/space/index.js +8 -8
  233. package/packages/space/src/space.vue +53 -53
  234. package/packages/step/index.js +8 -8
  235. package/packages/step/src/step.vue +122 -122
  236. package/packages/submit/index.js +8 -8
  237. package/packages/submit/src/submit.vue +103 -103
  238. package/packages/switch/index.js +9 -9
  239. package/packages/switch/src/component.vue +131 -131
  240. package/packages/tab/index.js +10 -10
  241. package/packages/tab/src/tab-item.vue +85 -85
  242. package/packages/tab/src/tab.vue +590 -590
  243. package/packages/table/index.js +8 -8
  244. package/packages/table/src/table-body.vue +301 -301
  245. package/packages/table/src/table-config.vue +139 -139
  246. package/packages/table/src/table-head.vue +239 -239
  247. package/packages/table/src/table.vue +1455 -1458
  248. package/packages/tag/index.js +8 -8
  249. package/packages/tag/src/tag.vue +129 -129
  250. package/packages/theme/package.json +33 -33
  251. package/packages/theme/src/global/mixin.less +416 -416
  252. package/packages/theme/src/global/reset.less +27 -27
  253. package/packages/theme/src/less/component/affix.less +8 -8
  254. package/packages/theme/src/less/component/article-dark.less +6 -6
  255. package/packages/theme/src/less/component/article.less +39 -39
  256. package/packages/theme/src/less/component/box-dark.less +85 -85
  257. package/packages/theme/src/less/component/box.less +272 -272
  258. package/packages/theme/src/less/component/calendar-dark.less +111 -111
  259. package/packages/theme/src/less/component/calendar.less +282 -282
  260. package/packages/theme/src/less/component/card-dark.less +17 -17
  261. package/packages/theme/src/less/component/card.less +89 -89
  262. package/packages/theme/src/less/component/chat-dark.less +47 -47
  263. package/packages/theme/src/less/component/chat.less +71 -71
  264. package/packages/theme/src/less/component/code-dark.less +41 -41
  265. package/packages/theme/src/less/component/code.less +33 -33
  266. package/packages/theme/src/less/component/cover.less +4 -4
  267. package/packages/theme/src/less/component/dialog-dark.less +54 -54
  268. package/packages/theme/src/less/component/dialog.less +49 -49
  269. package/packages/theme/src/less/component/filter-dark.less +31 -31
  270. package/packages/theme/src/less/component/filter.less +97 -97
  271. package/packages/theme/src/less/component/float-dark.less +26 -26
  272. package/packages/theme/src/less/component/float.less +61 -61
  273. package/packages/theme/src/less/component/form-dark.less +45 -45
  274. package/packages/theme/src/less/component/form.less +322 -322
  275. package/packages/theme/src/less/component/gantt-dark.less +44 -44
  276. package/packages/theme/src/less/component/gantt.less +52 -52
  277. package/packages/theme/src/less/component/guider-dark.less +6 -6
  278. package/packages/theme/src/less/component/guider.less +15 -15
  279. package/packages/theme/src/less/component/header-dark.less +41 -41
  280. package/packages/theme/src/less/component/header.less +121 -121
  281. package/packages/theme/src/less/component/keyboard-dark.less +15 -15
  282. package/packages/theme/src/less/component/keyboard.less +21 -21
  283. package/packages/theme/src/less/component/line-dark.less +20 -20
  284. package/packages/theme/src/less/component/line.less +21 -21
  285. package/packages/theme/src/less/component/msg-dark.less +42 -42
  286. package/packages/theme/src/less/component/msg.less +102 -102
  287. package/packages/theme/src/less/component/page-dark.less +26 -26
  288. package/packages/theme/src/less/component/page.less +26 -26
  289. package/packages/theme/src/less/component/param-dark.less +31 -31
  290. package/packages/theme/src/less/component/param.less +136 -136
  291. package/packages/theme/src/less/component/popup-dark.less +20 -20
  292. package/packages/theme/src/less/component/popup.less +85 -85
  293. package/packages/theme/src/less/component/print.less +121 -121
  294. package/packages/theme/src/less/component/scroll-dark.less +19 -19
  295. package/packages/theme/src/less/component/scroll.less +47 -47
  296. package/packages/theme/src/less/component/skeleton-dark.less +29 -29
  297. package/packages/theme/src/less/component/skeleton.less +78 -78
  298. package/packages/theme/src/less/component/slide.less +70 -70
  299. package/packages/theme/src/less/component/space.less +2 -2
  300. package/packages/theme/src/less/component/step-dark.less +165 -165
  301. package/packages/theme/src/less/component/step.less +147 -147
  302. package/packages/theme/src/less/component/submit.less +40 -40
  303. package/packages/theme/src/less/component/tab-dark.less +221 -221
  304. package/packages/theme/src/less/component/tab.less +459 -459
  305. package/packages/theme/src/less/component/table-dark.less +196 -196
  306. package/packages/theme/src/less/component/table.less +425 -425
  307. package/packages/theme/src/less/component/timeline-dark.less +13 -13
  308. package/packages/theme/src/less/component/timeline.less +114 -114
  309. package/packages/theme/src/less/component/tip-dark.less +76 -76
  310. package/packages/theme/src/less/component/tip.less +139 -139
  311. package/packages/theme/src/less/component/tooltip-dark.less +105 -105
  312. package/packages/theme/src/less/component/tooltip.less +159 -159
  313. package/packages/theme/src/less/component/tree-dark.less +56 -56
  314. package/packages/theme/src/less/component/tree.less +148 -148
  315. package/packages/theme/src/less/element/align.less +32 -32
  316. package/packages/theme/src/less/element/animation.less +5 -5
  317. package/packages/theme/src/less/element/button-dark.less +29 -29
  318. package/packages/theme/src/less/element/button.less +65 -65
  319. package/packages/theme/src/less/element/center-scroll-dark.less +3 -3
  320. package/packages/theme/src/less/element/center-scroll.less +6 -6
  321. package/packages/theme/src/less/element/checkbox-dark.less +68 -68
  322. package/packages/theme/src/less/element/checkbox.less +73 -73
  323. package/packages/theme/src/less/element/color-dark.less +15 -15
  324. package/packages/theme/src/less/element/color.less +33 -33
  325. package/packages/theme/src/less/element/dis.less +9 -9
  326. package/packages/theme/src/less/element/ellipsis.less +35 -35
  327. package/packages/theme/src/less/element/emote.less +5 -5
  328. package/packages/theme/src/less/element/font-dark.less +9 -9
  329. package/packages/theme/src/less/element/font.less +8 -8
  330. package/packages/theme/src/less/element/hide-dark.less +114 -114
  331. package/packages/theme/src/less/element/hide.less +114 -114
  332. package/packages/theme/src/less/element/icon.less +297 -297
  333. package/packages/theme/src/less/element/input-dark.less +205 -205
  334. package/packages/theme/src/less/element/input.less +405 -405
  335. package/packages/theme/src/less/element/menu-icon.less +1 -1
  336. package/packages/theme/src/less/element/pic.less +18 -18
  337. package/packages/theme/src/less/element/progress-dark.less +37 -37
  338. package/packages/theme/src/less/element/progress.less +82 -82
  339. package/packages/theme/src/less/element/radio-dark.less +18 -18
  340. package/packages/theme/src/less/element/radio.less +11 -11
  341. package/packages/theme/src/less/element/range-dark.less +24 -24
  342. package/packages/theme/src/less/element/range.less +56 -56
  343. package/packages/theme/src/less/element/rate.less +17 -17
  344. package/packages/theme/src/less/element/segment-dark.less +119 -119
  345. package/packages/theme/src/less/element/segment.less +197 -197
  346. package/packages/theme/src/less/element/select-dark.less +167 -167
  347. package/packages/theme/src/less/element/select.less +431 -431
  348. package/packages/theme/src/less/element/size.less +10 -10
  349. package/packages/theme/src/less/element/switch-dark.less +7 -7
  350. package/packages/theme/src/less/element/switch.less +37 -37
  351. package/packages/theme/src/less/element/tag-dark.less +115 -115
  352. package/packages/theme/src/less/element/tag.less +159 -159
  353. package/packages/theme/src/less/element/upload-dark.less +26 -26
  354. package/packages/theme/src/less/element/upload.less +64 -64
  355. package/packages/theme/src/less/layout/fix.less +2 -2
  356. package/packages/theme/src/less/layout/flow.less +47 -47
  357. package/packages/theme/src/less/layout/grid-dark.less +28 -28
  358. package/packages/theme/src/less/layout/grid.less +172 -172
  359. package/packages/theme/src/less/layout/org-dark.less +2 -2
  360. package/packages/theme/src/less/layout/org.less +72 -72
  361. package/packages/theme/src/less/layout/padding.less +1 -1
  362. package/packages/theme/src/less/layout/reverser.less +8 -8
  363. package/packages/theme/src/less/theme/B-Design.less +159 -159
  364. package/packages/theme/src/less/theme/aiplan.less +159 -159
  365. package/packages/theme/src/less/theme/aiplangd.less +159 -159
  366. package/packages/theme/src/less/theme/chbn.less +159 -159
  367. package/packages/theme/src/less/theme/default.less +160 -160
  368. package/packages/theme/src/less/theme/dt.less +159 -159
  369. package/packages/theme/src/less/theme/ecloud.less +159 -159
  370. package/packages/theme/src/less/theme/hongkong.less +159 -159
  371. package/packages/theme/src/less/theme/narrow.less +160 -160
  372. package/packages/theme/src/less/theme/sdpf.less +160 -160
  373. package/packages/theme/src/less/theme/upc.less +159 -159
  374. package/packages/theme/src/less/theme/website.less +159 -159
  375. package/packages/theme/src/less/theme/zj.less +159 -159
  376. package/packages/timeline/index.js +8 -8
  377. package/packages/timeline/src/timeline.vue +84 -84
  378. package/packages/tip/index.js +8 -8
  379. package/packages/tip/src/tip.vue +226 -226
  380. package/packages/tooltip/index.js +8 -8
  381. package/packages/tooltip/src/directive.js +180 -180
  382. package/packages/tooltip/src/tooltip.vue +467 -467
  383. package/packages/transfer/index.js +8 -8
  384. package/packages/transfer/src/transfer.vue +293 -293
  385. package/packages/tree/index.js +8 -8
  386. package/packages/tree/src/tree.vue +518 -518
  387. package/packages/tree/src/treeItem.vue +443 -443
  388. package/packages/upload/index.js +8 -8
  389. package/packages/upload/src/upload.vue +860 -860
  390. package/src/index.js +207 -207
  391. package/src/locale/format.js +46 -46
  392. package/src/locale/index.js +48 -48
  393. package/src/locale/lang/en.js +207 -207
  394. package/src/locale/lang/zh-CN.js +207 -207
  395. package/src/mixins/blur.js +9 -9
  396. package/src/mixins/emitter.js +33 -33
  397. package/src/mixins/focus.js +9 -9
  398. package/src/mixins/locale.js +9 -9
  399. package/src/mixins/migrating.js +54 -54
  400. package/src/mixins/tip.js +10 -10
  401. package/src/mixins/transition.js +130 -130
  402. package/src/msg/index.js +107 -107
  403. package/src/svg/menu/main/abnormal-mix.svg +5 -5
  404. package/src/svg/menu/main/abnormal.svg +5 -5
  405. package/src/svg/menu/main/accountManager-mix.svg +5 -5
  406. package/src/svg/menu/main/accountManager.svg +5 -5
  407. package/src/svg/menu/main/agreement-mix.svg +7 -7
  408. package/src/svg/menu/main/agreement.svg +7 -7
  409. package/src/svg/menu/main/ai-mix.svg +5 -5
  410. package/src/svg/menu/main/archives-mix.svg +6 -6
  411. package/src/svg/menu/main/arrearsReport-mix.svg +17 -17
  412. package/src/svg/menu/main/arrearsReport.svg +17 -17
  413. package/src/svg/menu/main/bill-mix.svg +13 -13
  414. package/src/svg/menu/main/bill.svg +13 -13
  415. package/src/svg/menu/main/box-mix.svg +5 -5
  416. package/src/svg/menu/main/broadband-mix.svg +4 -4
  417. package/src/svg/menu/main/broadband.svg +4 -4
  418. package/src/svg/menu/main/card-mix.svg +5 -5
  419. package/src/svg/menu/main/card.svg +5 -5
  420. package/src/svg/menu/main/cash-mix.svg +5 -5
  421. package/src/svg/menu/main/cash.svg +5 -5
  422. package/src/svg/menu/main/cloud-mix.svg +4 -4
  423. package/src/svg/menu/main/cloud.svg +4 -4
  424. package/src/svg/menu/main/clue-mix.svg +10 -10
  425. package/src/svg/menu/main/clue.svg +10 -10
  426. package/src/svg/menu/main/commonUse-mix.svg +4 -4
  427. package/src/svg/menu/main/commonUse.svg +4 -4
  428. package/src/svg/menu/main/construction-mix.svg +7 -7
  429. package/src/svg/menu/main/construction.svg +7 -7
  430. package/src/svg/menu/main/contract-mix.svg +8 -8
  431. package/src/svg/menu/main/contract.svg +8 -8
  432. package/src/svg/menu/main/credit-mix.svg +5 -5
  433. package/src/svg/menu/main/credit.svg +5 -5
  434. package/src/svg/menu/main/data-mix.svg +5 -5
  435. package/src/svg/menu/main/data.svg +5 -5
  436. package/src/svg/menu/main/date-mix.svg +7 -7
  437. package/src/svg/menu/main/deposit-mix.svg +4 -4
  438. package/src/svg/menu/main/device-mix.svg +4 -4
  439. package/src/svg/menu/main/device.svg +4 -4
  440. package/src/svg/menu/main/discrepancy-mix.svg +5 -5
  441. package/src/svg/menu/main/door-mix.svg +6 -6
  442. package/src/svg/menu/main/fault-mix.svg +12 -12
  443. package/src/svg/menu/main/fault.svg +16 -16
  444. package/src/svg/menu/main/finance-mix.svg +11 -11
  445. package/src/svg/menu/main/finance.svg +13 -13
  446. package/src/svg/menu/main/flow-mix.svg +4 -4
  447. package/src/svg/menu/main/flow.svg +4 -4
  448. package/src/svg/menu/main/folder-mix.svg +4 -4
  449. package/src/svg/menu/main/folder.svg +4 -4
  450. package/src/svg/menu/main/friendly-mix.svg +5 -5
  451. package/src/svg/menu/main/fusion-mix.svg +5 -5
  452. package/src/svg/menu/main/fusion.svg +5 -5
  453. package/src/svg/menu/main/gift-mix.svg +8 -8
  454. package/src/svg/menu/main/gift.svg +8 -8
  455. package/src/svg/menu/main/gps-mix.svg +6 -6
  456. package/src/svg/menu/main/gps.svg +6 -6
  457. package/src/svg/menu/main/grid-mix.svg +7 -7
  458. package/src/svg/menu/main/grid.svg +7 -7
  459. package/src/svg/menu/main/group-mix.svg +4 -4
  460. package/src/svg/menu/main/group.svg +4 -4
  461. package/src/svg/menu/main/home-mix.svg +5 -5
  462. package/src/svg/menu/main/home.svg +8 -8
  463. package/src/svg/menu/main/ict-mix.svg +4 -4
  464. package/src/svg/menu/main/industry-mix.svg +5 -5
  465. package/src/svg/menu/main/industry.svg +5 -5
  466. package/src/svg/menu/main/info-mix.svg +9 -9
  467. package/src/svg/menu/main/info.svg +9 -9
  468. package/src/svg/menu/main/integral-mix.svg +5 -5
  469. package/src/svg/menu/main/integral.svg +5 -5
  470. package/src/svg/menu/main/internet-mix.svg +5 -5
  471. package/src/svg/menu/main/internet.svg +5 -5
  472. package/src/svg/menu/main/inventory-mix.svg +5 -5
  473. package/src/svg/menu/main/invoice-mix.svg +6 -6
  474. package/src/svg/menu/main/invoice.svg +14 -14
  475. package/src/svg/menu/main/iot-mix.svg +5 -5
  476. package/src/svg/menu/main/iot.svg +5 -5
  477. package/src/svg/menu/main/label-mix.svg +4 -4
  478. package/src/svg/menu/main/label.svg +4 -4
  479. package/src/svg/menu/main/love-mix.svg +6 -6
  480. package/src/svg/menu/main/love.svg +13 -13
  481. package/src/svg/menu/main/m1-mix.svg +4 -4
  482. package/src/svg/menu/main/m1.svg +4 -4
  483. package/src/svg/menu/main/m2-mix.svg +12 -12
  484. package/src/svg/menu/main/m2.svg +11 -11
  485. package/src/svg/menu/main/m3-mix.svg +6 -6
  486. package/src/svg/menu/main/m3.svg +7 -7
  487. package/src/svg/menu/main/m4-mix.svg +5 -5
  488. package/src/svg/menu/main/m4.svg +7 -7
  489. package/src/svg/menu/main/m5-mix.svg +8 -8
  490. package/src/svg/menu/main/m5.svg +10 -10
  491. package/src/svg/menu/main/mail-mix.svg +5 -5
  492. package/src/svg/menu/main/manual-mix.svg +11 -11
  493. package/src/svg/menu/main/manual.svg +11 -11
  494. package/src/svg/menu/main/market-mix.svg +4 -4
  495. package/src/svg/menu/main/market.svg +4 -4
  496. package/src/svg/menu/main/member-mix.svg +6 -6
  497. package/src/svg/menu/main/member.svg +6 -6
  498. package/src/svg/menu/main/menu-mix.svg +4 -4
  499. package/src/svg/menu/main/menu.svg +4 -4
  500. package/src/svg/menu/main/message-mix.svg +11 -11
  501. package/src/svg/menu/main/message.svg +11 -11
  502. package/src/svg/menu/main/namelist-mix.svg +4 -4
  503. package/src/svg/menu/main/namelist.svg +4 -4
  504. package/src/svg/menu/main/net-mix.svg +7 -7
  505. package/src/svg/menu/main/niche-mix.svg +12 -12
  506. package/src/svg/menu/main/niche.svg +12 -12
  507. package/src/svg/menu/main/notice-mix.svg +4 -4
  508. package/src/svg/menu/main/notice.svg +4 -4
  509. package/src/svg/menu/main/number-mix.svg +6 -6
  510. package/src/svg/menu/main/operations-mix.svg +4 -4
  511. package/src/svg/menu/main/operations.svg +4 -4
  512. package/src/svg/menu/main/order-mix.svg +8 -8
  513. package/src/svg/menu/main/order.svg +8 -8
  514. package/src/svg/menu/main/person-mix.svg +6 -6
  515. package/src/svg/menu/main/person.svg +6 -6
  516. package/src/svg/menu/main/phone-mix.svg +4 -4
  517. package/src/svg/menu/main/phone.svg +4 -4
  518. package/src/svg/menu/main/phoneBill-mix.svg +6 -6
  519. package/src/svg/menu/main/phoneBill.svg +6 -6
  520. package/src/svg/menu/main/preferential-mix.svg +5 -5
  521. package/src/svg/menu/main/preferential.svg +5 -5
  522. package/src/svg/menu/main/print-mix.svg +5 -5
  523. package/src/svg/menu/main/problem-mix.svg +4 -4
  524. package/src/svg/menu/main/problem.svg +4 -4
  525. package/src/svg/menu/main/process-mix.svg +4 -4
  526. package/src/svg/menu/main/process.svg +4 -4
  527. package/src/svg/menu/main/product-mix.svg +5 -5
  528. package/src/svg/menu/main/product.svg +6 -6
  529. package/src/svg/menu/main/qrCode-mix.svg +8 -8
  530. package/src/svg/menu/main/qrCode.svg +8 -8
  531. package/src/svg/menu/main/refuelingBag-mix-mix.svg +4 -4
  532. package/src/svg/menu/main/refuelingBag-mix.svg +4 -4
  533. package/src/svg/menu/main/reportForm-mix.svg +8 -8
  534. package/src/svg/menu/main/reportForm.svg +8 -8
  535. package/src/svg/menu/main/risk-mix.svg +16 -16
  536. package/src/svg/menu/main/risk.svg +17 -17
  537. package/src/svg/menu/main/robot-mix.svg +9 -9
  538. package/src/svg/menu/main/robot.svg +9 -9
  539. package/src/svg/menu/main/satisfaction-mix.svg +4 -4
  540. package/src/svg/menu/main/satisfaction.svg +4 -4
  541. package/src/svg/menu/main/scratchCard-mix.svg +4 -4
  542. package/src/svg/menu/main/sim-mix.svg +4 -4
  543. package/src/svg/menu/main/sim.svg +4 -4
  544. package/src/svg/menu/main/staging-mix.svg +4 -4
  545. package/src/svg/menu/main/staging.svg +4 -4
  546. package/src/svg/menu/main/survey-mix.svg +5 -5
  547. package/src/svg/menu/main/survey.svg +5 -5
  548. package/src/svg/menu/main/tasks-mix.svg +8 -8
  549. package/src/svg/menu/main/tasks.svg +8 -8
  550. package/src/svg/menu/main/telephone-mix.svg +4 -4
  551. package/src/svg/menu/main/topUp-mix.svg +5 -5
  552. package/src/svg/menu/main/trajectory-mix.svg +11 -11
  553. package/src/svg/menu/main/trajectory.svg +23 -23
  554. package/src/svg/menu/main/transmit-mix.svg +5 -5
  555. package/src/svg/menu/main/tv-mix.svg +6 -6
  556. package/src/svg/menu/main/unlock-mix.svg +4 -4
  557. package/src/svg/menu/main/unlock.svg +4 -4
  558. package/src/svg/menu/main/view-mix.svg +5 -5
  559. package/src/svg/menu/main/view.svg +5 -5
  560. package/src/svg/menu/main/visits-mix.svg +19 -19
  561. package/src/svg/menu/main/visits.svg +19 -19
  562. package/src/svg/menu/main/voice-mix.svg +4 -4
  563. package/src/svg/menu/main/voice.svg +4 -4
  564. package/src/svg/menu/main/wiki-mix.svg +4 -4
  565. package/src/svg/menu/main/wiki.svg +4 -4
  566. package/src/svg/menu/main/workOrder-mix.svg +6 -6
  567. package/src/svg/menu/main/workOrder.svg +14 -14
  568. package/src/svg/menu/patch/Mo-space.svg +2 -2
  569. package/src/svg/menu/patch/Mo.svg +3 -3
  570. package/src/svg/menu/patch/add-space.svg +3 -3
  571. package/src/svg/menu/patch/add.svg +3 -3
  572. package/src/svg/menu/patch/address-space.svg +3 -3
  573. package/src/svg/menu/patch/address.svg +3 -3
  574. package/src/svg/menu/patch/approve-space.svg +3 -3
  575. package/src/svg/menu/patch/approve.svg +4 -4
  576. package/src/svg/menu/patch/avoid-space.svg +3 -3
  577. package/src/svg/menu/patch/avoid.svg +3 -3
  578. package/src/svg/menu/patch/batch-space.svg +3 -3
  579. package/src/svg/menu/patch/batch.svg +5 -5
  580. package/src/svg/menu/patch/broadband-space.svg +3 -3
  581. package/src/svg/menu/patch/broadband.svg +4 -4
  582. package/src/svg/menu/patch/cancellation-space.svg +3 -3
  583. package/src/svg/menu/patch/cancellation.svg +3 -3
  584. package/src/svg/menu/patch/center-space.svg +3 -3
  585. package/src/svg/menu/patch/center.svg +5 -5
  586. package/src/svg/menu/patch/change-space.svg +3 -3
  587. package/src/svg/menu/patch/change.svg +4 -4
  588. package/src/svg/menu/patch/click-space.svg +3 -3
  589. package/src/svg/menu/patch/click.svg +4 -4
  590. package/src/svg/menu/patch/close-1-space.svg +3 -3
  591. package/src/svg/menu/patch/close-1.svg +3 -3
  592. package/src/svg/menu/patch/close-space.svg +2 -2
  593. package/src/svg/menu/patch/close.svg +3 -3
  594. package/src/svg/menu/patch/collect-space.svg +3 -3
  595. package/src/svg/menu/patch/collect.svg +3 -3
  596. package/src/svg/menu/patch/comment-space.svg +3 -3
  597. package/src/svg/menu/patch/comment.svg +3 -3
  598. package/src/svg/menu/patch/confirm-space.svg +3 -3
  599. package/src/svg/menu/patch/confirm.svg +3 -3
  600. package/src/svg/menu/patch/contract-space.svg +3 -3
  601. package/src/svg/menu/patch/contract.svg +3 -3
  602. package/src/svg/menu/patch/credit-space.svg +3 -3
  603. package/src/svg/menu/patch/credit.svg +5 -5
  604. package/src/svg/menu/patch/dataMonitoring-space.svg +3 -3
  605. package/src/svg/menu/patch/dataMonitoring.svg +3 -3
  606. package/src/svg/menu/patch/dedicatedCircuit-space.svg +3 -3
  607. package/src/svg/menu/patch/dedicatedCircuit.svg +3 -3
  608. package/src/svg/menu/patch/detail-space.svg +3 -3
  609. package/src/svg/menu/patch/detail.svg +3 -3
  610. package/src/svg/menu/patch/disassemb-space.svg +3 -3
  611. package/src/svg/menu/patch/disassemb.svg +3 -3
  612. package/src/svg/menu/patch/earnestMoney-space.svg +3 -3
  613. package/src/svg/menu/patch/earnestMoney.svg +3 -3
  614. package/src/svg/menu/patch/empower-space.svg +3 -3
  615. package/src/svg/menu/patch/empower.svg +3 -3
  616. package/src/svg/menu/patch/entrust-space.svg +3 -3
  617. package/src/svg/menu/patch/entrust.svg +3 -3
  618. package/src/svg/menu/patch/expedite-space.svg +4 -4
  619. package/src/svg/menu/patch/expedite.svg +4 -4
  620. package/src/svg/menu/patch/flow-space.svg +3 -3
  621. package/src/svg/menu/patch/flow.svg +3 -3
  622. package/src/svg/menu/patch/folder-space.svg +3 -3
  623. package/src/svg/menu/patch/folder.svg +3 -3
  624. package/src/svg/menu/patch/forbidden-space.svg +3 -3
  625. package/src/svg/menu/patch/forbidden.svg +3 -3
  626. package/src/svg/menu/patch/forward-space.svg +3 -3
  627. package/src/svg/menu/patch/forward.svg +3 -3
  628. package/src/svg/menu/patch/fusion-space.svg +3 -3
  629. package/src/svg/menu/patch/fusion.svg +6 -6
  630. package/src/svg/menu/patch/history-space.svg +3 -3
  631. package/src/svg/menu/patch/history.svg +3 -3
  632. package/src/svg/menu/patch/information-space.svg +3 -3
  633. package/src/svg/menu/patch/information.svg +3 -3
  634. package/src/svg/menu/patch/insert-space.svg +3 -3
  635. package/src/svg/menu/patch/insert.svg +3 -3
  636. package/src/svg/menu/patch/letv-space.svg +3 -3
  637. package/src/svg/menu/patch/letv.svg +3 -3
  638. package/src/svg/menu/patch/link-space.svg +3 -3
  639. package/src/svg/menu/patch/link.svg +3 -3
  640. package/src/svg/menu/patch/location-space.svg +3 -3
  641. package/src/svg/menu/patch/location.svg +3 -3
  642. package/src/svg/menu/patch/message-space.svg +3 -3
  643. package/src/svg/menu/patch/message.svg +4 -4
  644. package/src/svg/menu/patch/minus-space.svg +3 -3
  645. package/src/svg/menu/patch/minus.svg +3 -3
  646. package/src/svg/menu/patch/mms-space.svg +3 -3
  647. package/src/svg/menu/patch/mms.svg +3 -3
  648. package/src/svg/menu/patch/monitor-space.svg +3 -3
  649. package/src/svg/menu/patch/monitor.svg +3 -3
  650. package/src/svg/menu/patch/move-space.svg +3 -3
  651. package/src/svg/menu/patch/move.svg +3 -3
  652. package/src/svg/menu/patch/negative-space.svg +2 -2
  653. package/src/svg/menu/patch/negative.svg +3 -3
  654. package/src/svg/menu/patch/net-space.svg +2 -2
  655. package/src/svg/menu/patch/net.svg +3 -3
  656. package/src/svg/menu/patch/news-space.svg +3 -3
  657. package/src/svg/menu/patch/news.svg +3 -3
  658. package/src/svg/menu/patch/notice-space.svg +4 -4
  659. package/src/svg/menu/patch/notice.svg +5 -5
  660. package/src/svg/menu/patch/officialBusiness-space.svg +3 -3
  661. package/src/svg/menu/patch/officialBusiness.svg +4 -4
  662. package/src/svg/menu/patch/pay-space.svg +3 -3
  663. package/src/svg/menu/patch/pay.svg +3 -3
  664. package/src/svg/menu/patch/phone-space.svg +3 -3
  665. package/src/svg/menu/patch/phone.svg +5 -5
  666. package/src/svg/menu/patch/print-space.svg +3 -3
  667. package/src/svg/menu/patch/print.svg +5 -5
  668. package/src/svg/menu/patch/product-space.svg +3 -3
  669. package/src/svg/menu/patch/product.svg +5 -5
  670. package/src/svg/menu/patch/reservation-space.svg +3 -3
  671. package/src/svg/menu/patch/reservation.svg +3 -3
  672. package/src/svg/menu/patch/sale-space.svg +3 -3
  673. package/src/svg/menu/patch/sale.svg +5 -5
  674. package/src/svg/menu/patch/search-space.svg +3 -3
  675. package/src/svg/menu/patch/search.svg +3 -3
  676. package/src/svg/menu/patch/secure-space.svg +3 -3
  677. package/src/svg/menu/patch/secure.svg +5 -5
  678. package/src/svg/menu/patch/setup-space.svg +3 -3
  679. package/src/svg/menu/patch/setup.svg +3 -3
  680. package/src/svg/menu/patch/shift-space.svg +3 -3
  681. package/src/svg/menu/patch/shift.svg +3 -3
  682. package/src/svg/menu/patch/situation-space.svg +3 -3
  683. package/src/svg/menu/patch/situation.svg +3 -3
  684. package/src/svg/menu/patch/special-space.svg +3 -3
  685. package/src/svg/menu/patch/special.svg +3 -3
  686. package/src/svg/menu/patch/tabulation-space.svg +3 -3
  687. package/src/svg/menu/patch/tabulation.svg +8 -8
  688. package/src/svg/menu/patch/track-space.svg +3 -3
  689. package/src/svg/menu/patch/track.svg +5 -5
  690. package/src/svg/menu/patch/transaction-space.svg +3 -3
  691. package/src/svg/menu/patch/transaction.svg +6 -6
  692. package/src/svg/menu/patch/user-space.svg +3 -3
  693. package/src/svg/menu/patch/user.svg +3 -3
  694. package/src/svg/menu/patch/visualize-space.svg +3 -3
  695. package/src/svg/menu/patch/visualize.svg +4 -4
  696. package/src/svg/menu/patch/vnet-space.svg +3 -3
  697. package/src/svg/menu/patch/vnet.svg +3 -3
  698. package/src/tip/tip.js +160 -160
  699. package/src/utils/after-leave.js +27 -27
  700. package/src/utils/ajax.js +59 -59
  701. package/src/utils/array.js +24 -24
  702. package/src/utils/clickoutside.js +105 -105
  703. package/src/utils/compare.js +16 -16
  704. package/src/utils/date.js +34 -34
  705. package/src/utils/disabledArea.js +18 -18
  706. package/src/utils/dom.js +301 -301
  707. package/src/utils/filetransfer.js +287 -287
  708. package/src/utils/isModified.js +20 -20
  709. package/src/utils/jsencrypt/JSEncrypt.js +192 -192
  710. package/src/utils/jsencrypt/JSEncryptRSAKey.js +320 -320
  711. package/src/utils/jsencrypt/index.js +3 -3
  712. package/src/utils/jsencrypt/jselib/asn1js/asn1.d.ts +51 -51
  713. package/src/utils/jsencrypt/jselib/asn1js/asn1.js +565 -565
  714. package/src/utils/jsencrypt/jselib/asn1js/base64.d.ts +5 -5
  715. package/src/utils/jsencrypt/jselib/asn1js/base64.js +88 -88
  716. package/src/utils/jsencrypt/jselib/asn1js/hex.d.ts +3 -3
  717. package/src/utils/jsencrypt/jselib/asn1js/hex.js +64 -64
  718. package/src/utils/jsencrypt/jselib/asn1js/int10.d.ts +9 -9
  719. package/src/utils/jsencrypt/jselib/asn1js/int10.js +87 -87
  720. package/src/utils/jsencrypt/jselib/asn1js/oids.d.ts +9778 -9778
  721. package/src/utils/jsencrypt/jselib/asn1js/oids.js +1962 -1962
  722. package/src/utils/jsencrypt/jselib/jsbn/base64.d.ts +3 -3
  723. package/src/utils/jsencrypt/jselib/jsbn/base64.js +76 -76
  724. package/src/utils/jsencrypt/jselib/jsbn/jsbn.d.ts +98 -98
  725. package/src/utils/jsencrypt/jselib/jsbn/jsbn.js +1754 -1754
  726. package/src/utils/jsencrypt/jselib/jsbn/prng4.d.ts +10 -10
  727. package/src/utils/jsencrypt/jselib/jsbn/prng4.js +46 -46
  728. package/src/utils/jsencrypt/jselib/jsbn/rng.d.ts +3 -3
  729. package/src/utils/jsencrypt/jselib/jsbn/rng.js +78 -78
  730. package/src/utils/jsencrypt/jselib/jsbn/rsa.d.ts +23 -23
  731. package/src/utils/jsencrypt/jselib/jsbn/rsa.js +373 -373
  732. package/src/utils/jsencrypt/jselib/jsbn/util.d.ts +7 -7
  733. package/src/utils/jsencrypt/jselib/jsbn/util.js +58 -58
  734. package/src/utils/jsencrypt/jselib/jsrsasign/asn1-1.0.js +1593 -1593
  735. package/src/utils/jsencrypt/jselib/jsrsasign/yahoo.js +63 -63
  736. package/src/utils/jsencrypt/util.js +58 -58
  737. package/src/utils/jsencrypt.js +263 -263
  738. package/src/utils/md5.js +203 -203
  739. package/src/utils/merge.js +15 -15
  740. package/src/utils/mime.js +75 -75
  741. package/src/utils/print.js +39 -39
  742. package/src/utils/ratio.js +230 -230
  743. package/src/utils/respo.js +9 -9
  744. package/src/utils/shared.js +7 -7
  745. package/src/utils/sign.js +185 -185
  746. package/src/utils/string.js +13 -13
  747. package/src/utils/theme.js +91 -91
  748. package/src/utils/types.js +40 -40
  749. package/src/utils/util.js +286 -286
  750. package/src/utils/uuid.js +12 -12
  751. package/src/utils/validate.js +373 -373
  752. package/packages/.DS_Store +0 -0
  753. package/packages/article/.DS_Store +0 -0
  754. package/packages/chat/.DS_Store +0 -0
  755. package/packages/chat/src/.DS_Store +0 -0
  756. package/packages/date-picker/.DS_Store +0 -0
  757. package/packages/dis/.DS_Store +0 -0
  758. package/packages/emote/.DS_Store +0 -0
  759. package/packages/filter/.DS_Store +0 -0
  760. package/packages/filter/src/.DS_Store +0 -0
  761. package/packages/float/.DS_Store +0 -0
  762. package/packages/flow/.DS_Store +0 -0
  763. package/packages/guider/.DS_Store +0 -0
  764. package/packages/ip/.DS_Store +0 -0
  765. package/packages/org/.DS_Store +0 -0
  766. package/packages/page/.DS_Store +0 -0
  767. package/packages/page/src/.DS_Store +0 -0
  768. package/packages/pic/.DS_Store +0 -0
  769. package/packages/rate/.DS_Store +0 -0
  770. package/packages/reverser/.DS_Store +0 -0
  771. package/packages/reverser/src/.DS_Store +0 -0
  772. package/packages/segment/.DS_Store +0 -0
  773. package/packages/slide/.DS_Store +0 -0
  774. package/packages/tab/.DS_Store +0 -0
  775. package/packages/table/.DS_Store +0 -0
  776. package/packages/theme/src/.DS_Store +0 -0
  777. package/packages/theme/src/img/.DS_Store +0 -0
  778. package/packages/theme/src/img/emote/.DS_Store +0 -0
  779. package/packages/theme/src/less/.DS_Store +0 -0
  780. package/packages/theme/src/less/theme/.DS_Store +0 -0
  781. package/packages/tooltip/.DS_Store +0 -0
  782. package/packages/tree/.DS_Store +0 -0
  783. package/packages/upload/.DS_Store +0 -0
  784. package/src/.DS_Store +0 -0
  785. package/src/svg/.DS_Store +0 -0
  786. package/src/svg/menu/.DS_Store +0 -0
@@ -1,860 +1,860 @@
1
- <template>
2
- <div class="to-upload" :class="setClass" :style="setStyle">
3
- <span v-if="verifiable && validateRequired" v-show="false" class="to-validate" :req="validateRequired" :desc="validateDesc" :value="validateValue"></span>
4
- <form ref="upForm" encType="multipart/form-data"><input ref="fileInput" :accept="accept" type="file" :multiple="Number(maxLength) > 1" style="position:absolute;width:0px;height:0px;left:-99999px;top:-99999px;" @change="fileInputChange" /></form>
5
- <to-input v-if="mode === 'input'" :class="setInputClass" :verifiable="false" type="html" width="full" v-bind="inputProps" :html="tipMessage">
6
- <to-button icon="browse" mode="none" link color="primary" @click="browse"></to-button>
7
- <to-button v-if="Object.keys(iFiles).length > 0 && !auto" icon="upload" mode="plain" link color="primary" @click="upload(iFiles)">{{ t('to.upload.button') }}</to-button>
8
- </to-input>
9
- <div v-if="mode === 'button'">
10
- <to-button
11
- v-size="buttonProps.size ? buttonProps.size : 1"
12
- :icon="buttonProps.icon ? buttonProps.icon : 'upload'"
13
- v-bind="buttonProps"
14
- :class="setInputClass"
15
- @click="browse"
16
- >
17
- {{ buttonProps.text ? buttonProps.text : t('to.upload.button') }}
18
- </to-button>
19
- </div>
20
- <span v-if="errorTip" v-color="'danger'" class="to-box-tip">
21
- <template v-if="errorType === 'rule'">
22
- 选择有误
23
- <to-icon v-tip.danger="errorTip" value="help" color="danger" mode="toast" fillet="round"></to-icon>
24
- </template>
25
- <template v-else>
26
- 不能为空
27
- </template>
28
- </span>
29
- <slot :oldFiles="finishedFiles" :files="iFiles">
30
- <template v-if="mode === 'img'">
31
- <div v-dis="vmDisabled" class="to-uploadImgGroup">
32
- <template v-if="Object.keys(iFiles).length + finishedFiles.length > 0">
33
- <div v-for="(file, index) in finishedFiles" :key="index" v-tip="picSize === 's' ? file.name :''" :style="file.iconClassName === 'img' ? { backgroundImage: `url(${file.fileObject.src})`} : ''" class="to-uploadImg" @click="openViewer(file,index,true)">
34
- <div v-if="file.iconClassName !== 'img'" class="to-uploadFile">
35
- <to-icon v-color="getColor(file.iconClassName)" :value="file.iconClassName" class="to-uploadFileIcon"></to-icon>
36
- <span v-if="picSize !== 's'" class="to-uploadFileName">{{ file.name }}</span>
37
- </div>
38
- <div class="to-uploadFn">
39
- <to-icon value="download" @click.stop="downloadFile(file)"></to-icon>
40
- <to-icon value="delete" @click.stop="deleteOldFile(file[fileIdText])"></to-icon>
41
- </div>
42
- </div>
43
- <div v-for="(file, index) in iFiles" :key="index" v-tip="picSize === 's' ? file.name :''" :style="file.iconClassName === 'img' ? { backgroundImage: `url(${file.fileObject.src})`} : ''" class="to-uploadImg" @click="openViewer(file,index,true)">
44
- <div v-if="file.iconClassName !== 'img'" class="to-uploadFile">
45
- <to-icon v-color="getColor(file.iconClassName)" :value="file.iconClassName" class="to-uploadFileIcon"></to-icon>
46
- <span v-if="picSize !== 's'" class="to-uploadFileName">{{ file.name }}</span>
47
- </div>
48
- <span v-if="file.status === 1" class="to-uploadProgress to-progress to-progress-type-normal to-progress-fillet-pill">
49
- <span class="to-progressBar" style="font-size:20%;">
50
- <span class="to-progressProgress" :style="`width:${file.percent}%;`"></span>
51
- </span>
52
- </span>
53
- <div v-if="file.status === 3" class="to-uploadError">{{ file.tipText }}</div>
54
- <to-icon v-if="file.status === 2" class="to-uploadSuccess" value="ok"></to-icon>
55
- <div class="to-uploadFn">
56
- <to-icon v-if="file.status === 2 && downloadable" value="download" @click.stop="downloadFile(file)"></to-icon>
57
- <to-icon value="delete" @click.stop="deleteFile(file)"></to-icon>
58
- </div>
59
- </div>
60
- </template>
61
- <div v-if="(Object.keys(iFiles).length + finishedFiles.length) < Number(maxLength)" class="to-uploadAdd" @click="browse">
62
- <to-icon value="add"></to-icon>
63
- </div>
64
- <picViewer v-if="showViewer" :z-index="2000" :initial-index="imgIndex" :on-close="() => {showViewer = false}" :url-list="previewSrcList"></picViewer>
65
- </div>
66
- <template v-if="Object.keys(iFiles).length > 0 && !auto">
67
- <to-space :value="0.5"></to-space>
68
- <to-button icon="upload" mode="plain" link color="primary" @click="upload">{{ t('to.upload.button') }}</to-button>
69
- </template>
70
- </template>
71
- <template v-else>
72
- <template v-if="Object.keys(iFiles).length + finishedFiles.length > 0">
73
- <to-space :value="0.5"></to-space>
74
- <to-grid v-dis="vmDisabled" :col="1">
75
- <to-grid-item v-for="(file, index) in finishedFiles" :key="index">
76
- <to-card :padding="0.5">
77
- <to-card-item><to-icon :value="file.iconClassName"></to-icon></to-card-item>
78
- <to-card-item v-align="'left'" main>
79
- <to-ellipsis tip :data="file.name"></to-ellipsis>
80
- </to-card-item>
81
- <to-card-item>
82
- <span v-color="'info'">{{ file.tipText }}</span>
83
- </to-card-item>
84
- <to-card-item>
85
- <to-icon fillet="round" color="primary" value="download" mode="none" link @click="downloadFile(file)"></to-icon>
86
- <to-icon fillet="round" color="primary" value="delete" mode="none" link @click="deleteOldFile(file[fileIdText])"></to-icon>
87
- </to-card-item>
88
- </to-card>
89
- </to-grid-item>
90
- <to-grid-item v-for="file in iFiles" :key="file.guid" :ref="file.guid + '_li'">
91
- <to-card :padding="0.5">
92
- <to-card-item><to-icon :class="file.status !== 2 ?'to-dis':''" :value="file.iconClassName"></to-icon></to-card-item>
93
- <to-card-item v-align="'left'" main>
94
- <to-ellipsis tip :data="file.name"></to-ellipsis>
95
- </to-card-item>
96
- <to-card-item>
97
- <span v-if="file.status === 3" class="to-color-danger">{{ file.tipText }}</span>
98
- </to-card-item>
99
- <to-card-item>
100
- <to-icon v-if="file.status === 2" fillet="round" color="success" value="ok" mode="none"></to-icon>
101
- <to-icon v-if="file.status === 2 && downloadable" fillet="round" color="primary" value="download" mode="none" link @click="downloadFile(file)"></to-icon>
102
- <to-icon :class="file.status === 1?'to-dis':''" fillet="round" color="primary" value="delete" mode="none" link @click="deleteFile(file)"></to-icon>
103
- </to-card-item>
104
- <span v-if="file.status === 1" class="to-uploadProgress to-progress to-progress-type-normal to-progress-fillet-pill">
105
- <span class="to-progressBar" style="font-size:20%;">
106
- <span class="to-progressProgress" :style="`width:${file.percent}%;`"></span>
107
- </span>
108
- </span>
109
- </to-card>
110
- </to-grid-item>
111
- </to-grid>
112
- </template>
113
- </template>
114
- </slot>
115
- </div>
116
- </template>
117
- <script>
118
- import Locale from 'ai.touchui-vue/src/mixins/locale'
119
- import Tip from 'ai.touchui-vue/src/mixins/tip'
120
- import FileTransfer from 'ai.touchui-vue/src/utils/filetransfer'
121
- import { isString } from 'ai.touchui-vue/src/utils/types'
122
- import { md5 } from 'ai.touchui-vue/src/utils/md5'
123
- import { transferSign } from 'ai.touchui-vue/src/utils/sign'
124
- import picViewer from '../../pic/src/pic-viewer'
125
- import { t } from 'ai.touchui-vue/src/locale'
126
- import Vue from 'vue'
127
- const EXT = {
128
- excel: ['.xls', '.xlsx', '.csv', '.XLS', '.XLSX', '.CSV'],
129
- img: ['.png', '.jpg', '.gif', '.PNG', '.JPG', '.GIF'],
130
- ppt: ['.ppt', '.pptx', '.ppsx', '.PPT', '.PPTX', '.PPSX'],
131
- rar: ['.rar', '.zip', '.tar', '.gz', '.tgz', '.RAR', '.ZIP', '.TAR', '.GZ', '.TGZ'],
132
- video: ['.rm', '.rmvb', '.avi', '.mkv', '.mp4', '.wmv', '.mov', '.movie', '.mpeg', '.mpg', '.qt', '.RM', '.RMVB', '.AVI', '.MKV', '.MP4', '.WMV', '.MOV', 'MOVIE', '.MPEG', '.MPG', '.QT'],
133
- voice: ['.mp2', '.mp3', '.wma', '.midi', '.MP2', '.MP3', '.WMA', '.MIDI'],
134
- word: ['.doc', '.docx', '.DOC', '.DOCX']
135
- }
136
-
137
- const ICON = {
138
- excel: 'excel',
139
- img: 'img',
140
- ppt: 'ppt',
141
- rar: 'rar',
142
- video: 'video',
143
- voice: 'voice',
144
- word: 'word',
145
- unknown: 'file'
146
- }
147
-
148
- export default {
149
- name: 'ToUpload',
150
- componentName: 'ToUpload',
151
- components: {
152
- picViewer
153
- },
154
- mixins: [Locale, Tip],
155
- inject: {
156
- ToForm: {
157
- default: ''
158
- },
159
- ToFormItem: {
160
- default: ''
161
- }
162
- },
163
- props: {
164
- // 表单校验
165
- desc: {
166
- type: String,
167
- default: ''
168
- },
169
- id: {
170
- type: String,
171
- default: ''
172
- },
173
- required: Boolean,
174
- // 模式,支持 input / button / img
175
- mode: {
176
- type: String,
177
- default: 'input'
178
- },
179
- picSize: {
180
- type: String,
181
- default: ''
182
- },
183
- width: {
184
- type: [Number, String],
185
- default: ''
186
- },
187
- fillet: {
188
- type: String,
189
- default() {
190
- return this.$TouchUI.upload.fillet || this.$TouchUI.global.fillet || 'normal'
191
- }
192
- },
193
- filletPosition: {
194
- type: String,
195
- default: ''
196
- },
197
- buttonProps: {
198
- type: Object,
199
- default() {
200
- return {}
201
- }
202
- },
203
- maxLength: {
204
- type: [String, Number],
205
- default: Infinity
206
- },
207
- accept: {
208
- type: String,
209
- default() {
210
- if (this.mode === 'img') {
211
- return '.jpg,.jpeg,.png,.gif'
212
- } else {
213
- return ''
214
- }
215
- }
216
- },
217
- maxSize: {
218
- type: [String, Number],
219
- default: ''
220
- },
221
- inputProps: {
222
- type: Object,
223
- default() {
224
- return {}
225
- }
226
- },
227
- fileRepeat: {
228
- type: Boolean,
229
- default: false
230
- },
231
- fileIdText: {
232
- type: String,
233
- default: 'fileId'
234
- },
235
- disabled: {
236
- type: Boolean,
237
- default: false
238
- },
239
- readonly: {
240
- type: Boolean,
241
- default: false
242
- },
243
- downloadable: {
244
- type: Boolean,
245
- default: false
246
- },
247
- name: {
248
- type: String,
249
- default: 'uploadfile'
250
- },
251
- action: {
252
- type: String,
253
- default: ''
254
- },
255
- headers: {
256
- type: Object,
257
- default: null
258
- },
259
- withCredentials: {
260
- type: Boolean,
261
- default: false
262
- },
263
- files: {
264
- type: Array,
265
- default: () => []
266
- },
267
- data: {
268
- type: Object,
269
- default: null
270
- },
271
- placeholder: {
272
- type: String,
273
- default: () => t('to.common.placeholder.select')
274
- },
275
- auto: Boolean,
276
- beforeChange: {
277
- type: Function,
278
- default: null
279
- },
280
- beforeStart: {
281
- type: Function,
282
- default: null
283
- },
284
- verifiable: {
285
- type: Boolean,
286
- default: true
287
- }
288
- },
289
- data() {
290
- return {
291
- iApiHeaders: '',
292
- errorTip: '',
293
- errorType: 'rule',
294
- imgIndex: 0,
295
- showViewer: false,
296
- iFiles: {},
297
- finishedFiles: [],
298
- queue: [],
299
- transfers: {},
300
- fileTypeList: [],
301
- tipMessage: this.placeholder,
302
- loading: false,
303
- uploading: false,
304
- vmDisabled: this.readonly || this.disabled
305
- }
306
- },
307
- computed: {
308
- previewSrcList() {
309
- let arr = []
310
- this.finishedFiles.map(file => {
311
- if (file.path) {
312
- arr.push(file.path)
313
- }
314
- })
315
- for (const key in this.iFiles) {
316
- const file = this.iFiles[key]
317
- if (file.fileObject && file.fileObject.src) {
318
- arr.push(file.fileObject.src)
319
- }
320
- }
321
- return arr
322
- },
323
- setStyle() {
324
- var obj = {}
325
- if (this.width) {
326
- if (!isNaN(this.width)) {
327
- obj.width = this.width + 'em'
328
- } else if (this.width === 'full') {
329
- obj.width = '100%'
330
- } else {
331
- obj.width = this.width
332
- }
333
- }
334
- return obj
335
- },
336
- setClass() {
337
- let arr = ['to-form-readonly']
338
- if (this.mode !== 'input') {
339
- arr.push(`to-upload-mode-${this.mode}`)
340
- }
341
- if (this.fillet !== 'none' && this.mode === 'img') {
342
- arr.push(`to-upload-fillet-${this.fillet}`)
343
- }
344
- if (this.picSize) {
345
- arr.push(`to-upload-pic-size-${this.picSize}`)
346
- }
347
- return arr
348
- },
349
- setInputClass() {
350
- let arr = []
351
- if (this.fillet !== 'none') {
352
- arr.push(`to-input-fillet-${this.fillet}`)
353
- }
354
- if (this.filletPosition) {
355
- arr.push(`to-input-fillet-position-${this.filletPosition}`)
356
- }
357
- if (this.errorTip) {
358
- arr.push('to-input-mode-line')
359
- arr.push('to-input-color-danger')
360
- }
361
- return arr
362
- },
363
- validateRequired() {
364
- if (this.required) {
365
- return 'true'
366
- } else if (this.ToFormItem && this.ToFormItem.required) {
367
- return 'true'
368
- } else {
369
- return 'false'
370
- }
371
- },
372
- validateDesc() {
373
- if (this.desc) {
374
- return this.desc
375
- } else if (this.ToFormItem && this.ToFormItem.label) {
376
- return this.ToFormItem.label
377
- } else {
378
- return ''
379
- }
380
- },
381
- validateValue() {
382
- if (Object.keys(this.iFiles).length + this.finishedFiles.length > 0) {
383
- return 'true'
384
- } else {
385
- return ''
386
- }
387
- }
388
- },
389
- watch: {
390
- readonly(val) {
391
- this.vmDisabled = val || this.disabled
392
- },
393
- disabled(val) {
394
- this.vmDisabled = val || this.readonly
395
- },
396
- files: {
397
- handler(val) {
398
- if (val.length > 0) {
399
- this.finishedFiles = []
400
- val.map(file => {
401
- if (file.name) {
402
- file.iconClassName = this._fileIconClassName(file.name)
403
- }
404
- if (file.size) {
405
- file.tipText = FileTransfer.humanSize(file.size)
406
- }
407
- this.finishedFiles.push(file)
408
- })
409
- }
410
- },
411
- immediate: true
412
- }
413
- },
414
- beforeDestroy() {
415
- if (this.iFiles) {
416
- let file
417
- for (let guid in this.iFiles) {
418
- file = this.iFiles[guid]
419
- for (let p in file) {
420
- Vue.delete(file, p)
421
- }
422
- file.fileObject = null
423
- Vue.delete(this.iFiles, guid)
424
- }
425
- file = null
426
- this.iFiles = {}
427
- }
428
-
429
- if (this.transfers) {
430
- for (let guid in this.transfers) {
431
- this.transfers[guid].destroy()
432
- Vue.delete(this.transfers, guid)
433
- }
434
- this.transfers = {}
435
- }
436
- },
437
- created() {
438
- this.iApiHeaders = this.headers
439
- },
440
- methods: {
441
- openViewer(file, index, isNew) {
442
- if (file.iconClassName !== 'img') return
443
- if (isNew) {
444
- this.imgIndex = this.finishedFiles.length + Object.keys(this.iFiles).indexOf(index)
445
- } else {
446
- this.imgIndex = index
447
- }
448
- this.showViewer = true
449
- },
450
- setTipMessage: function(message) {
451
- if (typeof message !== 'undefined') {
452
- this.tipMessage = message
453
- }
454
- },
455
- deleteOldFile(fileId) {
456
- if (!fileId) return
457
- this.finishedFiles = this.finishedFiles.filter(file => { return file.fileId !== fileId })
458
- this.$emit('delete', fileId)
459
- },
460
- updateTipFileInfo: function() {
461
- let n = 0
462
- let b = 0
463
- for (let guid in this.iFiles) {
464
- n++
465
- if (this.iFiles[guid].valid === false) { b++ }
466
- }
467
-
468
- let tipInfo = this.t('to.upload.tip.selected', n)
469
- if (b > 0) {
470
- this.t('to.upload.tip.error.selected', tipInfo, b)
471
- }
472
-
473
- this.setTipMessage(tipInfo)
474
- },
475
- _fileIconClassName: function(name) {
476
- let ext = name && isString(name) ? FileTransfer.extName(name) : null
477
- if (ext) {
478
- for (let type in EXT) {
479
- if (Array.prototype.indexOf.call(EXT[type], ext) > -1) {
480
- return ICON[type]
481
- }
482
- }
483
- }
484
- return ICON.unknown
485
- },
486
- _validateFileType: function(name) {
487
- if (!this.fileTypeList || !this.fileTypeList.length) {
488
- return true
489
- }
490
- let ext = FileTransfer.extName(name)
491
- return (ext && isString(ext) && Array.prototype.indexOf.call(this.fileTypeList, ext) > -1) || undefined === ext
492
- },
493
- _fileObjGUID: function(fileObj) {
494
- if (!fileObj) return
495
-
496
- let str = (fileObj.lastModifiedDate ? fileObj.lastModifiedDate.valueOf() : fileObj.modificationdate) + fileObj.name + fileObj.size
497
- return md5(str)
498
- },
499
- _addFile(fileObj) {
500
- // IE: msClose
501
- // Chrome: lastModified, webkitRelativePath
502
- // ALL: lastModifiedDate, name, size, type, slice
503
- let name = fileObj.name
504
- let size = fileObj.size
505
-
506
- // 使用修改时间, 文件名和文件大小生成唯一标识,fileObj.modificationdate for swfupload
507
- let guid = fileObj.guid ? fileObj.guid : this._fileObjGUID(fileObj)
508
- let valid = true
509
- let text = FileTransfer.humanSize(size)
510
-
511
- // 判断文件类型
512
- const nameArr = fileObj.name.split('.')
513
- let fileType = nameArr[nameArr.length - 1]
514
- if (this.accept && this.accept.indexOf(fileType) === -1) {
515
- this.$tip.warning(this.t('to.upload.tip.error.format', this.accept))
516
- return
517
- }
518
-
519
- // 单文件大小限制
520
- if (this.maxSize) {
521
- let maxSize
522
- if (typeof this.maxSize === 'number') {
523
- maxSize = this.maxSize
524
- } else {
525
- if (this.maxSize.indexOf('K') > -1) {
526
- maxSize = Number(this.maxSize.replace('K', '')) * Math.pow(1024, 1)
527
- } else if (this.maxSize.indexOf('k') > -1) {
528
- maxSize = Number(this.maxSize.replace('k', '')) * Math.pow(1024, 1)
529
- } else if (this.maxSize.indexOf('M') > -1) {
530
- maxSize = Number(this.maxSize.replace('M', '')) * Math.pow(1024, 2)
531
- } else if (this.maxSize.indexOf('m') > -1) {
532
- maxSize = Number(this.maxSize.replace('m', '')) * Math.pow(1024, 2)
533
- } else if (this.maxSize.indexOf('G') > -1) {
534
- maxSize = Number(this.maxSize.replace('G', '')) * Math.pow(1024, 3)
535
- } else if (this.maxSize.indexOf('g') > -1) {
536
- maxSize = Number(this.maxSize.replace('g', '')) * Math.pow(1024, 3)
537
- } else {
538
- maxSize = Infinity
539
- }
540
- }
541
- if (size > maxSize) {
542
- this.$tip.warning(this.t('to.upload.tip.error.size', this.maxSize))
543
- return
544
- }
545
- }
546
-
547
- // 已经存在相同的文件, 由于使用guid作为key, 目前不能支持重复文件
548
- if (this.fileRepeat === false && this.iFiles[guid]) {
549
- return
550
- }
551
-
552
- // 校验文件名
553
- if (!this._validateFileType(name)) {
554
- valid = false
555
- text += ' ' + this.t('to.upload.invalid-filetype')
556
- }
557
-
558
- if (valid && size > this.fileSize) {
559
- valid = false
560
- text += ' ' + this.t('to.upload.invalid-filesize')
561
- }
562
-
563
- // 判断文件个数限制
564
- let files_num = Object.keys(this.iFiles).length
565
- if (files_num + 1 + this.finishedFiles.length > Number(this.maxLength)) { // 超出文件限制直接返回
566
- this.$tip.warning(this.t('to.upload.tip.error.count', this.maxLength))
567
- return
568
- }
569
- let file = {
570
- guid,
571
- name,
572
- size,
573
- valid,
574
- fileId: fileObj.fileId,
575
- fileObject: fileObj,
576
- tipText: text,
577
- status: 0,
578
- iconClassName: this._fileIconClassName(name)
579
- }
580
- this.$set(this.iFiles, guid, file)
581
-
582
- if (this.$TouchUI.staticDataApiConfig.apiHeaders && !this.headers) {
583
- this.iApiHeaders = this.$TouchUI.staticDataApiConfig.apiHeaders
584
- }
585
-
586
- if (valid) {
587
- this.transfers[guid] = new FileTransfer({
588
- context: this,
589
- url: this.action,
590
- data: this.data,
591
- headers: Object.assign({}, this.iApiHeaders),
592
- withCredentials: this.withCredentials,
593
- fileField: this.name,
594
- start: this._transferStart,
595
- success: this._transferSuccess,
596
- error: this._transferError,
597
- init: function(settings, file) {
598
- settings = transferSign(settings)
599
- },
600
- progress: function(e, file) {
601
- this._transferProgress(e.loaded, e.total, file)
602
- }
603
- }, file)
604
- }
605
- return file
606
- },
607
- _removeFile(guid) {
608
- if (!guid || this.queue.length > 0) return
609
-
610
- let file = this.iFiles[guid]
611
- if (file) {
612
- // 发送删除文件请求
613
- let transfer = this.transfers[guid]
614
- if (transfer) {
615
- transfer.destroy()
616
- transfer = null
617
- }
618
-
619
- for (let p in file) {
620
- Vue.delete(file, p)
621
- }
622
- Vue.delete(this.iFiles, guid)
623
- file = null
624
- this.$forceUpdate()
625
- }
626
-
627
- // 移除DOM
628
- let refs = this.$refs[guid + '_li']
629
- let el = refs && refs.length ? refs[0] : null
630
- if (el && el.nodeType) {
631
- el.parentNode.removeChild(el)
632
- }
633
-
634
- // 重置form
635
- refs = this.$refs['upForm']
636
- refs.reset()
637
- },
638
- deleteFile(file) {
639
- if (!file.guid) return
640
- if (file.fileId) {
641
- this.$emit('delete', file.fileId)
642
- } else if (file.guid) {
643
- this.$emit('delete', file.guid)
644
- }
645
- this._removeFile(file.guid)
646
- this.updateTipFileInfo()
647
- },
648
- downloadFile(file) {
649
- if (file[this.fileIdText]) {
650
- this.$emit('download', file[this.fileIdText])
651
- } else {
652
- this.$emit('download', file)
653
- }
654
- },
655
- browse() {
656
- this.errorTip = ''
657
- if (this.vmDisabled) return
658
- if (this.loading || this.queue.length > 0) { // 判断队列是否还有未完成上传
659
- return
660
- }
661
- this.$refs['fileInput'].click()
662
- },
663
- fileInputChange(e) {
664
- this.selectFile(e)
665
- },
666
- selectFile(e) {
667
- if (this.beforeChange) {
668
- const fn = this.beforeChange(e, this.iFiles, this.finishedFiles)
669
- // 异步
670
- if (fn && fn.then) {
671
- fn.then(flag => {
672
- this.selectFileAction()
673
- })
674
- } else {
675
- // 是同步方法,则返回为 true 执行
676
- if (fn) {
677
- this.selectFileAction()
678
- }
679
- }
680
- } else {
681
- this.selectFileAction()
682
- }
683
- },
684
- selectFileAction() {
685
- if (this.vmDisabled) return
686
- if (this.loading || this.queue.length > 0) {
687
- return
688
- }
689
- let fileEl = this.$refs['fileInput']
690
- if (fileEl.files) {
691
- this.$emit('fileInputChange', fileEl.files)
692
- this.$emit('change', fileEl.files)
693
-
694
- for (let i = 0, size = fileEl.files.length; i < size; i++) {
695
- let reader = []
696
- if (this.mode === 'img') {
697
- reader = new FileReader()
698
- reader.addEventListener('load', () => {
699
- fileEl.files[i].src = reader.result
700
- this._addFile(fileEl.files[i])
701
- this.updateTipFileInfo()
702
- if (i === size - 1) {
703
- this.$nextTick(() => {
704
- if (this.auto) {
705
- this.upload(fileEl.files[i])
706
- }
707
- })
708
- }
709
- }, false)
710
- reader.readAsDataURL(fileEl.files[i])
711
- } else {
712
- this._addFile(fileEl.files[i])
713
- this.updateTipFileInfo()
714
- this.$nextTick(() => {
715
- if (this.auto || this.mode === 'button') {
716
- this.upload(fileEl.files[i])
717
- }
718
- })
719
- }
720
- }
721
- }
722
- },
723
- handleUploadStart(iFiles) {
724
- if (this.beforeStart) {
725
- const fn = this.beforeStart(iFiles)
726
- // 异步
727
- if (fn && fn.then) {
728
- fn.then(flag => {
729
- this.uploadAction()
730
- })
731
- } else {
732
- // 是同步方法,则返回为 true 执行
733
- if (fn) {
734
- this.uploadAction()
735
- }
736
- }
737
- } else {
738
- this.uploadAction()
739
- }
740
- },
741
- uploadAction() {
742
- // 调用onStart
743
- this.$emit('start', this.iFiles)
744
-
745
- if (this.vmDisabled || this.loading || this.queue.length > 0) {
746
- return
747
- }
748
-
749
- let file, transfer
750
- for (let guid in this.iFiles) {
751
- file = this.iFiles[guid]
752
- if (file.valid && !file.fileId && !file.finished && (transfer = this.transfers[guid])) { // 根据fileId判断是否已经完成上传
753
- transfer.send()
754
- }
755
- }
756
- },
757
- upload(iFiles) {
758
- this.handleUploadStart(iFiles)
759
- },
760
- clearClick() {
761
- if (this.vmDisabled) return
762
-
763
- // 清除已上传文件列表
764
- for (var guid in this.iFiles) {
765
- this._removeFile(guid)
766
- }
767
- this.finishedFiles = []
768
-
769
- // 重置form
770
- let refs = this.$refs['upForm']
771
- refs.reset()
772
-
773
- this.updateTipFileInfo()
774
-
775
- this.$emit('clear', this.iFiles, this.popup)
776
- },
777
- _transferStart(file) {
778
- if (!file.guid) return
779
-
780
- this.queue.push(file.guid)
781
-
782
- this.iFiles[file.guid].status = 1 // 1:start,2:success,3:error
783
- },
784
- _transferSuccess(data, status, file) {
785
- if (!file) return
786
- this.queue.splice(this.queue.indexOf(file.guid), 1)
787
-
788
- this.iFiles[file.guid].status = 2 // 1:start,2:success,3:error
789
- this.iFiles[file.guid].percent = 100
790
-
791
- // 成功事件
792
- file.finished = true
793
-
794
- // 处理 fileId 为 undefined 的情况
795
- if (!file.fileId) {
796
- if (typeof data === 'string') {
797
- file.fileId = data
798
- }
799
- if (typeof data === 'object') {
800
- if (data.data && data.data['id']) {
801
- file.fileId = data.data['id']
802
- } else {
803
- if (data['id']) {
804
- file.fileId = data['id']
805
- }
806
- if (data['fileId']) {
807
- file.fileId = data['fileId']
808
- }
809
- }
810
- }
811
- }
812
- this.$emit('success', data, status, file)
813
- },
814
- _transferError(data, status, file) {
815
- if (!file) return
816
- this.queue.splice(this.queue.indexOf(file.guid), 1)
817
-
818
- this.iFiles[file.guid].status = 3 // 1:start,2:success,3:error
819
-
820
- this.iFiles[file.guid].tipText = data.message
821
-
822
- // 错误事件
823
- this.$emit('error', data, status, file)
824
- },
825
- _transferProgress(loaded, total, file) {
826
- if (!file.guid) return
827
- let percent
828
-
829
- percent = loaded > 0 && total > 0 ? Math.round(loaded / total * 100) : 0
830
- if (percent >= 100) percent = 99 // 由 success 事件处理进度条最终完成
831
- this.iFiles[file.guid].percent = percent
832
- // el .style.width = percent + '%';
833
- // }
834
-
835
- // 调用 progress
836
- this.$emit('progress', loaded, total, file)
837
- },
838
- setDisabled(f) {
839
- this.vmDisabled = f
840
- },
841
- getColor(icon) {
842
- let color = ''
843
- switch (icon) {
844
- case 'word':
845
- color = 'primary'
846
- break
847
- case 'excel':
848
- color = 'success'
849
- break
850
- case 'ppt':
851
- color = 'warning'
852
- break
853
- default:
854
- break
855
- }
856
- return color
857
- }
858
- }
859
- }
860
- </script>
1
+ <template>
2
+ <div class="to-upload" :class="setClass" :style="setStyle">
3
+ <span v-if="verifiable && validateRequired" v-show="false" class="to-validate" :req="validateRequired" :desc="validateDesc" :value="validateValue"></span>
4
+ <form ref="upForm" encType="multipart/form-data"><input ref="fileInput" :accept="accept" type="file" :multiple="Number(maxLength) > 1" style="position:absolute;width:0px;height:0px;left:-99999px;top:-99999px;" @change="fileInputChange" /></form>
5
+ <to-input v-if="mode === 'input'" :class="setInputClass" :verifiable="false" type="html" width="full" v-bind="inputProps" :html="tipMessage">
6
+ <to-button icon="browse" mode="none" link color="primary" @click="browse"></to-button>
7
+ <to-button v-if="Object.keys(iFiles).length > 0 && !auto" icon="upload" mode="plain" link color="primary" @click="upload(iFiles)">{{ t('to.upload.button') }}</to-button>
8
+ </to-input>
9
+ <div v-if="mode === 'button'">
10
+ <to-button
11
+ v-size="buttonProps.size ? buttonProps.size : 1"
12
+ :icon="buttonProps.icon ? buttonProps.icon : 'upload'"
13
+ v-bind="buttonProps"
14
+ :class="setInputClass"
15
+ @click="browse"
16
+ >
17
+ {{ buttonProps.text ? buttonProps.text : t('to.upload.button') }}
18
+ </to-button>
19
+ </div>
20
+ <span v-if="errorTip" v-color="'danger'" class="to-box-tip">
21
+ <template v-if="errorType === 'rule'">
22
+ 选择有误
23
+ <to-icon v-tip.danger="errorTip" value="help" color="danger" mode="toast" fillet="round"></to-icon>
24
+ </template>
25
+ <template v-else>
26
+ 不能为空
27
+ </template>
28
+ </span>
29
+ <slot :oldFiles="finishedFiles" :files="iFiles">
30
+ <template v-if="mode === 'img'">
31
+ <div v-dis="vmDisabled" class="to-uploadImgGroup">
32
+ <template v-if="Object.keys(iFiles).length + finishedFiles.length > 0">
33
+ <div v-for="(file, index) in finishedFiles" :key="index" v-tip="picSize === 's' ? file.name :''" :style="file.iconClassName === 'img' ? { backgroundImage: `url(${file.fileObject.src})`} : ''" class="to-uploadImg" @click="openViewer(file,index,true)">
34
+ <div v-if="file.iconClassName !== 'img'" class="to-uploadFile">
35
+ <to-icon v-color="getColor(file.iconClassName)" :value="file.iconClassName" class="to-uploadFileIcon"></to-icon>
36
+ <span v-if="picSize !== 's'" class="to-uploadFileName">{{ file.name }}</span>
37
+ </div>
38
+ <div class="to-uploadFn">
39
+ <to-icon value="download" @click.stop="downloadFile(file)"></to-icon>
40
+ <to-icon value="delete" @click.stop="deleteOldFile(file[fileIdText])"></to-icon>
41
+ </div>
42
+ </div>
43
+ <div v-for="(file, index) in iFiles" :key="index" v-tip="picSize === 's' ? file.name :''" :style="file.iconClassName === 'img' ? { backgroundImage: `url(${file.fileObject.src})`} : ''" class="to-uploadImg" @click="openViewer(file,index,true)">
44
+ <div v-if="file.iconClassName !== 'img'" class="to-uploadFile">
45
+ <to-icon v-color="getColor(file.iconClassName)" :value="file.iconClassName" class="to-uploadFileIcon"></to-icon>
46
+ <span v-if="picSize !== 's'" class="to-uploadFileName">{{ file.name }}</span>
47
+ </div>
48
+ <span v-if="file.status === 1" class="to-uploadProgress to-progress to-progress-type-normal to-progress-fillet-pill">
49
+ <span class="to-progressBar" style="font-size:20%;">
50
+ <span class="to-progressProgress" :style="`width:${file.percent}%;`"></span>
51
+ </span>
52
+ </span>
53
+ <div v-if="file.status === 3" class="to-uploadError">{{ file.tipText }}</div>
54
+ <to-icon v-if="file.status === 2" class="to-uploadSuccess" value="ok"></to-icon>
55
+ <div class="to-uploadFn">
56
+ <to-icon v-if="file.status === 2 && downloadable" value="download" @click.stop="downloadFile(file)"></to-icon>
57
+ <to-icon value="delete" @click.stop="deleteFile(file)"></to-icon>
58
+ </div>
59
+ </div>
60
+ </template>
61
+ <div v-if="(Object.keys(iFiles).length + finishedFiles.length) < Number(maxLength)" class="to-uploadAdd" @click="browse">
62
+ <to-icon value="add"></to-icon>
63
+ </div>
64
+ <picViewer v-if="showViewer" :z-index="2000" :initial-index="imgIndex" :on-close="() => {showViewer = false}" :url-list="previewSrcList"></picViewer>
65
+ </div>
66
+ <template v-if="Object.keys(iFiles).length > 0 && !auto">
67
+ <to-space :value="0.5"></to-space>
68
+ <to-button icon="upload" mode="plain" link color="primary" @click="upload">{{ t('to.upload.button') }}</to-button>
69
+ </template>
70
+ </template>
71
+ <template v-else>
72
+ <template v-if="Object.keys(iFiles).length + finishedFiles.length > 0">
73
+ <to-space :value="0.5"></to-space>
74
+ <to-grid v-dis="vmDisabled" :col="1">
75
+ <to-grid-item v-for="(file, index) in finishedFiles" :key="index">
76
+ <to-card :padding="0.5">
77
+ <to-card-item><to-icon :value="file.iconClassName"></to-icon></to-card-item>
78
+ <to-card-item v-align="'left'" main>
79
+ <to-ellipsis tip :data="file.name"></to-ellipsis>
80
+ </to-card-item>
81
+ <to-card-item>
82
+ <span v-color="'info'">{{ file.tipText }}</span>
83
+ </to-card-item>
84
+ <to-card-item>
85
+ <to-icon fillet="round" color="primary" value="download" mode="none" link @click="downloadFile(file)"></to-icon>
86
+ <to-icon fillet="round" color="primary" value="delete" mode="none" link @click="deleteOldFile(file[fileIdText])"></to-icon>
87
+ </to-card-item>
88
+ </to-card>
89
+ </to-grid-item>
90
+ <to-grid-item v-for="file in iFiles" :key="file.guid" :ref="file.guid + '_li'">
91
+ <to-card :padding="0.5">
92
+ <to-card-item><to-icon :class="file.status !== 2 ?'to-dis':''" :value="file.iconClassName"></to-icon></to-card-item>
93
+ <to-card-item v-align="'left'" main>
94
+ <to-ellipsis tip :data="file.name"></to-ellipsis>
95
+ </to-card-item>
96
+ <to-card-item>
97
+ <span v-if="file.status === 3" class="to-color-danger">{{ file.tipText }}</span>
98
+ </to-card-item>
99
+ <to-card-item>
100
+ <to-icon v-if="file.status === 2" fillet="round" color="success" value="ok" mode="none"></to-icon>
101
+ <to-icon v-if="file.status === 2 && downloadable" fillet="round" color="primary" value="download" mode="none" link @click="downloadFile(file)"></to-icon>
102
+ <to-icon :class="file.status === 1?'to-dis':''" fillet="round" color="primary" value="delete" mode="none" link @click="deleteFile(file)"></to-icon>
103
+ </to-card-item>
104
+ <span v-if="file.status === 1" class="to-uploadProgress to-progress to-progress-type-normal to-progress-fillet-pill">
105
+ <span class="to-progressBar" style="font-size:20%;">
106
+ <span class="to-progressProgress" :style="`width:${file.percent}%;`"></span>
107
+ </span>
108
+ </span>
109
+ </to-card>
110
+ </to-grid-item>
111
+ </to-grid>
112
+ </template>
113
+ </template>
114
+ </slot>
115
+ </div>
116
+ </template>
117
+ <script>
118
+ import Locale from 'ai.touchui-vue/src/mixins/locale'
119
+ import Tip from 'ai.touchui-vue/src/mixins/tip'
120
+ import FileTransfer from 'ai.touchui-vue/src/utils/filetransfer'
121
+ import { isString } from 'ai.touchui-vue/src/utils/types'
122
+ import { md5 } from 'ai.touchui-vue/src/utils/md5'
123
+ import { transferSign } from 'ai.touchui-vue/src/utils/sign'
124
+ import picViewer from '../../pic/src/pic-viewer'
125
+ import { t } from 'ai.touchui-vue/src/locale'
126
+ import Vue from 'vue'
127
+ const EXT = {
128
+ excel: ['.xls', '.xlsx', '.csv', '.XLS', '.XLSX', '.CSV'],
129
+ img: ['.png', '.jpg', '.gif', '.PNG', '.JPG', '.GIF'],
130
+ ppt: ['.ppt', '.pptx', '.ppsx', '.PPT', '.PPTX', '.PPSX'],
131
+ rar: ['.rar', '.zip', '.tar', '.gz', '.tgz', '.RAR', '.ZIP', '.TAR', '.GZ', '.TGZ'],
132
+ video: ['.rm', '.rmvb', '.avi', '.mkv', '.mp4', '.wmv', '.mov', '.movie', '.mpeg', '.mpg', '.qt', '.RM', '.RMVB', '.AVI', '.MKV', '.MP4', '.WMV', '.MOV', 'MOVIE', '.MPEG', '.MPG', '.QT'],
133
+ voice: ['.mp2', '.mp3', '.wma', '.midi', '.MP2', '.MP3', '.WMA', '.MIDI'],
134
+ word: ['.doc', '.docx', '.DOC', '.DOCX']
135
+ }
136
+
137
+ const ICON = {
138
+ excel: 'excel',
139
+ img: 'img',
140
+ ppt: 'ppt',
141
+ rar: 'rar',
142
+ video: 'video',
143
+ voice: 'voice',
144
+ word: 'word',
145
+ unknown: 'file'
146
+ }
147
+
148
+ export default {
149
+ name: 'ToUpload',
150
+ componentName: 'ToUpload',
151
+ components: {
152
+ picViewer
153
+ },
154
+ mixins: [Locale, Tip],
155
+ inject: {
156
+ ToForm: {
157
+ default: ''
158
+ },
159
+ ToFormItem: {
160
+ default: ''
161
+ }
162
+ },
163
+ props: {
164
+ // 表单校验
165
+ desc: {
166
+ type: String,
167
+ default: ''
168
+ },
169
+ id: {
170
+ type: String,
171
+ default: ''
172
+ },
173
+ required: Boolean,
174
+ // 模式,支持 input / button / img
175
+ mode: {
176
+ type: String,
177
+ default: 'input'
178
+ },
179
+ picSize: {
180
+ type: String,
181
+ default: ''
182
+ },
183
+ width: {
184
+ type: [Number, String],
185
+ default: ''
186
+ },
187
+ fillet: {
188
+ type: String,
189
+ default() {
190
+ return this.$TouchUI.upload.fillet || this.$TouchUI.global.fillet || 'normal'
191
+ }
192
+ },
193
+ filletPosition: {
194
+ type: String,
195
+ default: ''
196
+ },
197
+ buttonProps: {
198
+ type: Object,
199
+ default() {
200
+ return {}
201
+ }
202
+ },
203
+ maxLength: {
204
+ type: [String, Number],
205
+ default: Infinity
206
+ },
207
+ accept: {
208
+ type: String,
209
+ default() {
210
+ if (this.mode === 'img') {
211
+ return '.jpg,.jpeg,.png,.gif'
212
+ } else {
213
+ return ''
214
+ }
215
+ }
216
+ },
217
+ maxSize: {
218
+ type: [String, Number],
219
+ default: ''
220
+ },
221
+ inputProps: {
222
+ type: Object,
223
+ default() {
224
+ return {}
225
+ }
226
+ },
227
+ fileRepeat: {
228
+ type: Boolean,
229
+ default: false
230
+ },
231
+ fileIdText: {
232
+ type: String,
233
+ default: 'fileId'
234
+ },
235
+ disabled: {
236
+ type: Boolean,
237
+ default: false
238
+ },
239
+ readonly: {
240
+ type: Boolean,
241
+ default: false
242
+ },
243
+ downloadable: {
244
+ type: Boolean,
245
+ default: false
246
+ },
247
+ name: {
248
+ type: String,
249
+ default: 'uploadfile'
250
+ },
251
+ action: {
252
+ type: String,
253
+ default: ''
254
+ },
255
+ headers: {
256
+ type: Object,
257
+ default: null
258
+ },
259
+ withCredentials: {
260
+ type: Boolean,
261
+ default: false
262
+ },
263
+ files: {
264
+ type: Array,
265
+ default: () => []
266
+ },
267
+ data: {
268
+ type: Object,
269
+ default: null
270
+ },
271
+ placeholder: {
272
+ type: String,
273
+ default: () => t('to.common.placeholder.select')
274
+ },
275
+ auto: Boolean,
276
+ beforeChange: {
277
+ type: Function,
278
+ default: null
279
+ },
280
+ beforeStart: {
281
+ type: Function,
282
+ default: null
283
+ },
284
+ verifiable: {
285
+ type: Boolean,
286
+ default: true
287
+ }
288
+ },
289
+ data() {
290
+ return {
291
+ iApiHeaders: '',
292
+ errorTip: '',
293
+ errorType: 'rule',
294
+ imgIndex: 0,
295
+ showViewer: false,
296
+ iFiles: {},
297
+ finishedFiles: [],
298
+ queue: [],
299
+ transfers: {},
300
+ fileTypeList: [],
301
+ tipMessage: this.placeholder,
302
+ loading: false,
303
+ uploading: false,
304
+ vmDisabled: this.readonly || this.disabled
305
+ }
306
+ },
307
+ computed: {
308
+ previewSrcList() {
309
+ let arr = []
310
+ this.finishedFiles.map(file => {
311
+ if (file.path) {
312
+ arr.push(file.path)
313
+ }
314
+ })
315
+ for (const key in this.iFiles) {
316
+ const file = this.iFiles[key]
317
+ if (file.fileObject && file.fileObject.src) {
318
+ arr.push(file.fileObject.src)
319
+ }
320
+ }
321
+ return arr
322
+ },
323
+ setStyle() {
324
+ var obj = {}
325
+ if (this.width) {
326
+ if (!isNaN(this.width)) {
327
+ obj.width = this.width + 'em'
328
+ } else if (this.width === 'full') {
329
+ obj.width = '100%'
330
+ } else {
331
+ obj.width = this.width
332
+ }
333
+ }
334
+ return obj
335
+ },
336
+ setClass() {
337
+ let arr = ['to-form-readonly']
338
+ if (this.mode !== 'input') {
339
+ arr.push(`to-upload-mode-${this.mode}`)
340
+ }
341
+ if (this.fillet !== 'none' && this.mode === 'img') {
342
+ arr.push(`to-upload-fillet-${this.fillet}`)
343
+ }
344
+ if (this.picSize) {
345
+ arr.push(`to-upload-pic-size-${this.picSize}`)
346
+ }
347
+ return arr
348
+ },
349
+ setInputClass() {
350
+ let arr = []
351
+ if (this.fillet !== 'none') {
352
+ arr.push(`to-input-fillet-${this.fillet}`)
353
+ }
354
+ if (this.filletPosition) {
355
+ arr.push(`to-input-fillet-position-${this.filletPosition}`)
356
+ }
357
+ if (this.errorTip) {
358
+ arr.push('to-input-mode-line')
359
+ arr.push('to-input-color-danger')
360
+ }
361
+ return arr
362
+ },
363
+ validateRequired() {
364
+ if (this.required) {
365
+ return 'true'
366
+ } else if (this.ToFormItem && this.ToFormItem.required) {
367
+ return 'true'
368
+ } else {
369
+ return 'false'
370
+ }
371
+ },
372
+ validateDesc() {
373
+ if (this.desc) {
374
+ return this.desc
375
+ } else if (this.ToFormItem && this.ToFormItem.label) {
376
+ return this.ToFormItem.label
377
+ } else {
378
+ return ''
379
+ }
380
+ },
381
+ validateValue() {
382
+ if (Object.keys(this.iFiles).length + this.finishedFiles.length > 0) {
383
+ return 'true'
384
+ } else {
385
+ return ''
386
+ }
387
+ }
388
+ },
389
+ watch: {
390
+ readonly(val) {
391
+ this.vmDisabled = val || this.disabled
392
+ },
393
+ disabled(val) {
394
+ this.vmDisabled = val || this.readonly
395
+ },
396
+ files: {
397
+ handler(val) {
398
+ if (val.length > 0) {
399
+ this.finishedFiles = []
400
+ val.map(file => {
401
+ if (file.name) {
402
+ file.iconClassName = this._fileIconClassName(file.name)
403
+ }
404
+ if (file.size) {
405
+ file.tipText = FileTransfer.humanSize(file.size)
406
+ }
407
+ this.finishedFiles.push(file)
408
+ })
409
+ }
410
+ },
411
+ immediate: true
412
+ }
413
+ },
414
+ beforeDestroy() {
415
+ if (this.iFiles) {
416
+ let file
417
+ for (let guid in this.iFiles) {
418
+ file = this.iFiles[guid]
419
+ for (let p in file) {
420
+ Vue.delete(file, p)
421
+ }
422
+ file.fileObject = null
423
+ Vue.delete(this.iFiles, guid)
424
+ }
425
+ file = null
426
+ this.iFiles = {}
427
+ }
428
+
429
+ if (this.transfers) {
430
+ for (let guid in this.transfers) {
431
+ this.transfers[guid].destroy()
432
+ Vue.delete(this.transfers, guid)
433
+ }
434
+ this.transfers = {}
435
+ }
436
+ },
437
+ created() {
438
+ this.iApiHeaders = this.headers
439
+ },
440
+ methods: {
441
+ openViewer(file, index, isNew) {
442
+ if (file.iconClassName !== 'img') return
443
+ if (isNew) {
444
+ this.imgIndex = this.finishedFiles.length + Object.keys(this.iFiles).indexOf(index)
445
+ } else {
446
+ this.imgIndex = index
447
+ }
448
+ this.showViewer = true
449
+ },
450
+ setTipMessage: function(message) {
451
+ if (typeof message !== 'undefined') {
452
+ this.tipMessage = message
453
+ }
454
+ },
455
+ deleteOldFile(fileId) {
456
+ if (!fileId) return
457
+ this.finishedFiles = this.finishedFiles.filter(file => { return file.fileId !== fileId })
458
+ this.$emit('delete', fileId)
459
+ },
460
+ updateTipFileInfo: function() {
461
+ let n = 0
462
+ let b = 0
463
+ for (let guid in this.iFiles) {
464
+ n++
465
+ if (this.iFiles[guid].valid === false) { b++ }
466
+ }
467
+
468
+ let tipInfo = this.t('to.upload.tip.selected', n)
469
+ if (b > 0) {
470
+ this.t('to.upload.tip.error.selected', tipInfo, b)
471
+ }
472
+
473
+ this.setTipMessage(tipInfo)
474
+ },
475
+ _fileIconClassName: function(name) {
476
+ let ext = name && isString(name) ? FileTransfer.extName(name) : null
477
+ if (ext) {
478
+ for (let type in EXT) {
479
+ if (Array.prototype.indexOf.call(EXT[type], ext) > -1) {
480
+ return ICON[type]
481
+ }
482
+ }
483
+ }
484
+ return ICON.unknown
485
+ },
486
+ _validateFileType: function(name) {
487
+ if (!this.fileTypeList || !this.fileTypeList.length) {
488
+ return true
489
+ }
490
+ let ext = FileTransfer.extName(name)
491
+ return (ext && isString(ext) && Array.prototype.indexOf.call(this.fileTypeList, ext) > -1) || undefined === ext
492
+ },
493
+ _fileObjGUID: function(fileObj) {
494
+ if (!fileObj) return
495
+
496
+ let str = (fileObj.lastModifiedDate ? fileObj.lastModifiedDate.valueOf() : fileObj.modificationdate) + fileObj.name + fileObj.size
497
+ return md5(str)
498
+ },
499
+ _addFile(fileObj) {
500
+ // IE: msClose
501
+ // Chrome: lastModified, webkitRelativePath
502
+ // ALL: lastModifiedDate, name, size, type, slice
503
+ let name = fileObj.name
504
+ let size = fileObj.size
505
+
506
+ // 使用修改时间, 文件名和文件大小生成唯一标识,fileObj.modificationdate for swfupload
507
+ let guid = fileObj.guid ? fileObj.guid : this._fileObjGUID(fileObj)
508
+ let valid = true
509
+ let text = FileTransfer.humanSize(size)
510
+
511
+ // 判断文件类型
512
+ const nameArr = fileObj.name.split('.')
513
+ let fileType = nameArr[nameArr.length - 1]
514
+ if (this.accept && this.accept.indexOf(fileType) === -1) {
515
+ this.$tip.warning(this.t('to.upload.tip.error.format', this.accept))
516
+ return
517
+ }
518
+
519
+ // 单文件大小限制
520
+ if (this.maxSize) {
521
+ let maxSize
522
+ if (typeof this.maxSize === 'number') {
523
+ maxSize = this.maxSize
524
+ } else {
525
+ if (this.maxSize.indexOf('K') > -1) {
526
+ maxSize = Number(this.maxSize.replace('K', '')) * Math.pow(1024, 1)
527
+ } else if (this.maxSize.indexOf('k') > -1) {
528
+ maxSize = Number(this.maxSize.replace('k', '')) * Math.pow(1024, 1)
529
+ } else if (this.maxSize.indexOf('M') > -1) {
530
+ maxSize = Number(this.maxSize.replace('M', '')) * Math.pow(1024, 2)
531
+ } else if (this.maxSize.indexOf('m') > -1) {
532
+ maxSize = Number(this.maxSize.replace('m', '')) * Math.pow(1024, 2)
533
+ } else if (this.maxSize.indexOf('G') > -1) {
534
+ maxSize = Number(this.maxSize.replace('G', '')) * Math.pow(1024, 3)
535
+ } else if (this.maxSize.indexOf('g') > -1) {
536
+ maxSize = Number(this.maxSize.replace('g', '')) * Math.pow(1024, 3)
537
+ } else {
538
+ maxSize = Infinity
539
+ }
540
+ }
541
+ if (size > maxSize) {
542
+ this.$tip.warning(this.t('to.upload.tip.error.size', this.maxSize))
543
+ return
544
+ }
545
+ }
546
+
547
+ // 已经存在相同的文件, 由于使用guid作为key, 目前不能支持重复文件
548
+ if (this.fileRepeat === false && this.iFiles[guid]) {
549
+ return
550
+ }
551
+
552
+ // 校验文件名
553
+ if (!this._validateFileType(name)) {
554
+ valid = false
555
+ text += ' ' + this.t('to.upload.invalid-filetype')
556
+ }
557
+
558
+ if (valid && size > this.fileSize) {
559
+ valid = false
560
+ text += ' ' + this.t('to.upload.invalid-filesize')
561
+ }
562
+
563
+ // 判断文件个数限制
564
+ let files_num = Object.keys(this.iFiles).length
565
+ if (files_num + 1 + this.finishedFiles.length > Number(this.maxLength)) { // 超出文件限制直接返回
566
+ this.$tip.warning(this.t('to.upload.tip.error.count', this.maxLength))
567
+ return
568
+ }
569
+ let file = {
570
+ guid,
571
+ name,
572
+ size,
573
+ valid,
574
+ fileId: fileObj.fileId,
575
+ fileObject: fileObj,
576
+ tipText: text,
577
+ status: 0,
578
+ iconClassName: this._fileIconClassName(name)
579
+ }
580
+ this.$set(this.iFiles, guid, file)
581
+
582
+ if (this.$TouchUI.staticDataApiConfig.apiHeaders && !this.headers) {
583
+ this.iApiHeaders = this.$TouchUI.staticDataApiConfig.apiHeaders
584
+ }
585
+
586
+ if (valid) {
587
+ this.transfers[guid] = new FileTransfer({
588
+ context: this,
589
+ url: this.action,
590
+ data: this.data,
591
+ headers: Object.assign({}, this.iApiHeaders),
592
+ withCredentials: this.withCredentials,
593
+ fileField: this.name,
594
+ start: this._transferStart,
595
+ success: this._transferSuccess,
596
+ error: this._transferError,
597
+ init: function(settings, file) {
598
+ settings = transferSign(settings)
599
+ },
600
+ progress: function(e, file) {
601
+ this._transferProgress(e.loaded, e.total, file)
602
+ }
603
+ }, file)
604
+ }
605
+ return file
606
+ },
607
+ _removeFile(guid) {
608
+ if (!guid || this.queue.length > 0) return
609
+
610
+ let file = this.iFiles[guid]
611
+ if (file) {
612
+ // 发送删除文件请求
613
+ let transfer = this.transfers[guid]
614
+ if (transfer) {
615
+ transfer.destroy()
616
+ transfer = null
617
+ }
618
+
619
+ for (let p in file) {
620
+ Vue.delete(file, p)
621
+ }
622
+ Vue.delete(this.iFiles, guid)
623
+ file = null
624
+ this.$forceUpdate()
625
+ }
626
+
627
+ // 移除DOM
628
+ let refs = this.$refs[guid + '_li']
629
+ let el = refs && refs.length ? refs[0] : null
630
+ if (el && el.nodeType) {
631
+ el.parentNode.removeChild(el)
632
+ }
633
+
634
+ // 重置form
635
+ refs = this.$refs['upForm']
636
+ refs.reset()
637
+ },
638
+ deleteFile(file) {
639
+ if (!file.guid) return
640
+ if (file.fileId) {
641
+ this.$emit('delete', file.fileId)
642
+ } else if (file.guid) {
643
+ this.$emit('delete', file.guid)
644
+ }
645
+ this._removeFile(file.guid)
646
+ this.updateTipFileInfo()
647
+ },
648
+ downloadFile(file) {
649
+ if (file[this.fileIdText]) {
650
+ this.$emit('download', file[this.fileIdText])
651
+ } else {
652
+ this.$emit('download', file)
653
+ }
654
+ },
655
+ browse() {
656
+ this.errorTip = ''
657
+ if (this.vmDisabled) return
658
+ if (this.loading || this.queue.length > 0) { // 判断队列是否还有未完成上传
659
+ return
660
+ }
661
+ this.$refs['fileInput'].click()
662
+ },
663
+ fileInputChange(e) {
664
+ this.selectFile(e)
665
+ },
666
+ selectFile(e) {
667
+ if (this.beforeChange) {
668
+ const fn = this.beforeChange(e, this.iFiles, this.finishedFiles)
669
+ // 异步
670
+ if (fn && fn.then) {
671
+ fn.then(flag => {
672
+ this.selectFileAction()
673
+ })
674
+ } else {
675
+ // 是同步方法,则返回为 true 执行
676
+ if (fn) {
677
+ this.selectFileAction()
678
+ }
679
+ }
680
+ } else {
681
+ this.selectFileAction()
682
+ }
683
+ },
684
+ selectFileAction() {
685
+ if (this.vmDisabled) return
686
+ if (this.loading || this.queue.length > 0) {
687
+ return
688
+ }
689
+ let fileEl = this.$refs['fileInput']
690
+ if (fileEl.files) {
691
+ this.$emit('fileInputChange', fileEl.files)
692
+ this.$emit('change', fileEl.files)
693
+
694
+ for (let i = 0, size = fileEl.files.length; i < size; i++) {
695
+ let reader = []
696
+ if (this.mode === 'img') {
697
+ reader = new FileReader()
698
+ reader.addEventListener('load', () => {
699
+ fileEl.files[i].src = reader.result
700
+ this._addFile(fileEl.files[i])
701
+ this.updateTipFileInfo()
702
+ if (i === size - 1) {
703
+ this.$nextTick(() => {
704
+ if (this.auto) {
705
+ this.upload(fileEl.files[i])
706
+ }
707
+ })
708
+ }
709
+ }, false)
710
+ reader.readAsDataURL(fileEl.files[i])
711
+ } else {
712
+ this._addFile(fileEl.files[i])
713
+ this.updateTipFileInfo()
714
+ this.$nextTick(() => {
715
+ if (this.auto || this.mode === 'button') {
716
+ this.upload(fileEl.files[i])
717
+ }
718
+ })
719
+ }
720
+ }
721
+ }
722
+ },
723
+ handleUploadStart(iFiles) {
724
+ if (this.beforeStart) {
725
+ const fn = this.beforeStart(iFiles)
726
+ // 异步
727
+ if (fn && fn.then) {
728
+ fn.then(flag => {
729
+ this.uploadAction()
730
+ })
731
+ } else {
732
+ // 是同步方法,则返回为 true 执行
733
+ if (fn) {
734
+ this.uploadAction()
735
+ }
736
+ }
737
+ } else {
738
+ this.uploadAction()
739
+ }
740
+ },
741
+ uploadAction() {
742
+ // 调用onStart
743
+ this.$emit('start', this.iFiles)
744
+
745
+ if (this.vmDisabled || this.loading || this.queue.length > 0) {
746
+ return
747
+ }
748
+
749
+ let file, transfer
750
+ for (let guid in this.iFiles) {
751
+ file = this.iFiles[guid]
752
+ if (file.valid && !file.fileId && !file.finished && (transfer = this.transfers[guid])) { // 根据fileId判断是否已经完成上传
753
+ transfer.send()
754
+ }
755
+ }
756
+ },
757
+ upload(iFiles) {
758
+ this.handleUploadStart(iFiles)
759
+ },
760
+ clearClick() {
761
+ if (this.vmDisabled) return
762
+
763
+ // 清除已上传文件列表
764
+ for (var guid in this.iFiles) {
765
+ this._removeFile(guid)
766
+ }
767
+ this.finishedFiles = []
768
+
769
+ // 重置form
770
+ let refs = this.$refs['upForm']
771
+ refs.reset()
772
+
773
+ this.updateTipFileInfo()
774
+
775
+ this.$emit('clear', this.iFiles, this.popup)
776
+ },
777
+ _transferStart(file) {
778
+ if (!file.guid) return
779
+
780
+ this.queue.push(file.guid)
781
+
782
+ this.iFiles[file.guid].status = 1 // 1:start,2:success,3:error
783
+ },
784
+ _transferSuccess(data, status, file) {
785
+ if (!file) return
786
+ this.queue.splice(this.queue.indexOf(file.guid), 1)
787
+
788
+ this.iFiles[file.guid].status = 2 // 1:start,2:success,3:error
789
+ this.iFiles[file.guid].percent = 100
790
+
791
+ // 成功事件
792
+ file.finished = true
793
+
794
+ // 处理 fileId 为 undefined 的情况
795
+ if (!file.fileId) {
796
+ if (typeof data === 'string') {
797
+ file.fileId = data
798
+ }
799
+ if (typeof data === 'object') {
800
+ if (data.data && data.data['id']) {
801
+ file.fileId = data.data['id']
802
+ } else {
803
+ if (data['id']) {
804
+ file.fileId = data['id']
805
+ }
806
+ if (data['fileId']) {
807
+ file.fileId = data['fileId']
808
+ }
809
+ }
810
+ }
811
+ }
812
+ this.$emit('success', data, status, file)
813
+ },
814
+ _transferError(data, status, file) {
815
+ if (!file) return
816
+ this.queue.splice(this.queue.indexOf(file.guid), 1)
817
+
818
+ this.iFiles[file.guid].status = 3 // 1:start,2:success,3:error
819
+
820
+ this.iFiles[file.guid].tipText = data.message
821
+
822
+ // 错误事件
823
+ this.$emit('error', data, status, file)
824
+ },
825
+ _transferProgress(loaded, total, file) {
826
+ if (!file.guid) return
827
+ let percent
828
+
829
+ percent = loaded > 0 && total > 0 ? Math.round(loaded / total * 100) : 0
830
+ if (percent >= 100) percent = 99 // 由 success 事件处理进度条最终完成
831
+ this.iFiles[file.guid].percent = percent
832
+ // el .style.width = percent + '%';
833
+ // }
834
+
835
+ // 调用 progress
836
+ this.$emit('progress', loaded, total, file)
837
+ },
838
+ setDisabled(f) {
839
+ this.vmDisabled = f
840
+ },
841
+ getColor(icon) {
842
+ let color = ''
843
+ switch (icon) {
844
+ case 'word':
845
+ color = 'primary'
846
+ break
847
+ case 'excel':
848
+ color = 'success'
849
+ break
850
+ case 'ppt':
851
+ color = 'warning'
852
+ break
853
+ default:
854
+ break
855
+ }
856
+ return color
857
+ }
858
+ }
859
+ }
860
+ </script>