vxe-pc-ui 3.13.11 → 3.13.13

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 (674) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +134 -134
  3. package/es/icon/style.css +1 -1
  4. package/es/style.css +1 -1
  5. package/es/style.min.css +1 -1
  6. package/es/tag/style.css +1 -3
  7. package/es/tag/style.min.css +1 -1
  8. package/es/ui/index.js +1 -1
  9. package/es/ui/src/log.js +1 -1
  10. package/es/vxe-tag/style.css +1 -3
  11. package/es/vxe-tag/style.min.css +1 -1
  12. package/lib/components.js +2 -1
  13. package/lib/components.min.js +1 -1
  14. package/lib/drawer/index.js +2 -1
  15. package/lib/drawer/index.min.js +1 -1
  16. package/lib/icon/style/style.css +1 -1
  17. package/lib/icon/style/style.min.css +1 -1
  18. package/lib/index.common.js +2 -1
  19. package/lib/index.umd.js +7962 -8834
  20. package/lib/index.umd.min.js +1 -1
  21. package/lib/modal/index.js +2 -1
  22. package/lib/modal/index.min.js +1 -1
  23. package/lib/style.css +1 -1
  24. package/lib/style.min.css +1 -1
  25. package/lib/tag/style/style.css +1 -3
  26. package/lib/tag/style/style.min.css +1 -1
  27. package/lib/ui/index.js +1 -1
  28. package/lib/ui/index.min.js +1 -1
  29. package/lib/ui/src/log.js +1 -1
  30. package/lib/ui/src/log.min.js +1 -1
  31. package/lib/vxe-alert/index.js +2 -1
  32. package/lib/vxe-alert/index.min.js +1 -1
  33. package/lib/vxe-anchor/index.js +2 -1
  34. package/lib/vxe-anchor/index.min.js +1 -1
  35. package/lib/vxe-anchor-link/index.js +2 -1
  36. package/lib/vxe-anchor-link/index.min.js +1 -1
  37. package/lib/vxe-avatar/index.js +2 -1
  38. package/lib/vxe-avatar/index.min.js +1 -1
  39. package/lib/vxe-backtop/index.js +2 -1
  40. package/lib/vxe-backtop/index.min.js +1 -1
  41. package/lib/vxe-badge/index.js +2 -1
  42. package/lib/vxe-badge/index.min.js +1 -1
  43. package/lib/vxe-breadcrumb/index.js +2 -1
  44. package/lib/vxe-breadcrumb/index.min.js +1 -1
  45. package/lib/vxe-breadcrumb-item/index.js +2 -1
  46. package/lib/vxe-breadcrumb-item/index.min.js +1 -1
  47. package/lib/vxe-button/index.js +2 -1
  48. package/lib/vxe-button/index.min.js +1 -1
  49. package/lib/vxe-button-group/index.js +2 -1
  50. package/lib/vxe-button-group/index.min.js +1 -1
  51. package/lib/vxe-calendar/index.js +2 -1
  52. package/lib/vxe-calendar/index.min.js +1 -1
  53. package/lib/vxe-card/index.js +2 -1
  54. package/lib/vxe-card/index.min.js +1 -1
  55. package/lib/vxe-carousel/index.js +2 -1
  56. package/lib/vxe-carousel/index.min.js +1 -1
  57. package/lib/vxe-carousel-item/index.js +2 -1
  58. package/lib/vxe-carousel-item/index.min.js +1 -1
  59. package/lib/vxe-cascader/index.js +2 -1
  60. package/lib/vxe-cascader/index.min.js +1 -1
  61. package/lib/vxe-checkbox/index.js +2 -1
  62. package/lib/vxe-checkbox/index.min.js +1 -1
  63. package/lib/vxe-checkbox-button/index.js +2 -1
  64. package/lib/vxe-checkbox-button/index.min.js +1 -1
  65. package/lib/vxe-checkbox-group/index.js +2 -1
  66. package/lib/vxe-checkbox-group/index.min.js +1 -1
  67. package/lib/vxe-col/index.js +2 -1
  68. package/lib/vxe-col/index.min.js +1 -1
  69. package/lib/vxe-collapse/index.js +2 -1
  70. package/lib/vxe-collapse/index.min.js +1 -1
  71. package/lib/vxe-collapse-pane/index.js +2 -1
  72. package/lib/vxe-collapse-pane/index.min.js +1 -1
  73. package/lib/vxe-color-picker/index.js +2 -1
  74. package/lib/vxe-color-picker/index.min.js +1 -1
  75. package/lib/vxe-context-menu/index.js +2 -1
  76. package/lib/vxe-context-menu/index.min.js +1 -1
  77. package/lib/vxe-countdown/index.js +2 -1
  78. package/lib/vxe-countdown/index.min.js +1 -1
  79. package/lib/vxe-date-panel/index.js +2 -1
  80. package/lib/vxe-date-panel/index.min.js +1 -1
  81. package/lib/vxe-date-picker/index.js +2 -1
  82. package/lib/vxe-date-picker/index.min.js +1 -1
  83. package/lib/vxe-date-range-picker/index.js +2 -1
  84. package/lib/vxe-date-range-picker/index.min.js +1 -1
  85. package/lib/vxe-drawer/index.js +2 -1
  86. package/lib/vxe-drawer/index.min.js +1 -1
  87. package/lib/vxe-empty/index.js +2 -1
  88. package/lib/vxe-empty/index.min.js +1 -1
  89. package/lib/vxe-form/index.js +2 -1
  90. package/lib/vxe-form/index.min.js +1 -1
  91. package/lib/vxe-form-gather/index.js +2 -1
  92. package/lib/vxe-form-gather/index.min.js +1 -1
  93. package/lib/vxe-form-group/index.js +2 -1
  94. package/lib/vxe-form-group/index.min.js +1 -1
  95. package/lib/vxe-form-item/index.js +2 -1
  96. package/lib/vxe-form-item/index.min.js +1 -1
  97. package/lib/vxe-icon/index.js +2 -1
  98. package/lib/vxe-icon/index.min.js +1 -1
  99. package/lib/vxe-icon-picker/index.js +2 -1
  100. package/lib/vxe-icon-picker/index.min.js +1 -1
  101. package/lib/vxe-image/index.js +2 -1
  102. package/lib/vxe-image/index.min.js +1 -1
  103. package/lib/vxe-image-group/index.js +2 -1
  104. package/lib/vxe-image-group/index.min.js +1 -1
  105. package/lib/vxe-image-preview/index.js +2 -1
  106. package/lib/vxe-image-preview/index.min.js +1 -1
  107. package/lib/vxe-input/index.js +2 -1
  108. package/lib/vxe-input/index.min.js +1 -1
  109. package/lib/vxe-layout-aside/index.js +2 -1
  110. package/lib/vxe-layout-aside/index.min.js +1 -1
  111. package/lib/vxe-layout-body/index.js +2 -1
  112. package/lib/vxe-layout-body/index.min.js +1 -1
  113. package/lib/vxe-layout-container/index.js +2 -1
  114. package/lib/vxe-layout-container/index.min.js +1 -1
  115. package/lib/vxe-layout-footer/index.js +2 -1
  116. package/lib/vxe-layout-footer/index.min.js +1 -1
  117. package/lib/vxe-layout-header/index.js +2 -1
  118. package/lib/vxe-layout-header/index.min.js +1 -1
  119. package/lib/vxe-link/index.js +2 -1
  120. package/lib/vxe-link/index.min.js +1 -1
  121. package/lib/vxe-list/index.js +2 -1
  122. package/lib/vxe-list/index.min.js +1 -1
  123. package/lib/vxe-loading/index.js +2 -1
  124. package/lib/vxe-loading/index.min.js +1 -1
  125. package/lib/vxe-mention/index.js +2 -1
  126. package/lib/vxe-mention/index.min.js +1 -1
  127. package/lib/vxe-menu/index.js +2 -1
  128. package/lib/vxe-menu/index.min.js +1 -1
  129. package/lib/vxe-modal/index.js +2 -1
  130. package/lib/vxe-modal/index.min.js +1 -1
  131. package/lib/vxe-notice-bar/index.js +2 -1
  132. package/lib/vxe-notice-bar/index.min.js +1 -1
  133. package/lib/vxe-number-input/index.js +2 -1
  134. package/lib/vxe-number-input/index.min.js +1 -1
  135. package/lib/vxe-optgroup/index.js +2 -1
  136. package/lib/vxe-optgroup/index.min.js +1 -1
  137. package/lib/vxe-option/index.js +2 -1
  138. package/lib/vxe-option/index.min.js +1 -1
  139. package/lib/vxe-pager/index.js +2 -1
  140. package/lib/vxe-pager/index.min.js +1 -1
  141. package/lib/vxe-password-input/index.js +2 -1
  142. package/lib/vxe-password-input/index.min.js +1 -1
  143. package/lib/vxe-print/index.js +2 -1
  144. package/lib/vxe-print/index.min.js +1 -1
  145. package/lib/vxe-print-page-break/index.js +2 -1
  146. package/lib/vxe-print-page-break/index.min.js +1 -1
  147. package/lib/vxe-pulldown/index.js +2 -1
  148. package/lib/vxe-pulldown/index.min.js +1 -1
  149. package/lib/vxe-radio/index.js +2 -1
  150. package/lib/vxe-radio/index.min.js +1 -1
  151. package/lib/vxe-radio-button/index.js +2 -1
  152. package/lib/vxe-radio-button/index.min.js +1 -1
  153. package/lib/vxe-radio-group/index.js +2 -1
  154. package/lib/vxe-radio-group/index.min.js +1 -1
  155. package/lib/vxe-rate/index.js +2 -1
  156. package/lib/vxe-rate/index.min.js +1 -1
  157. package/lib/vxe-result/index.js +2 -1
  158. package/lib/vxe-result/index.min.js +1 -1
  159. package/lib/vxe-row/index.js +2 -1
  160. package/lib/vxe-row/index.min.js +1 -1
  161. package/lib/vxe-segmented/index.js +2 -1
  162. package/lib/vxe-segmented/index.min.js +1 -1
  163. package/lib/vxe-select/index.js +2 -1
  164. package/lib/vxe-select/index.min.js +1 -1
  165. package/lib/vxe-slider/index.js +2 -1
  166. package/lib/vxe-slider/index.min.js +1 -1
  167. package/lib/vxe-split/index.js +2 -1
  168. package/lib/vxe-split/index.min.js +1 -1
  169. package/lib/vxe-split-pane/index.js +2 -1
  170. package/lib/vxe-split-pane/index.min.js +1 -1
  171. package/lib/vxe-splitter/index.js +2 -1
  172. package/lib/vxe-splitter/index.min.js +1 -1
  173. package/lib/vxe-splitter-panel/index.js +2 -1
  174. package/lib/vxe-splitter-panel/index.min.js +1 -1
  175. package/lib/vxe-steps/index.js +2 -1
  176. package/lib/vxe-steps/index.min.js +1 -1
  177. package/lib/vxe-switch/index.js +2 -1
  178. package/lib/vxe-switch/index.min.js +1 -1
  179. package/lib/vxe-tab-pane/index.js +2 -1
  180. package/lib/vxe-tab-pane/index.min.js +1 -1
  181. package/lib/vxe-table-select/index.js +2 -1
  182. package/lib/vxe-table-select/index.min.js +1 -1
  183. package/lib/vxe-tabs/index.js +2 -1
  184. package/lib/vxe-tabs/index.min.js +1 -1
  185. package/lib/vxe-tag/index.js +2 -1
  186. package/lib/vxe-tag/index.min.js +1 -1
  187. package/lib/vxe-tag/style/style.css +1 -3
  188. package/lib/vxe-tag/style/style.min.css +1 -1
  189. package/lib/vxe-text/index.js +2 -1
  190. package/lib/vxe-text/index.min.js +1 -1
  191. package/lib/vxe-text-ellipsis/index.js +2 -1
  192. package/lib/vxe-text-ellipsis/index.min.js +1 -1
  193. package/lib/vxe-textarea/index.js +2 -1
  194. package/lib/vxe-textarea/index.min.js +1 -1
  195. package/lib/vxe-timeline/index.js +2 -1
  196. package/lib/vxe-timeline/index.min.js +1 -1
  197. package/lib/vxe-timeline-item/index.js +2 -1
  198. package/lib/vxe-timeline-item/index.min.js +1 -1
  199. package/lib/vxe-tip/index.js +2 -1
  200. package/lib/vxe-tip/index.min.js +1 -1
  201. package/lib/vxe-tooltip/index.js +2 -1
  202. package/lib/vxe-tooltip/index.min.js +1 -1
  203. package/lib/vxe-tour/index.js +2 -1
  204. package/lib/vxe-tour/index.min.js +1 -1
  205. package/lib/vxe-tree/index.js +2 -1
  206. package/lib/vxe-tree/index.min.js +1 -1
  207. package/lib/vxe-tree-select/index.js +2 -1
  208. package/lib/vxe-tree-select/index.min.js +1 -1
  209. package/lib/vxe-u-i/index.js +2 -1
  210. package/lib/vxe-u-i/index.min.js +1 -1
  211. package/lib/vxe-ui/index.js +2 -1
  212. package/lib/vxe-ui/index.min.js +1 -1
  213. package/lib/vxe-upload/index.js +2 -1
  214. package/lib/vxe-upload/index.min.js +1 -1
  215. package/lib/vxe-watermark/index.js +2 -1
  216. package/lib/vxe-watermark/index.min.js +1 -1
  217. package/package.json +89 -89
  218. package/packages/alert/index.ts +16 -16
  219. package/packages/alert/src/alert.ts +106 -106
  220. package/packages/anchor/index.ts +16 -16
  221. package/packages/anchor/src/anchor-link.ts +158 -158
  222. package/packages/anchor/src/anchor.ts +267 -267
  223. package/packages/anchor/src/util.ts +23 -23
  224. package/packages/anchor-link/index.ts +16 -16
  225. package/packages/avatar/index.ts +16 -16
  226. package/packages/avatar/src/avatar.ts +141 -141
  227. package/packages/backtop/index.ts +16 -16
  228. package/packages/backtop/src/backtop.ts +330 -330
  229. package/packages/badge/index.ts +16 -16
  230. package/packages/badge/src/badge.ts +87 -87
  231. package/packages/breadcrumb/index.ts +16 -16
  232. package/packages/breadcrumb/src/breadcrumb-item.ts +118 -118
  233. package/packages/breadcrumb/src/breadcrumb.ts +89 -89
  234. package/packages/breadcrumb-item/index.ts +16 -16
  235. package/packages/button/index.ts +16 -16
  236. package/packages/button/src/button-group.ts +113 -113
  237. package/packages/button/src/button.ts +955 -955
  238. package/packages/button-group/index.ts +16 -16
  239. package/packages/calendar/index.ts +16 -16
  240. package/packages/calendar/src/calendar.ts +1527 -1527
  241. package/packages/card/index.ts +16 -16
  242. package/packages/card/src/card.ts +162 -162
  243. package/packages/carousel/index.ts +16 -16
  244. package/packages/carousel/src/carousel-item.ts +117 -117
  245. package/packages/carousel/src/carousel.ts +460 -460
  246. package/packages/carousel/src/util.ts +21 -21
  247. package/packages/carousel-item/index.ts +16 -16
  248. package/packages/cascader/index.ts +16 -16
  249. package/packages/cascader/src/cascader.ts +941 -941
  250. package/packages/checkbox/index.ts +16 -16
  251. package/packages/checkbox/src/button.ts +185 -185
  252. package/packages/checkbox/src/checkbox.ts +189 -189
  253. package/packages/checkbox/src/group.ts +259 -259
  254. package/packages/checkbox-button/index.ts +16 -16
  255. package/packages/checkbox-group/index.ts +16 -16
  256. package/packages/col/index.ts +16 -16
  257. package/packages/collapse/index.ts +16 -16
  258. package/packages/collapse/src/collapse-pane.ts +136 -136
  259. package/packages/collapse/src/collapse.ts +259 -259
  260. package/packages/collapse/src/util.ts +21 -21
  261. package/packages/collapse-pane/index.ts +16 -16
  262. package/packages/color-picker/index.ts +16 -16
  263. package/packages/color-picker/src/color-picker.ts +1277 -1277
  264. package/packages/color-picker/src/util.ts +198 -198
  265. package/packages/components.ts +307 -307
  266. package/packages/context-menu/index.ts +54 -54
  267. package/packages/context-menu/src/context-menu.ts +709 -709
  268. package/packages/countdown/index.ts +16 -16
  269. package/packages/countdown/src/countdown.ts +276 -276
  270. package/packages/date-panel/index.ts +16 -16
  271. package/packages/date-panel/src/date-panel.ts +2024 -2024
  272. package/packages/date-panel/src/util.ts +244 -244
  273. package/packages/date-picker/index.ts +17 -17
  274. package/packages/date-picker/src/date-picker.ts +1238 -1238
  275. package/packages/date-range-picker/index.ts +16 -16
  276. package/packages/date-range-picker/src/date-range-picker.ts +1466 -1466
  277. package/packages/drawer/index.ts +87 -87
  278. package/packages/drawer/src/drawer.ts +767 -767
  279. package/packages/dynamics/index.ts +125 -125
  280. package/packages/empty/index.ts +16 -16
  281. package/packages/empty/src/empty.ts +80 -80
  282. package/packages/form/index.ts +16 -16
  283. package/packages/form/render/index.ts +617 -617
  284. package/packages/form/src/form-config-item.ts +86 -86
  285. package/packages/form/src/form-group.ts +125 -125
  286. package/packages/form/src/form-item.ts +217 -217
  287. package/packages/form/src/form.ts +1032 -1032
  288. package/packages/form/src/itemInfo.ts +80 -80
  289. package/packages/form/src/render.ts +398 -398
  290. package/packages/form/src/util.ts +92 -92
  291. package/packages/form-gather/index.ts +18 -18
  292. package/packages/form-group/index.ts +16 -16
  293. package/packages/form-item/index.ts +16 -16
  294. package/packages/icon/index.ts +16 -16
  295. package/packages/icon/src/icon.ts +75 -75
  296. package/packages/icon-picker/index.ts +16 -16
  297. package/packages/icon-picker/src/icon-picker.ts +752 -752
  298. package/packages/image/index.ts +16 -16
  299. package/packages/image/src/group.ts +162 -162
  300. package/packages/image/src/image.ts +286 -286
  301. package/packages/image/src/preview.ts +737 -737
  302. package/packages/image/src/util.ts +62 -62
  303. package/packages/image-group/index.ts +16 -16
  304. package/packages/image-preview/index.ts +19 -19
  305. package/packages/index.ts +8 -8
  306. package/packages/input/index.ts +16 -16
  307. package/packages/input/src/input.ts +3187 -3187
  308. package/packages/language/ar-EG.ts +832 -832
  309. package/packages/language/de-DE.ts +832 -832
  310. package/packages/language/en-US.ts +832 -832
  311. package/packages/language/es-ES.ts +832 -832
  312. package/packages/language/fr-FR.ts +832 -832
  313. package/packages/language/hu-HU.ts +832 -832
  314. package/packages/language/hy-AM.ts +832 -832
  315. package/packages/language/id-ID.ts +832 -832
  316. package/packages/language/it-IT.ts +832 -832
  317. package/packages/language/ja-JP.ts +832 -832
  318. package/packages/language/ko-KR.ts +832 -832
  319. package/packages/language/ms-MY.ts +832 -832
  320. package/packages/language/nb-NO.ts +832 -832
  321. package/packages/language/pt-BR.ts +832 -832
  322. package/packages/language/ru-RU.ts +832 -832
  323. package/packages/language/th-TH.ts +832 -832
  324. package/packages/language/ug-CN.ts +832 -832
  325. package/packages/language/uk-UA.ts +832 -832
  326. package/packages/language/uz-UZ.ts +832 -832
  327. package/packages/language/vi-VN.ts +832 -832
  328. package/packages/language/zh-CHT.ts +832 -832
  329. package/packages/language/zh-CN.ts +832 -832
  330. package/packages/language/zh-HK.ts +3 -3
  331. package/packages/language/zh-MO.ts +3 -3
  332. package/packages/language/zh-TC.ts +3 -3
  333. package/packages/language/zh-TW.ts +3 -3
  334. package/packages/layout-aside/index.ts +16 -16
  335. package/packages/layout-aside/src/layout-aside.ts +115 -115
  336. package/packages/layout-body/index.ts +16 -16
  337. package/packages/layout-body/src/layout-body.ts +137 -137
  338. package/packages/layout-container/index.ts +16 -16
  339. package/packages/layout-container/src/layout-container.ts +65 -65
  340. package/packages/layout-footer/index.ts +16 -16
  341. package/packages/layout-footer/src/layout-footer.ts +53 -53
  342. package/packages/layout-header/index.ts +16 -16
  343. package/packages/layout-header/src/layout-header.ts +49 -49
  344. package/packages/link/index.ts +16 -16
  345. package/packages/link/src/link.ts +153 -153
  346. package/packages/list/index.ts +16 -16
  347. package/packages/list/src/list.ts +492 -492
  348. package/packages/loading/index.ts +34 -34
  349. package/packages/loading/src/loading.ts +162 -162
  350. package/packages/mention/index.ts +16 -16
  351. package/packages/mention/src/mention.ts +54 -54
  352. package/packages/menu/index.ts +16 -16
  353. package/packages/menu/src/menu.ts +632 -632
  354. package/packages/modal/index.ts +150 -150
  355. package/packages/modal/src/modal.ts +1657 -1657
  356. package/packages/notice-bar/index.ts +16 -16
  357. package/packages/notice-bar/src/notice-bar.ts +182 -182
  358. package/packages/number-input/index.ts +16 -16
  359. package/packages/number-input/src/number-input.ts +1255 -1255
  360. package/packages/number-input/src/util.ts +12 -12
  361. package/packages/optgroup/index.ts +16 -16
  362. package/packages/option/index.ts +16 -16
  363. package/packages/pager/index.ts +16 -16
  364. package/packages/pager/src/pager.ts +913 -913
  365. package/packages/password-input/index.ts +16 -16
  366. package/packages/password-input/src/password-input.ts +466 -466
  367. package/packages/print/index.ts +18 -18
  368. package/packages/print/src/page-break.ts +78 -78
  369. package/packages/print/src/print.ts +266 -266
  370. package/packages/print/src/util.ts +284 -284
  371. package/packages/print-page-break/index.ts +14 -14
  372. package/packages/pulldown/index.ts +16 -16
  373. package/packages/pulldown/src/pulldown.ts +532 -532
  374. package/packages/radio/index.ts +16 -16
  375. package/packages/radio/src/button.ts +221 -221
  376. package/packages/radio/src/group.ts +252 -252
  377. package/packages/radio/src/radio.ts +228 -228
  378. package/packages/radio-button/index.ts +16 -16
  379. package/packages/radio-group/index.ts +16 -16
  380. package/packages/rate/index.ts +16 -16
  381. package/packages/rate/src/rate.ts +199 -199
  382. package/packages/result/index.ts +16 -16
  383. package/packages/result/src/result.ts +93 -93
  384. package/packages/row/index.ts +16 -16
  385. package/packages/row/src/col.ts +130 -130
  386. package/packages/row/src/row.ts +106 -106
  387. package/packages/segmented/index.ts +16 -16
  388. package/packages/segmented/src/segmented.ts +281 -281
  389. package/packages/select/index.ts +16 -16
  390. package/packages/select/src/optgroup.ts +107 -107
  391. package/packages/select/src/option-info.ts +20 -20
  392. package/packages/select/src/option.ts +103 -103
  393. package/packages/select/src/select.ts +2000 -2000
  394. package/packages/select/src/util.ts +47 -47
  395. package/packages/slider/index.ts +16 -16
  396. package/packages/slider/src/slider.ts +332 -332
  397. package/packages/split/index.ts +16 -16
  398. package/packages/split-pane/index.ts +17 -17
  399. package/packages/splitter/index.ts +16 -16
  400. package/packages/splitter/src/splitter-panel.ts +171 -171
  401. package/packages/splitter/src/splitter.ts +1032 -1032
  402. package/packages/splitter/src/util.ts +21 -21
  403. package/packages/splitter-panel/index.ts +16 -16
  404. package/packages/steps/index.ts +16 -16
  405. package/packages/steps/src/steps.ts +57 -57
  406. package/packages/switch/index.ts +16 -16
  407. package/packages/switch/src/switch.ts +279 -279
  408. package/packages/tab-pane/index.ts +16 -16
  409. package/packages/table-select/index.ts +16 -16
  410. package/packages/table-select/src/table-select.ts +903 -903
  411. package/packages/tabs/index.ts +16 -16
  412. package/packages/tabs/src/tab-pane.ts +137 -137
  413. package/packages/tabs/src/tabs.ts +1014 -1014
  414. package/packages/tabs/src/util.ts +21 -21
  415. package/packages/tag/index.ts +16 -16
  416. package/packages/tag/src/tag.ts +195 -195
  417. package/packages/text/index.ts +16 -16
  418. package/packages/text/src/text.ts +267 -267
  419. package/packages/text-ellipsis/index.ts +16 -16
  420. package/packages/text-ellipsis/src/text-ellipsis.ts +291 -291
  421. package/packages/textarea/index.ts +16 -16
  422. package/packages/textarea/src/textarea.ts +436 -436
  423. package/packages/timeline/index.ts +16 -16
  424. package/packages/timeline/src/timeline-item.ts +41 -41
  425. package/packages/timeline/src/timeline.ts +54 -54
  426. package/packages/timeline-item/index.ts +16 -16
  427. package/packages/tip/index.ts +19 -19
  428. package/packages/tip/src/tip.ts +112 -112
  429. package/packages/tooltip/index.ts +16 -16
  430. package/packages/tooltip/src/tooltip.ts +641 -641
  431. package/packages/tour/index.ts +16 -16
  432. package/packages/tour/src/tour.ts +54 -54
  433. package/packages/tree/index.ts +16 -16
  434. package/packages/tree/src/store.ts +15 -15
  435. package/packages/tree/src/tree.ts +3080 -3080
  436. package/packages/tree/src/util.ts +44 -44
  437. package/packages/tree-select/index.ts +16 -16
  438. package/packages/tree-select/src/tree-select.ts +1115 -1115
  439. package/packages/ui/index.ts +695 -695
  440. package/packages/ui/src/anime.ts +52 -52
  441. package/packages/ui/src/comp.ts +3 -3
  442. package/packages/ui/src/dom.ts +263 -263
  443. package/packages/ui/src/log.ts +6 -6
  444. package/packages/ui/src/utils.ts +49 -49
  445. package/packages/ui/src/vn.ts +60 -60
  446. package/packages/upload/index.ts +20 -20
  447. package/packages/upload/src/upload.ts +2127 -2127
  448. package/packages/upload/src/util.ts +109 -109
  449. package/packages/vxe-u-i/index.ts +4 -4
  450. package/packages/watermark/index.ts +31 -31
  451. package/packages/watermark/src/util.ts +176 -176
  452. package/packages/watermark/src/watermark.ts +166 -166
  453. package/styles/all.scss +90 -90
  454. package/styles/base.scss +16 -16
  455. package/styles/components/alert.scss +101 -101
  456. package/styles/components/anchor.scss +44 -44
  457. package/styles/components/avatar.scss +115 -115
  458. package/styles/components/backtop.scss +82 -82
  459. package/styles/components/badge.scss +45 -45
  460. package/styles/components/breadcrumb.scss +29 -29
  461. package/styles/components/button-group.scss +30 -30
  462. package/styles/components/button.scss +415 -415
  463. package/styles/components/calendar.scss +471 -471
  464. package/styles/components/card.scss +121 -121
  465. package/styles/components/carousel.scss +184 -184
  466. package/styles/components/cascader.scss +140 -140
  467. package/styles/components/checkbox-button.scss +57 -57
  468. package/styles/components/checkbox.scss +81 -81
  469. package/styles/components/collapse.scss +56 -56
  470. package/styles/components/color-picker.scss +409 -409
  471. package/styles/components/context-menu.scss +102 -102
  472. package/styles/components/countdown.scss +35 -35
  473. package/styles/components/date-panel.scss +505 -505
  474. package/styles/components/date-picker.scss +247 -247
  475. package/styles/components/date-range-picker.scss +252 -252
  476. package/styles/components/drawer.scss +298 -298
  477. package/styles/components/empty.scss +79 -79
  478. package/styles/components/form.scss +668 -668
  479. package/styles/components/icon-picker.scss +211 -211
  480. package/styles/components/icon.scss +1044 -1044
  481. package/styles/components/image-group.scss +2 -2
  482. package/styles/components/image-preview.scss +215 -215
  483. package/styles/components/image.scss +16 -16
  484. package/styles/components/input.scss +846 -846
  485. package/styles/components/layout-aside.scss +22 -22
  486. package/styles/components/layout-body.scss +14 -14
  487. package/styles/components/layout-container.scss +13 -13
  488. package/styles/components/layout-footer.scss +14 -14
  489. package/styles/components/layout-header.scss +11 -11
  490. package/styles/components/link.scss +115 -115
  491. package/styles/components/list.scss +40 -40
  492. package/styles/components/loading.scss +137 -137
  493. package/styles/components/menu.scss +150 -150
  494. package/styles/components/modal.scss +480 -480
  495. package/styles/components/notice-bar.scss +91 -91
  496. package/styles/components/number-input.scss +283 -283
  497. package/styles/components/old-icon.scss +4 -4
  498. package/styles/components/pager.scss +282 -282
  499. package/styles/components/password-input.scss +374 -374
  500. package/styles/components/print.scss +3 -3
  501. package/styles/components/pulldown.scss +75 -75
  502. package/styles/components/radio-button.scss +57 -57
  503. package/styles/components/radio.scss +79 -79
  504. package/styles/components/rate.scss +76 -76
  505. package/styles/components/result.scss +91 -91
  506. package/styles/components/row.scss +69 -69
  507. package/styles/components/segmented.scss +215 -215
  508. package/styles/components/select.scss +244 -244
  509. package/styles/components/slider.scss +139 -139
  510. package/styles/components/split.scss +1 -1
  511. package/styles/components/splitter.scss +318 -318
  512. package/styles/components/switch.scss +128 -128
  513. package/styles/components/table-select.scss +105 -105
  514. package/styles/components/tabs.scss +745 -745
  515. package/styles/components/tag.scss +184 -184
  516. package/styles/components/text-ellipsis.scss +130 -130
  517. package/styles/components/text.scss +123 -123
  518. package/styles/components/textarea.scss +106 -106
  519. package/styles/components/tip.scss +97 -97
  520. package/styles/components/tooltip.scss +140 -140
  521. package/styles/components/tree-select.scss +166 -166
  522. package/styles/components/tree.scss +294 -294
  523. package/styles/components/upload.scss +497 -497
  524. package/styles/components/watermark.scss +26 -26
  525. package/styles/helpers/baseMixin.scss +95 -95
  526. package/styles/helpers/baseVar.scss +3 -3
  527. package/styles/helpers/placement.scss +38 -38
  528. package/styles/theme/base.scss +214 -214
  529. package/styles/theme/dark.scss +119 -119
  530. package/styles/theme/light.scss +118 -118
  531. package/styles/variable.scss +111 -111
  532. package/types/all.d.ts +328 -328
  533. package/types/components/alert.d.ts +80 -80
  534. package/types/components/anchor-link.d.ts +84 -84
  535. package/types/components/anchor.d.ts +84 -84
  536. package/types/components/avatar.d.ts +81 -81
  537. package/types/components/backtop.d.ts +115 -115
  538. package/types/components/badge.d.ts +69 -69
  539. package/types/components/breadcrumb-item.d.ts +73 -73
  540. package/types/components/breadcrumb.d.ts +80 -80
  541. package/types/components/button-group.d.ts +113 -113
  542. package/types/components/button.d.ts +314 -314
  543. package/types/components/calendar.d.ts +254 -254
  544. package/types/components/card.d.ts +86 -86
  545. package/types/components/carousel-item.d.ts +68 -68
  546. package/types/components/carousel.d.ts +126 -126
  547. package/types/components/cascader.d.ts +242 -242
  548. package/types/components/checkbox-button.d.ts +93 -93
  549. package/types/components/checkbox-group.d.ts +135 -135
  550. package/types/components/checkbox.d.ts +115 -115
  551. package/types/components/col.d.ts +73 -73
  552. package/types/components/colgroup.d.ts +131 -131
  553. package/types/components/collapse-pane.d.ts +82 -82
  554. package/types/components/collapse.d.ts +115 -115
  555. package/types/components/color-picker.d.ts +127 -127
  556. package/types/components/column.d.ts +852 -852
  557. package/types/components/context-menu.d.ts +300 -300
  558. package/types/components/countdown.d.ts +99 -99
  559. package/types/components/date-panel.d.ts +269 -269
  560. package/types/components/date-picker.d.ts +302 -302
  561. package/types/components/date-range-picker.d.ts +316 -316
  562. package/types/components/drawer.d.ts +295 -295
  563. package/types/components/empty.d.ts +71 -71
  564. package/types/components/flow-design.d.ts +78 -78
  565. package/types/components/flow-view.d.ts +78 -78
  566. package/types/components/form-design.d.ts +364 -364
  567. package/types/components/form-gather.d.ts +72 -72
  568. package/types/components/form-group.d.ts +63 -63
  569. package/types/components/form-item.d.ts +405 -405
  570. package/types/components/form-view.d.ts +175 -175
  571. package/types/components/form.d.ts +463 -463
  572. package/types/components/gantt-module/gantt-view.d.ts +170 -170
  573. package/types/components/gantt-module/index.d.ts +1 -1
  574. package/types/components/gantt-plugins/extend-gantt-chart.d.ts +114 -114
  575. package/types/components/gantt-plugins/index.d.ts +1 -1
  576. package/types/components/gantt.d.ts +1129 -1129
  577. package/types/components/grid.d.ts +1030 -1030
  578. package/types/components/icon-picker.d.ts +181 -181
  579. package/types/components/icon.d.ts +80 -80
  580. package/types/components/image-group.d.ts +120 -120
  581. package/types/components/image-preview.d.ts +159 -159
  582. package/types/components/image.d.ts +158 -158
  583. package/types/components/input.d.ts +425 -425
  584. package/types/components/layout-aside.d.ts +73 -73
  585. package/types/components/layout-body.d.ts +84 -84
  586. package/types/components/layout-container.d.ts +66 -66
  587. package/types/components/layout-footer.d.ts +66 -66
  588. package/types/components/layout-header.d.ts +64 -64
  589. package/types/components/link.d.ts +104 -104
  590. package/types/components/list-design.d.ts +177 -177
  591. package/types/components/list-view.d.ts +190 -190
  592. package/types/components/list.d.ts +196 -196
  593. package/types/components/loading.d.ts +96 -96
  594. package/types/components/mention.d.ts +70 -70
  595. package/types/components/menu.d.ts +203 -203
  596. package/types/components/modal.d.ts +540 -540
  597. package/types/components/notice-bar.d.ts +95 -95
  598. package/types/components/number-input.d.ts +300 -300
  599. package/types/components/optgroup.d.ts +81 -81
  600. package/types/components/option.d.ts +95 -95
  601. package/types/components/pager.d.ts +322 -322
  602. package/types/components/password-input.d.ts +129 -129
  603. package/types/components/print-page-break.d.ts +62 -62
  604. package/types/components/print.d.ts +199 -199
  605. package/types/components/pulldown.d.ts +222 -222
  606. package/types/components/radio-button.d.ts +104 -104
  607. package/types/components/radio-group.d.ts +136 -136
  608. package/types/components/radio.d.ts +121 -121
  609. package/types/components/rate.d.ts +75 -75
  610. package/types/components/result.d.ts +77 -77
  611. package/types/components/row.d.ts +72 -72
  612. package/types/components/segmented.d.ts +117 -117
  613. package/types/components/select.d.ts +515 -515
  614. package/types/components/slider.d.ts +117 -117
  615. package/types/components/split-pane.d.ts +135 -135
  616. package/types/components/split.d.ts +318 -318
  617. package/types/components/splitter-panel.d.ts +98 -98
  618. package/types/components/splitter.d.ts +283 -283
  619. package/types/components/steps.d.ts +61 -61
  620. package/types/components/switch.d.ts +124 -124
  621. package/types/components/tab-pane.d.ts +107 -107
  622. package/types/components/table-module/custom.d.ts +111 -111
  623. package/types/components/table-module/edit.d.ts +244 -244
  624. package/types/components/table-module/export.d.ts +96 -96
  625. package/types/components/table-module/filter.d.ts +140 -140
  626. package/types/components/table-module/index.d.ts +7 -7
  627. package/types/components/table-module/keyboard.d.ts +26 -26
  628. package/types/components/table-module/menu.d.ts +26 -26
  629. package/types/components/table-module/validator.d.ts +53 -53
  630. package/types/components/table-plugins/extend-cell-area.d.ts +734 -734
  631. package/types/components/table-plugins/extend-pivot-table.d.ts +62 -62
  632. package/types/components/table-plugins/filters-combination.d.ts +15 -15
  633. package/types/components/table-plugins/filters-complex-input.d.ts +9 -9
  634. package/types/components/table-plugins/index.d.ts +4 -4
  635. package/types/components/table-select.d.ts +212 -212
  636. package/types/components/table.d.ts +7222 -7206
  637. package/types/components/tabs.d.ts +324 -324
  638. package/types/components/tag.d.ts +107 -107
  639. package/types/components/text-ellipsis.d.ts +105 -105
  640. package/types/components/text.d.ts +115 -115
  641. package/types/components/textarea.d.ts +237 -237
  642. package/types/components/timeline-item.d.ts +68 -68
  643. package/types/components/timeline.d.ts +70 -70
  644. package/types/components/tip.d.ts +76 -76
  645. package/types/components/toolbar.d.ts +329 -329
  646. package/types/components/tooltip.d.ts +165 -165
  647. package/types/components/tour.d.ts +70 -70
  648. package/types/components/tree-select.d.ts +295 -295
  649. package/types/components/tree.d.ts +826 -826
  650. package/types/components/upload.d.ts +432 -432
  651. package/types/components/watermark.d.ts +113 -113
  652. package/types/index.d.ts +4 -4
  653. package/types/ui/commands.d.ts +57 -57
  654. package/types/ui/formats.d.ts +62 -62
  655. package/types/ui/global-config.d.ts +254 -254
  656. package/types/ui/global-icon.d.ts +292 -292
  657. package/types/ui/hooks.d.ts +11 -11
  658. package/types/ui/index.d.ts +95 -95
  659. package/types/ui/interceptor.d.ts +54 -54
  660. package/types/ui/menus.d.ts +77 -77
  661. package/types/ui/renderer.d.ts +1042 -1042
  662. package/types/ui/validators.d.ts +38 -38
  663. /package/es/icon/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  664. /package/es/icon/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  665. /package/es/icon/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  666. /package/es/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  667. /package/es/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  668. /package/es/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  669. /package/lib/icon/style/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  670. /package/lib/icon/style/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  671. /package/lib/icon/style/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  672. /package/lib/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  673. /package/lib/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  674. /package/lib/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
