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,1032 +1,1032 @@
1
- import { CreateElement, PropType, VNode } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import XEUtils from 'xe-utils'
4
- import { getConfig, getIcon, createEvent, globalEvents, globalMixins, globalResize, renderEmptyElement } from '../../ui'
5
- import { getSlotVNs } from '../../ui/src/vn'
6
- import { toCssUnit, isScale, addClass, removeClass } from '../../ui/src/dom'
7
- import { getGlobalDefaultConfig } from '../../ui/src/utils'
8
- import { warnLog, errLog } from '../../ui/src/log'
9
-
10
- import type { SplitterReactData, VxeSplitterPropTypes, VxeComponentSizeType, SplitterInternalData, VxeSplitterEmits, VxeSplitterPanelPropTypes, ValueOf, VxeSplitterPanelProps, VxeSplitterDefines } from '../../../types'
11
-
12
- export default /* define-vxe-component start */ defineVxeComponent({
13
- name: 'VxeSplitter',
14
- mixins: [
15
- globalMixins.sizeMixin
16
- ],
17
- props: {
18
- width: [Number, String] as PropType<VxeSplitterPropTypes.Width>,
19
- height: [Number, String] as PropType<VxeSplitterPropTypes.Height>,
20
- vertical: {
21
- type: Boolean as PropType<VxeSplitterPropTypes.Vertical>,
22
- default: () => getConfig().splitter.vertical
23
- },
24
- border: {
25
- type: Boolean as PropType<VxeSplitterPropTypes.Border>,
26
- default: () => getConfig().splitter.border
27
- },
28
- padding: {
29
- type: Boolean as PropType<VxeSplitterPropTypes.Padding>,
30
- default: () => getConfig().splitter.padding
31
- },
32
- resize: {
33
- type: Boolean as PropType<VxeSplitterPropTypes.Resize>,
34
- default: () => getConfig().splitter.resize
35
- },
36
- items: Array as PropType<VxeSplitterPropTypes.Items>,
37
- itemConfig: Object as PropType<VxeSplitterPropTypes.ItemConfig>,
38
- barConfig: Object as PropType<VxeSplitterPropTypes.BarConfig>,
39
- resizeConfig: Object as PropType<VxeSplitterPropTypes.ResizeConfig>,
40
- actionConfig: Object as PropType<VxeSplitterPropTypes.ActionConfig>,
41
- size: {
42
- type: String as PropType<VxeSplitterPropTypes.Size>,
43
- default: () => getConfig().splitter.size || getConfig().size
44
- }
45
- },
46
- data () {
47
- const xID = XEUtils.uniqueId()
48
- const reactData: SplitterReactData = {
49
- staticItems: [],
50
- itemList: [],
51
- barWidth: 0,
52
- barHeight: 0
53
- }
54
- const internalData: SplitterInternalData = {
55
- wrapperWidth: 0,
56
- wrapperHeight: 0
57
- }
58
- return {
59
- xID,
60
- reactData,
61
- internalData,
62
- reFlag: 0
63
- }
64
- },
65
- provide () {
66
- const $xeSplitter = this
67
- return {
68
- $xeSplitter
69
- }
70
- },
71
- computed: {
72
- ...({} as {
73
- computeSize(): VxeComponentSizeType
74
- }),
75
- computeItemOpts () {
76
- const $xeSplitter = this
77
- const props = $xeSplitter
78
-
79
- return Object.assign({}, getConfig().splitter.itemConfig, props.itemConfig)
80
- },
81
- computeBarOpts () {
82
- const $xeSplitter = this
83
- const props = $xeSplitter
84
-
85
- return Object.assign({}, getConfig().splitter.barConfig, props.barConfig)
86
- },
87
- computeResizeOpts () {
88
- const $xeSplitter = this
89
- const props = $xeSplitter
90
-
91
- return Object.assign({}, getConfig().splitter.resizeConfig, props.resizeConfig)
92
- },
93
- computeActionOpts () {
94
- const $xeSplitter = this
95
- const props = $xeSplitter
96
-
97
- return Object.assign({}, getConfig().splitter.actionConfig, props.actionConfig)
98
- },
99
- computeIsFoldNext () {
100
- const $xeSplitter = this
101
-
102
- const actionOpts = $xeSplitter.computeActionOpts as VxeSplitterPropTypes.ActionConfig
103
- return actionOpts.direction === 'next'
104
- },
105
- computeVisibleItems () {
106
- const $xeSplitter = this
107
- const reactData = $xeSplitter.reactData as SplitterReactData
108
-
109
- return reactData.itemList.filter(item => item.isExpand)
110
- },
111
- computeAutoItems () {
112
- const $xeSplitter = this
113
- const props = $xeSplitter
114
- const reactData = ($xeSplitter as any).reactData as SplitterReactData
115
-
116
- const { vertical } = props
117
- const autoItems: VxeSplitterDefines.PaneConfig[] = []
118
- reactData.itemList.forEach(vertical
119
- ? item => {
120
- if (!item.height) {
121
- autoItems.push(item)
122
- }
123
- }
124
- : item => {
125
- if (!item.width) {
126
- autoItems.push(item)
127
- }
128
- })
129
- return {
130
- autoItems
131
- }
132
- },
133
- computeBarStyle () {
134
- const $xeSplitter = this
135
-
136
- const barOpts = $xeSplitter.computeBarOpts
137
- const { width, height } = barOpts
138
- const stys: Record<string, string | number> = {}
139
- if (height) {
140
- stys.height = toCssUnit(height)
141
- }
142
- if (width) {
143
- stys.width = toCssUnit(width)
144
- }
145
- return stys
146
- },
147
- computeSItemSize () {
148
- const $xeSplitter = this
149
- const reactData = $xeSplitter.reactData as SplitterReactData
150
-
151
- return reactData.staticItems.length
152
- }
153
- },
154
- watch: {
155
- items (val) {
156
- const $xeSplitter = this
157
-
158
- $xeSplitter.loadItem(val || [])
159
- },
160
- computeSItemSize () {
161
- const $xeSplitter = this
162
- const props = $xeSplitter
163
- const reactData = $xeSplitter.reactData
164
-
165
- const actionOpts = $xeSplitter.computeActionOpts
166
- const { showPrevButton, showNextButton } = actionOpts
167
- if (props.items && props.items.length) {
168
- errLog('vxe.error.errConflicts', ['<vxe-splitter-panel ...>', 'items'])
169
- }
170
- reactData.itemList = reactData.staticItems || []
171
- if ((showPrevButton || showNextButton) && reactData.itemList.length > 2) {
172
- errLog('vxe.error.modelConflicts', ['[splitter] action-config.showPrevButton | action-config.showNextButton', '<vxe-splitter-panel ...> Only supports 2 panel'])
173
- }
174
- reactData.itemList.forEach(item => {
175
- if (item.showAction) {
176
- warnLog('vxe.error.removeProp', ['[splitter] show-action'])
177
- }
178
- })
179
- $xeSplitter.recalculate()
180
- }
181
- },
182
- methods: {
183
- //
184
- // Method
185
- //
186
- dispatchEvent (type: ValueOf<VxeSplitterEmits>, params: Record<string, any>, evnt: Event | null) {
187
- const $xeSplitter = this
188
- $xeSplitter.$emit(type, createEvent(evnt, { $splitter: $xeSplitter }, params))
189
- },
190
- callSlot (slotFunc: any, params: any) {
191
- const $xeSplitter = this
192
- const slots = $xeSplitter.$scopedSlots
193
-
194
- if (slotFunc) {
195
- if (XEUtils.isString(slotFunc)) {
196
- slotFunc = slots[slotFunc] || null
197
- }
198
- if (XEUtils.isFunction(slotFunc)) {
199
- return getSlotVNs(slotFunc(params))
200
- }
201
- }
202
- return []
203
- },
204
- reset () {
205
- const $xeSplitter = this
206
- const reactData = $xeSplitter.reactData
207
-
208
- const { itemList } = reactData
209
- itemList.forEach(item => {
210
- item.isExpand = true
211
- item.foldHeight = 0
212
- item.foldWidth = 0
213
- item.resizeHeight = 0
214
- item.resizeWidth = 0
215
- })
216
- return $xeSplitter.$nextTick()
217
- },
218
- handleLoadItem (list: VxeSplitterPanelProps[], isReset: boolean) {
219
- const $xeSplitter = this
220
- const slots = $xeSplitter.$scopedSlots
221
- const reactData = $xeSplitter.reactData
222
-
223
- const { staticItems } = reactData
224
- const itemDef = {
225
- isExpand: true,
226
- renderWidth: 0,
227
- resizeWidth: 0,
228
- foldWidth: 0,
229
- renderHeight: 0,
230
- resizeHeight: 0,
231
- foldHeight: 0
232
- }
233
- reactData.itemList = list.map(item => {
234
- if (item.slots) {
235
- XEUtils.each(item.slots, (func) => {
236
- if (!XEUtils.isFunction(func)) {
237
- if (!slots[func]) {
238
- errLog('vxe.error.notSlot', [`[splitter] ${func}`])
239
- }
240
- }
241
- })
242
- }
243
- return Object.assign({}, isReset ? null : itemDef, item, isReset ? itemDef : null, {
244
- id: XEUtils.uniqueId()
245
- })
246
- })
247
- if (staticItems.length) {
248
- errLog('vxe.error.errConflicts', ['<vxe-splitter-panel ...>', 'items'])
249
- }
250
- return $xeSplitter.recalculate()
251
- },
252
- loadItem (list: VxeSplitterPanelProps[]) {
253
- const $xeSplitter = this
254
-
255
- return $xeSplitter.handleLoadItem(list || [], false)
256
- },
257
- reloadItem (list: VxeSplitterPanelProps[]) {
258
- const $xeSplitter = this
259
-
260
- return $xeSplitter.handleLoadItem(list || [], true)
261
- },
262
- handleItemByName (name: VxeSplitterPanelPropTypes.Name) {
263
- const $xeSplitter = this
264
- const reactData = $xeSplitter.reactData
265
-
266
- const { itemList } = reactData
267
- let index = -1
268
- let currItem: VxeSplitterDefines.PaneConfig | null = null
269
- let prevItem: VxeSplitterDefines.PaneConfig | null = null
270
- let nextItem: VxeSplitterDefines.PaneConfig | null = null
271
- for (let i = 0; i < itemList.length; i++) {
272
- const item = itemList[i]
273
- if (item.name === name) {
274
- index = i
275
- currItem = item
276
- prevItem = itemList[i - 1] || null
277
- nextItem = itemList[i + 1] || null
278
- break
279
- }
280
- }
281
- return {
282
- index,
283
- currItem,
284
- prevItem,
285
- nextItem
286
- }
287
- },
288
- setItemExpand (name: VxeSplitterPanelPropTypes.Name, expanded: boolean) {
289
- const $xeSplitter = this
290
-
291
- const restItem = $xeSplitter.handleItemByName(name)
292
- if (restItem) {
293
- const { currItem, prevItem, nextItem } = restItem
294
- if (currItem) {
295
- if (expanded ? !currItem.isExpand : currItem.isExpand) {
296
- if (nextItem) {
297
- if (nextItem.isExpand) {
298
- $xeSplitter.handleItemActionEvent(null, currItem, nextItem, false)
299
- }
300
- } else if (prevItem) {
301
- if (prevItem.isExpand) {
302
- $xeSplitter.handleItemActionEvent(null, prevItem, currItem, true)
303
- }
304
- }
305
- }
306
- }
307
- }
308
- return $xeSplitter.$nextTick()
309
- },
310
- toggleItemExpand (name: VxeSplitterPanelPropTypes.Name) {
311
- const $xeSplitter = this
312
-
313
- const restItem = $xeSplitter.handleItemByName(name)
314
- if (restItem) {
315
- const { currItem } = restItem
316
- if (currItem) {
317
- return $xeSplitter.setItemExpand(name, !currItem.isExpand)
318
- }
319
- }
320
- return $xeSplitter.$nextTick()
321
- },
322
- getItemVisible (name: VxeSplitterPanelPropTypes.Name) {
323
- const $xeSplitter = this
324
-
325
- const restItem = $xeSplitter.handleItemByName(name)
326
- if (restItem) {
327
- const { currItem } = restItem
328
- if (currItem) {
329
- return $xeSplitter.setItemExpand(name, !currItem.isExpand)
330
- }
331
- }
332
- return false
333
- },
334
- recalculate () {
335
- const $xeSplitter = this
336
- const props = $xeSplitter
337
- const reactData = $xeSplitter.reactData
338
- const internalData = $xeSplitter.internalData
339
-
340
- return $xeSplitter.$nextTick().then(() => {
341
- const { vertical } = props
342
- const { itemList } = reactData
343
- const el = $xeSplitter.$refs.refElem as HTMLDivElement
344
- const barInfoElem = $xeSplitter.$refs.refBarInfoElem as HTMLDivElement
345
- if (!el) {
346
- return
347
- }
348
- const wWidth = el.clientWidth
349
- const wHeight = el.clientHeight
350
- if (!wWidth || !wHeight) {
351
- return
352
- }
353
- if (barInfoElem) {
354
- reactData.barWidth = barInfoElem.offsetWidth
355
- reactData.barHeight = barInfoElem.offsetHeight
356
- }
357
- const contentWidth = wWidth - (vertical ? 0 : reactData.barWidth * (itemList.length - 1))
358
- const contentHeight = wHeight - (vertical ? reactData.barHeight * (itemList.length - 1) : 0)
359
- const itemOpts = $xeSplitter.computeItemOpts
360
- const allMinWidth = XEUtils.toNumber(itemOpts.minWidth)
361
- const allMinHeight = XEUtils.toNumber(itemOpts.minHeight)
362
- const residueItems: VxeSplitterDefines.PaneConfig[] = []
363
- if (vertical) {
364
- let countHeight = 0
365
- itemList.forEach(item => {
366
- const { height } = item
367
- let itemHeight = 0
368
- if (height) {
369
- if (isScale(height)) {
370
- itemHeight = contentHeight * XEUtils.toNumber(height) / 100
371
- } else {
372
- itemHeight = XEUtils.toNumber(height)
373
- }
374
- item.renderHeight = itemHeight
375
- } else {
376
- residueItems.push(item)
377
- }
378
- countHeight += itemHeight
379
- })
380
- if (residueItems.length) {
381
- const reMeanHeight = (contentHeight - countHeight) / residueItems.length
382
- residueItems.forEach(item => {
383
- item.renderHeight = Math.max(XEUtils.toNumber(getGlobalDefaultConfig(item.minHeight, allMinHeight)), reMeanHeight)
384
- })
385
- }
386
- } else {
387
- let countWidth = 0
388
- itemList.forEach(item => {
389
- const { width } = item
390
- let itemWidth = 0
391
- if (width) {
392
- if (isScale(width)) {
393
- itemWidth = contentWidth * XEUtils.toNumber(width) / 100
394
- } else {
395
- itemWidth = XEUtils.toNumber(width)
396
- }
397
- item.renderWidth = itemWidth
398
- } else {
399
- residueItems.push(item)
400
- }
401
- countWidth += itemWidth
402
- })
403
- if (residueItems.length) {
404
- const reMeanWidth = (contentWidth - countWidth) / residueItems.length
405
- residueItems.forEach(item => {
406
- item.renderWidth = Math.max(XEUtils.toNumber(getGlobalDefaultConfig(item.minWidth, allMinWidth)), reMeanWidth)
407
- })
408
- }
409
- }
410
- internalData.wrapperWidth = contentWidth
411
- internalData.wrapperHeight = contentHeight
412
- })
413
- },
414
- dragEvent (evnt: MouseEvent) {
415
- const $xeSplitter = this
416
- const props = $xeSplitter
417
- const reactData = $xeSplitter.reactData
418
-
419
- const { resize, vertical } = props
420
- const { itemList } = reactData
421
- if (!resize) {
422
- return
423
- }
424
- evnt.preventDefault()
425
- const barEl = evnt.currentTarget as HTMLDivElement
426
- const handleEl = barEl.parentElement as HTMLDivElement
427
- const el = $xeSplitter.$refs.refElem as HTMLDivElement
428
- if (!el) {
429
- return
430
- }
431
- const prevEl = handleEl.previousElementSibling as HTMLDivElement
432
- const nextEl = handleEl.nextElementSibling as HTMLDivElement
433
- if (!prevEl || !nextEl) {
434
- return
435
- }
436
- const prevId = prevEl.getAttribute('itemid')
437
- const nextId = nextEl.getAttribute('itemid')
438
- const prevItem = itemList.find(item => item.id === prevId)
439
- const nextItem = itemList.find(item => item.id === nextId)
440
- if (!prevItem || !nextItem) {
441
- return
442
- }
443
- const containerRect = el.getBoundingClientRect()
444
- const barRect = barEl.getBoundingClientRect()
445
- const rsSplitterLineEl = $xeSplitter.$refs.refResizableSplitterTip as HTMLDivElement
446
- const rsSplitterTipEl = rsSplitterLineEl ? rsSplitterLineEl.children[0] as HTMLDivElement : null
447
- const itemOpts = $xeSplitter.computeItemOpts
448
- const resizeOpts = $xeSplitter.computeResizeOpts
449
- const { immediate } = resizeOpts
450
- const allMinWidth = XEUtils.toNumber(itemOpts.minWidth)
451
- const allMinHeight = XEUtils.toNumber(itemOpts.minHeight)
452
-
453
- const barOffsetX = Math.ceil(barRect.width - (evnt.clientX - barRect.left))
454
- const barOffsetY = Math.ceil(evnt.clientY - barRect.top)
455
-
456
- const prevWidth = prevEl.offsetWidth
457
- const nextWidth = nextEl.offsetWidth
458
- const prevMinWidth = XEUtils.toNumber(prevItem ? getGlobalDefaultConfig(prevItem.minWidth, allMinWidth) : allMinWidth)
459
- const nextMinWidth = XEUtils.toNumber(nextItem ? getGlobalDefaultConfig(nextItem.minWidth, allMinWidth) : allMinWidth)
460
- const minOffsetLeft = prevEl.offsetLeft + prevMinWidth - barOffsetX
461
- const maxOffsetLeft = nextEl.offsetLeft + nextEl.offsetWidth - nextMinWidth - barOffsetX
462
- const startOffsetLeft = evnt.clientX - containerRect.left
463
- let targetOffsetWidth = -1
464
- let prevResizeWidth = 0
465
- let nextResizeWidth = 0
466
- let offsetLeft = startOffsetLeft
467
-
468
- const prevHeight = prevEl.offsetHeight
469
- const nextHeight = nextEl.offsetHeight
470
- const prevMinHeight = XEUtils.toNumber(prevItem ? getGlobalDefaultConfig(prevItem.minHeight, allMinHeight) : allMinHeight)
471
- const nextMinHeight = XEUtils.toNumber(nextItem ? getGlobalDefaultConfig(nextItem.minHeight, allMinHeight) : allMinHeight)
472
- const minOffsetTop = prevEl.offsetTop + prevMinHeight + barOffsetY
473
- const maxOffsetTop = nextEl.offsetTop + nextEl.offsetHeight - nextMinHeight + barOffsetY
474
- const startOffsetTop = evnt.clientY - containerRect.top
475
- let targetOffsetHeight = -1
476
- let prevResizeHeight = 0
477
- let nextResizeHeight = 0
478
- let offsetTop = startOffsetTop
479
-
480
- const handleReStyle = (evnt: MouseEvent) => {
481
- if (!rsSplitterLineEl) {
482
- return
483
- }
484
- const rsNumPrevEl = rsSplitterTipEl ? rsSplitterTipEl.children[0] as HTMLDivElement : null
485
- const rsNumNextEl = rsSplitterTipEl ? rsSplitterTipEl.children[1] as HTMLDivElement : null
486
- if (vertical) {
487
- let tipWidth = 0
488
- if (rsNumPrevEl) {
489
- if (targetOffsetHeight < 0) {
490
- rsNumPrevEl.style.display = 'none'
491
- } else {
492
- rsNumPrevEl.textContent = `${Math.floor(prevResizeHeight)}px`
493
- rsNumPrevEl.style.display = 'block'
494
- tipWidth = rsNumPrevEl.offsetWidth
495
- }
496
- }
497
- if (rsNumNextEl) {
498
- if (targetOffsetHeight < 0) {
499
- rsNumNextEl.textContent = `${Math.floor(nextResizeHeight)}px`
500
- rsNumNextEl.style.display = 'block'
501
- tipWidth = rsNumNextEl.offsetWidth
502
- } else {
503
- rsNumNextEl.style.display = 'none'
504
- }
505
- }
506
- let rsLeft = Math.max(1, evnt.clientX - containerRect.left - tipWidth / 2)
507
- if (rsLeft > containerRect.width - tipWidth - 1) {
508
- rsLeft = containerRect.width - tipWidth - 1
509
- }
510
- rsSplitterLineEl.style.left = '0'
511
- rsSplitterLineEl.style.top = `${offsetTop}px`
512
- if (rsSplitterTipEl) {
513
- rsSplitterTipEl.style.left = `${rsLeft}px`
514
- }
515
- } else {
516
- let tipHeight = 0
517
- if (rsNumPrevEl) {
518
- if (targetOffsetWidth < 0) {
519
- rsNumPrevEl.style.display = 'none'
520
- } else {
521
- rsNumPrevEl.textContent = `${Math.floor(prevResizeWidth)}px`
522
- rsNumPrevEl.style.display = 'block'
523
- tipHeight = rsNumPrevEl.offsetHeight
524
- }
525
- }
526
- if (rsNumNextEl) {
527
- if (targetOffsetWidth < 0) {
528
- rsNumNextEl.textContent = `${Math.floor(nextResizeWidth)}px`
529
- rsNumNextEl.style.display = 'block'
530
- tipHeight = rsNumNextEl.offsetHeight
531
- } else {
532
- rsNumNextEl.style.display = 'none'
533
- }
534
- }
535
- let rsTop = Math.max(1, evnt.clientY - containerRect.top - tipHeight / 2)
536
- if (rsTop > containerRect.height - tipHeight - 1) {
537
- rsTop = containerRect.height - tipHeight - 1
538
- }
539
- rsSplitterLineEl.style.top = '0'
540
- rsSplitterLineEl.style.left = `${offsetLeft}px`
541
- if (rsSplitterTipEl) {
542
- rsSplitterTipEl.style.top = `${rsTop}px`
543
- }
544
- }
545
- }
546
-
547
- const handleUpdate = () => {
548
- if (vertical) {
549
- prevItem.resizeHeight = prevResizeHeight
550
- nextItem.resizeHeight = nextResizeHeight
551
- } else {
552
- prevItem.resizeWidth = prevResizeWidth
553
- nextItem.resizeWidth = nextResizeWidth
554
- }
555
- }
556
-
557
- const handleDrag = (evnt: MouseEvent) => {
558
- if (vertical) {
559
- offsetTop = evnt.clientY - containerRect.top
560
- if (offsetTop < minOffsetTop) {
561
- offsetTop = minOffsetTop
562
- }
563
- if (offsetTop > maxOffsetTop) {
564
- offsetTop = maxOffsetTop
565
- }
566
- targetOffsetHeight = offsetTop - startOffsetTop
567
- prevResizeHeight = prevHeight + targetOffsetHeight
568
- nextResizeHeight = nextHeight - targetOffsetHeight
569
- } else {
570
- offsetLeft = evnt.clientX - containerRect.left
571
- if (offsetLeft < minOffsetLeft) {
572
- offsetLeft = minOffsetLeft
573
- }
574
- if (offsetLeft > maxOffsetLeft) {
575
- offsetLeft = maxOffsetLeft
576
- }
577
- targetOffsetWidth = offsetLeft - startOffsetLeft
578
- prevResizeWidth = prevWidth + targetOffsetWidth
579
- nextResizeWidth = nextWidth - targetOffsetWidth
580
- }
581
- if (immediate) {
582
- if (vertical) {
583
- prevEl.style.height = toCssUnit(prevResizeHeight)
584
- nextEl.style.height = toCssUnit(nextResizeHeight)
585
- } else {
586
- prevEl.style.width = toCssUnit(prevResizeWidth)
587
- nextEl.style.width = toCssUnit(nextResizeWidth)
588
- }
589
- }
590
- if (rsSplitterLineEl) {
591
- handleReStyle(evnt)
592
- }
593
- $xeSplitter.dispatchEvent('resize-drag', { prevItem, nextItem, offsetHeight: targetOffsetHeight, offsetWidth: targetOffsetWidth }, evnt)
594
- }
595
-
596
- document.onmousemove = (evnt) => {
597
- evnt.preventDefault()
598
- handleDrag(evnt)
599
- }
600
- document.onmouseup = (evnt) => {
601
- document.onmousemove = null
602
- document.onmouseup = null
603
- if (rsSplitterLineEl) {
604
- rsSplitterLineEl.style.display = ''
605
- }
606
- handleUpdate()
607
- removeClass(el, 'is--drag')
608
- $xeSplitter.dispatchEvent('resize-end', { prevItem, nextItem, offsetHeight: targetOffsetHeight, offsetWidth: targetOffsetWidth }, evnt)
609
- $xeSplitter.recalculate()
610
- }
611
-
612
- if (rsSplitterLineEl) {
613
- rsSplitterLineEl.style.display = 'block'
614
- handleReStyle(evnt)
615
- }
616
- handleDrag(evnt)
617
- addClass(el, 'is--drag')
618
- $xeSplitter.dispatchEvent('resize-start', { prevItem, nextItem }, evnt)
619
- },
620
- handleItemActionEvent (evnt: MouseEvent | null, prevItem: VxeSplitterDefines.PaneConfig, nextItem: VxeSplitterDefines.PaneConfig, isNext: boolean) {
621
- const $xeSplitter = this
622
- const props = $xeSplitter
623
-
624
- const { vertical } = props
625
- let expanded = false
626
- let item = prevItem
627
- if (isNext) {
628
- item = nextItem
629
- expanded = !nextItem.isExpand
630
- nextItem.isExpand = expanded
631
- } else {
632
- expanded = !prevItem.isExpand
633
- prevItem.isExpand = expanded
634
- }
635
- if (vertical) {
636
- if (prevItem.isExpand && nextItem.isExpand) {
637
- prevItem.foldHeight = 0
638
- nextItem.foldHeight = 0
639
- } else if (prevItem.isExpand) {
640
- nextItem.foldHeight = 0
641
- prevItem.foldHeight = (prevItem.resizeHeight || prevItem.renderHeight) + (nextItem.resizeHeight || nextItem.renderHeight)
642
- } else {
643
- prevItem.foldHeight = 0
644
- nextItem.foldHeight = (prevItem.resizeHeight || prevItem.renderHeight) + (nextItem.resizeHeight || nextItem.renderHeight)
645
- }
646
- } else {
647
- if (prevItem.isExpand && nextItem.isExpand) {
648
- prevItem.foldWidth = 0
649
- nextItem.foldWidth = 0
650
- } else if (prevItem.isExpand) {
651
- nextItem.foldWidth = 0
652
- prevItem.foldWidth = (prevItem.resizeWidth || prevItem.renderWidth) + (nextItem.resizeWidth || nextItem.renderWidth)
653
- } else {
654
- prevItem.foldWidth = 0
655
- nextItem.foldWidth = (prevItem.resizeWidth || prevItem.renderWidth) + (nextItem.resizeWidth || nextItem.renderWidth)
656
- }
657
- }
658
- if (evnt) {
659
- $xeSplitter.dispatchEvent('toggle-expand', { prevItem, nextItem, expanded, item }, evnt)
660
- }
661
- $xeSplitter.recalculate()
662
- },
663
- handlePrevActionDblclickEvent (evnt: MouseEvent) {
664
- const $xeSplitter = this
665
- const reactData = $xeSplitter.reactData
666
-
667
- const { itemList } = reactData
668
- const actionOpts = $xeSplitter.computeActionOpts
669
- const btnEl = evnt.currentTarget as HTMLDivElement
670
- const btnWrapperEl = btnEl.parentElement as HTMLDivElement
671
- const handleEl = btnWrapperEl.parentElement as HTMLDivElement
672
- const prevEl = handleEl.previousElementSibling as HTMLDivElement
673
- const prevId = prevEl.getAttribute('itemid')
674
- const prevItem = itemList.find(item => item.id === prevId)
675
- const nextEl = handleEl.nextElementSibling as HTMLDivElement
676
- const nextId = nextEl.getAttribute('itemid')
677
- const nextItem = itemList.find(item => item.id === nextId)
678
-
679
- if (actionOpts.trigger === 'dblclick') {
680
- if (prevItem && nextItem && nextItem.isExpand) {
681
- $xeSplitter.handleItemActionEvent(evnt, prevItem, nextItem, false)
682
- }
683
- }
684
- $xeSplitter.dispatchEvent('action-dblclick', { prevItem, nextItem }, evnt)
685
- },
686
- handlePrevActionClickEvent (evnt: MouseEvent) {
687
- const $xeSplitter = this
688
- const reactData = $xeSplitter.reactData
689
-
690
- const { itemList } = reactData
691
- const actionOpts = $xeSplitter.computeActionOpts
692
- const btnEl = evnt.currentTarget as HTMLDivElement
693
- const btnWrapperEl = btnEl.parentElement as HTMLDivElement
694
- const handleEl = btnWrapperEl.parentElement as HTMLDivElement
695
- const prevEl = handleEl.previousElementSibling as HTMLDivElement
696
- const prevId = prevEl.getAttribute('itemid')
697
- const prevItem = itemList.find(item => item.id === prevId)
698
- const nextEl = handleEl.nextElementSibling as HTMLDivElement
699
- const nextId = nextEl.getAttribute('itemid')
700
- const nextItem = itemList.find(item => item.id === nextId)
701
-
702
- if (actionOpts.trigger !== 'dblclick') {
703
- if (prevItem && nextItem && nextItem.isExpand) {
704
- $xeSplitter.handleItemActionEvent(evnt, prevItem, nextItem, false)
705
- }
706
- }
707
- $xeSplitter.dispatchEvent('action-click', { prevItem, nextItem }, evnt)
708
- },
709
- handleNextActionDblclickEvent (evnt: MouseEvent) {
710
- const $xeSplitter = this
711
- const reactData = $xeSplitter.reactData
712
-
713
- const { itemList } = reactData
714
- const actionOpts = $xeSplitter.computeActionOpts
715
- const btnEl = evnt.currentTarget as HTMLDivElement
716
- const btnWrapperEl = btnEl.parentElement as HTMLDivElement
717
- const handleEl = btnWrapperEl.parentElement as HTMLDivElement
718
- const prevEl = handleEl.previousElementSibling as HTMLDivElement
719
- const prevId = prevEl.getAttribute('itemid')
720
- const prevItem = itemList.find(item => item.id === prevId)
721
- const nextEl = handleEl.nextElementSibling as HTMLDivElement
722
- const nextId = nextEl.getAttribute('itemid')
723
- const nextItem = itemList.find(item => item.id === nextId)
724
-
725
- if (actionOpts.trigger === 'dblclick') {
726
- if (prevItem && nextItem && prevItem.isExpand) {
727
- $xeSplitter.handleItemActionEvent(evnt, prevItem, nextItem, true)
728
- }
729
- }
730
- $xeSplitter.dispatchEvent('action-dblclick', { prevItem, nextItem }, evnt)
731
- },
732
- handleNextActionClickEvent (evnt: MouseEvent) {
733
- const $xeSplitter = this
734
- const reactData = $xeSplitter.reactData
735
-
736
- const { itemList } = reactData
737
- const actionOpts = $xeSplitter.computeActionOpts
738
- const btnEl = evnt.currentTarget as HTMLDivElement
739
- const btnWrapperEl = btnEl.parentElement as HTMLDivElement
740
- const handleEl = btnWrapperEl.parentElement as HTMLDivElement
741
- const prevEl = handleEl.previousElementSibling as HTMLDivElement
742
- const prevId = prevEl.getAttribute('itemid')
743
- const prevItem = itemList.find(item => item.id === prevId)
744
- const nextEl = handleEl.nextElementSibling as HTMLDivElement
745
- const nextId = nextEl.getAttribute('itemid')
746
- const nextItem = itemList.find(item => item.id === nextId)
747
-
748
- if (actionOpts.trigger !== 'dblclick') {
749
- if (prevItem && nextItem && prevItem.isExpand) {
750
- $xeSplitter.handleItemActionEvent(evnt, prevItem, nextItem, true)
751
- }
752
- }
753
- $xeSplitter.dispatchEvent('action-click', { prevItem, nextItem }, evnt)
754
- },
755
- handleGlobalResizeEvent () {
756
- const $xeSplitter = this
757
-
758
- $xeSplitter.recalculate()
759
- },
760
- getActionIcon (prevItem: VxeSplitterDefines.PaneConfig, nextItem: VxeSplitterDefines.PaneConfig, isNext: boolean) {
761
- const $xeSplitter = this
762
- const props = $xeSplitter
763
-
764
- const { vertical } = props
765
- const topIcon = 'SPLIT_TOP_ACTION'
766
- const bottomIcon = 'SPLIT_BOTTOM_ACTION'
767
- const leftIcon = 'SPLIT_LEFT_ACTION'
768
- const rightIcon = 'SPLIT_RIGHT_ACTION'
769
- let iconName: 'SPLIT_TOP_ACTION' | 'SPLIT_BOTTOM_ACTION' | 'SPLIT_LEFT_ACTION' | 'SPLIT_RIGHT_ACTION' | '' = ''
770
- if (vertical) {
771
- if (isNext) {
772
- iconName = nextItem.isExpand ? bottomIcon : topIcon
773
- } else {
774
- iconName = prevItem.isExpand ? topIcon : bottomIcon
775
- }
776
- } else {
777
- if (isNext) {
778
- iconName = nextItem.isExpand ? rightIcon : leftIcon
779
- } else {
780
- iconName = prevItem.isExpand ? leftIcon : rightIcon
781
- }
782
- }
783
- if (iconName) {
784
- return getIcon()[iconName]
785
- }
786
- return ''
787
- },
788
-
789
- //
790
- // Render
791
- //
792
- renderHandleBar (h: CreateElement, prevItem: VxeSplitterDefines.PaneConfig, nextItem: VxeSplitterDefines.PaneConfig) {
793
- const $xeSplitter = this
794
- const props = $xeSplitter
795
- const reactData = $xeSplitter.reactData
796
-
797
- const { border, resize, vertical } = props
798
- const { itemList } = reactData
799
- const barStyle = $xeSplitter.computeBarStyle
800
- const actionOpts = $xeSplitter.computeActionOpts
801
- const { direction } = actionOpts
802
- const showPrevButton = XEUtils.isBoolean(actionOpts.showPrevButton) ? actionOpts.showPrevButton : (itemList.some(item => item.showAction))
803
- const showNextButton = XEUtils.isBoolean(actionOpts.showNextButton) ? actionOpts.showNextButton : (direction === 'next' && itemList.some(item => item.showAction))
804
- const resizeOpts = $xeSplitter.computeResizeOpts
805
- const { immediate } = resizeOpts
806
- return h('div', {
807
- class: ['vxe-splitter-panel-handle', vertical ? 'is--vertical' : 'is--horizontal', immediate ? 'is-resize--immediate' : 'is-resize--lazy', {
808
- 'is--resize': resize,
809
- 'is--border': border
810
- }]
811
- }, [
812
- h('div', {
813
- class: 'vxe-splitter-panel-handle-bar',
814
- style: barStyle,
815
- on: {
816
- mousedown: $xeSplitter.dragEvent
817
- }
818
- }),
819
- itemList.length === 2
820
- ? h('div', {
821
- class: 'vxe-splitter-panel-action-btn-wrapper'
822
- }, [
823
- showPrevButton && nextItem.isExpand
824
- ? h('div', {
825
- class: 'vxe-splitter-panel-action-btn',
826
- on: {
827
- dblclick: $xeSplitter.handlePrevActionDblclickEvent,
828
- click: $xeSplitter.handlePrevActionClickEvent
829
- }
830
- }, [
831
- h('i', {
832
- class: $xeSplitter.getActionIcon(prevItem, nextItem, false)
833
- })
834
- ])
835
- : renderEmptyElement($xeSplitter),
836
- showNextButton && prevItem.isExpand
837
- ? h('div', {
838
- class: 'vxe-splitter-panel-action-btn',
839
- on: {
840
- dblclick: $xeSplitter.handleNextActionDblclickEvent,
841
- click: $xeSplitter.handleNextActionClickEvent
842
- }
843
- }, [
844
- h('i', {
845
- class: $xeSplitter.getActionIcon(prevItem, nextItem, true)
846
- })
847
- ])
848
- : renderEmptyElement($xeSplitter)
849
- ])
850
- : renderEmptyElement($xeSplitter)
851
- ])
852
- },
853
- renderItems (h: CreateElement) {
854
- const $xeSplitter = this
855
- const props = $xeSplitter
856
- const reactData = $xeSplitter.reactData
857
-
858
- const { border, padding, resize, vertical } = props
859
- const { itemList } = reactData
860
- const vSize = $xeSplitter.computeSize
861
- const resizeOpts = $xeSplitter.computeResizeOpts
862
- const { immediate } = resizeOpts
863
- const visibleItems = $xeSplitter.computeVisibleItems
864
- const { autoItems } = $xeSplitter.computeAutoItems
865
- const itemVNs: VNode[] = []
866
- itemList.forEach((prevItem, index) => {
867
- const { id, name, slots, renderHeight, resizeHeight, foldHeight, renderWidth, resizeWidth, foldWidth, isExpand } = prevItem
868
- const nextItem = itemList[index + 1]
869
- const defaultSlot = slots ? slots.default : null
870
- const stys: Record<string, string | number> = {}
871
- let itemWidth = isExpand ? (foldWidth || resizeWidth || renderWidth) : 0
872
- let itemHeight = isExpand ? (foldHeight || resizeHeight || renderHeight) : 0
873
- // 至少存在一个自适应
874
- if (autoItems.length === 1) {
875
- if (vertical) {
876
- if (!prevItem.height) {
877
- itemHeight = 0
878
- }
879
- } else {
880
- if (!prevItem.width) {
881
- itemWidth = 0
882
- }
883
- }
884
- }
885
- let isFill = true
886
- if (vertical) {
887
- if (itemHeight && visibleItems.length > 1) {
888
- isFill = false
889
- stys.height = toCssUnit(itemHeight)
890
- }
891
- } else {
892
- if (itemWidth && visibleItems.length > 1) {
893
- isFill = false
894
- stys.width = toCssUnit(itemWidth)
895
- }
896
- }
897
-
898
- itemVNs.push(
899
- h('div', {
900
- attrs: {
901
- itemid: id
902
- },
903
- class: ['vxe-splitter-panel', vertical ? 'is--vertical' : 'is--horizontal', immediate ? 'is-resize--immediate' : 'is-resize--lazy', {
904
- [`size--${vSize}`]: vSize,
905
- 'is--resize': resize,
906
- 'is--padding': padding,
907
- 'is--border': border,
908
- 'is--height': itemHeight,
909
- 'is--width': itemWidth,
910
- 'is--visible': isExpand,
911
- 'is--hidden': !isExpand,
912
- 'is--fill': isExpand && isFill
913
- }],
914
- style: stys
915
- }, [
916
- h('div', {
917
- attrs: {
918
- itemid: id
919
- },
920
- class: 'vxe-splitter-panel--wrapper'
921
- }, [
922
- h('div', {
923
- class: 'vxe-splitter-panel--inner'
924
- }, defaultSlot ? $xeSplitter.callSlot(defaultSlot, { name, isExpand }) : [])
925
- ])
926
- ])
927
- )
928
-
929
- if (nextItem) {
930
- itemVNs.push($xeSplitter.renderHandleBar(h, prevItem, nextItem))
931
- }
932
- })
933
- return h('div', {
934
- class: 'vxe-splitter-wrapper'
935
- }, itemVNs)
936
- },
937
- renderVN (h: CreateElement): VNode {
938
- const $xeSplitter = this
939
- const props = $xeSplitter
940
- const slots = $xeSplitter.$scopedSlots
941
-
942
- const { vertical, width, height } = props
943
- const vSize = $xeSplitter.computeSize
944
- const resizeOpts = $xeSplitter.computeResizeOpts
945
- const { immediate, showTip } = resizeOpts
946
- const defaultSlot = slots.default
947
- const stys: Record<string, string | number> = {}
948
- if (height) {
949
- stys.height = toCssUnit(height)
950
- }
951
- if (width) {
952
- stys.width = toCssUnit(width)
953
- }
954
- return h('div', {
955
- ref: 'refElem',
956
- class: ['vxe-splitter', vertical ? 'is--vertical' : 'is--horizontal', immediate ? 'is-resize--immediate' : 'is-resize--lazy', {
957
- [`size--${vSize}`]: vSize
958
- }],
959
- style: stys
960
- }, [
961
- h('div', {
962
- class: 'vxe-splitter-slots'
963
- }, defaultSlot ? defaultSlot({}) : []),
964
- $xeSplitter.renderItems(h),
965
- h('div', {
966
- ref: 'refResizableSplitterTip',
967
- class: ['vxe-splitter--resizable-splitter-tip', vertical ? 'is--vertical' : 'is--horizontal', immediate ? 'is-resize--immediate' : 'is-resize--lazy']
968
- }, showTip
969
- ? [
970
- h('div', {
971
- class: 'vxe-splitter--resizable-splitter-tip-number'
972
- }, [
973
- h('div', {
974
- class: 'vxe-splitter--resizable-splitter-number-prev'
975
- }),
976
- h('div', {
977
- class: 'vxe-splitter--resizable-splitter-number-next'
978
- })
979
- ])
980
- ]
981
- : []),
982
- h('div', {
983
- class: 'vxe-splitter--render-vars'
984
- }, [
985
- h('div', {
986
- ref: 'refBarInfoElem',
987
- class: 'vxe-splitter--handle-bar-info'
988
- })
989
- ])
990
- ])
991
- }
992
- },
993
- created () {
994
- const $xeSplitter = this
995
-
996
- globalEvents.on($xeSplitter, 'resize', $xeSplitter.handleGlobalResizeEvent)
997
- },
998
- mounted () {
999
- const $xeSplitter = this
1000
- const props = $xeSplitter
1001
-
1002
- const el = $xeSplitter.$refs.refElem as HTMLDivElement
1003
- if (el) {
1004
- const resizeObserver = globalResize.create(() => {
1005
- $xeSplitter.recalculate()
1006
- })
1007
- resizeObserver.observe(el)
1008
- ;(this as any).$resize = resizeObserver
1009
- }
1010
- if (props.items) {
1011
- $xeSplitter.loadItem(props.items)
1012
- }
1013
- const actionOpts = $xeSplitter.computeActionOpts
1014
- if (actionOpts.direction) {
1015
- errLog('vxe.error.delProp', ['[splitter] action-config.direction', 'action-config.showPrevButton | action-config.showNextButton'])
1016
- }
1017
- $xeSplitter.$nextTick(() => {
1018
- $xeSplitter.recalculate()
1019
- })
1020
- },
1021
- beforeDestroy () {
1022
- const $xeSplitter = this
1023
-
1024
- if ((this as any).$resize) {
1025
- (this as any).$resize.disconnect()
1026
- }
1027
- globalEvents.off($xeSplitter, 'resize')
1028
- },
1029
- render (this: any, h) {
1030
- return this.renderVN(h)
1031
- }
1032
- }) /* define-vxe-component end */
1
+ import { CreateElement, PropType, VNode } from 'vue'
2
+ import { defineVxeComponent } from '../../ui/src/comp'
3
+ import XEUtils from 'xe-utils'
4
+ import { getConfig, getIcon, createEvent, globalEvents, globalMixins, globalResize, renderEmptyElement } from '../../ui'
5
+ import { getSlotVNs } from '../../ui/src/vn'
6
+ import { toCssUnit, isScale, addClass, removeClass } from '../../ui/src/dom'
7
+ import { getGlobalDefaultConfig } from '../../ui/src/utils'
8
+ import { warnLog, errLog } from '../../ui/src/log'
9
+
10
+ import type { SplitterReactData, VxeSplitterPropTypes, VxeComponentSizeType, SplitterInternalData, VxeSplitterEmits, VxeSplitterPanelPropTypes, ValueOf, VxeSplitterPanelProps, VxeSplitterDefines } from '../../../types'
11
+
12
+ export default /* define-vxe-component start */ defineVxeComponent({
13
+ name: 'VxeSplitter',
14
+ mixins: [
15
+ globalMixins.sizeMixin
16
+ ],
17
+ props: {
18
+ width: [Number, String] as PropType<VxeSplitterPropTypes.Width>,
19
+ height: [Number, String] as PropType<VxeSplitterPropTypes.Height>,
20
+ vertical: {
21
+ type: Boolean as PropType<VxeSplitterPropTypes.Vertical>,
22
+ default: () => getConfig().splitter.vertical
23
+ },
24
+ border: {
25
+ type: Boolean as PropType<VxeSplitterPropTypes.Border>,
26
+ default: () => getConfig().splitter.border
27
+ },
28
+ padding: {
29
+ type: Boolean as PropType<VxeSplitterPropTypes.Padding>,
30
+ default: () => getConfig().splitter.padding
31
+ },
32
+ resize: {
33
+ type: Boolean as PropType<VxeSplitterPropTypes.Resize>,
34
+ default: () => getConfig().splitter.resize
35
+ },
36
+ items: Array as PropType<VxeSplitterPropTypes.Items>,
37
+ itemConfig: Object as PropType<VxeSplitterPropTypes.ItemConfig>,
38
+ barConfig: Object as PropType<VxeSplitterPropTypes.BarConfig>,
39
+ resizeConfig: Object as PropType<VxeSplitterPropTypes.ResizeConfig>,
40
+ actionConfig: Object as PropType<VxeSplitterPropTypes.ActionConfig>,
41
+ size: {
42
+ type: String as PropType<VxeSplitterPropTypes.Size>,
43
+ default: () => getConfig().splitter.size || getConfig().size
44
+ }
45
+ },
46
+ data () {
47
+ const xID = XEUtils.uniqueId()
48
+ const reactData: SplitterReactData = {
49
+ staticItems: [],
50
+ itemList: [],
51
+ barWidth: 0,
52
+ barHeight: 0
53
+ }
54
+ const internalData: SplitterInternalData = {
55
+ wrapperWidth: 0,
56
+ wrapperHeight: 0
57
+ }
58
+ return {
59
+ xID,
60
+ reactData,
61
+ internalData,
62
+ reFlag: 0
63
+ }
64
+ },
65
+ provide () {
66
+ const $xeSplitter = this
67
+ return {
68
+ $xeSplitter
69
+ }
70
+ },
71
+ computed: {
72
+ ...({} as {
73
+ computeSize(): VxeComponentSizeType
74
+ }),
75
+ computeItemOpts () {
76
+ const $xeSplitter = this
77
+ const props = $xeSplitter
78
+
79
+ return Object.assign({}, getConfig().splitter.itemConfig, props.itemConfig)
80
+ },
81
+ computeBarOpts () {
82
+ const $xeSplitter = this
83
+ const props = $xeSplitter
84
+
85
+ return Object.assign({}, getConfig().splitter.barConfig, props.barConfig)
86
+ },
87
+ computeResizeOpts () {
88
+ const $xeSplitter = this
89
+ const props = $xeSplitter
90
+
91
+ return Object.assign({}, getConfig().splitter.resizeConfig, props.resizeConfig)
92
+ },
93
+ computeActionOpts () {
94
+ const $xeSplitter = this
95
+ const props = $xeSplitter
96
+
97
+ return Object.assign({}, getConfig().splitter.actionConfig, props.actionConfig)
98
+ },
99
+ computeIsFoldNext () {
100
+ const $xeSplitter = this
101
+
102
+ const actionOpts = $xeSplitter.computeActionOpts as VxeSplitterPropTypes.ActionConfig
103
+ return actionOpts.direction === 'next'
104
+ },
105
+ computeVisibleItems () {
106
+ const $xeSplitter = this
107
+ const reactData = $xeSplitter.reactData as SplitterReactData
108
+
109
+ return reactData.itemList.filter(item => item.isExpand)
110
+ },
111
+ computeAutoItems () {
112
+ const $xeSplitter = this
113
+ const props = $xeSplitter
114
+ const reactData = ($xeSplitter as any).reactData as SplitterReactData
115
+
116
+ const { vertical } = props
117
+ const autoItems: VxeSplitterDefines.PaneConfig[] = []
118
+ reactData.itemList.forEach(vertical
119
+ ? item => {
120
+ if (!item.height) {
121
+ autoItems.push(item)
122
+ }
123
+ }
124
+ : item => {
125
+ if (!item.width) {
126
+ autoItems.push(item)
127
+ }
128
+ })
129
+ return {
130
+ autoItems
131
+ }
132
+ },
133
+ computeBarStyle () {
134
+ const $xeSplitter = this
135
+
136
+ const barOpts = $xeSplitter.computeBarOpts
137
+ const { width, height } = barOpts
138
+ const stys: Record<string, string | number> = {}
139
+ if (height) {
140
+ stys.height = toCssUnit(height)
141
+ }
142
+ if (width) {
143
+ stys.width = toCssUnit(width)
144
+ }
145
+ return stys
146
+ },
147
+ computeSItemSize () {
148
+ const $xeSplitter = this
149
+ const reactData = $xeSplitter.reactData as SplitterReactData
150
+
151
+ return reactData.staticItems.length
152
+ }
153
+ },
154
+ watch: {
155
+ items (val) {
156
+ const $xeSplitter = this
157
+
158
+ $xeSplitter.loadItem(val || [])
159
+ },
160
+ computeSItemSize () {
161
+ const $xeSplitter = this
162
+ const props = $xeSplitter
163
+ const reactData = $xeSplitter.reactData
164
+
165
+ const actionOpts = $xeSplitter.computeActionOpts
166
+ const { showPrevButton, showNextButton } = actionOpts
167
+ if (props.items && props.items.length) {
168
+ errLog('vxe.error.errConflicts', ['<vxe-splitter-panel ...>', 'items'])
169
+ }
170
+ reactData.itemList = reactData.staticItems || []
171
+ if ((showPrevButton || showNextButton) && reactData.itemList.length > 2) {
172
+ errLog('vxe.error.modelConflicts', ['[splitter] action-config.showPrevButton | action-config.showNextButton', '<vxe-splitter-panel ...> Only supports 2 panel'])
173
+ }
174
+ reactData.itemList.forEach(item => {
175
+ if (item.showAction) {
176
+ warnLog('vxe.error.removeProp', ['[splitter] show-action'])
177
+ }
178
+ })
179
+ $xeSplitter.recalculate()
180
+ }
181
+ },
182
+ methods: {
183
+ //
184
+ // Method
185
+ //
186
+ dispatchEvent (type: ValueOf<VxeSplitterEmits>, params: Record<string, any>, evnt: Event | null) {
187
+ const $xeSplitter = this
188
+ $xeSplitter.$emit(type, createEvent(evnt, { $splitter: $xeSplitter }, params))
189
+ },
190
+ callSlot (slotFunc: any, params: any) {
191
+ const $xeSplitter = this
192
+ const slots = $xeSplitter.$scopedSlots
193
+
194
+ if (slotFunc) {
195
+ if (XEUtils.isString(slotFunc)) {
196
+ slotFunc = slots[slotFunc] || null
197
+ }
198
+ if (XEUtils.isFunction(slotFunc)) {
199
+ return getSlotVNs(slotFunc(params))
200
+ }
201
+ }
202
+ return []
203
+ },
204
+ reset () {
205
+ const $xeSplitter = this
206
+ const reactData = $xeSplitter.reactData
207
+
208
+ const { itemList } = reactData
209
+ itemList.forEach(item => {
210
+ item.isExpand = true
211
+ item.foldHeight = 0
212
+ item.foldWidth = 0
213
+ item.resizeHeight = 0
214
+ item.resizeWidth = 0
215
+ })
216
+ return $xeSplitter.$nextTick()
217
+ },
218
+ handleLoadItem (list: VxeSplitterPanelProps[], isReset: boolean) {
219
+ const $xeSplitter = this
220
+ const slots = $xeSplitter.$scopedSlots
221
+ const reactData = $xeSplitter.reactData
222
+
223
+ const { staticItems } = reactData
224
+ const itemDef = {
225
+ isExpand: true,
226
+ renderWidth: 0,
227
+ resizeWidth: 0,
228
+ foldWidth: 0,
229
+ renderHeight: 0,
230
+ resizeHeight: 0,
231
+ foldHeight: 0
232
+ }
233
+ reactData.itemList = list.map(item => {
234
+ if (item.slots) {
235
+ XEUtils.each(item.slots, (func) => {
236
+ if (!XEUtils.isFunction(func)) {
237
+ if (!slots[func]) {
238
+ errLog('vxe.error.notSlot', [`[splitter] ${func}`])
239
+ }
240
+ }
241
+ })
242
+ }
243
+ return Object.assign({}, isReset ? null : itemDef, item, isReset ? itemDef : null, {
244
+ id: XEUtils.uniqueId()
245
+ })
246
+ })
247
+ if (staticItems.length) {
248
+ errLog('vxe.error.errConflicts', ['<vxe-splitter-panel ...>', 'items'])
249
+ }
250
+ return $xeSplitter.recalculate()
251
+ },
252
+ loadItem (list: VxeSplitterPanelProps[]) {
253
+ const $xeSplitter = this
254
+
255
+ return $xeSplitter.handleLoadItem(list || [], false)
256
+ },
257
+ reloadItem (list: VxeSplitterPanelProps[]) {
258
+ const $xeSplitter = this
259
+
260
+ return $xeSplitter.handleLoadItem(list || [], true)
261
+ },
262
+ handleItemByName (name: VxeSplitterPanelPropTypes.Name) {
263
+ const $xeSplitter = this
264
+ const reactData = $xeSplitter.reactData
265
+
266
+ const { itemList } = reactData
267
+ let index = -1
268
+ let currItem: VxeSplitterDefines.PaneConfig | null = null
269
+ let prevItem: VxeSplitterDefines.PaneConfig | null = null
270
+ let nextItem: VxeSplitterDefines.PaneConfig | null = null
271
+ for (let i = 0; i < itemList.length; i++) {
272
+ const item = itemList[i]
273
+ if (item.name === name) {
274
+ index = i
275
+ currItem = item
276
+ prevItem = itemList[i - 1] || null
277
+ nextItem = itemList[i + 1] || null
278
+ break
279
+ }
280
+ }
281
+ return {
282
+ index,
283
+ currItem,
284
+ prevItem,
285
+ nextItem
286
+ }
287
+ },
288
+ setItemExpand (name: VxeSplitterPanelPropTypes.Name, expanded: boolean) {
289
+ const $xeSplitter = this
290
+
291
+ const restItem = $xeSplitter.handleItemByName(name)
292
+ if (restItem) {
293
+ const { currItem, prevItem, nextItem } = restItem
294
+ if (currItem) {
295
+ if (expanded ? !currItem.isExpand : currItem.isExpand) {
296
+ if (nextItem) {
297
+ if (nextItem.isExpand) {
298
+ $xeSplitter.handleItemActionEvent(null, currItem, nextItem, false)
299
+ }
300
+ } else if (prevItem) {
301
+ if (prevItem.isExpand) {
302
+ $xeSplitter.handleItemActionEvent(null, prevItem, currItem, true)
303
+ }
304
+ }
305
+ }
306
+ }
307
+ }
308
+ return $xeSplitter.$nextTick()
309
+ },
310
+ toggleItemExpand (name: VxeSplitterPanelPropTypes.Name) {
311
+ const $xeSplitter = this
312
+
313
+ const restItem = $xeSplitter.handleItemByName(name)
314
+ if (restItem) {
315
+ const { currItem } = restItem
316
+ if (currItem) {
317
+ return $xeSplitter.setItemExpand(name, !currItem.isExpand)
318
+ }
319
+ }
320
+ return $xeSplitter.$nextTick()
321
+ },
322
+ getItemVisible (name: VxeSplitterPanelPropTypes.Name) {
323
+ const $xeSplitter = this
324
+
325
+ const restItem = $xeSplitter.handleItemByName(name)
326
+ if (restItem) {
327
+ const { currItem } = restItem
328
+ if (currItem) {
329
+ return $xeSplitter.setItemExpand(name, !currItem.isExpand)
330
+ }
331
+ }
332
+ return false
333
+ },
334
+ recalculate () {
335
+ const $xeSplitter = this
336
+ const props = $xeSplitter
337
+ const reactData = $xeSplitter.reactData
338
+ const internalData = $xeSplitter.internalData
339
+
340
+ return $xeSplitter.$nextTick().then(() => {
341
+ const { vertical } = props
342
+ const { itemList } = reactData
343
+ const el = $xeSplitter.$refs.refElem as HTMLDivElement
344
+ const barInfoElem = $xeSplitter.$refs.refBarInfoElem as HTMLDivElement
345
+ if (!el) {
346
+ return
347
+ }
348
+ const wWidth = el.clientWidth
349
+ const wHeight = el.clientHeight
350
+ if (!wWidth || !wHeight) {
351
+ return
352
+ }
353
+ if (barInfoElem) {
354
+ reactData.barWidth = barInfoElem.offsetWidth
355
+ reactData.barHeight = barInfoElem.offsetHeight
356
+ }
357
+ const contentWidth = wWidth - (vertical ? 0 : reactData.barWidth * (itemList.length - 1))
358
+ const contentHeight = wHeight - (vertical ? reactData.barHeight * (itemList.length - 1) : 0)
359
+ const itemOpts = $xeSplitter.computeItemOpts
360
+ const allMinWidth = XEUtils.toNumber(itemOpts.minWidth)
361
+ const allMinHeight = XEUtils.toNumber(itemOpts.minHeight)
362
+ const residueItems: VxeSplitterDefines.PaneConfig[] = []
363
+ if (vertical) {
364
+ let countHeight = 0
365
+ itemList.forEach(item => {
366
+ const { height } = item
367
+ let itemHeight = 0
368
+ if (height) {
369
+ if (isScale(height)) {
370
+ itemHeight = contentHeight * XEUtils.toNumber(height) / 100
371
+ } else {
372
+ itemHeight = XEUtils.toNumber(height)
373
+ }
374
+ item.renderHeight = itemHeight
375
+ } else {
376
+ residueItems.push(item)
377
+ }
378
+ countHeight += itemHeight
379
+ })
380
+ if (residueItems.length) {
381
+ const reMeanHeight = (contentHeight - countHeight) / residueItems.length
382
+ residueItems.forEach(item => {
383
+ item.renderHeight = Math.max(XEUtils.toNumber(getGlobalDefaultConfig(item.minHeight, allMinHeight)), reMeanHeight)
384
+ })
385
+ }
386
+ } else {
387
+ let countWidth = 0
388
+ itemList.forEach(item => {
389
+ const { width } = item
390
+ let itemWidth = 0
391
+ if (width) {
392
+ if (isScale(width)) {
393
+ itemWidth = contentWidth * XEUtils.toNumber(width) / 100
394
+ } else {
395
+ itemWidth = XEUtils.toNumber(width)
396
+ }
397
+ item.renderWidth = itemWidth
398
+ } else {
399
+ residueItems.push(item)
400
+ }
401
+ countWidth += itemWidth
402
+ })
403
+ if (residueItems.length) {
404
+ const reMeanWidth = (contentWidth - countWidth) / residueItems.length
405
+ residueItems.forEach(item => {
406
+ item.renderWidth = Math.max(XEUtils.toNumber(getGlobalDefaultConfig(item.minWidth, allMinWidth)), reMeanWidth)
407
+ })
408
+ }
409
+ }
410
+ internalData.wrapperWidth = contentWidth
411
+ internalData.wrapperHeight = contentHeight
412
+ })
413
+ },
414
+ dragEvent (evnt: MouseEvent) {
415
+ const $xeSplitter = this
416
+ const props = $xeSplitter
417
+ const reactData = $xeSplitter.reactData
418
+
419
+ const { resize, vertical } = props
420
+ const { itemList } = reactData
421
+ if (!resize) {
422
+ return
423
+ }
424
+ evnt.preventDefault()
425
+ const barEl = evnt.currentTarget as HTMLDivElement
426
+ const handleEl = barEl.parentElement as HTMLDivElement
427
+ const el = $xeSplitter.$refs.refElem as HTMLDivElement
428
+ if (!el) {
429
+ return
430
+ }
431
+ const prevEl = handleEl.previousElementSibling as HTMLDivElement
432
+ const nextEl = handleEl.nextElementSibling as HTMLDivElement
433
+ if (!prevEl || !nextEl) {
434
+ return
435
+ }
436
+ const prevId = prevEl.getAttribute('itemid')
437
+ const nextId = nextEl.getAttribute('itemid')
438
+ const prevItem = itemList.find(item => item.id === prevId)
439
+ const nextItem = itemList.find(item => item.id === nextId)
440
+ if (!prevItem || !nextItem) {
441
+ return
442
+ }
443
+ const containerRect = el.getBoundingClientRect()
444
+ const barRect = barEl.getBoundingClientRect()
445
+ const rsSplitterLineEl = $xeSplitter.$refs.refResizableSplitterTip as HTMLDivElement
446
+ const rsSplitterTipEl = rsSplitterLineEl ? rsSplitterLineEl.children[0] as HTMLDivElement : null
447
+ const itemOpts = $xeSplitter.computeItemOpts
448
+ const resizeOpts = $xeSplitter.computeResizeOpts
449
+ const { immediate } = resizeOpts
450
+ const allMinWidth = XEUtils.toNumber(itemOpts.minWidth)
451
+ const allMinHeight = XEUtils.toNumber(itemOpts.minHeight)
452
+
453
+ const barOffsetX = Math.ceil(barRect.width - (evnt.clientX - barRect.left))
454
+ const barOffsetY = Math.ceil(evnt.clientY - barRect.top)
455
+
456
+ const prevWidth = prevEl.offsetWidth
457
+ const nextWidth = nextEl.offsetWidth
458
+ const prevMinWidth = XEUtils.toNumber(prevItem ? getGlobalDefaultConfig(prevItem.minWidth, allMinWidth) : allMinWidth)
459
+ const nextMinWidth = XEUtils.toNumber(nextItem ? getGlobalDefaultConfig(nextItem.minWidth, allMinWidth) : allMinWidth)
460
+ const minOffsetLeft = prevEl.offsetLeft + prevMinWidth - barOffsetX
461
+ const maxOffsetLeft = nextEl.offsetLeft + nextEl.offsetWidth - nextMinWidth - barOffsetX
462
+ const startOffsetLeft = evnt.clientX - containerRect.left
463
+ let targetOffsetWidth = -1
464
+ let prevResizeWidth = 0
465
+ let nextResizeWidth = 0
466
+ let offsetLeft = startOffsetLeft
467
+
468
+ const prevHeight = prevEl.offsetHeight
469
+ const nextHeight = nextEl.offsetHeight
470
+ const prevMinHeight = XEUtils.toNumber(prevItem ? getGlobalDefaultConfig(prevItem.minHeight, allMinHeight) : allMinHeight)
471
+ const nextMinHeight = XEUtils.toNumber(nextItem ? getGlobalDefaultConfig(nextItem.minHeight, allMinHeight) : allMinHeight)
472
+ const minOffsetTop = prevEl.offsetTop + prevMinHeight + barOffsetY
473
+ const maxOffsetTop = nextEl.offsetTop + nextEl.offsetHeight - nextMinHeight + barOffsetY
474
+ const startOffsetTop = evnt.clientY - containerRect.top
475
+ let targetOffsetHeight = -1
476
+ let prevResizeHeight = 0
477
+ let nextResizeHeight = 0
478
+ let offsetTop = startOffsetTop
479
+
480
+ const handleReStyle = (evnt: MouseEvent) => {
481
+ if (!rsSplitterLineEl) {
482
+ return
483
+ }
484
+ const rsNumPrevEl = rsSplitterTipEl ? rsSplitterTipEl.children[0] as HTMLDivElement : null
485
+ const rsNumNextEl = rsSplitterTipEl ? rsSplitterTipEl.children[1] as HTMLDivElement : null
486
+ if (vertical) {
487
+ let tipWidth = 0
488
+ if (rsNumPrevEl) {
489
+ if (targetOffsetHeight < 0) {
490
+ rsNumPrevEl.style.display = 'none'
491
+ } else {
492
+ rsNumPrevEl.textContent = `${Math.floor(prevResizeHeight)}px`
493
+ rsNumPrevEl.style.display = 'block'
494
+ tipWidth = rsNumPrevEl.offsetWidth
495
+ }
496
+ }
497
+ if (rsNumNextEl) {
498
+ if (targetOffsetHeight < 0) {
499
+ rsNumNextEl.textContent = `${Math.floor(nextResizeHeight)}px`
500
+ rsNumNextEl.style.display = 'block'
501
+ tipWidth = rsNumNextEl.offsetWidth
502
+ } else {
503
+ rsNumNextEl.style.display = 'none'
504
+ }
505
+ }
506
+ let rsLeft = Math.max(1, evnt.clientX - containerRect.left - tipWidth / 2)
507
+ if (rsLeft > containerRect.width - tipWidth - 1) {
508
+ rsLeft = containerRect.width - tipWidth - 1
509
+ }
510
+ rsSplitterLineEl.style.left = '0'
511
+ rsSplitterLineEl.style.top = `${offsetTop}px`
512
+ if (rsSplitterTipEl) {
513
+ rsSplitterTipEl.style.left = `${rsLeft}px`
514
+ }
515
+ } else {
516
+ let tipHeight = 0
517
+ if (rsNumPrevEl) {
518
+ if (targetOffsetWidth < 0) {
519
+ rsNumPrevEl.style.display = 'none'
520
+ } else {
521
+ rsNumPrevEl.textContent = `${Math.floor(prevResizeWidth)}px`
522
+ rsNumPrevEl.style.display = 'block'
523
+ tipHeight = rsNumPrevEl.offsetHeight
524
+ }
525
+ }
526
+ if (rsNumNextEl) {
527
+ if (targetOffsetWidth < 0) {
528
+ rsNumNextEl.textContent = `${Math.floor(nextResizeWidth)}px`
529
+ rsNumNextEl.style.display = 'block'
530
+ tipHeight = rsNumNextEl.offsetHeight
531
+ } else {
532
+ rsNumNextEl.style.display = 'none'
533
+ }
534
+ }
535
+ let rsTop = Math.max(1, evnt.clientY - containerRect.top - tipHeight / 2)
536
+ if (rsTop > containerRect.height - tipHeight - 1) {
537
+ rsTop = containerRect.height - tipHeight - 1
538
+ }
539
+ rsSplitterLineEl.style.top = '0'
540
+ rsSplitterLineEl.style.left = `${offsetLeft}px`
541
+ if (rsSplitterTipEl) {
542
+ rsSplitterTipEl.style.top = `${rsTop}px`
543
+ }
544
+ }
545
+ }
546
+
547
+ const handleUpdate = () => {
548
+ if (vertical) {
549
+ prevItem.resizeHeight = prevResizeHeight
550
+ nextItem.resizeHeight = nextResizeHeight
551
+ } else {
552
+ prevItem.resizeWidth = prevResizeWidth
553
+ nextItem.resizeWidth = nextResizeWidth
554
+ }
555
+ }
556
+
557
+ const handleDrag = (evnt: MouseEvent) => {
558
+ if (vertical) {
559
+ offsetTop = evnt.clientY - containerRect.top
560
+ if (offsetTop < minOffsetTop) {
561
+ offsetTop = minOffsetTop
562
+ }
563
+ if (offsetTop > maxOffsetTop) {
564
+ offsetTop = maxOffsetTop
565
+ }
566
+ targetOffsetHeight = offsetTop - startOffsetTop
567
+ prevResizeHeight = prevHeight + targetOffsetHeight
568
+ nextResizeHeight = nextHeight - targetOffsetHeight
569
+ } else {
570
+ offsetLeft = evnt.clientX - containerRect.left
571
+ if (offsetLeft < minOffsetLeft) {
572
+ offsetLeft = minOffsetLeft
573
+ }
574
+ if (offsetLeft > maxOffsetLeft) {
575
+ offsetLeft = maxOffsetLeft
576
+ }
577
+ targetOffsetWidth = offsetLeft - startOffsetLeft
578
+ prevResizeWidth = prevWidth + targetOffsetWidth
579
+ nextResizeWidth = nextWidth - targetOffsetWidth
580
+ }
581
+ if (immediate) {
582
+ if (vertical) {
583
+ prevEl.style.height = toCssUnit(prevResizeHeight)
584
+ nextEl.style.height = toCssUnit(nextResizeHeight)
585
+ } else {
586
+ prevEl.style.width = toCssUnit(prevResizeWidth)
587
+ nextEl.style.width = toCssUnit(nextResizeWidth)
588
+ }
589
+ }
590
+ if (rsSplitterLineEl) {
591
+ handleReStyle(evnt)
592
+ }
593
+ $xeSplitter.dispatchEvent('resize-drag', { prevItem, nextItem, offsetHeight: targetOffsetHeight, offsetWidth: targetOffsetWidth }, evnt)
594
+ }
595
+
596
+ document.onmousemove = (evnt) => {
597
+ evnt.preventDefault()
598
+ handleDrag(evnt)
599
+ }
600
+ document.onmouseup = (evnt) => {
601
+ document.onmousemove = null
602
+ document.onmouseup = null
603
+ if (rsSplitterLineEl) {
604
+ rsSplitterLineEl.style.display = ''
605
+ }
606
+ handleUpdate()
607
+ removeClass(el, 'is--drag')
608
+ $xeSplitter.dispatchEvent('resize-end', { prevItem, nextItem, offsetHeight: targetOffsetHeight, offsetWidth: targetOffsetWidth }, evnt)
609
+ $xeSplitter.recalculate()
610
+ }
611
+
612
+ if (rsSplitterLineEl) {
613
+ rsSplitterLineEl.style.display = 'block'
614
+ handleReStyle(evnt)
615
+ }
616
+ handleDrag(evnt)
617
+ addClass(el, 'is--drag')
618
+ $xeSplitter.dispatchEvent('resize-start', { prevItem, nextItem }, evnt)
619
+ },
620
+ handleItemActionEvent (evnt: MouseEvent | null, prevItem: VxeSplitterDefines.PaneConfig, nextItem: VxeSplitterDefines.PaneConfig, isNext: boolean) {
621
+ const $xeSplitter = this
622
+ const props = $xeSplitter
623
+
624
+ const { vertical } = props
625
+ let expanded = false
626
+ let item = prevItem
627
+ if (isNext) {
628
+ item = nextItem
629
+ expanded = !nextItem.isExpand
630
+ nextItem.isExpand = expanded
631
+ } else {
632
+ expanded = !prevItem.isExpand
633
+ prevItem.isExpand = expanded
634
+ }
635
+ if (vertical) {
636
+ if (prevItem.isExpand && nextItem.isExpand) {
637
+ prevItem.foldHeight = 0
638
+ nextItem.foldHeight = 0
639
+ } else if (prevItem.isExpand) {
640
+ nextItem.foldHeight = 0
641
+ prevItem.foldHeight = (prevItem.resizeHeight || prevItem.renderHeight) + (nextItem.resizeHeight || nextItem.renderHeight)
642
+ } else {
643
+ prevItem.foldHeight = 0
644
+ nextItem.foldHeight = (prevItem.resizeHeight || prevItem.renderHeight) + (nextItem.resizeHeight || nextItem.renderHeight)
645
+ }
646
+ } else {
647
+ if (prevItem.isExpand && nextItem.isExpand) {
648
+ prevItem.foldWidth = 0
649
+ nextItem.foldWidth = 0
650
+ } else if (prevItem.isExpand) {
651
+ nextItem.foldWidth = 0
652
+ prevItem.foldWidth = (prevItem.resizeWidth || prevItem.renderWidth) + (nextItem.resizeWidth || nextItem.renderWidth)
653
+ } else {
654
+ prevItem.foldWidth = 0
655
+ nextItem.foldWidth = (prevItem.resizeWidth || prevItem.renderWidth) + (nextItem.resizeWidth || nextItem.renderWidth)
656
+ }
657
+ }
658
+ if (evnt) {
659
+ $xeSplitter.dispatchEvent('toggle-expand', { prevItem, nextItem, expanded, item }, evnt)
660
+ }
661
+ $xeSplitter.recalculate()
662
+ },
663
+ handlePrevActionDblclickEvent (evnt: MouseEvent) {
664
+ const $xeSplitter = this
665
+ const reactData = $xeSplitter.reactData
666
+
667
+ const { itemList } = reactData
668
+ const actionOpts = $xeSplitter.computeActionOpts
669
+ const btnEl = evnt.currentTarget as HTMLDivElement
670
+ const btnWrapperEl = btnEl.parentElement as HTMLDivElement
671
+ const handleEl = btnWrapperEl.parentElement as HTMLDivElement
672
+ const prevEl = handleEl.previousElementSibling as HTMLDivElement
673
+ const prevId = prevEl.getAttribute('itemid')
674
+ const prevItem = itemList.find(item => item.id === prevId)
675
+ const nextEl = handleEl.nextElementSibling as HTMLDivElement
676
+ const nextId = nextEl.getAttribute('itemid')
677
+ const nextItem = itemList.find(item => item.id === nextId)
678
+
679
+ if (actionOpts.trigger === 'dblclick') {
680
+ if (prevItem && nextItem && nextItem.isExpand) {
681
+ $xeSplitter.handleItemActionEvent(evnt, prevItem, nextItem, false)
682
+ }
683
+ }
684
+ $xeSplitter.dispatchEvent('action-dblclick', { prevItem, nextItem }, evnt)
685
+ },
686
+ handlePrevActionClickEvent (evnt: MouseEvent) {
687
+ const $xeSplitter = this
688
+ const reactData = $xeSplitter.reactData
689
+
690
+ const { itemList } = reactData
691
+ const actionOpts = $xeSplitter.computeActionOpts
692
+ const btnEl = evnt.currentTarget as HTMLDivElement
693
+ const btnWrapperEl = btnEl.parentElement as HTMLDivElement
694
+ const handleEl = btnWrapperEl.parentElement as HTMLDivElement
695
+ const prevEl = handleEl.previousElementSibling as HTMLDivElement
696
+ const prevId = prevEl.getAttribute('itemid')
697
+ const prevItem = itemList.find(item => item.id === prevId)
698
+ const nextEl = handleEl.nextElementSibling as HTMLDivElement
699
+ const nextId = nextEl.getAttribute('itemid')
700
+ const nextItem = itemList.find(item => item.id === nextId)
701
+
702
+ if (actionOpts.trigger !== 'dblclick') {
703
+ if (prevItem && nextItem && nextItem.isExpand) {
704
+ $xeSplitter.handleItemActionEvent(evnt, prevItem, nextItem, false)
705
+ }
706
+ }
707
+ $xeSplitter.dispatchEvent('action-click', { prevItem, nextItem }, evnt)
708
+ },
709
+ handleNextActionDblclickEvent (evnt: MouseEvent) {
710
+ const $xeSplitter = this
711
+ const reactData = $xeSplitter.reactData
712
+
713
+ const { itemList } = reactData
714
+ const actionOpts = $xeSplitter.computeActionOpts
715
+ const btnEl = evnt.currentTarget as HTMLDivElement
716
+ const btnWrapperEl = btnEl.parentElement as HTMLDivElement
717
+ const handleEl = btnWrapperEl.parentElement as HTMLDivElement
718
+ const prevEl = handleEl.previousElementSibling as HTMLDivElement
719
+ const prevId = prevEl.getAttribute('itemid')
720
+ const prevItem = itemList.find(item => item.id === prevId)
721
+ const nextEl = handleEl.nextElementSibling as HTMLDivElement
722
+ const nextId = nextEl.getAttribute('itemid')
723
+ const nextItem = itemList.find(item => item.id === nextId)
724
+
725
+ if (actionOpts.trigger === 'dblclick') {
726
+ if (prevItem && nextItem && prevItem.isExpand) {
727
+ $xeSplitter.handleItemActionEvent(evnt, prevItem, nextItem, true)
728
+ }
729
+ }
730
+ $xeSplitter.dispatchEvent('action-dblclick', { prevItem, nextItem }, evnt)
731
+ },
732
+ handleNextActionClickEvent (evnt: MouseEvent) {
733
+ const $xeSplitter = this
734
+ const reactData = $xeSplitter.reactData
735
+
736
+ const { itemList } = reactData
737
+ const actionOpts = $xeSplitter.computeActionOpts
738
+ const btnEl = evnt.currentTarget as HTMLDivElement
739
+ const btnWrapperEl = btnEl.parentElement as HTMLDivElement
740
+ const handleEl = btnWrapperEl.parentElement as HTMLDivElement
741
+ const prevEl = handleEl.previousElementSibling as HTMLDivElement
742
+ const prevId = prevEl.getAttribute('itemid')
743
+ const prevItem = itemList.find(item => item.id === prevId)
744
+ const nextEl = handleEl.nextElementSibling as HTMLDivElement
745
+ const nextId = nextEl.getAttribute('itemid')
746
+ const nextItem = itemList.find(item => item.id === nextId)
747
+
748
+ if (actionOpts.trigger !== 'dblclick') {
749
+ if (prevItem && nextItem && prevItem.isExpand) {
750
+ $xeSplitter.handleItemActionEvent(evnt, prevItem, nextItem, true)
751
+ }
752
+ }
753
+ $xeSplitter.dispatchEvent('action-click', { prevItem, nextItem }, evnt)
754
+ },
755
+ handleGlobalResizeEvent () {
756
+ const $xeSplitter = this
757
+
758
+ $xeSplitter.recalculate()
759
+ },
760
+ getActionIcon (prevItem: VxeSplitterDefines.PaneConfig, nextItem: VxeSplitterDefines.PaneConfig, isNext: boolean) {
761
+ const $xeSplitter = this
762
+ const props = $xeSplitter
763
+
764
+ const { vertical } = props
765
+ const topIcon = 'SPLIT_TOP_ACTION'
766
+ const bottomIcon = 'SPLIT_BOTTOM_ACTION'
767
+ const leftIcon = 'SPLIT_LEFT_ACTION'
768
+ const rightIcon = 'SPLIT_RIGHT_ACTION'
769
+ let iconName: 'SPLIT_TOP_ACTION' | 'SPLIT_BOTTOM_ACTION' | 'SPLIT_LEFT_ACTION' | 'SPLIT_RIGHT_ACTION' | '' = ''
770
+ if (vertical) {
771
+ if (isNext) {
772
+ iconName = nextItem.isExpand ? bottomIcon : topIcon
773
+ } else {
774
+ iconName = prevItem.isExpand ? topIcon : bottomIcon
775
+ }
776
+ } else {
777
+ if (isNext) {
778
+ iconName = nextItem.isExpand ? rightIcon : leftIcon
779
+ } else {
780
+ iconName = prevItem.isExpand ? leftIcon : rightIcon
781
+ }
782
+ }
783
+ if (iconName) {
784
+ return getIcon()[iconName]
785
+ }
786
+ return ''
787
+ },
788
+
789
+ //
790
+ // Render
791
+ //
792
+ renderHandleBar (h: CreateElement, prevItem: VxeSplitterDefines.PaneConfig, nextItem: VxeSplitterDefines.PaneConfig) {
793
+ const $xeSplitter = this
794
+ const props = $xeSplitter
795
+ const reactData = $xeSplitter.reactData
796
+
797
+ const { border, resize, vertical } = props
798
+ const { itemList } = reactData
799
+ const barStyle = $xeSplitter.computeBarStyle
800
+ const actionOpts = $xeSplitter.computeActionOpts
801
+ const { direction } = actionOpts
802
+ const showPrevButton = XEUtils.isBoolean(actionOpts.showPrevButton) ? actionOpts.showPrevButton : (itemList.some(item => item.showAction))
803
+ const showNextButton = XEUtils.isBoolean(actionOpts.showNextButton) ? actionOpts.showNextButton : (direction === 'next' && itemList.some(item => item.showAction))
804
+ const resizeOpts = $xeSplitter.computeResizeOpts
805
+ const { immediate } = resizeOpts
806
+ return h('div', {
807
+ class: ['vxe-splitter-panel-handle', vertical ? 'is--vertical' : 'is--horizontal', immediate ? 'is-resize--immediate' : 'is-resize--lazy', {
808
+ 'is--resize': resize,
809
+ 'is--border': border
810
+ }]
811
+ }, [
812
+ h('div', {
813
+ class: 'vxe-splitter-panel-handle-bar',
814
+ style: barStyle,
815
+ on: {
816
+ mousedown: $xeSplitter.dragEvent
817
+ }
818
+ }),
819
+ itemList.length === 2
820
+ ? h('div', {
821
+ class: 'vxe-splitter-panel-action-btn-wrapper'
822
+ }, [
823
+ showPrevButton && nextItem.isExpand
824
+ ? h('div', {
825
+ class: 'vxe-splitter-panel-action-btn',
826
+ on: {
827
+ dblclick: $xeSplitter.handlePrevActionDblclickEvent,
828
+ click: $xeSplitter.handlePrevActionClickEvent
829
+ }
830
+ }, [
831
+ h('i', {
832
+ class: $xeSplitter.getActionIcon(prevItem, nextItem, false)
833
+ })
834
+ ])
835
+ : renderEmptyElement($xeSplitter),
836
+ showNextButton && prevItem.isExpand
837
+ ? h('div', {
838
+ class: 'vxe-splitter-panel-action-btn',
839
+ on: {
840
+ dblclick: $xeSplitter.handleNextActionDblclickEvent,
841
+ click: $xeSplitter.handleNextActionClickEvent
842
+ }
843
+ }, [
844
+ h('i', {
845
+ class: $xeSplitter.getActionIcon(prevItem, nextItem, true)
846
+ })
847
+ ])
848
+ : renderEmptyElement($xeSplitter)
849
+ ])
850
+ : renderEmptyElement($xeSplitter)
851
+ ])
852
+ },
853
+ renderItems (h: CreateElement) {
854
+ const $xeSplitter = this
855
+ const props = $xeSplitter
856
+ const reactData = $xeSplitter.reactData
857
+
858
+ const { border, padding, resize, vertical } = props
859
+ const { itemList } = reactData
860
+ const vSize = $xeSplitter.computeSize
861
+ const resizeOpts = $xeSplitter.computeResizeOpts
862
+ const { immediate } = resizeOpts
863
+ const visibleItems = $xeSplitter.computeVisibleItems
864
+ const { autoItems } = $xeSplitter.computeAutoItems
865
+ const itemVNs: VNode[] = []
866
+ itemList.forEach((prevItem, index) => {
867
+ const { id, name, slots, renderHeight, resizeHeight, foldHeight, renderWidth, resizeWidth, foldWidth, isExpand } = prevItem
868
+ const nextItem = itemList[index + 1]
869
+ const defaultSlot = slots ? slots.default : null
870
+ const stys: Record<string, string | number> = {}
871
+ let itemWidth = isExpand ? (foldWidth || resizeWidth || renderWidth) : 0
872
+ let itemHeight = isExpand ? (foldHeight || resizeHeight || renderHeight) : 0
873
+ // 至少存在一个自适应
874
+ if (autoItems.length === 1) {
875
+ if (vertical) {
876
+ if (!prevItem.height) {
877
+ itemHeight = 0
878
+ }
879
+ } else {
880
+ if (!prevItem.width) {
881
+ itemWidth = 0
882
+ }
883
+ }
884
+ }
885
+ let isFill = true
886
+ if (vertical) {
887
+ if (itemHeight && visibleItems.length > 1) {
888
+ isFill = false
889
+ stys.height = toCssUnit(itemHeight)
890
+ }
891
+ } else {
892
+ if (itemWidth && visibleItems.length > 1) {
893
+ isFill = false
894
+ stys.width = toCssUnit(itemWidth)
895
+ }
896
+ }
897
+
898
+ itemVNs.push(
899
+ h('div', {
900
+ attrs: {
901
+ itemid: id
902
+ },
903
+ class: ['vxe-splitter-panel', vertical ? 'is--vertical' : 'is--horizontal', immediate ? 'is-resize--immediate' : 'is-resize--lazy', {
904
+ [`size--${vSize}`]: vSize,
905
+ 'is--resize': resize,
906
+ 'is--padding': padding,
907
+ 'is--border': border,
908
+ 'is--height': itemHeight,
909
+ 'is--width': itemWidth,
910
+ 'is--visible': isExpand,
911
+ 'is--hidden': !isExpand,
912
+ 'is--fill': isExpand && isFill
913
+ }],
914
+ style: stys
915
+ }, [
916
+ h('div', {
917
+ attrs: {
918
+ itemid: id
919
+ },
920
+ class: 'vxe-splitter-panel--wrapper'
921
+ }, [
922
+ h('div', {
923
+ class: 'vxe-splitter-panel--inner'
924
+ }, defaultSlot ? $xeSplitter.callSlot(defaultSlot, { name, isExpand }) : [])
925
+ ])
926
+ ])
927
+ )
928
+
929
+ if (nextItem) {
930
+ itemVNs.push($xeSplitter.renderHandleBar(h, prevItem, nextItem))
931
+ }
932
+ })
933
+ return h('div', {
934
+ class: 'vxe-splitter-wrapper'
935
+ }, itemVNs)
936
+ },
937
+ renderVN (h: CreateElement): VNode {
938
+ const $xeSplitter = this
939
+ const props = $xeSplitter
940
+ const slots = $xeSplitter.$scopedSlots
941
+
942
+ const { vertical, width, height } = props
943
+ const vSize = $xeSplitter.computeSize
944
+ const resizeOpts = $xeSplitter.computeResizeOpts
945
+ const { immediate, showTip } = resizeOpts
946
+ const defaultSlot = slots.default
947
+ const stys: Record<string, string | number> = {}
948
+ if (height) {
949
+ stys.height = toCssUnit(height)
950
+ }
951
+ if (width) {
952
+ stys.width = toCssUnit(width)
953
+ }
954
+ return h('div', {
955
+ ref: 'refElem',
956
+ class: ['vxe-splitter', vertical ? 'is--vertical' : 'is--horizontal', immediate ? 'is-resize--immediate' : 'is-resize--lazy', {
957
+ [`size--${vSize}`]: vSize
958
+ }],
959
+ style: stys
960
+ }, [
961
+ h('div', {
962
+ class: 'vxe-splitter-slots'
963
+ }, defaultSlot ? defaultSlot({}) : []),
964
+ $xeSplitter.renderItems(h),
965
+ h('div', {
966
+ ref: 'refResizableSplitterTip',
967
+ class: ['vxe-splitter--resizable-splitter-tip', vertical ? 'is--vertical' : 'is--horizontal', immediate ? 'is-resize--immediate' : 'is-resize--lazy']
968
+ }, showTip
969
+ ? [
970
+ h('div', {
971
+ class: 'vxe-splitter--resizable-splitter-tip-number'
972
+ }, [
973
+ h('div', {
974
+ class: 'vxe-splitter--resizable-splitter-number-prev'
975
+ }),
976
+ h('div', {
977
+ class: 'vxe-splitter--resizable-splitter-number-next'
978
+ })
979
+ ])
980
+ ]
981
+ : []),
982
+ h('div', {
983
+ class: 'vxe-splitter--render-vars'
984
+ }, [
985
+ h('div', {
986
+ ref: 'refBarInfoElem',
987
+ class: 'vxe-splitter--handle-bar-info'
988
+ })
989
+ ])
990
+ ])
991
+ }
992
+ },
993
+ created () {
994
+ const $xeSplitter = this
995
+
996
+ globalEvents.on($xeSplitter, 'resize', $xeSplitter.handleGlobalResizeEvent)
997
+ },
998
+ mounted () {
999
+ const $xeSplitter = this
1000
+ const props = $xeSplitter
1001
+
1002
+ const el = $xeSplitter.$refs.refElem as HTMLDivElement
1003
+ if (el) {
1004
+ const resizeObserver = globalResize.create(() => {
1005
+ $xeSplitter.recalculate()
1006
+ })
1007
+ resizeObserver.observe(el)
1008
+ ;(this as any).$resize = resizeObserver
1009
+ }
1010
+ if (props.items) {
1011
+ $xeSplitter.loadItem(props.items)
1012
+ }
1013
+ const actionOpts = $xeSplitter.computeActionOpts
1014
+ if (actionOpts.direction) {
1015
+ errLog('vxe.error.delProp', ['[splitter] action-config.direction', 'action-config.showPrevButton | action-config.showNextButton'])
1016
+ }
1017
+ $xeSplitter.$nextTick(() => {
1018
+ $xeSplitter.recalculate()
1019
+ })
1020
+ },
1021
+ beforeDestroy () {
1022
+ const $xeSplitter = this
1023
+
1024
+ if ((this as any).$resize) {
1025
+ (this as any).$resize.disconnect()
1026
+ }
1027
+ globalEvents.off($xeSplitter, 'resize')
1028
+ },
1029
+ render (this: any, h) {
1030
+ return this.renderVN(h)
1031
+ }
1032
+ }) /* define-vxe-component end */