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,814 +1,814 @@
1
- <template>
2
- <span ref="link" v-tip="changed ? t('to.common.originalValue', getLabelPath(valueStore[0])) : ''" :class="setClass" :tabindex="tabindex" :style="setStyle" class="to-select" @focus="focus" @blur="blur" @keyup.enter="toggleLayer" @keyup.esc="closeLayer" @mousedown="layerMousedown">
3
- <span v-if="verifiable && validateRequired" v-show="false" class="to-validate" :req="validateRequired" :desc="validateDesc" :value="value ? 'true' : ''"></span>
4
- <span v-if="$slots.prefix" class="to-selectPrefix"><slot name="prefix"></slot></span>
5
- <span class="to-selectContent" :class="setContentClass" @click="openLayer">
6
-
7
- <!-- 前缀文本/图标 -->
8
- <to-icon v-if="icon" v-bind="iconProps" :value="icon" :mode="iconProps && iconProps.mode ? iconProps.mode : 'none'" class="to-selectIcon"></to-icon>
9
- <span v-if="prefix" class="to-selectPrefixLabel">{{ prefix }}</span>
10
-
11
- <!-- 内容 -->
12
- <span v-if="multiple && selected.length > 0" class="to-selectTag">
13
- <template v-if="selected.length > 0">
14
- <template v-for="(item, index) in selected">
15
- <to-tag :key="index" color="fg" mode="plain" :deletable="!disabled" @delete="removeCheck(item.value); setSelected()">{{ item.labelPath }}</to-tag>
16
- </template>
17
- </template>
18
- </span>
19
- <span v-else class="to-selectValue">{{ label }}</span>
20
- <span class="to-selectArrow"></span>
21
-
22
- <!-- 后缀文本 -->
23
- <span v-if="suffix" class="to-selectSuffixLabel">{{ suffix }}</span>
24
-
25
- </span>
26
- <span v-if="$slots.suffix" class="to-selectSuffix"><slot name="suffix"></slot></span>
27
- <span v-if="$slots.default" class="to-selectSuffix"><slot></slot></span>
28
-
29
- <!-- 错误提示 -->
30
- <span v-if="errorTip" v-color="'danger'" class="to-box-tip">
31
- <template v-if="errorType === 'rule'">
32
- 选择有误
33
- <to-icon v-tip.danger="errorTip" value="help" color="danger" mode="toast" fillet="round"></to-icon>
34
- </template>
35
- <template v-else>
36
- 不能为空
37
- </template>
38
- </span>
39
-
40
- <!-- 弹出模式 -->
41
- <to-popup v-if="iOptionDisplay === 'popup'" ref="popup" @mousedown="layerMousedown">
42
- <to-popup-group v-for="(level, levelIndex) in levels" :key="levelIndex">
43
- <to-popup-item :tag="level.tag">
44
- <to-grid type="v" height="full">
45
- <to-grid-item side>
46
- <to-header color="bg" mode="fill" level="0" :title="level.title" @back="$refs.popup.back()">
47
- <to-button v-if="data.length > 0 && level.tag === 'level0' && clearable" icon="close" mode="none" color="primary" fillet="normal" @click="clear">{{ t('to.common.clear') }}</to-button>
48
- </to-header>
49
- </to-grid-item>
50
- <to-grid-item>
51
- <to-scroll color="bg" padding="0.5">
52
- <to-grid v-if="data.length > 0" :col="optionCol">
53
- <to-grid-item v-for="(item, index) in level.data" :key="index">
54
- <to-card link padding="0" :space="multiple ? 0:1" @click="forward(item, levelIndex)">
55
- <to-card-item v-if="multiple"><to-checkbox v-model="item.checked" @click="checked => { return check(checked, item)}"></to-checkbox></to-card-item>
56
- <to-card-item main>
57
- <to-padding :value="multiple ? 0:1">
58
- <to-ellipsis>{{ item.label }}</to-ellipsis>
59
- </to-padding>
60
- </to-card-item>
61
- <to-card-item v-if="!item.isLeaf" more><to-space type="inline"></to-space></to-card-item>
62
- <to-card-item v-if="valueLevel == 'any' && !multiple" link>
63
- <to-icon value="ok" mode="plain" link fillet="round" color="primary" @click.stop="select(item)"></to-icon>
64
- <to-space type="inline"></to-space>
65
- </to-card-item>
66
- </to-card>
67
- </to-grid-item>
68
- </to-grid>
69
- <to-msg v-else position="full" :title="t('to.common.noData')" :content="t('to.common.noDataDesc')" show></to-msg>
70
- </to-scroll>
71
- </to-grid-item>
72
- <to-grid-item v-if="multiple && $refs.popup && levelIndex === $refs.popup.currentPopupGroupIdx" side>
73
- <to-box padding="0">
74
- <to-submit width="full" :space="0" class="to-cascaderSubmit">
75
- <to-button v-size="'l'" mode="line" color="primary" @click="$refs.popup.close()">{{ t('to.common.cancel') }}</to-button>
76
- <to-button v-size="'l'" color="primary" @click="submit">{{ t('to.common.confirm') }}</to-button>
77
- </to-submit>
78
- </to-box>
79
- </to-grid-item>
80
- </to-grid>
81
- </to-popup-item>
82
- </to-popup-group>
83
- </to-popup>
84
-
85
- <!-- 悬浮下拉模式 -->
86
- <to-float v-else ref="layer" :width="optionWidth" :lazy="lazy" :align="optionAlign" @mousedown="layerMousedown">
87
- <to-padding v-if="data.length === 0" v-color="'info'" :value="1.5">
88
- {{ t('to.common.noData') }}
89
- </to-padding>
90
- <to-scroll v-else height="full">
91
- <to-tab ref="tab" v-model="curLevel" :height="tHeight" type="sup" @change="tabChange">
92
- <template v-if="clearable" slot="fn">
93
- <to-button icon="close" mode="none" fillet="normal" color="primary" @click="clear"></to-button>
94
- </template>
95
- <to-tab-item v-for="(level, levelIndex) in levels" :key="levelIndex" :label="level.title" :value="level.tag">
96
- <to-grid :col="optionCol" padding="0.5" padding-position="u">
97
- <to-grid-item v-for="(item, index) in level.data" :key="index">
98
- <to-card link :padding="0" :space="multiple ? 0:1" @click="forward(item, levelIndex)">
99
- <to-card-item v-if="multiple"><to-checkbox v-model="item.checked" @click="checked => { return check(checked, item)}"></to-checkbox></to-card-item>
100
- <to-card-item main>
101
- <to-padding :value="multiple ? 0:1">
102
- <to-ellipsis>{{ item.label }}</to-ellipsis>
103
- </to-padding>
104
- </to-card-item>
105
- <to-card-item v-if="valueLevel == 'any' && !multiple" link>
106
- <to-icon value="ok" mode="plain" link fillet="round" color="primary" @click.stop="select(item, levelIndex)"></to-icon>
107
- <to-space type="inline"></to-space>
108
- </to-card-item>
109
- </to-card>
110
- </to-grid-item>
111
- </to-grid>
112
- </to-tab-item>
113
- </to-tab>
114
- </to-scroll>
115
- </to-float>
116
-
117
- </span>
118
- </template>
119
- <script>
120
- import Locale from 'ai.touchui-vue/src/mixins/locale'
121
- import Tip from 'ai.touchui-vue/src/mixins/tip'
122
- import { t } from 'ai.touchui-vue/src/locale';
123
- export default {
124
- name: 'ToCascader',
125
- componentName: 'ToCascader',
126
- mixins: [Locale, Tip],
127
- model: {
128
- event: 'change'
129
- },
130
- inject: {
131
- ToForm: {
132
- default: ''
133
- },
134
- ToFormItem: {
135
- default: ''
136
- }
137
- },
138
- props: {
139
- lazy: {
140
- type: Boolean,
141
- default() {
142
- if (this.$TouchUI && this.$TouchUI.cascader && this.$TouchUI.cascader.lazy === false) {
143
- return false
144
- } else {
145
- return true
146
- }
147
- }
148
- },
149
- // 表单校验
150
- desc: {
151
- type: String,
152
- default: ''
153
- },
154
- required: Boolean,
155
- id: {
156
- type: String,
157
- default: ''
158
- },
159
- // 插件---------
160
- prefix: {
161
- type: String,
162
- default: ''
163
- },
164
- suffix: {
165
- type: String,
166
- default: ''
167
- },
168
- icon: {
169
- type: String,
170
- default: ''
171
- },
172
- iconProps: {
173
- type: Object,
174
- default: ()=>{}
175
- },
176
- // 数据设置---------
177
- value: {
178
- type: [String, Number, Boolean],
179
- default: ''
180
- },
181
- valueText: {
182
- type: String,
183
- default: 'value'
184
- },
185
- labelText: {
186
- type: String,
187
- default: 'label'
188
- },
189
- childrenText: {
190
- type: String,
191
- default: 'children'
192
- },
193
- data: {
194
- type: Array,
195
- default() {
196
- return []
197
- }
198
- },
199
- placeholder: {
200
- type: String,
201
- default: () => t('to.common.placeholder.select')
202
- },
203
- placeholderColor: {
204
- type: String,
205
- default: ''
206
- },
207
- // 外观设置---------
208
- color: {
209
- type: String,
210
- default: ''
211
- },
212
- verifiable: {
213
- type: Boolean,
214
- default: true
215
- },
216
- fillet: {
217
- type: String,
218
- default() {
219
- return this.$TouchUI.cascader.fillet || this.$TouchUI.global.fillet || 'normal'
220
- }
221
- },
222
- filletPosition: {
223
- type: String,
224
- default: ''
225
- },
226
- mode: {
227
- type: String,
228
- default: ''
229
- },
230
- width: {
231
- type: [Number, String],
232
- default: ''
233
- },
234
- // 选项设置---------
235
- optionDisplay: {
236
- type: String,
237
- default: ''
238
- },
239
- optionAlign: {
240
- type: String,
241
- default: 'left'
242
- },
243
- optionWidth: {
244
- type: [Number, String],
245
- default: ''
246
- },
247
- optionCol: {
248
- type: [Number, String],
249
- default: 1
250
- },
251
- multiple: Boolean,
252
- // 功能设置---------
253
- // 可选级别
254
- // 空:最后一级
255
- // any:任意一级
256
- valueLevel: {
257
- type: String,
258
- default: ''
259
- },
260
- clearable: {
261
- type: Boolean,
262
- default: true
263
- },
264
- tabindex: {
265
- type: String,
266
- default: '1'
267
- },
268
- readonly: Boolean,
269
- comparable: Boolean
270
- },
271
- data() {
272
- return {
273
- errorTip: '',
274
- errorType: 'rule',
275
- disabled: this.readonly,
276
- timer: null,
277
- blurByLayer: false,
278
- focused: false,
279
- iOptionDisplay: '',
280
- levels: [],
281
- valueStore: [],
282
- cur: {},
283
- label: '',
284
- iValue: '',
285
- curLevel: '',
286
- selected: null,
287
- popupSelected: '', // 缓存多选的值,提交后才广播
288
- deep: 1,
289
- labelArr: [],
290
- options: [],
291
- valuePath: [],
292
- tHeight: ''
293
- };
294
- },
295
- computed: {
296
- setStyle() {
297
- var obj = {};
298
- if (this.width) {
299
- if (!isNaN(this.width)) {
300
- obj.width = this.width + 'em';
301
- } else if (this.width === 'full') {
302
- obj.width = '100%';
303
- } else {
304
- obj.width = this.width;
305
- }
306
- }
307
- return obj;
308
- },
309
- setClass() {
310
- let arr = ['to-form-readonly']
311
- if (this.fillet !== 'none') {
312
- arr.push(`to-input-fillet-${this.fillet}`);
313
- }
314
- if (this.filletPosition) {
315
- arr.push(`to-input-fillet-position-${this.filletPosition}`);
316
- }
317
- if (this.placeholderColor) {
318
- arr.push(`to-select-placeholder-color-${this.placeholderColor}`);
319
- }
320
- if (this.value === '') {
321
- arr.push('to-select-placeholder')
322
- }
323
- if (this.errorTip) {
324
- arr.push('to-select-mode-line');
325
- arr.push('to-box-mode-line');
326
- arr.push('to-select-color-danger');
327
- arr.push('to-box-color-danger');
328
- arr.push('to-select-tip-show')
329
- } else {
330
- if (this.color) {
331
- if (this.color !== 'radam') {
332
- arr.push(`to-select-color-${this.color}`);
333
- } else {
334
- let colors = this.$TouchUI.colors
335
- let number = Math.round(Math.random() * 6)
336
- arr.push(`to-select-color-${ colors[number]}`);
337
- }
338
- }
339
- if (this.mode === 'fill' || this.mode === 'line') {
340
- arr.push('to-select-color-primary')
341
- arr.push('to-box-color-primary')
342
- } else {
343
- arr.push('to-select-color-fg')
344
- arr.push('to-box-color-fg')
345
- }
346
- if (this.mode) {
347
- arr.push(`to-select-mode-${this.mode}`)
348
- arr.push(`to-box-mode-${this.mode}`)
349
- } else if (this.ToForm && this.ToForm.type === 'list') {
350
- arr.push('to-select-mode-none')
351
- arr.push('to-box-mode-none')
352
- } else {
353
- arr.push('to-select-mode-toast')
354
- arr.push('to-box-mode-toast')
355
- }
356
- }
357
- if (this.focused) {
358
- arr.push('to-select-state-focus')
359
- }
360
- if (this.disabled) {
361
- arr.push('to-select-state-readonly')
362
- }
363
- if (this.changed) {
364
- arr.push('to-select-changed')
365
- }
366
- if ((this.ToForm && this.ToForm.comparable) || this.comparable) {
367
- arr.push('to-compare')
368
- }
369
- return arr
370
- },
371
- setContentClass() {
372
- let arr = []
373
- if (!this.disabled) {
374
- arr.push('to-box-link')
375
- }
376
- if (this.color) {
377
- arr.push(`to-box-color-${this.color}`)
378
- } else if (this.mode === 'fill' || this.mode === 'line') {
379
- arr.push('to-box-color-primary')
380
- } else {
381
- arr.push('to-box-color-fg')
382
- }
383
- if (this.mode) {
384
- arr.push(`to-box-mode-${this.mode}`)
385
- } else if (this.ToForm && this.ToForm.type === 'list') {
386
- arr.push('to-box-mode-none')
387
- } else {
388
- arr.push('to-box-mode-toast')
389
- }
390
- return arr
391
- },
392
- validateRequired() {
393
- if (this.required) {
394
- return 'true'
395
- } else if (this.ToFormItem && this.ToFormItem.required) {
396
- return 'true'
397
- } else {
398
- return 'false'
399
- }
400
- },
401
- validateDesc() {
402
- if (this.desc) {
403
- return this.desc
404
- } else if (this.ToFormItem && this.ToFormItem.label) {
405
- return this.ToFormItem.label
406
- } else {
407
- return ''
408
- }
409
- },
410
- changed() {
411
- if ((this.comparable || this.ToForm.comparable) && this.valueStore.length > 0 && this.value !== this.valueStore[0]) {
412
- return true
413
- } else {
414
- return false
415
- }
416
- }
417
- },
418
- watch: {
419
- readonly(val) {
420
- this.disabled = val
421
- },
422
- multiple: {
423
- handler(val) {
424
- if (val) {
425
- this.selected = []
426
- } else {
427
- this.selected = {}
428
- }
429
- },
430
- immediate: true
431
- },
432
- value: {
433
- handler(val) {
434
- this.iValue = this.value
435
- if (this.data && this.data.length) {
436
- this.$nextTick(()=>{
437
- this.setLabel()
438
- })
439
- }
440
- },
441
- immediate: true
442
- },
443
- data: {
444
- handler() {
445
- this.initData()
446
- this.initLevels()
447
- if (this.data && this.data.length) {
448
- this.$nextTick(()=>{
449
- this.setLabel()
450
- })
451
- }
452
- },
453
- deep: true
454
- },
455
- selected(val) {
456
- if (!val) {
457
- this.$emit('change', '')
458
- this.initData()
459
- this.initLevels()
460
- } else {
461
- if (this.multiple) {
462
-
463
- let arr = []
464
- val.map(node => {
465
- arr.push(node.value)
466
- })
467
-
468
- // 抛出值
469
- this.$emit('change', arr.join(','))
470
-
471
- if (this.iOptionDisplay !== 'popup') {
472
-
473
- // 调整 float 位置
474
- this.$nextTick(()=>{
475
- this.$refs.layer.set(this.$refs.link)
476
- })
477
- }
478
- } else {
479
- this.label = this.getLabelPath(val.value)
480
- this.$emit('change', val.value)
481
- }
482
- }
483
- }
484
- },
485
- created() {
486
- // 设置 placeholder
487
- this.iValue = this.value
488
- if (!this.value) {
489
- this.label = this.placeholder
490
- }
491
-
492
- // 初始化数据
493
- this.initData()
494
- this.initLevels()
495
-
496
- // 设置弹出模式
497
- if (this.optionDisplay) {
498
- this.iOptionDisplay = this.optionDisplay
499
- } else {
500
- if (this.$phone) {
501
- this.iOptionDisplay = 'popup'
502
- } else {
503
- this.iOptionDisplay = 'flaot'
504
- }
505
- }
506
- },
507
- mounted() {
508
- },
509
- methods: {
510
- getTHeight() {
511
- let h = ''
512
- let c_h = document.body.clientHeight
513
- this.$nextTick(function() {
514
- if (this.$refs.link && this.$refs.tab) {
515
- let y = this.$refs.link.getBoundingClientRect().top
516
- let linkHeight = this.$refs.link.offsetHeight
517
- let t_h = this.$refs.tab.$el.offsetHeight
518
- h = t_h + 'px'
519
- if (y > (c_h - y - linkHeight) && y < t_h) {
520
- h = y + 'px'
521
- } else if (y < (c_h - y - linkHeight) && (c_h - y - linkHeight) < t_h) {
522
- h = (c_h - y - linkHeight) + 'px'
523
- }
524
- }
525
- this.tHeight = h
526
- })
527
- },
528
- // 初始化展示数据
529
- initLevels() {
530
- let arr = []
531
- this.nodes.map(node=>{
532
- arr.push(node.level)
533
- })
534
- this.deep = arr.sort().reverse()[0] + 1
535
- this.levels = [
536
- {
537
- title: this.placeholder,
538
- data: this.nodes.filter(node => node.level === 0),
539
- tag: 'level0'
540
- }
541
- ]
542
- for (let i = 1; i < this.deep; i++) {
543
- this.levels[i] = {
544
- title: '',
545
- data: [],
546
- tag: 'level' + i
547
- }
548
- }
549
- this.curLevel = ''
550
- },
551
-
552
- initData() {
553
- this.nodes = this.getNodes(this.data)
554
- },
555
-
556
- getLabelPath(val) {
557
- if (val && this.nodes.find(node => node.value === val)) {
558
- return this.nodes.find(node => node.value === val).labelPath
559
- } else {
560
- return this.placeholder
561
- }
562
- },
563
-
564
- setLabel() {
565
- if (this.iValue) {
566
- if (this.multiple) {
567
- this.selected = []
568
- this.nodes.map(node => {
569
- if ((node.isLeaf || this.valueLevel === 'any') && this.iValue.split(',').includes(node.value)) {
570
- this.addCheck(node.value)
571
- }
572
- })
573
- } else {
574
- this.label = this.getLabelPath(this.iValue)
575
- }
576
- this.setSelected()
577
- } else {
578
- this.label = this.placeholder
579
- }
580
- },
581
-
582
- // 把所有数据打平成一个数组
583
- getNodes(data) {
584
- let arr = []
585
- let that = this
586
- function set(node, level = 0, path = '', labelPath = '', parent = '__root__') {
587
- for (let i = 0; i < node.length; i++) {
588
- arr.push({
589
- label: node[i][that.labelText] || '',
590
- value: node[i][that.valueText] || '',
591
- level: level,
592
- path: (path + ',' + node[i][that.valueText]).substr(1),
593
- labelPath: (labelPath + ' / ' + node[i][that.labelText]).substr(3),
594
- parent: parent,
595
- isLeaf: !(node[i][that.childrenText] && node[i][that.childrenText].length > 0)
596
- })
597
- if (node[i][that.childrenText]) {
598
- set(
599
- node[i][that.childrenText],
600
- level + 1,
601
- path + ',' + node[i][that.valueText],
602
- labelPath + ' / ' + node[i][that.labelText],
603
- node[i][that.valueText]
604
- )
605
- }
606
- }
607
- }
608
- set(data)
609
- return arr
610
- },
611
- forward(item, levelIndex) {
612
- this.cur = item
613
- if (item.isLeaf) {
614
- if (!this.multiple) {
615
- this.select(item)
616
- } else {
617
- this.check(!item.checked, item)
618
- }
619
- } else {
620
- const path = item.path.split(',')
621
- this.$set(
622
- this.levels,
623
- levelIndex + 1,
624
- {
625
- title: item.label,
626
- data: this.nodes.filter(node => node.level === levelIndex + 1 && node.path.split(',').includes(path[levelIndex])),
627
- tag: 'level' + (levelIndex + 1)
628
- }
629
- )
630
- if (this.iOptionDisplay === 'popup') {
631
- this.$refs.popup.forward('level' + (levelIndex + 1))
632
- } else {
633
- this.curLevel = 'level' + (levelIndex + 1)
634
- this.tHeight = ''
635
- this.getTHeight()
636
- }
637
- }
638
- },
639
- clear() {
640
- if (this.iOptionDisplay === 'popup') {
641
- this.$refs.popup.close()
642
- } else {
643
- this.$refs.layer.close()
644
- }
645
- this.selected = ''
646
- },
647
- focus() {
648
- this.errorTip = ''
649
- this.focused = true
650
- },
651
- blur() {
652
- this.focused = false
653
- if (!this.blurByLayer) {
654
- this.closeLayer()
655
- }
656
- },
657
- layerMousedown() {
658
- this.blurByLayer = true
659
- this.timer = setTimeout(() => {
660
- this.blurByLayer = false
661
- clearTimeout(this.timer)
662
- this.timer = null
663
- }, 200);
664
- },
665
- select(item) {
666
- this.selected = item
667
- this.closeLayer()
668
- },
669
- toggleLayer() {
670
- if (this.iOptionDisplay === 'popup') {
671
- if (this.$refs.popup.visible) {
672
- this.closeLayer()
673
- } else {
674
- this.openLayer()
675
- }
676
- } else {
677
- if (this.$refs.layer.show) {
678
- this.closeLayer()
679
- } else {
680
- this.openLayer()
681
- }
682
- }
683
- },
684
- closeLayer() {
685
- if (!this.disabled) {
686
- if (this.iOptionDisplay === 'popup') {
687
- this.$refs.popup.close()
688
- } else {
689
- this.$refs.layer.close()
690
- }
691
- }
692
- },
693
- openLayer() {
694
- if (!this.disabled) {
695
- if (this.iOptionDisplay === 'popup') {
696
- this.$refs.popup.open('level0')
697
- } else {
698
- this.$refs.layer.toggle('link')
699
- this.tHeight = ''
700
- this.getTHeight()
701
- }
702
- }
703
- },
704
- tabChange() {
705
- this.$nextTick(function() {
706
- this.tHeight = ''
707
- this.getTHeight()
708
- })
709
- },
710
- check(checked, item) {
711
- if (checked) {
712
- this.addCheck(item.value)
713
- } else {
714
- this.removeCheck(item.value)
715
- }
716
- if (this.iOptionDisplay === 'popup') {
717
- this.setPopupSelected()
718
- } else {
719
- this.setSelected()
720
- }
721
- },
722
- addCheck(val) {
723
-
724
- if (this.valueLevel === 'any') {
725
- this.getNode(val).checked = true
726
- } else {
727
-
728
- // 添加所有路径中含有本元素值的元素
729
- this.nodes.map(node=>{
730
- if (node.path.split(',').includes(val)) {
731
- node.checked = true
732
- }
733
- })
734
-
735
- // 和自己同级的元素如果全部都加上,父元素执行递归执行 addCheck
736
- let isAddAll = true
737
- let item = this.getNode(val)
738
- this.nodes.map(node=>{
739
- if (node.parent === item.parent && !node.checked) {
740
- isAddAll = false
741
- }
742
- })
743
- if (isAddAll && item.parent !== '__root__') {
744
- this.addCheck(item.parent)
745
- }
746
- }
747
- },
748
- removeCheck(val, notspread) {
749
-
750
- if (this.valueLevel === 'any') {
751
- this.getNode(val).checked = false
752
- } else {
753
-
754
- // 清空所有路径中含有本元素值的元素
755
- if (!notspread) {
756
- this.nodes.map(node=>{
757
- if (node.path.split(',').includes(val)) {
758
- node.checked = false
759
- }
760
- })
761
- }
762
-
763
- // 父元素也勾掉
764
- let item = this.getNode(val)
765
- if (item.parent !== '__root__') {
766
- let parent = this.getNode(item.parent)
767
- parent.checked = false
768
- this.removeCheck(parent.value, true)
769
- }
770
- }
771
- },
772
- setPopupSelected() {
773
- this.popupSelected = []
774
- this.nodes.map(node=>{
775
- if (node.checked && (node.isLeaf || this.valueLevel === 'any')) {
776
- this.popupSelected.push(node)
777
- }
778
- })
779
- },
780
- setSelected() {
781
- if (this.multiple) {
782
- this.selected = []
783
- this.nodes.map(node=>{
784
- if (node.checked && (node.isLeaf || this.valueLevel === 'any')) {
785
- this.selected.push(node)
786
- }
787
- })
788
- } else {
789
- this.selected = this.nodes.find(node => node.value === this.iValue)
790
- }
791
- },
792
- getNode(val) {
793
- return this.nodes.find(node=>node.value === val)
794
- },
795
- submit() {
796
- this.$refs.popup.close();
797
- this.selected = [...this.popupSelected]
798
- },
799
-
800
- // 记录历史值,以便对比或者取值
801
- compare() {
802
- this.valueStore.unshift(this.value)
803
- },
804
- setDisabled(f) {
805
- this.disabled = f
806
- },
807
- // 撤销
808
- restore() {
809
- this.data = this.valueStore[0]
810
- this.valueStore.splice(0, 1)
811
- }
812
- }
813
- };
814
- </script>
1
+ <template>
2
+ <span ref="link" v-tip="changed ? t('to.common.originalValue', getLabelPath(valueStore[0])) : ''" :class="setClass" :tabindex="tabindex" :style="setStyle" class="to-select" @focus="focus" @blur="blur" @keyup.enter="toggleLayer" @keyup.esc="closeLayer" @mousedown="layerMousedown">
3
+ <span v-if="verifiable && validateRequired" v-show="false" class="to-validate" :req="validateRequired" :desc="validateDesc" :value="value ? 'true' : ''"></span>
4
+ <span v-if="$slots.prefix" class="to-selectPrefix"><slot name="prefix"></slot></span>
5
+ <span class="to-selectContent" :class="setContentClass" @click="openLayer">
6
+
7
+ <!-- 前缀文本/图标 -->
8
+ <to-icon v-if="icon" v-bind="iconProps" :value="icon" :mode="iconProps && iconProps.mode ? iconProps.mode : 'none'" class="to-selectIcon"></to-icon>
9
+ <span v-if="prefix" class="to-selectPrefixLabel">{{ prefix }}</span>
10
+
11
+ <!-- 内容 -->
12
+ <span v-if="multiple && selected.length > 0" class="to-selectTag">
13
+ <template v-if="selected.length > 0">
14
+ <template v-for="(item, index) in selected">
15
+ <to-tag :key="index" color="fg" mode="plain" :deletable="!disabled" @delete="removeCheck(item.value); setSelected()">{{ item.labelPath }}</to-tag>
16
+ </template>
17
+ </template>
18
+ </span>
19
+ <span v-else class="to-selectValue">{{ label }}</span>
20
+ <span class="to-selectArrow"></span>
21
+
22
+ <!-- 后缀文本 -->
23
+ <span v-if="suffix" class="to-selectSuffixLabel">{{ suffix }}</span>
24
+
25
+ </span>
26
+ <span v-if="$slots.suffix" class="to-selectSuffix"><slot name="suffix"></slot></span>
27
+ <span v-if="$slots.default" class="to-selectSuffix"><slot></slot></span>
28
+
29
+ <!-- 错误提示 -->
30
+ <span v-if="errorTip" v-color="'danger'" class="to-box-tip">
31
+ <template v-if="errorType === 'rule'">
32
+ 选择有误
33
+ <to-icon v-tip.danger="errorTip" value="help" color="danger" mode="toast" fillet="round"></to-icon>
34
+ </template>
35
+ <template v-else>
36
+ 不能为空
37
+ </template>
38
+ </span>
39
+
40
+ <!-- 弹出模式 -->
41
+ <to-popup v-if="iOptionDisplay === 'popup'" ref="popup" @mousedown="layerMousedown">
42
+ <to-popup-group v-for="(level, levelIndex) in levels" :key="levelIndex">
43
+ <to-popup-item :tag="level.tag">
44
+ <to-grid type="v" height="full">
45
+ <to-grid-item side>
46
+ <to-header color="bg" mode="fill" level="0" :title="level.title" @back="$refs.popup.back()">
47
+ <to-button v-if="data.length > 0 && level.tag === 'level0' && clearable" icon="close" mode="none" color="primary" fillet="normal" @click="clear">{{ t('to.common.clear') }}</to-button>
48
+ </to-header>
49
+ </to-grid-item>
50
+ <to-grid-item>
51
+ <to-scroll color="bg" padding="0.5">
52
+ <to-grid v-if="data.length > 0" :col="optionCol">
53
+ <to-grid-item v-for="(item, index) in level.data" :key="index">
54
+ <to-card link padding="0" :space="multiple ? 0:1" @click="forward(item, levelIndex)">
55
+ <to-card-item v-if="multiple"><to-checkbox v-model="item.checked" @click="checked => { return check(checked, item)}"></to-checkbox></to-card-item>
56
+ <to-card-item main>
57
+ <to-padding :value="multiple ? 0:1">
58
+ <to-ellipsis>{{ item.label }}</to-ellipsis>
59
+ </to-padding>
60
+ </to-card-item>
61
+ <to-card-item v-if="!item.isLeaf" more><to-space type="inline"></to-space></to-card-item>
62
+ <to-card-item v-if="valueLevel == 'any' && !multiple" link>
63
+ <to-icon value="ok" mode="plain" link fillet="round" color="primary" @click.stop="select(item)"></to-icon>
64
+ <to-space type="inline"></to-space>
65
+ </to-card-item>
66
+ </to-card>
67
+ </to-grid-item>
68
+ </to-grid>
69
+ <to-msg v-else position="full" :title="t('to.common.noData')" :content="t('to.common.noDataDesc')" show></to-msg>
70
+ </to-scroll>
71
+ </to-grid-item>
72
+ <to-grid-item v-if="multiple && $refs.popup && levelIndex === $refs.popup.currentPopupGroupIdx" side>
73
+ <to-box padding="0">
74
+ <to-submit width="full" :space="0" class="to-cascaderSubmit">
75
+ <to-button v-size="'l'" mode="line" color="primary" @click="$refs.popup.close()">{{ t('to.common.cancel') }}</to-button>
76
+ <to-button v-size="'l'" color="primary" @click="submit">{{ t('to.common.confirm') }}</to-button>
77
+ </to-submit>
78
+ </to-box>
79
+ </to-grid-item>
80
+ </to-grid>
81
+ </to-popup-item>
82
+ </to-popup-group>
83
+ </to-popup>
84
+
85
+ <!-- 悬浮下拉模式 -->
86
+ <to-float v-else ref="layer" :width="optionWidth" :lazy="lazy" :align="optionAlign" @mousedown="layerMousedown">
87
+ <to-padding v-if="data.length === 0" v-color="'info'" :value="1.5">
88
+ {{ t('to.common.noData') }}
89
+ </to-padding>
90
+ <to-scroll v-else height="full">
91
+ <to-tab ref="tab" v-model="curLevel" :height="tHeight" type="sup" @change="tabChange">
92
+ <template v-if="clearable" slot="fn">
93
+ <to-button icon="close" mode="none" fillet="normal" color="primary" @click="clear"></to-button>
94
+ </template>
95
+ <to-tab-item v-for="(level, levelIndex) in levels" :key="levelIndex" :label="level.title" :value="level.tag">
96
+ <to-grid :col="optionCol" padding="0.5" padding-position="u">
97
+ <to-grid-item v-for="(item, index) in level.data" :key="index">
98
+ <to-card link :padding="0" :space="multiple ? 0:1" @click="forward(item, levelIndex)">
99
+ <to-card-item v-if="multiple"><to-checkbox v-model="item.checked" @click="checked => { return check(checked, item)}"></to-checkbox></to-card-item>
100
+ <to-card-item main>
101
+ <to-padding :value="multiple ? 0:1">
102
+ <to-ellipsis>{{ item.label }}</to-ellipsis>
103
+ </to-padding>
104
+ </to-card-item>
105
+ <to-card-item v-if="valueLevel == 'any' && !multiple" link>
106
+ <to-icon value="ok" mode="plain" link fillet="round" color="primary" @click.stop="select(item, levelIndex)"></to-icon>
107
+ <to-space type="inline"></to-space>
108
+ </to-card-item>
109
+ </to-card>
110
+ </to-grid-item>
111
+ </to-grid>
112
+ </to-tab-item>
113
+ </to-tab>
114
+ </to-scroll>
115
+ </to-float>
116
+
117
+ </span>
118
+ </template>
119
+ <script>
120
+ import Locale from 'ai.touchui-vue/src/mixins/locale'
121
+ import Tip from 'ai.touchui-vue/src/mixins/tip'
122
+ import { t } from 'ai.touchui-vue/src/locale';
123
+ export default {
124
+ name: 'ToCascader',
125
+ componentName: 'ToCascader',
126
+ mixins: [Locale, Tip],
127
+ model: {
128
+ event: 'change'
129
+ },
130
+ inject: {
131
+ ToForm: {
132
+ default: ''
133
+ },
134
+ ToFormItem: {
135
+ default: ''
136
+ }
137
+ },
138
+ props: {
139
+ lazy: {
140
+ type: Boolean,
141
+ default() {
142
+ if (this.$TouchUI && this.$TouchUI.cascader && this.$TouchUI.cascader.lazy === false) {
143
+ return false
144
+ } else {
145
+ return true
146
+ }
147
+ }
148
+ },
149
+ // 表单校验
150
+ desc: {
151
+ type: String,
152
+ default: ''
153
+ },
154
+ required: Boolean,
155
+ id: {
156
+ type: String,
157
+ default: ''
158
+ },
159
+ // 插件---------
160
+ prefix: {
161
+ type: String,
162
+ default: ''
163
+ },
164
+ suffix: {
165
+ type: String,
166
+ default: ''
167
+ },
168
+ icon: {
169
+ type: String,
170
+ default: ''
171
+ },
172
+ iconProps: {
173
+ type: Object,
174
+ default: ()=>{}
175
+ },
176
+ // 数据设置---------
177
+ value: {
178
+ type: [String, Number, Boolean],
179
+ default: ''
180
+ },
181
+ valueText: {
182
+ type: String,
183
+ default: 'value'
184
+ },
185
+ labelText: {
186
+ type: String,
187
+ default: 'label'
188
+ },
189
+ childrenText: {
190
+ type: String,
191
+ default: 'children'
192
+ },
193
+ data: {
194
+ type: Array,
195
+ default() {
196
+ return []
197
+ }
198
+ },
199
+ placeholder: {
200
+ type: String,
201
+ default: () => t('to.common.placeholder.select')
202
+ },
203
+ placeholderColor: {
204
+ type: String,
205
+ default: ''
206
+ },
207
+ // 外观设置---------
208
+ color: {
209
+ type: String,
210
+ default: ''
211
+ },
212
+ verifiable: {
213
+ type: Boolean,
214
+ default: true
215
+ },
216
+ fillet: {
217
+ type: String,
218
+ default() {
219
+ return this.$TouchUI.cascader.fillet || this.$TouchUI.global.fillet || 'normal'
220
+ }
221
+ },
222
+ filletPosition: {
223
+ type: String,
224
+ default: ''
225
+ },
226
+ mode: {
227
+ type: String,
228
+ default: ''
229
+ },
230
+ width: {
231
+ type: [Number, String],
232
+ default: ''
233
+ },
234
+ // 选项设置---------
235
+ optionDisplay: {
236
+ type: String,
237
+ default: ''
238
+ },
239
+ optionAlign: {
240
+ type: String,
241
+ default: 'left'
242
+ },
243
+ optionWidth: {
244
+ type: [Number, String],
245
+ default: ''
246
+ },
247
+ optionCol: {
248
+ type: [Number, String],
249
+ default: 1
250
+ },
251
+ multiple: Boolean,
252
+ // 功能设置---------
253
+ // 可选级别
254
+ // 空:最后一级
255
+ // any:任意一级
256
+ valueLevel: {
257
+ type: String,
258
+ default: ''
259
+ },
260
+ clearable: {
261
+ type: Boolean,
262
+ default: true
263
+ },
264
+ tabindex: {
265
+ type: String,
266
+ default: '1'
267
+ },
268
+ readonly: Boolean,
269
+ comparable: Boolean
270
+ },
271
+ data() {
272
+ return {
273
+ errorTip: '',
274
+ errorType: 'rule',
275
+ disabled: this.readonly,
276
+ timer: null,
277
+ blurByLayer: false,
278
+ focused: false,
279
+ iOptionDisplay: '',
280
+ levels: [],
281
+ valueStore: [],
282
+ cur: {},
283
+ label: '',
284
+ iValue: '',
285
+ curLevel: '',
286
+ selected: null,
287
+ popupSelected: '', // 缓存多选的值,提交后才广播
288
+ deep: 1,
289
+ labelArr: [],
290
+ options: [],
291
+ valuePath: [],
292
+ tHeight: ''
293
+ };
294
+ },
295
+ computed: {
296
+ setStyle() {
297
+ var obj = {};
298
+ if (this.width) {
299
+ if (!isNaN(this.width)) {
300
+ obj.width = this.width + 'em';
301
+ } else if (this.width === 'full') {
302
+ obj.width = '100%';
303
+ } else {
304
+ obj.width = this.width;
305
+ }
306
+ }
307
+ return obj;
308
+ },
309
+ setClass() {
310
+ let arr = ['to-form-readonly']
311
+ if (this.fillet !== 'none') {
312
+ arr.push(`to-input-fillet-${this.fillet}`);
313
+ }
314
+ if (this.filletPosition) {
315
+ arr.push(`to-input-fillet-position-${this.filletPosition}`);
316
+ }
317
+ if (this.placeholderColor) {
318
+ arr.push(`to-select-placeholder-color-${this.placeholderColor}`);
319
+ }
320
+ if (this.value === '') {
321
+ arr.push('to-select-placeholder')
322
+ }
323
+ if (this.errorTip) {
324
+ arr.push('to-select-mode-line');
325
+ arr.push('to-box-mode-line');
326
+ arr.push('to-select-color-danger');
327
+ arr.push('to-box-color-danger');
328
+ arr.push('to-select-tip-show')
329
+ } else {
330
+ if (this.color) {
331
+ if (this.color !== 'radam') {
332
+ arr.push(`to-select-color-${this.color}`);
333
+ } else {
334
+ let colors = this.$TouchUI.colors
335
+ let number = Math.round(Math.random() * 6)
336
+ arr.push(`to-select-color-${ colors[number]}`);
337
+ }
338
+ }
339
+ if (this.mode === 'fill' || this.mode === 'line') {
340
+ arr.push('to-select-color-primary')
341
+ arr.push('to-box-color-primary')
342
+ } else {
343
+ arr.push('to-select-color-fg')
344
+ arr.push('to-box-color-fg')
345
+ }
346
+ if (this.mode) {
347
+ arr.push(`to-select-mode-${this.mode}`)
348
+ arr.push(`to-box-mode-${this.mode}`)
349
+ } else if (this.ToForm && this.ToForm.type === 'list') {
350
+ arr.push('to-select-mode-none')
351
+ arr.push('to-box-mode-none')
352
+ } else {
353
+ arr.push('to-select-mode-toast')
354
+ arr.push('to-box-mode-toast')
355
+ }
356
+ }
357
+ if (this.focused) {
358
+ arr.push('to-select-state-focus')
359
+ }
360
+ if (this.disabled) {
361
+ arr.push('to-select-state-readonly')
362
+ }
363
+ if (this.changed) {
364
+ arr.push('to-select-changed')
365
+ }
366
+ if ((this.ToForm && this.ToForm.comparable) || this.comparable) {
367
+ arr.push('to-compare')
368
+ }
369
+ return arr
370
+ },
371
+ setContentClass() {
372
+ let arr = []
373
+ if (!this.disabled) {
374
+ arr.push('to-box-link')
375
+ }
376
+ if (this.color) {
377
+ arr.push(`to-box-color-${this.color}`)
378
+ } else if (this.mode === 'fill' || this.mode === 'line') {
379
+ arr.push('to-box-color-primary')
380
+ } else {
381
+ arr.push('to-box-color-fg')
382
+ }
383
+ if (this.mode) {
384
+ arr.push(`to-box-mode-${this.mode}`)
385
+ } else if (this.ToForm && this.ToForm.type === 'list') {
386
+ arr.push('to-box-mode-none')
387
+ } else {
388
+ arr.push('to-box-mode-toast')
389
+ }
390
+ return arr
391
+ },
392
+ validateRequired() {
393
+ if (this.required) {
394
+ return 'true'
395
+ } else if (this.ToFormItem && this.ToFormItem.required) {
396
+ return 'true'
397
+ } else {
398
+ return 'false'
399
+ }
400
+ },
401
+ validateDesc() {
402
+ if (this.desc) {
403
+ return this.desc
404
+ } else if (this.ToFormItem && this.ToFormItem.label) {
405
+ return this.ToFormItem.label
406
+ } else {
407
+ return ''
408
+ }
409
+ },
410
+ changed() {
411
+ if ((this.comparable || this.ToForm.comparable) && this.valueStore.length > 0 && this.value !== this.valueStore[0]) {
412
+ return true
413
+ } else {
414
+ return false
415
+ }
416
+ }
417
+ },
418
+ watch: {
419
+ readonly(val) {
420
+ this.disabled = val
421
+ },
422
+ multiple: {
423
+ handler(val) {
424
+ if (val) {
425
+ this.selected = []
426
+ } else {
427
+ this.selected = {}
428
+ }
429
+ },
430
+ immediate: true
431
+ },
432
+ value: {
433
+ handler(val) {
434
+ this.iValue = this.value
435
+ if (this.data && this.data.length) {
436
+ this.$nextTick(()=>{
437
+ this.setLabel()
438
+ })
439
+ }
440
+ },
441
+ immediate: true
442
+ },
443
+ data: {
444
+ handler() {
445
+ this.initData()
446
+ this.initLevels()
447
+ if (this.data && this.data.length) {
448
+ this.$nextTick(()=>{
449
+ this.setLabel()
450
+ })
451
+ }
452
+ },
453
+ deep: true
454
+ },
455
+ selected(val) {
456
+ if (!val) {
457
+ this.$emit('change', '')
458
+ this.initData()
459
+ this.initLevels()
460
+ } else {
461
+ if (this.multiple) {
462
+
463
+ let arr = []
464
+ val.map(node => {
465
+ arr.push(node.value)
466
+ })
467
+
468
+ // 抛出值
469
+ this.$emit('change', arr.join(','))
470
+
471
+ if (this.iOptionDisplay !== 'popup') {
472
+
473
+ // 调整 float 位置
474
+ this.$nextTick(()=>{
475
+ this.$refs.layer.set(this.$refs.link)
476
+ })
477
+ }
478
+ } else {
479
+ this.label = this.getLabelPath(val.value)
480
+ this.$emit('change', val.value)
481
+ }
482
+ }
483
+ }
484
+ },
485
+ created() {
486
+ // 设置 placeholder
487
+ this.iValue = this.value
488
+ if (!this.value) {
489
+ this.label = this.placeholder
490
+ }
491
+
492
+ // 初始化数据
493
+ this.initData()
494
+ this.initLevels()
495
+
496
+ // 设置弹出模式
497
+ if (this.optionDisplay) {
498
+ this.iOptionDisplay = this.optionDisplay
499
+ } else {
500
+ if (this.$phone) {
501
+ this.iOptionDisplay = 'popup'
502
+ } else {
503
+ this.iOptionDisplay = 'flaot'
504
+ }
505
+ }
506
+ },
507
+ mounted() {
508
+ },
509
+ methods: {
510
+ getTHeight() {
511
+ let h = ''
512
+ let c_h = document.body.clientHeight
513
+ this.$nextTick(function() {
514
+ if (this.$refs.link && this.$refs.tab) {
515
+ let y = this.$refs.link.getBoundingClientRect().top
516
+ let linkHeight = this.$refs.link.offsetHeight
517
+ let t_h = this.$refs.tab.$el.offsetHeight
518
+ h = t_h + 'px'
519
+ if (y > (c_h - y - linkHeight) && y < t_h) {
520
+ h = y + 'px'
521
+ } else if (y < (c_h - y - linkHeight) && (c_h - y - linkHeight) < t_h) {
522
+ h = (c_h - y - linkHeight) + 'px'
523
+ }
524
+ }
525
+ this.tHeight = h
526
+ })
527
+ },
528
+ // 初始化展示数据
529
+ initLevels() {
530
+ let arr = []
531
+ this.nodes.map(node=>{
532
+ arr.push(node.level)
533
+ })
534
+ this.deep = arr.sort().reverse()[0] + 1
535
+ this.levels = [
536
+ {
537
+ title: this.placeholder,
538
+ data: this.nodes.filter(node => node.level === 0),
539
+ tag: 'level0'
540
+ }
541
+ ]
542
+ for (let i = 1; i < this.deep; i++) {
543
+ this.levels[i] = {
544
+ title: '',
545
+ data: [],
546
+ tag: 'level' + i
547
+ }
548
+ }
549
+ this.curLevel = ''
550
+ },
551
+
552
+ initData() {
553
+ this.nodes = this.getNodes(this.data)
554
+ },
555
+
556
+ getLabelPath(val) {
557
+ if (val && this.nodes.find(node => node.value === val)) {
558
+ return this.nodes.find(node => node.value === val).labelPath
559
+ } else {
560
+ return this.placeholder
561
+ }
562
+ },
563
+
564
+ setLabel() {
565
+ if (this.iValue) {
566
+ if (this.multiple) {
567
+ this.selected = []
568
+ this.nodes.map(node => {
569
+ if ((node.isLeaf || this.valueLevel === 'any') && this.iValue.split(',').includes(node.value)) {
570
+ this.addCheck(node.value)
571
+ }
572
+ })
573
+ } else {
574
+ this.label = this.getLabelPath(this.iValue)
575
+ }
576
+ this.setSelected()
577
+ } else {
578
+ this.label = this.placeholder
579
+ }
580
+ },
581
+
582
+ // 把所有数据打平成一个数组
583
+ getNodes(data) {
584
+ let arr = []
585
+ let that = this
586
+ function set(node, level = 0, path = '', labelPath = '', parent = '__root__') {
587
+ for (let i = 0; i < node.length; i++) {
588
+ arr.push({
589
+ label: node[i][that.labelText] || '',
590
+ value: node[i][that.valueText] || '',
591
+ level: level,
592
+ path: (path + ',' + node[i][that.valueText]).substr(1),
593
+ labelPath: (labelPath + ' / ' + node[i][that.labelText]).substr(3),
594
+ parent: parent,
595
+ isLeaf: !(node[i][that.childrenText] && node[i][that.childrenText].length > 0)
596
+ })
597
+ if (node[i][that.childrenText]) {
598
+ set(
599
+ node[i][that.childrenText],
600
+ level + 1,
601
+ path + ',' + node[i][that.valueText],
602
+ labelPath + ' / ' + node[i][that.labelText],
603
+ node[i][that.valueText]
604
+ )
605
+ }
606
+ }
607
+ }
608
+ set(data)
609
+ return arr
610
+ },
611
+ forward(item, levelIndex) {
612
+ this.cur = item
613
+ if (item.isLeaf) {
614
+ if (!this.multiple) {
615
+ this.select(item)
616
+ } else {
617
+ this.check(!item.checked, item)
618
+ }
619
+ } else {
620
+ const path = item.path.split(',')
621
+ this.$set(
622
+ this.levels,
623
+ levelIndex + 1,
624
+ {
625
+ title: item.label,
626
+ data: this.nodes.filter(node => node.level === levelIndex + 1 && node.path.split(',').includes(path[levelIndex])),
627
+ tag: 'level' + (levelIndex + 1)
628
+ }
629
+ )
630
+ if (this.iOptionDisplay === 'popup') {
631
+ this.$refs.popup.forward('level' + (levelIndex + 1))
632
+ } else {
633
+ this.curLevel = 'level' + (levelIndex + 1)
634
+ this.tHeight = ''
635
+ this.getTHeight()
636
+ }
637
+ }
638
+ },
639
+ clear() {
640
+ if (this.iOptionDisplay === 'popup') {
641
+ this.$refs.popup.close()
642
+ } else {
643
+ this.$refs.layer.close()
644
+ }
645
+ this.selected = ''
646
+ },
647
+ focus() {
648
+ this.errorTip = ''
649
+ this.focused = true
650
+ },
651
+ blur() {
652
+ this.focused = false
653
+ if (!this.blurByLayer) {
654
+ this.closeLayer()
655
+ }
656
+ },
657
+ layerMousedown() {
658
+ this.blurByLayer = true
659
+ this.timer = setTimeout(() => {
660
+ this.blurByLayer = false
661
+ clearTimeout(this.timer)
662
+ this.timer = null
663
+ }, 200);
664
+ },
665
+ select(item) {
666
+ this.selected = item
667
+ this.closeLayer()
668
+ },
669
+ toggleLayer() {
670
+ if (this.iOptionDisplay === 'popup') {
671
+ if (this.$refs.popup.visible) {
672
+ this.closeLayer()
673
+ } else {
674
+ this.openLayer()
675
+ }
676
+ } else {
677
+ if (this.$refs.layer.show) {
678
+ this.closeLayer()
679
+ } else {
680
+ this.openLayer()
681
+ }
682
+ }
683
+ },
684
+ closeLayer() {
685
+ if (!this.disabled) {
686
+ if (this.iOptionDisplay === 'popup') {
687
+ this.$refs.popup.close()
688
+ } else {
689
+ this.$refs.layer.close()
690
+ }
691
+ }
692
+ },
693
+ openLayer() {
694
+ if (!this.disabled) {
695
+ if (this.iOptionDisplay === 'popup') {
696
+ this.$refs.popup.open('level0')
697
+ } else {
698
+ this.$refs.layer.toggle('link')
699
+ this.tHeight = ''
700
+ this.getTHeight()
701
+ }
702
+ }
703
+ },
704
+ tabChange() {
705
+ this.$nextTick(function() {
706
+ this.tHeight = ''
707
+ this.getTHeight()
708
+ })
709
+ },
710
+ check(checked, item) {
711
+ if (checked) {
712
+ this.addCheck(item.value)
713
+ } else {
714
+ this.removeCheck(item.value)
715
+ }
716
+ if (this.iOptionDisplay === 'popup') {
717
+ this.setPopupSelected()
718
+ } else {
719
+ this.setSelected()
720
+ }
721
+ },
722
+ addCheck(val) {
723
+
724
+ if (this.valueLevel === 'any') {
725
+ this.getNode(val).checked = true
726
+ } else {
727
+
728
+ // 添加所有路径中含有本元素值的元素
729
+ this.nodes.map(node=>{
730
+ if (node.path.split(',').includes(val)) {
731
+ node.checked = true
732
+ }
733
+ })
734
+
735
+ // 和自己同级的元素如果全部都加上,父元素执行递归执行 addCheck
736
+ let isAddAll = true
737
+ let item = this.getNode(val)
738
+ this.nodes.map(node=>{
739
+ if (node.parent === item.parent && !node.checked) {
740
+ isAddAll = false
741
+ }
742
+ })
743
+ if (isAddAll && item.parent !== '__root__') {
744
+ this.addCheck(item.parent)
745
+ }
746
+ }
747
+ },
748
+ removeCheck(val, notspread) {
749
+
750
+ if (this.valueLevel === 'any') {
751
+ this.getNode(val).checked = false
752
+ } else {
753
+
754
+ // 清空所有路径中含有本元素值的元素
755
+ if (!notspread) {
756
+ this.nodes.map(node=>{
757
+ if (node.path.split(',').includes(val)) {
758
+ node.checked = false
759
+ }
760
+ })
761
+ }
762
+
763
+ // 父元素也勾掉
764
+ let item = this.getNode(val)
765
+ if (item.parent !== '__root__') {
766
+ let parent = this.getNode(item.parent)
767
+ parent.checked = false
768
+ this.removeCheck(parent.value, true)
769
+ }
770
+ }
771
+ },
772
+ setPopupSelected() {
773
+ this.popupSelected = []
774
+ this.nodes.map(node=>{
775
+ if (node.checked && (node.isLeaf || this.valueLevel === 'any')) {
776
+ this.popupSelected.push(node)
777
+ }
778
+ })
779
+ },
780
+ setSelected() {
781
+ if (this.multiple) {
782
+ this.selected = []
783
+ this.nodes.map(node=>{
784
+ if (node.checked && (node.isLeaf || this.valueLevel === 'any')) {
785
+ this.selected.push(node)
786
+ }
787
+ })
788
+ } else {
789
+ this.selected = this.nodes.find(node => node.value === this.iValue)
790
+ }
791
+ },
792
+ getNode(val) {
793
+ return this.nodes.find(node=>node.value === val)
794
+ },
795
+ submit() {
796
+ this.$refs.popup.close();
797
+ this.selected = [...this.popupSelected]
798
+ },
799
+
800
+ // 记录历史值,以便对比或者取值
801
+ compare() {
802
+ this.valueStore.unshift(this.value)
803
+ },
804
+ setDisabled(f) {
805
+ this.disabled = f
806
+ },
807
+ // 撤销
808
+ restore() {
809
+ this.data = this.valueStore[0]
810
+ this.valueStore.splice(0, 1)
811
+ }
812
+ }
813
+ };
814
+ </script>