@@ -1,1014 +1,1014 @@
1
- import { PropType, CreateElement, VNode } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import XEUtils from 'xe-utils'
4
- import { createEvent, getConfig, getIcon, globalEvents, globalMixins, permission, renderEmptyElement } from '../../ui'
5
- import { getSlotVNs } from '../../ui/src/vn'
6
- import { toCssUnit, addClass, removeClass } from '../../ui/src/dom'
7
- import { isEnableConf } from '../../ui/src/utils'
8
- import { warnLog, errLog } from '../../ui/src/log'
9
- import VxeLoadingComponent from '../../loading/src/loading'
10
-
11
- import type { VxeTabsPropTypes, VxeTabPaneProps, VxeTabsEmits, TabsInternalData, TabsReactData, VxeComponentSizeType, VxeTabsConstructor, VxeTabsPrivateMethods, VxeTabPaneDefines, ValueOf, VxeComponentStyleType } from '../../../types'
12
-
13
- const scrollbarOffsetSize = 20
14
-
15
- export default /* define-vxe-component start */ defineVxeComponent({
16
- name: 'VxeTabs',
17
- mixins: [
18
- globalMixins.sizeMixin
19
- ],
20
- props: {
21
- value: [String, Number, Boolean] as PropType<VxeTabsPropTypes.ModelValue>,
22
- options: Array as PropType<VxeTabsPropTypes.Options>,
23
- width: [String, Number] as PropType<VxeTabsPropTypes.Width>,
24
- height: [String, Number] as PropType<VxeTabsPropTypes.Height>,
25
- destroyOnClose: {
26
- type: Boolean as PropType<VxeTabsPropTypes.DestroyOnClose>,
27
- default: () => getConfig().tabs.destroyOnClose
28
- },
29
- titleWidth: [String, Number] as PropType<VxeTabsPropTypes.TitleWidth>,
30
- titleAlign: [String, Number] as PropType<VxeTabsPropTypes.TitleAlign>,
31
- type: {
32
- type: String as PropType<VxeTabsPropTypes.Type>,
33
- default: () => getConfig().tabs.type
34
- },
35
- position: {
36
- type: String as PropType<VxeTabsPropTypes.Position>,
37
- default: () => getConfig().tabs.position
38
- },
39
- showClose: Boolean as PropType<VxeTabsPropTypes.ShowClose>,
40
- showBody: {
41
- type: Boolean as PropType<VxeTabsPropTypes.ShowBody>,
42
- default: true
43
- },
44
- padding: {
45
- type: Boolean as PropType<VxeTabsPropTypes.Padding>,
46
- default: () => getConfig().tabs.padding
47
- },
48
- trigger: String as PropType<VxeTabsPropTypes.Trigger>,
49
- beforeChangeMethod: Function as PropType<VxeTabsPropTypes.BeforeChangeMethod>,
50
- closeConfig: Object as PropType<VxeTabsPropTypes.CloseConfig>,
51
- refreshConfig: Object as PropType<VxeTabsPropTypes.RefreshConfig>,
52
- size: {
53
- type: String as PropType<VxeTabsPropTypes.Size>,
54
- default: () => getConfig().tabs.size || getConfig().size
55
- },
56
- // 已废弃
57
- beforeCloseMethod: Function as PropType<VxeTabsPropTypes.BeforeCloseMethod>
58
- },
59
- inject: {
60
- $xeParentTabs: {
61
- from: '$xeTabs',
62
- default: null
63
- }
64
- },
65
- provide () {
66
- const $xeTabs = this
67
- return {
68
- $xeTabs
69
- }
70
- },
71
- data () {
72
- const xID = XEUtils.uniqueId()
73
- const reactData: TabsReactData = {
74
- staticTabs: [],
75
- activeName: null,
76
- initNames: [],
77
- lintLeft: 0,
78
- lintTop: 0,
79
- lintWidth: 0,
80
- lintHeight: 0,
81
- scrollbarWidth: 0,
82
- scrollbarHeight: 0,
83
- isTabOver: false,
84
- resizeFlag: 1,
85
- cacheTabMaps: {}
86
- }
87
- const internalData: TabsInternalData = {
88
- slTimeout: undefined
89
- }
90
- return {
91
- xID,
92
- reactData,
93
- internalData
94
- }
95
- },
96
- computed: {
97
- ...({} as {
98
- computeSize(): VxeComponentSizeType
99
- $xeParentTabs():(VxeTabsConstructor & VxeTabsPrivateMethods) | null
100
- }),
101
- computeParentTabsResizeFlag () {
102
- const $xeTabs = this
103
- const $xeParentTabs = $xeTabs.$xeParentTabs
104
-
105
- return $xeParentTabs ? $xeParentTabs.reactData.resizeFlag : null
106
- },
107
- computeTabType () {
108
- const $xeTabs = this
109
- const props = $xeTabs
110
-
111
- const { type } = props
112
- return type || 'default'
113
- },
114
- computeTabPosition () {
115
- const $xeTabs = this
116
- const props = $xeTabs
117
-
118
- const { position } = props
119
- return position || 'top'
120
- },
121
- computeLrPosition () {
122
- const $xeTabs = this
123
-
124
- const tabPosition = $xeTabs.computeTabPosition
125
- return tabPosition === 'left' || tabPosition === 'right'
126
- },
127
- computeLineStyle (this: any) {
128
- const $xeTabs = this
129
- const reactData = $xeTabs.reactData
130
-
131
- const { lintLeft, lintTop, lintWidth, lintHeight } = reactData
132
- const lrPosition = $xeTabs.computeLrPosition
133
- return lrPosition
134
- ? {
135
- top: `${lintTop}px`,
136
- height: `${lintHeight}px`
137
- }
138
- : {
139
- left: `${lintLeft}px`,
140
- width: `${lintWidth}px`
141
- }
142
- },
143
- computeWrapperStyle () {
144
- const $xeTabs = this
145
- const props = $xeTabs
146
-
147
- const { width, height } = props
148
- const stys: VxeComponentStyleType = {}
149
- if (width) {
150
- stys.width = toCssUnit(width)
151
- }
152
- if (height) {
153
- stys.height = toCssUnit(height)
154
- }
155
- return stys
156
- },
157
- computeCloseOpts () {
158
- const $xeTabs = this
159
- const props = $xeTabs
160
-
161
- return Object.assign({}, getConfig().tabs.closeConfig, props.closeConfig)
162
- },
163
- computeRefreshOpts () {
164
- const $xeTabs = this
165
- const props = $xeTabs
166
-
167
- return Object.assign({}, getConfig().tabs.refreshConfig, props.refreshConfig)
168
- },
169
- computeTabOptions (this: any) {
170
- const $xeTabs = this
171
- const props = $xeTabs
172
-
173
- const options = props.options as VxeTabsPropTypes.Options
174
- return (options || []).filter((item) => $xeTabs.handleFilterTab(item))
175
- },
176
- computeTabStaticOptions (this: any) {
177
- const $xeTabs = this
178
- const reactData = $xeTabs.reactData
179
-
180
- const staticTabs = reactData.staticTabs as VxeTabPaneDefines.TabConfig[]
181
- return staticTabs.filter((item) => $xeTabs.handleFilterTab(item))
182
- }
183
- },
184
- methods: {
185
- //
186
- // Method
187
- //
188
- dispatchEvent (type: ValueOf<VxeTabsEmits>, params: Record<string, any>, evnt: Event | null) {
189
- const $xeTabs = this
190
- $xeTabs.$emit(type, createEvent(evnt, { $tabs: $xeTabs }, params))
191
- },
192
- emitModel (value: any) {
193
- const $xeTabs = this
194
-
195
- const { _events } = $xeTabs as any
196
- $xeTabs.$emit('input', value)
197
- if (_events && _events.modelValue) {
198
- $xeTabs.$emit('modelValue', value)
199
- } else {
200
- $xeTabs.$emit('model-value', value)
201
- }
202
- },
203
- prev () {
204
- const $xeTabs = this
205
-
206
- return $xeTabs.handlePrevNext(false)
207
- },
208
- next () {
209
- const $xeTabs = this
210
-
211
- return $xeTabs.handlePrevNext(true)
212
- },
213
- prevTab () {
214
- const $xeTabs = this
215
-
216
- warnLog('vxe.error.delFunc', ['[tabs] prevTab', 'prev'])
217
- return $xeTabs.prev()
218
- },
219
- nextTab () {
220
- const $xeTabs = this
221
-
222
- warnLog('vxe.error.delFunc', ['[tabs] nextTab', 'next'])
223
- return $xeTabs.next()
224
- },
225
- handleFilterTab (item: VxeTabPaneProps | VxeTabPaneDefines.TabConfig) {
226
- const { permissionCode } = item
227
- if (permissionCode) {
228
- if (!permission.checkVisible(permissionCode)) {
229
- return false
230
- }
231
- }
232
- return true
233
- },
234
- callSlot (slotFunc: any, params: any, h: CreateElement) {
235
- const $xeTabs = this
236
- const slots = $xeTabs.$scopedSlots
237
-
238
- if (slotFunc) {
239
- if (XEUtils.isString(slotFunc)) {
240
- slotFunc = slots[slotFunc] || null
241
- }
242
- if (XEUtils.isFunction(slotFunc)) {
243
- return getSlotVNs(slotFunc.call($xeTabs, params, h))
244
- }
245
- }
246
- return []
247
- },
248
- checkScrolling () {
249
- const $xeTabs = this
250
-
251
- const lrPosition = $xeTabs.computeLrPosition
252
- const headerWrapperEl = $xeTabs.$refs.refHeadWrapperElem as HTMLDivElement
253
- const headPrevEl = $xeTabs.$refs.refHeadPrevElem as HTMLDivElement
254
- const headNextEl = $xeTabs.$refs.refHeadNextElem as HTMLDivElement
255
- if (headerWrapperEl) {
256
- const { scrollLeft, scrollTop, clientWidth, clientHeight, scrollWidth, scrollHeight } = headerWrapperEl
257
- if (headPrevEl) {
258
- if ((lrPosition ? scrollTop : scrollLeft) > 0) {
259
- addClass(headPrevEl, 'scrolling--middle')
260
- } else {
261
- removeClass(headPrevEl, 'scrolling--middle')
262
- }
263
- }
264
- if (headNextEl) {
265
- if (lrPosition ? (clientHeight < scrollHeight - Math.ceil(scrollTop)) : (clientWidth < scrollWidth - Math.ceil(scrollLeft))) {
266
- addClass(headNextEl, 'scrolling--middle')
267
- } else {
268
- removeClass(headNextEl, 'scrolling--middle')
269
- }
270
- }
271
- }
272
- },
273
- updateTabStyle () {
274
- const $xeTabs = this
275
- const reactData = $xeTabs.reactData
276
-
277
- const handleStyle = () => {
278
- const { activeName } = reactData
279
- const tabType = $xeTabs.computeTabType
280
- const tabOptions = $xeTabs.computeTabOptions
281
- const tabStaticOptions = $xeTabs.computeTabStaticOptions
282
- const headerWrapperEl = $xeTabs.$refs.refHeadWrapperElem as HTMLDivElement
283
- const lrPosition = $xeTabs.computeLrPosition
284
- let lintWidth = 0
285
- let lintHeight = 0
286
- let lintLeft = 0
287
- let lintTop = 0
288
- let sBarWidth = 0
289
- let sBarHeight = 0
290
- let isOver = false
291
- if (headerWrapperEl) {
292
- const index = XEUtils.findIndexOf(tabStaticOptions.length ? tabStaticOptions : tabOptions, item => item.name === activeName)
293
- const { children, offsetWidth, scrollWidth, offsetHeight, scrollHeight, clientWidth, clientHeight } = headerWrapperEl
294
- sBarWidth = offsetWidth - clientWidth
295
- sBarHeight = offsetHeight - clientHeight
296
- if (lrPosition) {
297
- isOver = scrollHeight !== clientHeight
298
- if (index > -1) {
299
- const tabEl = children[index] as HTMLDivElement
300
- if (tabEl) {
301
- const tabHeight = tabEl.clientHeight
302
- const tabWidth = tabEl.clientWidth
303
- if (tabType === 'card') {
304
- lintWidth = tabWidth
305
- lintHeight = tabHeight
306
- lintTop = tabEl.offsetTop
307
- } else if (tabType === 'border-card') {
308
- lintWidth = tabWidth
309
- lintHeight = tabHeight
310
- lintTop = tabEl.offsetTop - 1
311
- } else {
312
- lintHeight = Math.max(4, Math.floor(tabHeight * 0.6))
313
- lintTop = tabEl.offsetTop + Math.floor((tabHeight - lintHeight) / 2)
314
- }
315
- }
316
- }
317
- } else {
318
- isOver = scrollWidth !== clientWidth
319
- if (index > -1) {
320
- const tabEl = children[index] as HTMLDivElement
321
- if (tabEl) {
322
- const tabWidth = tabEl.clientWidth
323
- if (tabType === 'card') {
324
- lintWidth = tabWidth + 1
325
- lintLeft = tabEl.offsetLeft
326
- } else if (tabType === 'border-card') {
327
- lintWidth = tabWidth
328
- lintLeft = tabEl.offsetLeft - 1
329
- } else {
330
- lintWidth = Math.max(4, Math.floor(tabWidth * 0.6))
331
- lintLeft = tabEl.offsetLeft + Math.floor((tabWidth - lintWidth) / 2)
332
- }
333
- }
334
- }
335
- }
336
- }
337
- reactData.scrollbarWidth = sBarWidth
338
- reactData.scrollbarHeight = sBarHeight
339
- reactData.lintLeft = lintLeft
340
- reactData.lintTop = lintTop
341
- reactData.lintWidth = lintWidth
342
- reactData.lintHeight = lintHeight
343
- reactData.isTabOver = isOver
344
- $xeTabs.checkScrolling()
345
- }
346
-
347
- handleStyle()
348
- $xeTabs.$nextTick(handleStyle)
349
- },
350
- addInitName (name: VxeTabsPropTypes.ModelValue, evnt: Event | null) {
351
- const $xeTabs = this
352
- const reactData = $xeTabs.reactData
353
-
354
- const { initNames } = reactData
355
- if (name && !initNames.includes(name)) {
356
- $xeTabs.dispatchEvent('tab-load', { name }, evnt)
357
- initNames.push(name)
358
- return true
359
- }
360
- return false
361
- },
362
- initDefaultName (list?: VxeTabsPropTypes.Options | VxeTabPaneDefines.TabConfig[]) {
363
- const $xeTabs = this
364
- const props = $xeTabs
365
- const reactData = $xeTabs.reactData
366
-
367
- let activeName: VxeTabsPropTypes.ModelValue = null
368
- const nameMaps: Record<string, {
369
- loading: boolean
370
- }> = {}
371
- if (list && list.length) {
372
- let validVal = false
373
- activeName = props.value
374
- list.forEach((item) => {
375
- const { name, preload } = item || {}
376
- if (name) {
377
- nameMaps[`${name}`] = {
378
- loading: false
379
- }
380
- if (activeName === name) {
381
- validVal = true
382
- }
383
- if (preload) {
384
- $xeTabs.addInitName(name, null)
385
- }
386
- }
387
- })
388
- if (!validVal) {
389
- activeName = list[0].name
390
- $xeTabs.addInitName(activeName, null)
391
- $xeTabs.emitModel(activeName)
392
- }
393
- }
394
- reactData.activeName = activeName
395
- reactData.cacheTabMaps = nameMaps
396
- },
397
- clickEvent (evnt: KeyboardEvent, item: VxeTabPaneProps | VxeTabPaneDefines.TabConfig) {
398
- const $xeTabs = this
399
- const props = $xeTabs
400
- const reactData = $xeTabs.reactData
401
-
402
- const { trigger } = props
403
- const beforeMethod = props.beforeChangeMethod || getConfig().tabs.beforeChangeMethod
404
- const { activeName } = reactData
405
- const { name } = item
406
- const value = name
407
- $xeTabs.dispatchEvent('tab-click', { name }, evnt)
408
- if (trigger === 'manual') {
409
- return
410
- }
411
- if (name !== activeName) {
412
- Promise.resolve(
413
- !beforeMethod || beforeMethod({ $tabs: $xeTabs, name, oldName: activeName, newName: name, option: item })
414
- ).then((status) => {
415
- if (status) {
416
- reactData.activeName = name
417
- $xeTabs.emitModel(value)
418
- $xeTabs.addInitName(name, evnt)
419
- $xeTabs.dispatchEvent('change', { value, name, oldName: activeName, newName: name, option: item }, evnt)
420
- $xeTabs.dispatchEvent('tab-change', { value, name, oldName: activeName, newName: name, option: item }, evnt)
421
- } else {
422
- $xeTabs.dispatchEvent('tab-change-fail', { value, name, oldName: activeName, newName: name, option: item }, evnt)
423
- }
424
- }).catch(() => {
425
- $xeTabs.dispatchEvent('tab-change-fail', { value, name, oldName: activeName, newName: name, option: item }, evnt)
426
- })
427
- }
428
- },
429
- handleRefreshTabEvent (evnt: KeyboardEvent, item: VxeTabPaneDefines.TabConfig | VxeTabPaneProps) {
430
- const $xeTabs = this
431
- const reactData = $xeTabs.reactData
432
-
433
- evnt.stopPropagation()
434
- const { activeName, cacheTabMaps } = reactData
435
- const { name } = item
436
- const refreshOpts = $xeTabs.computeRefreshOpts
437
- const { queryMethod } = refreshOpts
438
- const cacheItem = name ? cacheTabMaps[`${name}`] : null
439
- if (cacheItem) {
440
- if (cacheItem.loading) {
441
- return
442
- }
443
- if (queryMethod) {
444
- cacheItem.loading = true
445
- Promise.resolve(
446
- queryMethod({ $tabs: $xeTabs, value: activeName, name, option: item })
447
- ).finally(() => {
448
- cacheItem.loading = false
449
- })
450
- } else {
451
- errLog('vxe.error.notFunc', ['refresh-config.queryMethod'])
452
- }
453
- }
454
- },
455
- handleCloseTabEvent (evnt: KeyboardEvent, item: VxeTabPaneDefines.TabConfig | VxeTabPaneProps, index: number, list: VxeTabsPropTypes.Options | VxeTabPaneDefines.TabConfig[]) {
456
- const $xeTabs = this
457
- const props = $xeTabs
458
- const reactData = $xeTabs.reactData
459
-
460
- evnt.stopPropagation()
461
- const { activeName } = reactData
462
- const closeOpts = $xeTabs.computeCloseOpts
463
- const beforeMethod = closeOpts.beforeMethod || props.beforeCloseMethod || getConfig().tabs.beforeCloseMethod
464
- const { name } = item
465
- const value = activeName
466
- let nextName = value
467
- if (activeName === name) {
468
- const nextItem = index < list.length - 1 ? list[index + 1] : list[index - 1]
469
- nextName = nextItem ? nextItem.name : null
470
- }
471
- Promise.resolve(
472
- !beforeMethod || beforeMethod({ $tabs: $xeTabs, value, name, nextName, option: item })
473
- ).then(status => {
474
- if (status) {
475
- $xeTabs.dispatchEvent('tab-close', { value, name, nextName }, evnt)
476
- } else {
477
- $xeTabs.dispatchEvent('tab-close-fail', { value, name, nextName }, evnt)
478
- }
479
- }).catch(() => {
480
- $xeTabs.dispatchEvent('tab-close-fail', { value, name, nextName }, evnt)
481
- })
482
- },
483
- startScrollAnimation (offsetPos: number, offsetSize: number) {
484
- const $xeTabs = this
485
- const internalData = $xeTabs.internalData
486
-
487
- const { slTimeout } = internalData
488
- const lrPosition = $xeTabs.computeLrPosition
489
- let offsetLeft = lrPosition ? 0 : offsetSize
490
- let offsetTop = lrPosition ? offsetSize : 0
491
- let scrollCount = 6
492
- let delayNum = 35
493
- if (slTimeout) {
494
- clearTimeout(slTimeout)
495
- internalData.slTimeout = undefined
496
- }
497
- const scrollAnimate = () => {
498
- const headerWrapperEl = $xeTabs.$refs.refHeadWrapperElem as HTMLDivElement
499
- if (scrollCount > 0) {
500
- scrollCount--
501
- if (headerWrapperEl) {
502
- const { clientWidth, clientHeight, scrollWidth, scrollHeight, scrollLeft, scrollTop } = headerWrapperEl
503
- if (lrPosition) {
504
- offsetTop = Math.floor(offsetTop / 2)
505
- if (offsetPos > 0) {
506
- if (clientHeight + scrollTop < scrollHeight) {
507
- headerWrapperEl.scrollTop += offsetTop
508
- delayNum -= 4
509
- internalData.slTimeout = setTimeout(scrollAnimate, delayNum)
510
- }
511
- } else {
512
- if (scrollTop > 0) {
513
- headerWrapperEl.scrollTop -= offsetTop
514
- delayNum -= 4
515
- internalData.slTimeout = setTimeout(scrollAnimate, delayNum)
516
- }
517
- }
518
- } else {
519
- offsetLeft = Math.floor(offsetLeft / 2)
520
- if (offsetPos > 0) {
521
- if (clientWidth + scrollLeft < scrollWidth) {
522
- headerWrapperEl.scrollLeft += offsetLeft
523
- delayNum -= 4
524
- internalData.slTimeout = setTimeout(scrollAnimate, delayNum)
525
- }
526
- } else {
527
- if (scrollLeft > 0) {
528
- headerWrapperEl.scrollLeft -= offsetLeft
529
- delayNum -= 4
530
- internalData.slTimeout = setTimeout(scrollAnimate, delayNum)
531
- }
532
- }
533
- }
534
- $xeTabs.updateTabStyle()
535
- }
536
- }
537
- }
538
- scrollAnimate()
539
- },
540
- handleScrollToLeft (offsetPos: number) {
541
- const $xeTabs = this
542
-
543
- const lrPosition = $xeTabs.computeLrPosition
544
- const headerWrapperEl = $xeTabs.$refs.refHeadWrapperElem as HTMLDivElement
545
- if (headerWrapperEl) {
546
- const { clientWidth, clientHeight } = headerWrapperEl
547
- const offsetSize = Math.floor((lrPosition ? clientHeight : clientWidth) * 0.75)
548
- $xeTabs.startScrollAnimation(offsetPos, offsetSize)
549
- }
550
- },
551
- scrollLeftEvent () {
552
- const $xeTabs = this
553
-
554
- $xeTabs.handleScrollToLeft(-1)
555
- },
556
- scrollRightEvent () {
557
- const $xeTabs = this
558
-
559
- $xeTabs.handleScrollToLeft(1)
560
- },
561
- scrollToTab (name: VxeTabsPropTypes.ModelValue) {
562
- const $xeTabs = this
563
-
564
- const tabOptions = $xeTabs.computeTabOptions
565
- const tabStaticOptions = $xeTabs.computeTabStaticOptions
566
- const lrPosition = $xeTabs.computeLrPosition
567
- return $xeTabs.$nextTick().then(() => {
568
- const headerWrapperEl = $xeTabs.$refs.refHeadWrapperElem as HTMLDivElement
569
- if (headerWrapperEl) {
570
- const index = XEUtils.findIndexOf(tabStaticOptions.length ? tabStaticOptions : tabOptions, item => item.name === name)
571
- if (index > -1) {
572
- const { scrollLeft, scrollTop, clientWidth, clientHeight, children } = headerWrapperEl
573
- const tabEl = children[index] as HTMLDivElement
574
- if (tabEl) {
575
- if (lrPosition) {
576
- const tabOffsetTop = tabEl.offsetTop
577
- const tabClientHeight = tabEl.clientHeight
578
- // 如果顶部被挡
579
- const overSize = (tabOffsetTop + tabClientHeight) - (scrollTop + clientHeight)
580
- if (overSize > 0) {
581
- headerWrapperEl.scrollTop += overSize
582
- }
583
- // 如果底部被挡,优先
584
- if (tabOffsetTop < scrollTop) {
585
- headerWrapperEl.scrollTop = tabOffsetTop
586
- }
587
- } else {
588
- const tabOffsetLeft = tabEl.offsetLeft
589
- const tabClientWidth = tabEl.clientWidth
590
- // 如果右侧被挡
591
- const overSize = (tabOffsetLeft + tabClientWidth) - (scrollLeft + clientWidth)
592
- if (overSize > 0) {
593
- headerWrapperEl.scrollLeft += overSize
594
- }
595
- // 如果左侧被挡,优先
596
- if (tabOffsetLeft < scrollLeft) {
597
- headerWrapperEl.scrollLeft = tabOffsetLeft
598
- }
599
- }
600
- }
601
- }
602
- $xeTabs.updateTabStyle()
603
- }
604
- })
605
- },
606
- handlePrevNext (isNext: boolean) {
607
- const $xeTabs = this
608
- const reactData = $xeTabs.reactData
609
-
610
- const { activeName } = reactData
611
- const tabOptions = $xeTabs.computeTabOptions
612
- const tabStaticOptions = $xeTabs.computeTabStaticOptions
613
- const list = tabStaticOptions.length ? tabStaticOptions : tabOptions
614
- const index = XEUtils.findIndexOf(list, item => item.name === activeName)
615
- if (index > -1) {
616
- let item: VxeTabPaneProps | null = null
617
- if (isNext) {
618
- if (index < list.length - 1) {
619
- item = list[index + 1]
620
- }
621
- } else {
622
- if (index > 0) {
623
- item = list[index - 1]
624
- }
625
- }
626
- if (item) {
627
- const name = item.name
628
- const value = name
629
- reactData.activeName = name
630
- $xeTabs.emitModel(value)
631
- $xeTabs.addInitName(name, null)
632
- }
633
- }
634
- return $xeTabs.$nextTick()
635
- },
636
-
637
- //
638
- // Render
639
- //
640
- renderTabHeader (h: CreateElement, tabList: VxeTabsPropTypes.Options | VxeTabPaneDefines.TabConfig[]) {
641
- const $xeTabs = this
642
- const props = $xeTabs
643
- const slots = $xeTabs.$scopedSlots
644
- const reactData = $xeTabs.reactData
645
-
646
- const { titleWidth: allTitleWidth, titleAlign: allTitleAlign, showClose, closeConfig, refreshConfig } = props
647
- const { activeName, scrollbarWidth, scrollbarHeight, isTabOver, cacheTabMaps } = reactData
648
- const tabType = $xeTabs.computeTabType
649
- const tabPosition = $xeTabs.computeTabPosition
650
- const lrPosition = $xeTabs.computeLrPosition
651
- const lineStyle = $xeTabs.computeLineStyle
652
- const tabPrefixSlot = slots.tabPrefix || slots['tab-prefix'] || slots.prefix
653
- const tabSuffixSlot = slots.tabSuffix || slots['tab-suffix'] || slots.suffix || slots.extra
654
- const closeOpts = $xeTabs.computeCloseOpts
655
- const closeVisibleMethod = closeOpts.visibleMethod
656
- const refreshOpts = $xeTabs.computeRefreshOpts
657
- const refreshVisibleMethod = refreshOpts.visibleMethod
658
-
659
- return h('div', {
660
- key: 'th',
661
- class: ['vxe-tabs-header', `type--${tabType}`, `pos--${tabPosition}`]
662
- }, [
663
- tabPrefixSlot
664
- ? h('div', {
665
- class: ['vxe-tabs-header--prefix', `type--${tabType}`, `pos--${tabPosition}`]
666
- }, $xeTabs.callSlot(tabPrefixSlot, { name: activeName }, h))
667
- : renderEmptyElement($xeTabs),
668
- isTabOver
669
- ? h('div', {
670
- ref: 'refHeadPrevElem',
671
- class: ['vxe-tabs-header--bar vxe-tabs-header--prev-bar', `type--${tabType}`, `pos--${tabPosition}`],
672
- on: {
673
- click: $xeTabs.scrollLeftEvent
674
- }
675
- }, [
676
- h('span', {
677
- class: lrPosition ? getIcon().TABS_TAB_BUTTON_TOP : getIcon().TABS_TAB_BUTTON_LEFT
678
- })
679
- ])
680
- : renderEmptyElement($xeTabs),
681
- h('div', {
682
- class: ['vxe-tabs-header--wrapper', `type--${tabType}`, `pos--${tabPosition}`]
683
- }, [
684
- h('div', {
685
- ref: 'refHeadWrapperElem',
686
- class: 'vxe-tabs-header--item-wrapper',
687
- style: lrPosition
688
- ? {
689
- marginRight: `-${scrollbarWidth + scrollbarOffsetSize}px`,
690
- paddingRight: `${scrollbarOffsetSize}px`
691
- }
692
- : {
693
- marginBottom: `-${scrollbarHeight + scrollbarOffsetSize}px`,
694
- paddingBottom: `${scrollbarOffsetSize}px`
695
- },
696
- on: {
697
- scroll: $xeTabs.checkScrolling
698
- }
699
- }, tabList.map((item, index) => {
700
- const { title, titleWidth, titleAlign, icon, name } = item
701
- const itemSlots = item.slots || {}
702
- const titleSlot = itemSlots.title || itemSlots.tab
703
- const titlePrefixSlot = itemSlots.titlePrefix || (itemSlots as any)['title-prefix']
704
- const titleSuffixSlot = itemSlots.titleSuffix || (itemSlots as any)['title-suffix']
705
- const itemWidth = titleWidth || allTitleWidth
706
- const itemAlign = titleAlign || allTitleAlign
707
- const params = { $tabs: $xeTabs, value: activeName, name, option: item }
708
- const isActive = activeName === name
709
- const cacheItem = name ? cacheTabMaps[`${name}`] : null
710
- const isLoading = cacheItem ? cacheItem.loading : false
711
- return h('div', {
712
- key: `${name}`,
713
- class: ['vxe-tabs-header--item', `type--${tabType}`, `pos--${tabPosition}`, itemAlign ? `align--${itemAlign}` : '', {
714
- 'is--active': isActive
715
- }],
716
- style: itemWidth
717
- ? {
718
- width: toCssUnit(itemWidth)
719
- }
720
- : undefined,
721
- on: {
722
- click (evnt: KeyboardEvent) {
723
- $xeTabs.clickEvent(evnt, item)
724
- }
725
- }
726
- }, [
727
- h('div', {
728
- class: 'vxe-tabs-header--item-inner'
729
- }, [
730
- h('div', {
731
- class: 'vxe-tabs-header--item-content'
732
- }, [
733
- icon
734
- ? h('span', {
735
- class: 'vxe-tabs-header--item-icon'
736
- }, [
737
- h('i', {
738
- class: icon
739
- })
740
- ])
741
- : renderEmptyElement($xeTabs),
742
- titlePrefixSlot
743
- ? h('span', {
744
- class: 'vxe-tabs-header--item-prefix'
745
- }, $xeTabs.callSlot(titlePrefixSlot, { name, title }, h))
746
- : renderEmptyElement($xeTabs),
747
- h('span', {
748
- class: 'vxe-tabs-header--item-name'
749
- }, titleSlot ? $xeTabs.callSlot(titleSlot, { name, title }, h) : `${title}`),
750
- titleSuffixSlot
751
- ? h('span', {
752
- class: 'vxe-tabs-header--item-suffix'
753
- }, $xeTabs.callSlot(titleSuffixSlot, { name, title }, h))
754
- : renderEmptyElement($xeTabs)
755
- ]),
756
- (isEnableConf(refreshConfig) || refreshOpts.enabled) && (refreshVisibleMethod ? refreshVisibleMethod(params) : true)
757
- ? h('div', {
758
- class: ['vxe-tabs-header--refresh-btn', {
759
- 'is--active': isActive,
760
- 'is--loading': isLoading,
761
- 'is--disabled': isLoading
762
- }],
763
- on: {
764
- click (evnt: KeyboardEvent) {
765
- $xeTabs.handleRefreshTabEvent(evnt, item)
766
- }
767
- }
768
- }, [
769
- h('i', {
770
- class: isLoading ? getIcon().TABS_TAB_REFRESH_LOADING : getIcon().TABS_TAB_REFRESH
771
- })
772
- ])
773
- : renderEmptyElement($xeTabs),
774
- (showClose || (isEnableConf(closeConfig) || closeOpts.enabled)) && (!closeVisibleMethod || closeVisibleMethod(params))
775
- ? h('div', {
776
- class: ['vxe-tabs-header--close-btn', {
777
- 'is--active': isActive
778
- }],
779
- on: {
780
- click (evnt: KeyboardEvent) {
781
- $xeTabs.handleCloseTabEvent(evnt, item, index, tabList)
782
- }
783
- }
784
- }, [
785
- h('i', {
786
- class: getIcon().TABS_TAB_CLOSE
787
- })
788
- ])
789
- : renderEmptyElement($xeTabs)
790
- ])
791
- ])
792
- }).concat([
793
- h('span', {
794
- key: 'line',
795
- class: ['vxe-tabs-header--active-line', `type--${tabType}`, `pos--${tabPosition}`],
796
- style: lineStyle
797
- })
798
- ]))
799
- ]),
800
- isTabOver
801
- ? h('div', {
802
- ref: 'refHeadNextElem',
803
- class: ['vxe-tabs-header--bar vxe-tabs-header--next-bar', `type--${tabType}`, `pos--${tabPosition}`],
804
- on: {
805
- click: $xeTabs.scrollRightEvent
806
- }
807
- }, [
808
- h('span', {
809
- class: lrPosition ? getIcon().TABS_TAB_BUTTON_BOTTOM : getIcon().TABS_TAB_BUTTON_RIGHT
810
- })
811
- ])
812
- : renderEmptyElement($xeTabs),
813
- tabSuffixSlot
814
- ? h('div', {
815
- class: ['vxe-tabs-header--suffix', `type--${tabType}`, `pos--${tabPosition}`]
816
- }, $xeTabs.callSlot(tabSuffixSlot, { name: activeName }, h))
817
- : renderEmptyElement($xeTabs)
818
- ])
819
- },
820
- renderTabPane (h: CreateElement, item: VxeTabPaneProps | VxeTabPaneDefines.TabConfig) {
821
- const $xeTabs = this
822
- const reactData = $xeTabs.reactData
823
-
824
- const { initNames, activeName } = reactData
825
- const { name, slots } = item
826
- const defaultSlot = slots ? slots.default : null
827
- return name && initNames.includes(name)
828
- ? h('div', {
829
- key: `${name}`,
830
- class: ['vxe-tabs-pane--item', {
831
- 'is--visible': activeName === name
832
- }]
833
- }, defaultSlot ? $xeTabs.callSlot(defaultSlot, { name }, h) : [])
834
- : renderEmptyElement($xeTabs)
835
- },
836
- renderTabContent (h: CreateElement, tabList: VxeTabsPropTypes.Options | VxeTabPaneDefines.TabConfig[]) {
837
- const $xeTabs = this
838
- const props = $xeTabs
839
- const reactData = $xeTabs.reactData
840
-
841
- const { destroyOnClose } = props
842
- const { activeName } = reactData
843
- if (destroyOnClose) {
844
- const activeTab = tabList.find(item => item.name === activeName)
845
- return [activeTab ? $xeTabs.renderTabPane(h, activeTab) : renderEmptyElement($xeTabs)]
846
- }
847
- return tabList.map((item) => $xeTabs.renderTabPane(h, item))
848
- },
849
- rendetTabBody (h: CreateElement, tabList: VxeTabsPropTypes.Options | VxeTabPaneDefines.TabConfig[]) {
850
- const $xeTabs = this
851
- const props = $xeTabs
852
- const slots = $xeTabs.$scopedSlots
853
- const reactData = $xeTabs.reactData
854
-
855
- const { height, padding, showBody } = props
856
- const { activeName, cacheTabMaps } = reactData
857
- const vSize = $xeTabs.computeSize
858
- const tabType = $xeTabs.computeTabType
859
- const tabPosition = $xeTabs.computeTabPosition
860
- const refreshOpts = $xeTabs.computeRefreshOpts
861
- const { showLoading } = refreshOpts
862
- const headerpSlot = slots.header
863
- const footerSlot = slots.footer
864
- if (!showBody) {
865
- return renderEmptyElement($xeTabs)
866
- }
867
- const cacheItem = activeName ? cacheTabMaps[`${activeName}`] : null
868
- const isLoading = cacheItem ? cacheItem.loading : false
869
- const defParams = { name: activeName }
870
- return h('div', {
871
- key: 'tb',
872
- class: ['vxe-tabs-pane--wrapper', `type--${tabType}`, `pos--${tabPosition}`, {
873
- 'is--content': showBody
874
- }]
875
- }, [
876
- headerpSlot
877
- ? h('div', {
878
- class: 'vxe-tabs-pane--header'
879
- }, $xeTabs.callSlot(headerpSlot, defParams, h))
880
- : renderEmptyElement($xeTabs),
881
- h('div', {
882
- class: ['vxe-tabs-pane--body', `type--${tabType}`, `pos--${tabPosition}`, {
883
- [`size--${vSize}`]: vSize,
884
- 'is--padding': padding,
885
- 'is--height': height
886
- }]
887
- }, $xeTabs.renderTabContent(h, tabList)),
888
- footerSlot
889
- ? h('div', {
890
- class: 'vxe-tabs-pane--footer'
891
- }, $xeTabs.callSlot(footerSlot, defParams, h))
892
- : renderEmptyElement($xeTabs),
893
- showLoading && isLoading
894
- ? renderEmptyElement($xeTabs)
895
- : h(VxeLoadingComponent, {
896
- class: 'vxe-tabs--loading',
897
- props: {
898
- value: isLoading
899
- }
900
- })
901
- ])
902
- },
903
- renderVN (h: CreateElement): VNode {
904
- const $xeTabs = this
905
- const props = $xeTabs
906
- const slots = $xeTabs.$scopedSlots
907
- const reactData = $xeTabs.reactData
908
-
909
- const { height, padding, trigger } = props
910
- const { activeName } = reactData
911
- const vSize = $xeTabs.computeSize
912
- const tabOptions = $xeTabs.computeTabOptions
913
- const tabStaticOptions = $xeTabs.computeTabStaticOptions
914
- const tabType = $xeTabs.computeTabType
915
- const tabPosition = $xeTabs.computeTabPosition
916
- const wrapperStyle = $xeTabs.computeWrapperStyle
917
- const defaultSlot = slots.default
918
- const tabList = defaultSlot ? tabStaticOptions : tabOptions
919
-
920
- const vns = [
921
- h('div', {
922
- key: 'ts',
923
- class: 'vxe-tabs-slots'
924
- }, defaultSlot ? defaultSlot({ name: activeName }) : [])
925
- ]
926
-
927
- if (tabPosition === 'right' || tabPosition === 'bottom') {
928
- vns.push(
929
- $xeTabs.rendetTabBody(h, tabList),
930
- $xeTabs.renderTabHeader(h, tabList)
931
- )
932
- } else {
933
- vns.push(
934
- $xeTabs.renderTabHeader(h, tabList),
935
- $xeTabs.rendetTabBody(h, tabList)
936
- )
937
- }
938
-
939
- return h('div', {
940
- ref: 'refElem',
941
- class: ['vxe-tabs', `pos--${tabPosition}`, `vxe-tabs--${tabType}`, `trigger--${trigger === 'manual' ? 'trigger' : 'default'}`, {
942
- [`size--${vSize}`]: vSize,
943
- 'is--padding': padding,
944
- 'is--height': height
945
- }],
946
- style: wrapperStyle
947
- }, vns)
948
- }
949
- },
950
- watch: {
951
- position () {
952
- const $xeTabs = this
953
- const reactData = $xeTabs.reactData
954
-
955
- reactData.resizeFlag++
956
- },
957
- value (val) {
958
- const $xeTabs = this
959
- const reactData = $xeTabs.reactData
960
-
961
- $xeTabs.addInitName(val, null)
962
- reactData.activeName = val
963
- },
964
- 'reactData.activeName' (val) {
965
- const $xeTabs = this
966
-
967
- $xeTabs.scrollToTab(val)
968
- },
969
- options () {
970
- const $xeTabs = this
971
- const props = $xeTabs
972
- const reactData = $xeTabs.reactData
973
-
974
- $xeTabs.initDefaultName(props.options)
975
- reactData.resizeFlag++
976
- },
977
- 'reactData.staticTabs' () {
978
- const $xeTabs = this
979
- const reactData = $xeTabs.reactData
980
-
981
- $xeTabs.initDefaultName(reactData.staticTabs)
982
- reactData.resizeFlag++
983
- },
984
- computeParentTabsResizeFlag () {
985
- const $xeTabs = this
986
-
987
- $xeTabs.$nextTick(() => {
988
- $xeTabs.updateTabStyle()
989
- })
990
- }
991
- },
992
- created () {
993
- const $xeTabs = this
994
- const props = $xeTabs
995
- const reactData = $xeTabs.reactData
996
-
997
- $xeTabs.addInitName(props.value, null)
998
- $xeTabs.initDefaultName(reactData.staticTabs.length ? reactData.staticTabs : props.options)
999
- },
1000
- mounted () {
1001
- const $xeTabs = this
1002
-
1003
- $xeTabs.updateTabStyle()
1004
- globalEvents.on($xeTabs, 'resize', $xeTabs.updateTabStyle)
1005
- },
1006
- beforeDestroy () {
1007
- const $xeTabs = this
1008
-
1009
- globalEvents.off($xeTabs, 'resize')
1010
- },
1011
- render (this: any, h) {
1012
- return this.renderVN(h)
1013
- }
1014
- }) /* define-vxe-component end */
1
+ import { PropType, CreateElement, VNode } from 'vue'
2
+ import { defineVxeComponent } from '../../ui/src/comp'
3
+ import XEUtils from 'xe-utils'
4
+ import { createEvent, getConfig, getIcon, globalEvents, globalMixins, permission, renderEmptyElement } from '../../ui'
5
+ import { getSlotVNs } from '../../ui/src/vn'
6
+ import { toCssUnit, addClass, removeClass } from '../../ui/src/dom'
7
+ import { isEnableConf } from '../../ui/src/utils'
8
+ import { warnLog, errLog } from '../../ui/src/log'
9
+ import VxeLoadingComponent from '../../loading/src/loading'
10
+
11
+ import type { VxeTabsPropTypes, VxeTabPaneProps, VxeTabsEmits, TabsInternalData, TabsReactData, VxeComponentSizeType, VxeTabsConstructor, VxeTabsPrivateMethods, VxeTabPaneDefines, ValueOf, VxeComponentStyleType } from '../../../types'
12
+
13
+ const scrollbarOffsetSize = 20
14
+
15
+ export default /* define-vxe-component start */ defineVxeComponent({
16
+ name: 'VxeTabs',
17
+ mixins: [
18
+ globalMixins.sizeMixin
19
+ ],
20
+ props: {
21
+ value: [String, Number, Boolean] as PropType<VxeTabsPropTypes.ModelValue>,
22
+ options: Array as PropType<VxeTabsPropTypes.Options>,
23
+ width: [String, Number] as PropType<VxeTabsPropTypes.Width>,
24
+ height: [String, Number] as PropType<VxeTabsPropTypes.Height>,
25
+ destroyOnClose: {
26
+ type: Boolean as PropType<VxeTabsPropTypes.DestroyOnClose>,
27
+ default: () => getConfig().tabs.destroyOnClose
28
+ },
29
+ titleWidth: [String, Number] as PropType<VxeTabsPropTypes.TitleWidth>,
30
+ titleAlign: [String, Number] as PropType<VxeTabsPropTypes.TitleAlign>,
31
+ type: {
32
+ type: String as PropType<VxeTabsPropTypes.Type>,
33
+ default: () => getConfig().tabs.type
34
+ },
35
+ position: {
36
+ type: String as PropType<VxeTabsPropTypes.Position>,
37
+ default: () => getConfig().tabs.position
38
+ },
39
+ showClose: Boolean as PropType<VxeTabsPropTypes.ShowClose>,
40
+ showBody: {
41
+ type: Boolean as PropType<VxeTabsPropTypes.ShowBody>,
42
+ default: true
43
+ },
44
+ padding: {
45
+ type: Boolean as PropType<VxeTabsPropTypes.Padding>,
46
+ default: () => getConfig().tabs.padding
47
+ },
48
+ trigger: String as PropType<VxeTabsPropTypes.Trigger>,
49
+ beforeChangeMethod: Function as PropType<VxeTabsPropTypes.BeforeChangeMethod>,
50
+ closeConfig: Object as PropType<VxeTabsPropTypes.CloseConfig>,
51
+ refreshConfig: Object as PropType<VxeTabsPropTypes.RefreshConfig>,
52
+ size: {
53
+ type: String as PropType<VxeTabsPropTypes.Size>,
54
+ default: () => getConfig().tabs.size || getConfig().size
55
+ },
56
+ // 已废弃
57
+ beforeCloseMethod: Function as PropType<VxeTabsPropTypes.BeforeCloseMethod>
58
+ },
59
+ inject: {
60
+ $xeParentTabs: {
61
+ from: '$xeTabs',
62
+ default: null
63
+ }
64
+ },
65
+ provide () {
66
+ const $xeTabs = this
67
+ return {
68
+ $xeTabs
69
+ }
70
+ },
71
+ data () {
72
+ const xID = XEUtils.uniqueId()
73
+ const reactData: TabsReactData = {
74
+ staticTabs: [],
75
+ activeName: null,
76
+ initNames: [],
77
+ lintLeft: 0,
78
+ lintTop: 0,
79
+ lintWidth: 0,
80
+ lintHeight: 0,
81
+ scrollbarWidth: 0,
82
+ scrollbarHeight: 0,
83
+ isTabOver: false,
84
+ resizeFlag: 1,
85
+ cacheTabMaps: {}
86
+ }
87
+ const internalData: TabsInternalData = {
88
+ slTimeout: undefined
89
+ }
90
+ return {
91
+ xID,
92
+ reactData,
93
+ internalData
94
+ }
95
+ },
96
+ computed: {
97
+ ...({} as {
98
+ computeSize(): VxeComponentSizeType
99
+ $xeParentTabs():(VxeTabsConstructor & VxeTabsPrivateMethods) | null
100
+ }),
101
+ computeParentTabsResizeFlag () {
102
+ const $xeTabs = this
103
+ const $xeParentTabs = $xeTabs.$xeParentTabs
104
+
105
+ return $xeParentTabs ? $xeParentTabs.reactData.resizeFlag : null
106
+ },
107
+ computeTabType () {
108
+ const $xeTabs = this
109
+ const props = $xeTabs
110
+
111
+ const { type } = props
112
+ return type || 'default'
113
+ },
114
+ computeTabPosition () {
115
+ const $xeTabs = this
116
+ const props = $xeTabs
117
+
118
+ const { position } = props
119
+ return position || 'top'
120
+ },
121
+ computeLrPosition () {
122
+ const $xeTabs = this
123
+
124
+ const tabPosition = $xeTabs.computeTabPosition
125
+ return tabPosition === 'left' || tabPosition === 'right'
126
+ },
127
+ computeLineStyle (this: any) {
128
+ const $xeTabs = this
129
+ const reactData = $xeTabs.reactData
130
+
131
+ const { lintLeft, lintTop, lintWidth, lintHeight } = reactData
132
+ const lrPosition = $xeTabs.computeLrPosition
133
+ return lrPosition
134
+ ? {
135
+ top: `${lintTop}px`,
136
+ height: `${lintHeight}px`
137
+ }
138
+ : {
139
+ left: `${lintLeft}px`,
140
+ width: `${lintWidth}px`
141
+ }
142
+ },
143
+ computeWrapperStyle () {
144
+ const $xeTabs = this
145
+ const props = $xeTabs
146
+
147
+ const { width, height } = props
148
+ const stys: VxeComponentStyleType = {}
149
+ if (width) {
150
+ stys.width = toCssUnit(width)
151
+ }
152
+ if (height) {
153
+ stys.height = toCssUnit(height)
154
+ }
155
+ return stys
156
+ },
157
+ computeCloseOpts () {
158
+ const $xeTabs = this
159
+ const props = $xeTabs
160
+
161
+ return Object.assign({}, getConfig().tabs.closeConfig, props.closeConfig)
162
+ },
163
+ computeRefreshOpts () {
164
+ const $xeTabs = this
165
+ const props = $xeTabs
166
+
167
+ return Object.assign({}, getConfig().tabs.refreshConfig, props.refreshConfig)
168
+ },
169
+ computeTabOptions (this: any) {
170
+ const $xeTabs = this
171
+ const props = $xeTabs
172
+
173
+ const options = props.options as VxeTabsPropTypes.Options
174
+ return (options || []).filter((item) => $xeTabs.handleFilterTab(item))
175
+ },
176
+ computeTabStaticOptions (this: any) {
177
+ const $xeTabs = this
178
+ const reactData = $xeTabs.reactData
179
+
180
+ const staticTabs = reactData.staticTabs as VxeTabPaneDefines.TabConfig[]
181
+ return staticTabs.filter((item) => $xeTabs.handleFilterTab(item))
182
+ }
183
+ },
184
+ methods: {
185
+ //
186
+ // Method
187
+ //
188
+ dispatchEvent (type: ValueOf<VxeTabsEmits>, params: Record<string, any>, evnt: Event | null) {
189
+ const $xeTabs = this
190
+ $xeTabs.$emit(type, createEvent(evnt, { $tabs: $xeTabs }, params))
191
+ },
192
+ emitModel (value: any) {
193
+ const $xeTabs = this
194
+
195
+ const { _events } = $xeTabs as any
196
+ $xeTabs.$emit('input', value)
197
+ if (_events && _events.modelValue) {
198
+ $xeTabs.$emit('modelValue', value)
199
+ } else {
200
+ $xeTabs.$emit('model-value', value)
201
+ }
202
+ },
203
+ prev () {
204
+ const $xeTabs = this
205
+
206
+ return $xeTabs.handlePrevNext(false)
207
+ },
208
+ next () {
209
+ const $xeTabs = this
210
+
211
+ return $xeTabs.handlePrevNext(true)
212
+ },
213
+ prevTab () {
214
+ const $xeTabs = this
215
+
216
+ warnLog('vxe.error.delFunc', ['[tabs] prevTab', 'prev'])
217
+ return $xeTabs.prev()
218
+ },
219
+ nextTab () {
220
+ const $xeTabs = this
221
+
222
+ warnLog('vxe.error.delFunc', ['[tabs] nextTab', 'next'])
223
+ return $xeTabs.next()
224
+ },
225
+ handleFilterTab (item: VxeTabPaneProps | VxeTabPaneDefines.TabConfig) {
226
+ const { permissionCode } = item
227
+ if (permissionCode) {
228
+ if (!permission.checkVisible(permissionCode)) {
229
+ return false
230
+ }
231
+ }
232
+ return true
233
+ },
234
+ callSlot (slotFunc: any, params: any, h: CreateElement) {
235
+ const $xeTabs = this
236
+ const slots = $xeTabs.$scopedSlots
237
+
238
+ if (slotFunc) {
239
+ if (XEUtils.isString(slotFunc)) {
240
+ slotFunc = slots[slotFunc] || null
241
+ }
242
+ if (XEUtils.isFunction(slotFunc)) {
243
+ return getSlotVNs(slotFunc.call($xeTabs, params, h))
244
+ }
245
+ }
246
+ return []
247
+ },
248
+ checkScrolling () {
249
+ const $xeTabs = this
250
+
251
+ const lrPosition = $xeTabs.computeLrPosition
252
+ const headerWrapperEl = $xeTabs.$refs.refHeadWrapperElem as HTMLDivElement
253
+ const headPrevEl = $xeTabs.$refs.refHeadPrevElem as HTMLDivElement
254
+ const headNextEl = $xeTabs.$refs.refHeadNextElem as HTMLDivElement
255
+ if (headerWrapperEl) {
256
+ const { scrollLeft, scrollTop, clientWidth, clientHeight, scrollWidth, scrollHeight } = headerWrapperEl
257
+ if (headPrevEl) {
258
+ if ((lrPosition ? scrollTop : scrollLeft) > 0) {
259
+ addClass(headPrevEl, 'scrolling--middle')
260
+ } else {
261
+ removeClass(headPrevEl, 'scrolling--middle')
262
+ }
263
+ }
264
+ if (headNextEl) {
265
+ if (lrPosition ? (clientHeight < scrollHeight - Math.ceil(scrollTop)) : (clientWidth < scrollWidth - Math.ceil(scrollLeft))) {
266
+ addClass(headNextEl, 'scrolling--middle')
267
+ } else {
268
+ removeClass(headNextEl, 'scrolling--middle')
269
+ }
270
+ }
271
+ }
272
+ },
273
+ updateTabStyle () {
274
+ const $xeTabs = this
275
+ const reactData = $xeTabs.reactData
276
+
277
+ const handleStyle = () => {
278
+ const { activeName } = reactData
279
+ const tabType = $xeTabs.computeTabType
280
+ const tabOptions = $xeTabs.computeTabOptions
281
+ const tabStaticOptions = $xeTabs.computeTabStaticOptions
282
+ const headerWrapperEl = $xeTabs.$refs.refHeadWrapperElem as HTMLDivElement
283
+ const lrPosition = $xeTabs.computeLrPosition
284
+ let lintWidth = 0
285
+ let lintHeight = 0
286
+ let lintLeft = 0
287
+ let lintTop = 0
288
+ let sBarWidth = 0
289
+ let sBarHeight = 0
290
+ let isOver = false
291
+ if (headerWrapperEl) {
292
+ const index = XEUtils.findIndexOf(tabStaticOptions.length ? tabStaticOptions : tabOptions, item => item.name === activeName)
293
+ const { children, offsetWidth, scrollWidth, offsetHeight, scrollHeight, clientWidth, clientHeight } = headerWrapperEl
294
+ sBarWidth = offsetWidth - clientWidth
295
+ sBarHeight = offsetHeight - clientHeight
296
+ if (lrPosition) {
297
+ isOver = scrollHeight !== clientHeight
298
+ if (index > -1) {
299
+ const tabEl = children[index] as HTMLDivElement
300
+ if (tabEl) {
301
+ const tabHeight = tabEl.clientHeight
302
+ const tabWidth = tabEl.clientWidth
303
+ if (tabType === 'card') {
304
+ lintWidth = tabWidth
305
+ lintHeight = tabHeight
306
+ lintTop = tabEl.offsetTop
307
+ } else if (tabType === 'border-card') {
308
+ lintWidth = tabWidth
309
+ lintHeight = tabHeight
310
+ lintTop = tabEl.offsetTop - 1
311
+ } else {
312
+ lintHeight = Math.max(4, Math.floor(tabHeight * 0.6))
313
+ lintTop = tabEl.offsetTop + Math.floor((tabHeight - lintHeight) / 2)
314
+ }
315
+ }
316
+ }
317
+ } else {
318
+ isOver = scrollWidth !== clientWidth
319
+ if (index > -1) {
320
+ const tabEl = children[index] as HTMLDivElement
321
+ if (tabEl) {
322
+ const tabWidth = tabEl.clientWidth
323
+ if (tabType === 'card') {
324
+ lintWidth = tabWidth + 1
325
+ lintLeft = tabEl.offsetLeft
326
+ } else if (tabType === 'border-card') {
327
+ lintWidth = tabWidth
328
+ lintLeft = tabEl.offsetLeft - 1
329
+ } else {
330
+ lintWidth = Math.max(4, Math.floor(tabWidth * 0.6))
331
+ lintLeft = tabEl.offsetLeft + Math.floor((tabWidth - lintWidth) / 2)
332
+ }
333
+ }
334
+ }
335
+ }
336
+ }
337
+ reactData.scrollbarWidth = sBarWidth
338
+ reactData.scrollbarHeight = sBarHeight
339
+ reactData.lintLeft = lintLeft
340
+ reactData.lintTop = lintTop
341
+ reactData.lintWidth = lintWidth
342
+ reactData.lintHeight = lintHeight
343
+ reactData.isTabOver = isOver
344
+ $xeTabs.checkScrolling()
345
+ }
346
+
347
+ handleStyle()
348
+ $xeTabs.$nextTick(handleStyle)
349
+ },
350
+ addInitName (name: VxeTabsPropTypes.ModelValue, evnt: Event | null) {
351
+ const $xeTabs = this
352
+ const reactData = $xeTabs.reactData
353
+
354
+ const { initNames } = reactData
355
+ if (name && !initNames.includes(name)) {
356
+ $xeTabs.dispatchEvent('tab-load', { name }, evnt)
357
+ initNames.push(name)
358
+ return true
359
+ }
360
+ return false
361
+ },
362
+ initDefaultName (list?: VxeTabsPropTypes.Options | VxeTabPaneDefines.TabConfig[]) {
363
+ const $xeTabs = this
364
+ const props = $xeTabs
365
+ const reactData = $xeTabs.reactData
366
+
367
+ let activeName: VxeTabsPropTypes.ModelValue = null
368
+ const nameMaps: Record<string, {
369
+ loading: boolean
370
+ }> = {}
371
+ if (list && list.length) {
372
+ let validVal = false
373
+ activeName = props.value
374
+ list.forEach((item) => {
375
+ const { name, preload } = item || {}
376
+ if (name) {
377
+ nameMaps[`${name}`] = {
378
+ loading: false
379
+ }
380
+ if (activeName === name) {
381
+ validVal = true
382
+ }
383
+ if (preload) {
384
+ $xeTabs.addInitName(name, null)
385
+ }
386
+ }
387
+ })
388
+ if (!validVal) {
389
+ activeName = list[0].name
390
+ $xeTabs.addInitName(activeName, null)
391
+ $xeTabs.emitModel(activeName)
392
+ }
393
+ }
394
+ reactData.activeName = activeName
395
+ reactData.cacheTabMaps = nameMaps
396
+ },
397
+ clickEvent (evnt: KeyboardEvent, item: VxeTabPaneProps | VxeTabPaneDefines.TabConfig) {
398
+ const $xeTabs = this
399
+ const props = $xeTabs
400
+ const reactData = $xeTabs.reactData
401
+
402
+ const { trigger } = props
403
+ const beforeMethod = props.beforeChangeMethod || getConfig().tabs.beforeChangeMethod
404
+ const { activeName } = reactData
405
+ const { name } = item
406
+ const value = name
407
+ $xeTabs.dispatchEvent('tab-click', { name }, evnt)
408
+ if (trigger === 'manual') {
409
+ return
410
+ }
411
+ if (name !== activeName) {
412
+ Promise.resolve(
413
+ !beforeMethod || beforeMethod({ $tabs: $xeTabs, name, oldName: activeName, newName: name, option: item })
414
+ ).then((status) => {
415
+ if (status) {
416
+ reactData.activeName = name
417
+ $xeTabs.emitModel(value)
418
+ $xeTabs.addInitName(name, evnt)
419
+ $xeTabs.dispatchEvent('change', { value, name, oldName: activeName, newName: name, option: item }, evnt)
420
+ $xeTabs.dispatchEvent('tab-change', { value, name, oldName: activeName, newName: name, option: item }, evnt)
421
+ } else {
422
+ $xeTabs.dispatchEvent('tab-change-fail', { value, name, oldName: activeName, newName: name, option: item }, evnt)
423
+ }
424
+ }).catch(() => {
425
+ $xeTabs.dispatchEvent('tab-change-fail', { value, name, oldName: activeName, newName: name, option: item }, evnt)
426
+ })
427
+ }
428
+ },
429
+ handleRefreshTabEvent (evnt: KeyboardEvent, item: VxeTabPaneDefines.TabConfig | VxeTabPaneProps) {
430
+ const $xeTabs = this
431
+ const reactData = $xeTabs.reactData
432
+
433
+ evnt.stopPropagation()
434
+ const { activeName, cacheTabMaps } = reactData
435
+ const { name } = item
436
+ const refreshOpts = $xeTabs.computeRefreshOpts
437
+ const { queryMethod } = refreshOpts
438
+ const cacheItem = name ? cacheTabMaps[`${name}`] : null
439
+ if (cacheItem) {
440
+ if (cacheItem.loading) {
441
+ return
442
+ }
443
+ if (queryMethod) {
444
+ cacheItem.loading = true
445
+ Promise.resolve(
446
+ queryMethod({ $tabs: $xeTabs, value: activeName, name, option: item })
447
+ ).finally(() => {
448
+ cacheItem.loading = false
449
+ })
450
+ } else {
451
+ errLog('vxe.error.notFunc', ['refresh-config.queryMethod'])
452
+ }
453
+ }
454
+ },
455
+ handleCloseTabEvent (evnt: KeyboardEvent, item: VxeTabPaneDefines.TabConfig | VxeTabPaneProps, index: number, list: VxeTabsPropTypes.Options | VxeTabPaneDefines.TabConfig[]) {
456
+ const $xeTabs = this
457
+ const props = $xeTabs
458
+ const reactData = $xeTabs.reactData
459
+
460
+ evnt.stopPropagation()
461
+ const { activeName } = reactData
462
+ const closeOpts = $xeTabs.computeCloseOpts
463
+ const beforeMethod = closeOpts.beforeMethod || props.beforeCloseMethod || getConfig().tabs.beforeCloseMethod
464
+ const { name } = item
465
+ const value = activeName
466
+ let nextName = value
467
+ if (activeName === name) {
468
+ const nextItem = index < list.length - 1 ? list[index + 1] : list[index - 1]
469
+ nextName = nextItem ? nextItem.name : null
470
+ }
471
+ Promise.resolve(
472
+ !beforeMethod || beforeMethod({ $tabs: $xeTabs, value, name, nextName, option: item })
473
+ ).then(status => {
474
+ if (status) {
475
+ $xeTabs.dispatchEvent('tab-close', { value, name, nextName }, evnt)
476
+ } else {
477
+ $xeTabs.dispatchEvent('tab-close-fail', { value, name, nextName }, evnt)
478
+ }
479
+ }).catch(() => {
480
+ $xeTabs.dispatchEvent('tab-close-fail', { value, name, nextName }, evnt)
481
+ })
482
+ },
483
+ startScrollAnimation (offsetPos: number, offsetSize: number) {
484
+ const $xeTabs = this
485
+ const internalData = $xeTabs.internalData
486
+
487
+ const { slTimeout } = internalData
488
+ const lrPosition = $xeTabs.computeLrPosition
489
+ let offsetLeft = lrPosition ? 0 : offsetSize
490
+ let offsetTop = lrPosition ? offsetSize : 0
491
+ let scrollCount = 6
492
+ let delayNum = 35
493
+ if (slTimeout) {
494
+ clearTimeout(slTimeout)
495
+ internalData.slTimeout = undefined
496
+ }
497
+ const scrollAnimate = () => {
498
+ const headerWrapperEl = $xeTabs.$refs.refHeadWrapperElem as HTMLDivElement
499
+ if (scrollCount > 0) {
500
+ scrollCount--
501
+ if (headerWrapperEl) {
502
+ const { clientWidth, clientHeight, scrollWidth, scrollHeight, scrollLeft, scrollTop } = headerWrapperEl
503
+ if (lrPosition) {
504
+ offsetTop = Math.floor(offsetTop / 2)
505
+ if (offsetPos > 0) {
506
+ if (clientHeight + scrollTop < scrollHeight) {
507
+ headerWrapperEl.scrollTop += offsetTop
508
+ delayNum -= 4
509
+ internalData.slTimeout = setTimeout(scrollAnimate, delayNum)
510
+ }
511
+ } else {
512
+ if (scrollTop > 0) {
513
+ headerWrapperEl.scrollTop -= offsetTop
514
+ delayNum -= 4
515
+ internalData.slTimeout = setTimeout(scrollAnimate, delayNum)
516
+ }
517
+ }
518
+ } else {
519
+ offsetLeft = Math.floor(offsetLeft / 2)
520
+ if (offsetPos > 0) {
521
+ if (clientWidth + scrollLeft < scrollWidth) {
522
+ headerWrapperEl.scrollLeft += offsetLeft
523
+ delayNum -= 4
524
+ internalData.slTimeout = setTimeout(scrollAnimate, delayNum)
525
+ }
526
+ } else {
527
+ if (scrollLeft > 0) {
528
+ headerWrapperEl.scrollLeft -= offsetLeft
529
+ delayNum -= 4
530
+ internalData.slTimeout = setTimeout(scrollAnimate, delayNum)
531
+ }
532
+ }
533
+ }
534
+ $xeTabs.updateTabStyle()
535
+ }
536
+ }
537
+ }
538
+ scrollAnimate()
539
+ },
540
+ handleScrollToLeft (offsetPos: number) {
541
+ const $xeTabs = this
542
+
543
+ const lrPosition = $xeTabs.computeLrPosition
544
+ const headerWrapperEl = $xeTabs.$refs.refHeadWrapperElem as HTMLDivElement
545
+ if (headerWrapperEl) {
546
+ const { clientWidth, clientHeight } = headerWrapperEl
547
+ const offsetSize = Math.floor((lrPosition ? clientHeight : clientWidth) * 0.75)
548
+ $xeTabs.startScrollAnimation(offsetPos, offsetSize)
549
+ }
550
+ },
551
+ scrollLeftEvent () {
552
+ const $xeTabs = this
553
+
554
+ $xeTabs.handleScrollToLeft(-1)
555
+ },
556
+ scrollRightEvent () {
557
+ const $xeTabs = this
558
+
559
+ $xeTabs.handleScrollToLeft(1)
560
+ },
561
+ scrollToTab (name: VxeTabsPropTypes.ModelValue) {
562
+ const $xeTabs = this
563
+
564
+ const tabOptions = $xeTabs.computeTabOptions
565
+ const tabStaticOptions = $xeTabs.computeTabStaticOptions
566
+ const lrPosition = $xeTabs.computeLrPosition
567
+ return $xeTabs.$nextTick().then(() => {
568
+ const headerWrapperEl = $xeTabs.$refs.refHeadWrapperElem as HTMLDivElement
569
+ if (headerWrapperEl) {
570
+ const index = XEUtils.findIndexOf(tabStaticOptions.length ? tabStaticOptions : tabOptions, item => item.name === name)
571
+ if (index > -1) {
572
+ const { scrollLeft, scrollTop, clientWidth, clientHeight, children } = headerWrapperEl
573
+ const tabEl = children[index] as HTMLDivElement
574
+ if (tabEl) {
575
+ if (lrPosition) {
576
+ const tabOffsetTop = tabEl.offsetTop
577
+ const tabClientHeight = tabEl.clientHeight
578
+ // 如果顶部被挡
579
+ const overSize = (tabOffsetTop + tabClientHeight) - (scrollTop + clientHeight)
580
+ if (overSize > 0) {
581
+ headerWrapperEl.scrollTop += overSize
582
+ }
583
+ // 如果底部被挡,优先
584
+ if (tabOffsetTop < scrollTop) {
585
+ headerWrapperEl.scrollTop = tabOffsetTop
586
+ }
587
+ } else {
588
+ const tabOffsetLeft = tabEl.offsetLeft
589
+ const tabClientWidth = tabEl.clientWidth
590
+ // 如果右侧被挡
591
+ const overSize = (tabOffsetLeft + tabClientWidth) - (scrollLeft + clientWidth)
592
+ if (overSize > 0) {
593
+ headerWrapperEl.scrollLeft += overSize
594
+ }
595
+ // 如果左侧被挡,优先
596
+ if (tabOffsetLeft < scrollLeft) {
597
+ headerWrapperEl.scrollLeft = tabOffsetLeft
598
+ }
599
+ }
600
+ }
601
+ }
602
+ $xeTabs.updateTabStyle()
603
+ }
604
+ })
605
+ },
606
+ handlePrevNext (isNext: boolean) {
607
+ const $xeTabs = this
608
+ const reactData = $xeTabs.reactData
609
+
610
+ const { activeName } = reactData
611
+ const tabOptions = $xeTabs.computeTabOptions
612
+ const tabStaticOptions = $xeTabs.computeTabStaticOptions
613
+ const list = tabStaticOptions.length ? tabStaticOptions : tabOptions
614
+ const index = XEUtils.findIndexOf(list, item => item.name === activeName)
615
+ if (index > -1) {
616
+ let item: VxeTabPaneProps | null = null
617
+ if (isNext) {
618
+ if (index < list.length - 1) {
619
+ item = list[index + 1]
620
+ }
621
+ } else {
622
+ if (index > 0) {
623
+ item = list[index - 1]
624
+ }
625
+ }
626
+ if (item) {
627
+ const name = item.name
628
+ const value = name
629
+ reactData.activeName = name
630
+ $xeTabs.emitModel(value)
631
+ $xeTabs.addInitName(name, null)
632
+ }
633
+ }
634
+ return $xeTabs.$nextTick()
635
+ },
636
+
637
+ //
638
+ // Render
639
+ //
640
+ renderTabHeader (h: CreateElement, tabList: VxeTabsPropTypes.Options | VxeTabPaneDefines.TabConfig[]) {
641
+ const $xeTabs = this
642
+ const props = $xeTabs
643
+ const slots = $xeTabs.$scopedSlots
644
+ const reactData = $xeTabs.reactData
645
+
646
+ const { titleWidth: allTitleWidth, titleAlign: allTitleAlign, showClose, closeConfig, refreshConfig } = props
647
+ const { activeName, scrollbarWidth, scrollbarHeight, isTabOver, cacheTabMaps } = reactData
648
+ const tabType = $xeTabs.computeTabType
649
+ const tabPosition = $xeTabs.computeTabPosition
650
+ const lrPosition = $xeTabs.computeLrPosition
651
+ const lineStyle = $xeTabs.computeLineStyle
652
+ const tabPrefixSlot = slots.tabPrefix || slots['tab-prefix'] || slots.prefix
653
+ const tabSuffixSlot = slots.tabSuffix || slots['tab-suffix'] || slots.suffix || slots.extra
654
+ const closeOpts = $xeTabs.computeCloseOpts
655
+ const closeVisibleMethod = closeOpts.visibleMethod
656
+ const refreshOpts = $xeTabs.computeRefreshOpts
657
+ const refreshVisibleMethod = refreshOpts.visibleMethod
658
+
659
+ return h('div', {
660
+ key: 'th',
661
+ class: ['vxe-tabs-header', `type--${tabType}`, `pos--${tabPosition}`]
662
+ }, [
663
+ tabPrefixSlot
664
+ ? h('div', {
665
+ class: ['vxe-tabs-header--prefix', `type--${tabType}`, `pos--${tabPosition}`]
666
+ }, $xeTabs.callSlot(tabPrefixSlot, { name: activeName }, h))
667
+ : renderEmptyElement($xeTabs),
668
+ isTabOver
669
+ ? h('div', {
670
+ ref: 'refHeadPrevElem',
671
+ class: ['vxe-tabs-header--bar vxe-tabs-header--prev-bar', `type--${tabType}`, `pos--${tabPosition}`],
672
+ on: {
673
+ click: $xeTabs.scrollLeftEvent
674
+ }
675
+ }, [
676
+ h('span', {
677
+ class: lrPosition ? getIcon().TABS_TAB_BUTTON_TOP : getIcon().TABS_TAB_BUTTON_LEFT
678
+ })
679
+ ])
680
+ : renderEmptyElement($xeTabs),
681
+ h('div', {
682
+ class: ['vxe-tabs-header--wrapper', `type--${tabType}`, `pos--${tabPosition}`]
683
+ }, [
684
+ h('div', {
685
+ ref: 'refHeadWrapperElem',
686
+ class: 'vxe-tabs-header--item-wrapper',
687
+ style: lrPosition
688
+ ? {
689
+ marginRight: `-${scrollbarWidth + scrollbarOffsetSize}px`,
690
+ paddingRight: `${scrollbarOffsetSize}px`
691
+ }
692
+ : {
693
+ marginBottom: `-${scrollbarHeight + scrollbarOffsetSize}px`,
694
+ paddingBottom: `${scrollbarOffsetSize}px`
695
+ },
696
+ on: {
697
+ scroll: $xeTabs.checkScrolling
698
+ }
699
+ }, tabList.map((item, index) => {
700
+ const { title, titleWidth, titleAlign, icon, name } = item
701
+ const itemSlots = item.slots || {}
702
+ const titleSlot = itemSlots.title || itemSlots.tab
703
+ const titlePrefixSlot = itemSlots.titlePrefix || (itemSlots as any)['title-prefix']
704
+ const titleSuffixSlot = itemSlots.titleSuffix || (itemSlots as any)['title-suffix']
705
+ const itemWidth = titleWidth || allTitleWidth
706
+ const itemAlign = titleAlign || allTitleAlign
707
+ const params = { $tabs: $xeTabs, value: activeName, name, option: item }
708
+ const isActive = activeName === name
709
+ const cacheItem = name ? cacheTabMaps[`${name}`] : null
710
+ const isLoading = cacheItem ? cacheItem.loading : false
711
+ return h('div', {
712
+ key: `${name}`,
713
+ class: ['vxe-tabs-header--item', `type--${tabType}`, `pos--${tabPosition}`, itemAlign ? `align--${itemAlign}` : '', {
714
+ 'is--active': isActive
715
+ }],
716
+ style: itemWidth
717
+ ? {
718
+ width: toCssUnit(itemWidth)
719
+ }
720
+ : undefined,
721
+ on: {
722
+ click (evnt: KeyboardEvent) {
723
+ $xeTabs.clickEvent(evnt, item)
724
+ }
725
+ }
726
+ }, [
727
+ h('div', {
728
+ class: 'vxe-tabs-header--item-inner'
729
+ }, [
730
+ h('div', {
731
+ class: 'vxe-tabs-header--item-content'
732
+ }, [
733
+ icon
734
+ ? h('span', {
735
+ class: 'vxe-tabs-header--item-icon'
736
+ }, [
737
+ h('i', {
738
+ class: icon
739
+ })
740
+ ])
741
+ : renderEmptyElement($xeTabs),
742
+ titlePrefixSlot
743
+ ? h('span', {
744
+ class: 'vxe-tabs-header--item-prefix'
745
+ }, $xeTabs.callSlot(titlePrefixSlot, { name, title }, h))
746
+ : renderEmptyElement($xeTabs),
747
+ h('span', {
748
+ class: 'vxe-tabs-header--item-name'
749
+ }, titleSlot ? $xeTabs.callSlot(titleSlot, { name, title }, h) : `${title}`),
750
+ titleSuffixSlot
751
+ ? h('span', {
752
+ class: 'vxe-tabs-header--item-suffix'
753
+ }, $xeTabs.callSlot(titleSuffixSlot, { name, title }, h))
754
+ : renderEmptyElement($xeTabs)
755
+ ]),
756
+ (isEnableConf(refreshConfig) || refreshOpts.enabled) && (refreshVisibleMethod ? refreshVisibleMethod(params) : true)
757
+ ? h('div', {
758
+ class: ['vxe-tabs-header--refresh-btn', {
759
+ 'is--active': isActive,
760
+ 'is--loading': isLoading,
761
+ 'is--disabled': isLoading
762
+ }],
763
+ on: {
764
+ click (evnt: KeyboardEvent) {
765
+ $xeTabs.handleRefreshTabEvent(evnt, item)
766
+ }
767
+ }
768
+ }, [
769
+ h('i', {
770
+ class: isLoading ? getIcon().TABS_TAB_REFRESH_LOADING : getIcon().TABS_TAB_REFRESH
771
+ })
772
+ ])
773
+ : renderEmptyElement($xeTabs),
774
+ (showClose || (isEnableConf(closeConfig) || closeOpts.enabled)) && (!closeVisibleMethod || closeVisibleMethod(params))
775
+ ? h('div', {
776
+ class: ['vxe-tabs-header--close-btn', {
777
+ 'is--active': isActive
778
+ }],
779
+ on: {
780
+ click (evnt: KeyboardEvent) {
781
+ $xeTabs.handleCloseTabEvent(evnt, item, index, tabList)
782
+ }
783
+ }
784
+ }, [
785
+ h('i', {
786
+ class: getIcon().TABS_TAB_CLOSE
787
+ })
788
+ ])
789
+ : renderEmptyElement($xeTabs)
790
+ ])
791
+ ])
792
+ }).concat([
793
+ h('span', {
794
+ key: 'line',
795
+ class: ['vxe-tabs-header--active-line', `type--${tabType}`, `pos--${tabPosition}`],
796
+ style: lineStyle
797
+ })
798
+ ]))
799
+ ]),
800
+ isTabOver
801
+ ? h('div', {
802
+ ref: 'refHeadNextElem',
803
+ class: ['vxe-tabs-header--bar vxe-tabs-header--next-bar', `type--${tabType}`, `pos--${tabPosition}`],
804
+ on: {
805
+ click: $xeTabs.scrollRightEvent
806
+ }
807
+ }, [
808
+ h('span', {
809
+ class: lrPosition ? getIcon().TABS_TAB_BUTTON_BOTTOM : getIcon().TABS_TAB_BUTTON_RIGHT
810
+ })
811
+ ])
812
+ : renderEmptyElement($xeTabs),
813
+ tabSuffixSlot
814
+ ? h('div', {
815
+ class: ['vxe-tabs-header--suffix', `type--${tabType}`, `pos--${tabPosition}`]
816
+ }, $xeTabs.callSlot(tabSuffixSlot, { name: activeName }, h))
817
+ : renderEmptyElement($xeTabs)
818
+ ])
819
+ },
820
+ renderTabPane (h: CreateElement, item: VxeTabPaneProps | VxeTabPaneDefines.TabConfig) {
821
+ const $xeTabs = this
822
+ const reactData = $xeTabs.reactData
823
+
824
+ const { initNames, activeName } = reactData
825
+ const { name, slots } = item
826
+ const defaultSlot = slots ? slots.default : null
827
+ return name && initNames.includes(name)
828
+ ? h('div', {
829
+ key: `${name}`,
830
+ class: ['vxe-tabs-pane--item', {
831
+ 'is--visible': activeName === name
832
+ }]
833
+ }, defaultSlot ? $xeTabs.callSlot(defaultSlot, { name }, h) : [])
834
+ : renderEmptyElement($xeTabs)
835
+ },
836
+ renderTabContent (h: CreateElement, tabList: VxeTabsPropTypes.Options | VxeTabPaneDefines.TabConfig[]) {
837
+ const $xeTabs = this
838
+ const props = $xeTabs
839
+ const reactData = $xeTabs.reactData
840
+
841
+ const { destroyOnClose } = props
842
+ const { activeName } = reactData
843
+ if (destroyOnClose) {
844
+ const activeTab = tabList.find(item => item.name === activeName)
845
+ return [activeTab ? $xeTabs.renderTabPane(h, activeTab) : renderEmptyElement($xeTabs)]
846
+ }
847
+ return tabList.map((item) => $xeTabs.renderTabPane(h, item))
848
+ },
849
+ rendetTabBody (h: CreateElement, tabList: VxeTabsPropTypes.Options | VxeTabPaneDefines.TabConfig[]) {
850
+ const $xeTabs = this
851
+ const props = $xeTabs
852
+ const slots = $xeTabs.$scopedSlots
853
+ const reactData = $xeTabs.reactData
854
+
855
+ const { height, padding, showBody } = props
856
+ const { activeName, cacheTabMaps } = reactData
857
+ const vSize = $xeTabs.computeSize
858
+ const tabType = $xeTabs.computeTabType
859
+ const tabPosition = $xeTabs.computeTabPosition
860
+ const refreshOpts = $xeTabs.computeRefreshOpts
861
+ const { showLoading } = refreshOpts
862
+ const headerpSlot = slots.header
863
+ const footerSlot = slots.footer
864
+ if (!showBody) {
865
+ return renderEmptyElement($xeTabs)
866
+ }
867
+ const cacheItem = activeName ? cacheTabMaps[`${activeName}`] : null
868
+ const isLoading = cacheItem ? cacheItem.loading : false
869
+ const defParams = { name: activeName }
870
+ return h('div', {
871
+ key: 'tb',
872
+ class: ['vxe-tabs-pane--wrapper', `type--${tabType}`, `pos--${tabPosition}`, {
873
+ 'is--content': showBody
874
+ }]
875
+ }, [
876
+ headerpSlot
877
+ ? h('div', {
878
+ class: 'vxe-tabs-pane--header'
879
+ }, $xeTabs.callSlot(headerpSlot, defParams, h))
880
+ : renderEmptyElement($xeTabs),
881
+ h('div', {
882
+ class: ['vxe-tabs-pane--body', `type--${tabType}`, `pos--${tabPosition}`, {
883
+ [`size--${vSize}`]: vSize,
884
+ 'is--padding': padding,
885
+ 'is--height': height
886
+ }]
887
+ }, $xeTabs.renderTabContent(h, tabList)),
888
+ footerSlot
889
+ ? h('div', {
890
+ class: 'vxe-tabs-pane--footer'
891
+ }, $xeTabs.callSlot(footerSlot, defParams, h))
892
+ : renderEmptyElement($xeTabs),
893
+ showLoading && isLoading
894
+ ? renderEmptyElement($xeTabs)
895
+ : h(VxeLoadingComponent, {
896
+ class: 'vxe-tabs--loading',
897
+ props: {
898
+ value: isLoading
899
+ }
900
+ })
901
+ ])
902
+ },
903
+ renderVN (h: CreateElement): VNode {
904
+ const $xeTabs = this
905
+ const props = $xeTabs
906
+ const slots = $xeTabs.$scopedSlots
907
+ const reactData = $xeTabs.reactData
908
+
909
+ const { height, padding, trigger } = props
910
+ const { activeName } = reactData
911
+ const vSize = $xeTabs.computeSize
912
+ const tabOptions = $xeTabs.computeTabOptions
913
+ const tabStaticOptions = $xeTabs.computeTabStaticOptions
914
+ const tabType = $xeTabs.computeTabType
915
+ const tabPosition = $xeTabs.computeTabPosition
916
+ const wrapperStyle = $xeTabs.computeWrapperStyle
917
+ const defaultSlot = slots.default
918
+ const tabList = defaultSlot ? tabStaticOptions : tabOptions
919
+
920
+ const vns = [
921
+ h('div', {
922
+ key: 'ts',
923
+ class: 'vxe-tabs-slots'
924
+ }, defaultSlot ? defaultSlot({ name: activeName }) : [])
925
+ ]
926
+
927
+ if (tabPosition === 'right' || tabPosition === 'bottom') {
928
+ vns.push(
929
+ $xeTabs.rendetTabBody(h, tabList),
930
+ $xeTabs.renderTabHeader(h, tabList)
931
+ )
932
+ } else {
933
+ vns.push(
934
+ $xeTabs.renderTabHeader(h, tabList),
935
+ $xeTabs.rendetTabBody(h, tabList)
936
+ )
937
+ }
938
+
939
+ return h('div', {
940
+ ref: 'refElem',
941
+ class: ['vxe-tabs', `pos--${tabPosition}`, `vxe-tabs--${tabType}`, `trigger--${trigger === 'manual' ? 'trigger' : 'default'}`, {
942
+ [`size--${vSize}`]: vSize,
943
+ 'is--padding': padding,
944
+ 'is--height': height
945
+ }],
946
+ style: wrapperStyle
947
+ }, vns)
948
+ }
949
+ },
950
+ watch: {
951
+ position () {
952
+ const $xeTabs = this
953
+ const reactData = $xeTabs.reactData
954
+
955
+ reactData.resizeFlag++
956
+ },
957
+ value (val) {
958
+ const $xeTabs = this
959
+ const reactData = $xeTabs.reactData
960
+
961
+ $xeTabs.addInitName(val, null)
962
+ reactData.activeName = val
963
+ },
964
+ 'reactData.activeName' (val) {
965
+ const $xeTabs = this
966
+
967
+ $xeTabs.scrollToTab(val)
968
+ },
969
+ options () {
970
+ const $xeTabs = this
971
+ const props = $xeTabs
972
+ const reactData = $xeTabs.reactData
973
+
974
+ $xeTabs.initDefaultName(props.options)
975
+ reactData.resizeFlag++
976
+ },
977
+ 'reactData.staticTabs' () {
978
+ const $xeTabs = this
979
+ const reactData = $xeTabs.reactData
980
+
981
+ $xeTabs.initDefaultName(reactData.staticTabs)
982
+ reactData.resizeFlag++
983
+ },
984
+ computeParentTabsResizeFlag () {
985
+ const $xeTabs = this
986
+
987
+ $xeTabs.$nextTick(() => {
988
+ $xeTabs.updateTabStyle()
989
+ })
990
+ }
991
+ },
992
+ created () {
993
+ const $xeTabs = this
994
+ const props = $xeTabs
995
+ const reactData = $xeTabs.reactData
996
+
997
+ $xeTabs.addInitName(props.value, null)
998
+ $xeTabs.initDefaultName(reactData.staticTabs.length ? reactData.staticTabs : props.options)
999
+ },
1000
+ mounted () {
1001
+ const $xeTabs = this
1002
+
1003
+ $xeTabs.updateTabStyle()
1004
+ globalEvents.on($xeTabs, 'resize', $xeTabs.updateTabStyle)
1005
+ },
1006
+ beforeDestroy () {
1007
+ const $xeTabs = this
1008
+
1009
+ globalEvents.off($xeTabs, 'resize')
1010
+ },
1011
+ render (this: any, h) {
1012
+ return this.renderVN(h)
1013
+ }
1014
+ }) /* define-vxe-component end */