@class-kit/vue 0.1.0

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 (541) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/LICENSE +3 -0
  3. package/README.md +86 -0
  4. package/dist/components/affix.cjs +132 -0
  5. package/dist/components/affix.cjs.map +1 -0
  6. package/dist/components/affix.d.ts +2 -0
  7. package/dist/components/affix.d.ts.map +1 -0
  8. package/dist/components/affix.js +130 -0
  9. package/dist/components/affix.js.map +1 -0
  10. package/dist/components/backtop.cjs +180 -0
  11. package/dist/components/backtop.cjs.map +1 -0
  12. package/dist/components/backtop.d.ts +2 -0
  13. package/dist/components/backtop.d.ts.map +1 -0
  14. package/dist/components/backtop.js +178 -0
  15. package/dist/components/backtop.js.map +1 -0
  16. package/dist/components/badge.cjs +84 -0
  17. package/dist/components/badge.cjs.map +1 -0
  18. package/dist/components/badge.d.ts +2 -0
  19. package/dist/components/badge.d.ts.map +1 -0
  20. package/dist/components/badge.js +82 -0
  21. package/dist/components/badge.js.map +1 -0
  22. package/dist/components/barcode.cjs +122 -0
  23. package/dist/components/barcode.cjs.map +1 -0
  24. package/dist/components/barcode.d.ts +2 -0
  25. package/dist/components/barcode.d.ts.map +1 -0
  26. package/dist/components/barcode.js +120 -0
  27. package/dist/components/barcode.js.map +1 -0
  28. package/dist/components/breadcrumb.cjs +76 -0
  29. package/dist/components/breadcrumb.cjs.map +1 -0
  30. package/dist/components/breadcrumb.d.ts +2 -0
  31. package/dist/components/breadcrumb.d.ts.map +1 -0
  32. package/dist/components/breadcrumb.js +74 -0
  33. package/dist/components/breadcrumb.js.map +1 -0
  34. package/dist/components/button.cjs +104 -0
  35. package/dist/components/button.cjs.map +1 -0
  36. package/dist/components/button.d.ts +2 -0
  37. package/dist/components/button.d.ts.map +1 -0
  38. package/dist/components/button.js +102 -0
  39. package/dist/components/button.js.map +1 -0
  40. package/dist/components/calendar.cjs +173 -0
  41. package/dist/components/calendar.cjs.map +1 -0
  42. package/dist/components/calendar.d.ts +2 -0
  43. package/dist/components/calendar.d.ts.map +1 -0
  44. package/dist/components/calendar.js +171 -0
  45. package/dist/components/calendar.js.map +1 -0
  46. package/dist/components/canvas-editor.cjs +450 -0
  47. package/dist/components/canvas-editor.cjs.map +1 -0
  48. package/dist/components/canvas-editor.d.ts +2 -0
  49. package/dist/components/canvas-editor.d.ts.map +1 -0
  50. package/dist/components/canvas-editor.js +448 -0
  51. package/dist/components/canvas-editor.js.map +1 -0
  52. package/dist/components/canvas-image.cjs +124 -0
  53. package/dist/components/canvas-image.cjs.map +1 -0
  54. package/dist/components/canvas-image.d.ts +2 -0
  55. package/dist/components/canvas-image.d.ts.map +1 -0
  56. package/dist/components/canvas-image.js +122 -0
  57. package/dist/components/canvas-image.js.map +1 -0
  58. package/dist/components/chat-virtual-list.cjs +625 -0
  59. package/dist/components/chat-virtual-list.cjs.map +1 -0
  60. package/dist/components/chat-virtual-list.d.ts +2 -0
  61. package/dist/components/chat-virtual-list.d.ts.map +1 -0
  62. package/dist/components/chat-virtual-list.js +623 -0
  63. package/dist/components/chat-virtual-list.js.map +1 -0
  64. package/dist/components/checkbox.cjs +195 -0
  65. package/dist/components/checkbox.cjs.map +1 -0
  66. package/dist/components/checkbox.d.ts +2 -0
  67. package/dist/components/checkbox.d.ts.map +1 -0
  68. package/dist/components/checkbox.js +193 -0
  69. package/dist/components/checkbox.js.map +1 -0
  70. package/dist/components/checked.cjs +196 -0
  71. package/dist/components/checked.cjs.map +1 -0
  72. package/dist/components/checked.d.ts +2 -0
  73. package/dist/components/checked.d.ts.map +1 -0
  74. package/dist/components/checked.js +194 -0
  75. package/dist/components/checked.js.map +1 -0
  76. package/dist/components/color-picker.cjs +364 -0
  77. package/dist/components/color-picker.cjs.map +1 -0
  78. package/dist/components/color-picker.d.ts +2 -0
  79. package/dist/components/color-picker.d.ts.map +1 -0
  80. package/dist/components/color-picker.js +362 -0
  81. package/dist/components/color-picker.js.map +1 -0
  82. package/dist/components/comic-reader.cjs +166 -0
  83. package/dist/components/comic-reader.cjs.map +1 -0
  84. package/dist/components/comic-reader.d.ts +2 -0
  85. package/dist/components/comic-reader.d.ts.map +1 -0
  86. package/dist/components/comic-reader.js +164 -0
  87. package/dist/components/comic-reader.js.map +1 -0
  88. package/dist/components/config-provider.cjs +55 -0
  89. package/dist/components/config-provider.cjs.map +1 -0
  90. package/dist/components/config-provider.d.ts +2 -0
  91. package/dist/components/config-provider.d.ts.map +1 -0
  92. package/dist/components/config-provider.js +53 -0
  93. package/dist/components/config-provider.js.map +1 -0
  94. package/dist/components/config-table.cjs +697 -0
  95. package/dist/components/config-table.cjs.map +1 -0
  96. package/dist/components/config-table.d.ts +2 -0
  97. package/dist/components/config-table.d.ts.map +1 -0
  98. package/dist/components/config-table.js +695 -0
  99. package/dist/components/config-table.js.map +1 -0
  100. package/dist/components/countdown.cjs +122 -0
  101. package/dist/components/countdown.cjs.map +1 -0
  102. package/dist/components/countdown.d.ts +2 -0
  103. package/dist/components/countdown.d.ts.map +1 -0
  104. package/dist/components/countdown.js +120 -0
  105. package/dist/components/countdown.js.map +1 -0
  106. package/dist/components/danmaku.cjs +116 -0
  107. package/dist/components/danmaku.cjs.map +1 -0
  108. package/dist/components/danmaku.d.ts +2 -0
  109. package/dist/components/danmaku.d.ts.map +1 -0
  110. package/dist/components/danmaku.js +114 -0
  111. package/dist/components/danmaku.js.map +1 -0
  112. package/dist/components/date-picker.cjs +350 -0
  113. package/dist/components/date-picker.cjs.map +1 -0
  114. package/dist/components/date-picker.d.ts +2 -0
  115. package/dist/components/date-picker.d.ts.map +1 -0
  116. package/dist/components/date-picker.js +348 -0
  117. package/dist/components/date-picker.js.map +1 -0
  118. package/dist/components/date-range-picker.cjs +428 -0
  119. package/dist/components/date-range-picker.cjs.map +1 -0
  120. package/dist/components/date-range-picker.d.ts +2 -0
  121. package/dist/components/date-range-picker.d.ts.map +1 -0
  122. package/dist/components/date-range-picker.js +426 -0
  123. package/dist/components/date-range-picker.js.map +1 -0
  124. package/dist/components/design-effect.cjs +121 -0
  125. package/dist/components/design-effect.cjs.map +1 -0
  126. package/dist/components/design-effect.d.ts +2 -0
  127. package/dist/components/design-effect.d.ts.map +1 -0
  128. package/dist/components/design-effect.js +119 -0
  129. package/dist/components/design-effect.js.map +1 -0
  130. package/dist/components/drag-drop-board.cjs +399 -0
  131. package/dist/components/drag-drop-board.cjs.map +1 -0
  132. package/dist/components/drag-drop-board.d.ts +2 -0
  133. package/dist/components/drag-drop-board.d.ts.map +1 -0
  134. package/dist/components/drag-drop-board.js +397 -0
  135. package/dist/components/drag-drop-board.js.map +1 -0
  136. package/dist/components/draggable.cjs +193 -0
  137. package/dist/components/draggable.cjs.map +1 -0
  138. package/dist/components/draggable.d.ts +2 -0
  139. package/dist/components/draggable.d.ts.map +1 -0
  140. package/dist/components/draggable.js +191 -0
  141. package/dist/components/draggable.js.map +1 -0
  142. package/dist/components/ellipsis-text.cjs +176 -0
  143. package/dist/components/ellipsis-text.cjs.map +1 -0
  144. package/dist/components/ellipsis-text.d.ts +2 -0
  145. package/dist/components/ellipsis-text.d.ts.map +1 -0
  146. package/dist/components/ellipsis-text.js +174 -0
  147. package/dist/components/ellipsis-text.js.map +1 -0
  148. package/dist/components/empty.cjs +124 -0
  149. package/dist/components/empty.cjs.map +1 -0
  150. package/dist/components/empty.d.ts +2 -0
  151. package/dist/components/empty.d.ts.map +1 -0
  152. package/dist/components/empty.js +122 -0
  153. package/dist/components/empty.js.map +1 -0
  154. package/dist/components/field.cjs +265 -0
  155. package/dist/components/field.cjs.map +1 -0
  156. package/dist/components/field.d.ts +2 -0
  157. package/dist/components/field.d.ts.map +1 -0
  158. package/dist/components/field.js +263 -0
  159. package/dist/components/field.js.map +1 -0
  160. package/dist/components/file-preview.cjs +392 -0
  161. package/dist/components/file-preview.cjs.map +1 -0
  162. package/dist/components/file-preview.d.ts +3 -0
  163. package/dist/components/file-preview.d.ts.map +1 -0
  164. package/dist/components/file-preview.js +390 -0
  165. package/dist/components/file-preview.js.map +1 -0
  166. package/dist/components/floating-ball.cjs +203 -0
  167. package/dist/components/floating-ball.cjs.map +1 -0
  168. package/dist/components/floating-ball.d.ts +2 -0
  169. package/dist/components/floating-ball.d.ts.map +1 -0
  170. package/dist/components/floating-ball.js +201 -0
  171. package/dist/components/floating-ball.js.map +1 -0
  172. package/dist/components/form.cjs +146 -0
  173. package/dist/components/form.cjs.map +1 -0
  174. package/dist/components/form.d.ts +3 -0
  175. package/dist/components/form.d.ts.map +1 -0
  176. package/dist/components/form.js +141 -0
  177. package/dist/components/form.js.map +1 -0
  178. package/dist/components/gradient-text.cjs +103 -0
  179. package/dist/components/gradient-text.cjs.map +1 -0
  180. package/dist/components/gradient-text.d.ts +2 -0
  181. package/dist/components/gradient-text.d.ts.map +1 -0
  182. package/dist/components/gradient-text.js +101 -0
  183. package/dist/components/gradient-text.js.map +1 -0
  184. package/dist/components/input.cjs +264 -0
  185. package/dist/components/input.cjs.map +1 -0
  186. package/dist/components/input.d.ts +2 -0
  187. package/dist/components/input.d.ts.map +1 -0
  188. package/dist/components/input.js +262 -0
  189. package/dist/components/input.js.map +1 -0
  190. package/dist/components/lazy-image.cjs +203 -0
  191. package/dist/components/lazy-image.cjs.map +1 -0
  192. package/dist/components/lazy-image.d.ts +3 -0
  193. package/dist/components/lazy-image.d.ts.map +1 -0
  194. package/dist/components/lazy-image.js +201 -0
  195. package/dist/components/lazy-image.js.map +1 -0
  196. package/dist/components/live-room.cjs +644 -0
  197. package/dist/components/live-room.cjs.map +1 -0
  198. package/dist/components/live-room.d.ts +2 -0
  199. package/dist/components/live-room.d.ts.map +1 -0
  200. package/dist/components/live-room.js +642 -0
  201. package/dist/components/live-room.js.map +1 -0
  202. package/dist/components/loading.cjs +105 -0
  203. package/dist/components/loading.cjs.map +1 -0
  204. package/dist/components/loading.d.ts +2 -0
  205. package/dist/components/loading.d.ts.map +1 -0
  206. package/dist/components/loading.js +103 -0
  207. package/dist/components/loading.js.map +1 -0
  208. package/dist/components/marquee.cjs +267 -0
  209. package/dist/components/marquee.cjs.map +1 -0
  210. package/dist/components/marquee.d.ts +2 -0
  211. package/dist/components/marquee.d.ts.map +1 -0
  212. package/dist/components/marquee.js +265 -0
  213. package/dist/components/marquee.js.map +1 -0
  214. package/dist/components/masonry-virtual-list.cjs +241 -0
  215. package/dist/components/masonry-virtual-list.cjs.map +1 -0
  216. package/dist/components/masonry-virtual-list.d.ts +2 -0
  217. package/dist/components/masonry-virtual-list.d.ts.map +1 -0
  218. package/dist/components/masonry-virtual-list.js +239 -0
  219. package/dist/components/masonry-virtual-list.js.map +1 -0
  220. package/dist/components/modal.cjs +337 -0
  221. package/dist/components/modal.cjs.map +1 -0
  222. package/dist/components/modal.d.ts +2 -0
  223. package/dist/components/modal.d.ts.map +1 -0
  224. package/dist/components/modal.js +335 -0
  225. package/dist/components/modal.js.map +1 -0
  226. package/dist/components/multi-column-picker.cjs +284 -0
  227. package/dist/components/multi-column-picker.cjs.map +1 -0
  228. package/dist/components/multi-column-picker.d.ts +2 -0
  229. package/dist/components/multi-column-picker.d.ts.map +1 -0
  230. package/dist/components/multi-column-picker.js +282 -0
  231. package/dist/components/multi-column-picker.js.map +1 -0
  232. package/dist/components/novel-reader.cjs +401 -0
  233. package/dist/components/novel-reader.cjs.map +1 -0
  234. package/dist/components/novel-reader.d.ts +2 -0
  235. package/dist/components/novel-reader.d.ts.map +1 -0
  236. package/dist/components/novel-reader.js +399 -0
  237. package/dist/components/novel-reader.js.map +1 -0
  238. package/dist/components/number-input.cjs +399 -0
  239. package/dist/components/number-input.cjs.map +1 -0
  240. package/dist/components/number-input.d.ts +2 -0
  241. package/dist/components/number-input.d.ts.map +1 -0
  242. package/dist/components/number-input.js +397 -0
  243. package/dist/components/number-input.js.map +1 -0
  244. package/dist/components/pagination.cjs +144 -0
  245. package/dist/components/pagination.cjs.map +1 -0
  246. package/dist/components/pagination.d.ts +2 -0
  247. package/dist/components/pagination.d.ts.map +1 -0
  248. package/dist/components/pagination.js +142 -0
  249. package/dist/components/pagination.js.map +1 -0
  250. package/dist/components/password-input.cjs +344 -0
  251. package/dist/components/password-input.cjs.map +1 -0
  252. package/dist/components/password-input.d.ts +2 -0
  253. package/dist/components/password-input.d.ts.map +1 -0
  254. package/dist/components/password-input.js +342 -0
  255. package/dist/components/password-input.js.map +1 -0
  256. package/dist/components/popconfirm.cjs +198 -0
  257. package/dist/components/popconfirm.cjs.map +1 -0
  258. package/dist/components/popconfirm.d.ts +2 -0
  259. package/dist/components/popconfirm.d.ts.map +1 -0
  260. package/dist/components/popconfirm.js +196 -0
  261. package/dist/components/popconfirm.js.map +1 -0
  262. package/dist/components/popup.cjs +391 -0
  263. package/dist/components/popup.cjs.map +1 -0
  264. package/dist/components/popup.d.ts +2 -0
  265. package/dist/components/popup.d.ts.map +1 -0
  266. package/dist/components/popup.js +389 -0
  267. package/dist/components/popup.js.map +1 -0
  268. package/dist/components/progress-bar.cjs +276 -0
  269. package/dist/components/progress-bar.cjs.map +1 -0
  270. package/dist/components/progress-bar.d.ts +2 -0
  271. package/dist/components/progress-bar.d.ts.map +1 -0
  272. package/dist/components/progress-bar.js +274 -0
  273. package/dist/components/progress-bar.js.map +1 -0
  274. package/dist/components/qr-code.cjs +144 -0
  275. package/dist/components/qr-code.cjs.map +1 -0
  276. package/dist/components/qr-code.d.ts +2 -0
  277. package/dist/components/qr-code.d.ts.map +1 -0
  278. package/dist/components/qr-code.js +142 -0
  279. package/dist/components/qr-code.js.map +1 -0
  280. package/dist/components/radio-group.cjs +210 -0
  281. package/dist/components/radio-group.cjs.map +1 -0
  282. package/dist/components/radio-group.d.ts +3 -0
  283. package/dist/components/radio-group.d.ts.map +1 -0
  284. package/dist/components/radio-group.js +208 -0
  285. package/dist/components/radio-group.js.map +1 -0
  286. package/dist/components/rating.cjs +251 -0
  287. package/dist/components/rating.cjs.map +1 -0
  288. package/dist/components/rating.d.ts +2 -0
  289. package/dist/components/rating.d.ts.map +1 -0
  290. package/dist/components/rating.js +249 -0
  291. package/dist/components/rating.js.map +1 -0
  292. package/dist/components/rolling-number.cjs +99 -0
  293. package/dist/components/rolling-number.cjs.map +1 -0
  294. package/dist/components/rolling-number.d.ts +2 -0
  295. package/dist/components/rolling-number.d.ts.map +1 -0
  296. package/dist/components/rolling-number.js +97 -0
  297. package/dist/components/rolling-number.js.map +1 -0
  298. package/dist/components/select.cjs +475 -0
  299. package/dist/components/select.cjs.map +1 -0
  300. package/dist/components/select.d.ts +3 -0
  301. package/dist/components/select.d.ts.map +1 -0
  302. package/dist/components/select.js +473 -0
  303. package/dist/components/select.js.map +1 -0
  304. package/dist/components/signature.cjs +372 -0
  305. package/dist/components/signature.cjs.map +1 -0
  306. package/dist/components/signature.d.ts +2 -0
  307. package/dist/components/signature.d.ts.map +1 -0
  308. package/dist/components/signature.js +370 -0
  309. package/dist/components/signature.js.map +1 -0
  310. package/dist/components/skeleton.cjs +102 -0
  311. package/dist/components/skeleton.cjs.map +1 -0
  312. package/dist/components/skeleton.d.ts +2 -0
  313. package/dist/components/skeleton.d.ts.map +1 -0
  314. package/dist/components/skeleton.js +100 -0
  315. package/dist/components/skeleton.js.map +1 -0
  316. package/dist/components/slide-captcha.cjs +418 -0
  317. package/dist/components/slide-captcha.cjs.map +1 -0
  318. package/dist/components/slide-captcha.d.ts +2 -0
  319. package/dist/components/slide-captcha.d.ts.map +1 -0
  320. package/dist/components/slide-captcha.js +416 -0
  321. package/dist/components/slide-captcha.js.map +1 -0
  322. package/dist/components/swiper.cjs +441 -0
  323. package/dist/components/swiper.cjs.map +1 -0
  324. package/dist/components/swiper.d.ts +2 -0
  325. package/dist/components/swiper.d.ts.map +1 -0
  326. package/dist/components/swiper.js +439 -0
  327. package/dist/components/swiper.js.map +1 -0
  328. package/dist/components/switch.cjs +214 -0
  329. package/dist/components/switch.cjs.map +1 -0
  330. package/dist/components/switch.d.ts +2 -0
  331. package/dist/components/switch.d.ts.map +1 -0
  332. package/dist/components/switch.js +212 -0
  333. package/dist/components/switch.js.map +1 -0
  334. package/dist/components/table.cjs +695 -0
  335. package/dist/components/table.cjs.map +1 -0
  336. package/dist/components/table.d.ts +2 -0
  337. package/dist/components/table.d.ts.map +1 -0
  338. package/dist/components/table.js +693 -0
  339. package/dist/components/table.js.map +1 -0
  340. package/dist/components/tabs.cjs +330 -0
  341. package/dist/components/tabs.cjs.map +1 -0
  342. package/dist/components/tabs.d.ts +3 -0
  343. package/dist/components/tabs.d.ts.map +1 -0
  344. package/dist/components/tabs.js +328 -0
  345. package/dist/components/tabs.js.map +1 -0
  346. package/dist/components/tag.cjs +151 -0
  347. package/dist/components/tag.cjs.map +1 -0
  348. package/dist/components/tag.d.ts +2 -0
  349. package/dist/components/tag.d.ts.map +1 -0
  350. package/dist/components/tag.js +149 -0
  351. package/dist/components/tag.js.map +1 -0
  352. package/dist/components/textarea.cjs +266 -0
  353. package/dist/components/textarea.cjs.map +1 -0
  354. package/dist/components/textarea.d.ts +2 -0
  355. package/dist/components/textarea.d.ts.map +1 -0
  356. package/dist/components/textarea.js +264 -0
  357. package/dist/components/textarea.js.map +1 -0
  358. package/dist/components/tilt-card.cjs +221 -0
  359. package/dist/components/tilt-card.cjs.map +1 -0
  360. package/dist/components/tilt-card.d.ts +2 -0
  361. package/dist/components/tilt-card.d.ts.map +1 -0
  362. package/dist/components/tilt-card.js +219 -0
  363. package/dist/components/tilt-card.js.map +1 -0
  364. package/dist/components/timeline.cjs +87 -0
  365. package/dist/components/timeline.cjs.map +1 -0
  366. package/dist/components/timeline.d.ts +2 -0
  367. package/dist/components/timeline.d.ts.map +1 -0
  368. package/dist/components/timeline.js +85 -0
  369. package/dist/components/timeline.js.map +1 -0
  370. package/dist/components/toast.cjs +186 -0
  371. package/dist/components/toast.cjs.map +1 -0
  372. package/dist/components/toast.d.ts +2 -0
  373. package/dist/components/toast.d.ts.map +1 -0
  374. package/dist/components/toast.js +183 -0
  375. package/dist/components/toast.js.map +1 -0
  376. package/dist/components/tooltip.cjs +210 -0
  377. package/dist/components/tooltip.cjs.map +1 -0
  378. package/dist/components/tooltip.d.ts +2 -0
  379. package/dist/components/tooltip.d.ts.map +1 -0
  380. package/dist/components/tooltip.js +208 -0
  381. package/dist/components/tooltip.js.map +1 -0
  382. package/dist/components/typewriter-text.cjs +180 -0
  383. package/dist/components/typewriter-text.cjs.map +1 -0
  384. package/dist/components/typewriter-text.d.ts +2 -0
  385. package/dist/components/typewriter-text.d.ts.map +1 -0
  386. package/dist/components/typewriter-text.js +178 -0
  387. package/dist/components/typewriter-text.js.map +1 -0
  388. package/dist/components/upload.cjs +273 -0
  389. package/dist/components/upload.cjs.map +1 -0
  390. package/dist/components/upload.d.ts +2 -0
  391. package/dist/components/upload.d.ts.map +1 -0
  392. package/dist/components/upload.js +271 -0
  393. package/dist/components/upload.js.map +1 -0
  394. package/dist/components/verification-code.cjs +242 -0
  395. package/dist/components/verification-code.cjs.map +1 -0
  396. package/dist/components/verification-code.d.ts +2 -0
  397. package/dist/components/verification-code.d.ts.map +1 -0
  398. package/dist/components/verification-code.js +240 -0
  399. package/dist/components/verification-code.js.map +1 -0
  400. package/dist/components/video-detail-transition.cjs +637 -0
  401. package/dist/components/video-detail-transition.cjs.map +1 -0
  402. package/dist/components/video-detail-transition.d.ts +2 -0
  403. package/dist/components/video-detail-transition.d.ts.map +1 -0
  404. package/dist/components/video-detail-transition.js +635 -0
  405. package/dist/components/video-detail-transition.js.map +1 -0
  406. package/dist/components/video-player.cjs +384 -0
  407. package/dist/components/video-player.cjs.map +1 -0
  408. package/dist/components/video-player.d.ts +2 -0
  409. package/dist/components/video-player.d.ts.map +1 -0
  410. package/dist/components/video-player.js +382 -0
  411. package/dist/components/video-player.js.map +1 -0
  412. package/dist/components/virtual-list.cjs +503 -0
  413. package/dist/components/virtual-list.cjs.map +1 -0
  414. package/dist/components/virtual-list.d.ts +2 -0
  415. package/dist/components/virtual-list.d.ts.map +1 -0
  416. package/dist/components/virtual-list.js +501 -0
  417. package/dist/components/virtual-list.js.map +1 -0
  418. package/dist/components/virtual-select.cjs +538 -0
  419. package/dist/components/virtual-select.cjs.map +1 -0
  420. package/dist/components/virtual-select.d.ts +3 -0
  421. package/dist/components/virtual-select.d.ts.map +1 -0
  422. package/dist/components/virtual-select.js +536 -0
  423. package/dist/components/virtual-select.js.map +1 -0
  424. package/dist/components/virtual-table.cjs +696 -0
  425. package/dist/components/virtual-table.cjs.map +1 -0
  426. package/dist/components/virtual-table.d.ts +2 -0
  427. package/dist/components/virtual-table.d.ts.map +1 -0
  428. package/dist/components/virtual-table.js +694 -0
  429. package/dist/components/virtual-table.js.map +1 -0
  430. package/dist/import-transform-BiXH181o.js +144 -0
  431. package/dist/import-transform-BiXH181o.js.map +1 -0
  432. package/dist/import-transform-DLby8nRN.js +142 -0
  433. package/dist/import-transform-DLby8nRN.js.map +1 -0
  434. package/dist/import-transform.d.ts +6 -0
  435. package/dist/import-transform.d.ts.map +1 -0
  436. package/dist/index.cjs +11361 -0
  437. package/dist/index.cjs.map +1 -0
  438. package/dist/index.d.ts +6649 -0
  439. package/dist/index.d.ts.map +1 -0
  440. package/dist/index.js +11070 -0
  441. package/dist/index.js.map +1 -0
  442. package/dist/styles/base.css +455 -0
  443. package/dist/styles/components/affix.css +15 -0
  444. package/dist/styles/components/backtop.css +67 -0
  445. package/dist/styles/components/badge.css +33 -0
  446. package/dist/styles/components/barcode.css +33 -0
  447. package/dist/styles/components/breadcrumb.css +15 -0
  448. package/dist/styles/components/button.css +156 -0
  449. package/dist/styles/components/calendar.css +174 -0
  450. package/dist/styles/components/canvas-editor.css +327 -0
  451. package/dist/styles/components/canvas-image.css +40 -0
  452. package/dist/styles/components/chat-virtual-list.css +108 -0
  453. package/dist/styles/components/checkbox.css +318 -0
  454. package/dist/styles/components/checked.css +318 -0
  455. package/dist/styles/components/color-picker.css +377 -0
  456. package/dist/styles/components/comic-reader.css +135 -0
  457. package/dist/styles/components/config-provider.css +12 -0
  458. package/dist/styles/components/config-table.css +458 -0
  459. package/dist/styles/components/countdown.css +14 -0
  460. package/dist/styles/components/danmaku.css +56 -0
  461. package/dist/styles/components/date-picker.css +381 -0
  462. package/dist/styles/components/date-range-picker.css +454 -0
  463. package/dist/styles/components/design-effect.css +285 -0
  464. package/dist/styles/components/drag-drop-board.css +87 -0
  465. package/dist/styles/components/draggable.css +37 -0
  466. package/dist/styles/components/ellipsis-text.css +59 -0
  467. package/dist/styles/components/empty.css +168 -0
  468. package/dist/styles/components/field.css +221 -0
  469. package/dist/styles/components/file-preview.css +216 -0
  470. package/dist/styles/components/floating-ball.css +33 -0
  471. package/dist/styles/components/form.css +221 -0
  472. package/dist/styles/components/gradient-text.css +54 -0
  473. package/dist/styles/components/input.css +221 -0
  474. package/dist/styles/components/lazy-image.css +79 -0
  475. package/dist/styles/components/live-room.css +226 -0
  476. package/dist/styles/components/loading.css +98 -0
  477. package/dist/styles/components/marquee.css +281 -0
  478. package/dist/styles/components/masonry-virtual-list.css +29 -0
  479. package/dist/styles/components/modal.css +164 -0
  480. package/dist/styles/components/multi-column-picker.css +97 -0
  481. package/dist/styles/components/novel-reader.css +1163 -0
  482. package/dist/styles/components/number-input.css +221 -0
  483. package/dist/styles/components/pagination.css +43 -0
  484. package/dist/styles/components/password-input.css +289 -0
  485. package/dist/styles/components/popconfirm.css +156 -0
  486. package/dist/styles/components/popup.css +216 -0
  487. package/dist/styles/components/progress-bar.css +79 -0
  488. package/dist/styles/components/qr-code.css +62 -0
  489. package/dist/styles/components/radio-group.css +318 -0
  490. package/dist/styles/components/rating.css +260 -0
  491. package/dist/styles/components/rolling-number.css +37 -0
  492. package/dist/styles/components/select.css +342 -0
  493. package/dist/styles/components/signature.css +286 -0
  494. package/dist/styles/components/skeleton.css +70 -0
  495. package/dist/styles/components/slide-captcha.css +420 -0
  496. package/dist/styles/components/swiper.css +199 -0
  497. package/dist/styles/components/switch.css +294 -0
  498. package/dist/styles/components/table.css +458 -0
  499. package/dist/styles/components/tabs.css +156 -0
  500. package/dist/styles/components/tag.css +90 -0
  501. package/dist/styles/components/textarea.css +204 -0
  502. package/dist/styles/components/tilt-card.css +114 -0
  503. package/dist/styles/components/timeline.css +116 -0
  504. package/dist/styles/components/toast.css +204 -0
  505. package/dist/styles/components/tooltip.css +137 -0
  506. package/dist/styles/components/typewriter-text.css +95 -0
  507. package/dist/styles/components/upload.css +246 -0
  508. package/dist/styles/components/verification-code.css +240 -0
  509. package/dist/styles/components/video-detail-transition.css +169 -0
  510. package/dist/styles/components/video-player.css +93 -0
  511. package/dist/styles/components/virtual-list.css +206 -0
  512. package/dist/styles/components/virtual-select.css +472 -0
  513. package/dist/styles/components/virtual-table.css +458 -0
  514. package/dist/styles/components.css +8377 -0
  515. package/dist/styles/themes/amber.css +19 -0
  516. package/dist/styles/themes/emerald.css +19 -0
  517. package/dist/styles/themes/liquid-glass.css +55 -0
  518. package/dist/styles/themes/minimal.css +19 -0
  519. package/dist/styles/themes/rose.css +19 -0
  520. package/dist/styles/themes/sky.css +19 -0
  521. package/dist/styles/themes/violet.css +19 -0
  522. package/dist/styles.css +8377 -0
  523. package/dist/vite.cjs +27 -0
  524. package/dist/vite.cjs.map +1 -0
  525. package/dist/vite.d.ts +11 -0
  526. package/dist/vite.d.ts.map +1 -0
  527. package/dist/vite.js +22 -0
  528. package/dist/vite.js.map +1 -0
  529. package/dist/webpack-loader.cjs +18 -0
  530. package/dist/webpack-loader.cjs.map +1 -0
  531. package/dist/webpack-loader.d.ts +9 -0
  532. package/dist/webpack-loader.d.ts.map +1 -0
  533. package/dist/webpack-loader.js +14 -0
  534. package/dist/webpack-loader.js.map +1 -0
  535. package/dist/webpack.cjs +45 -0
  536. package/dist/webpack.cjs.map +1 -0
  537. package/dist/webpack.d.ts +21 -0
  538. package/dist/webpack.d.ts.map +1 -0
  539. package/dist/webpack.js +38 -0
  540. package/dist/webpack.js.map +1 -0
  541. package/package.json +104 -0
@@ -0,0 +1,695 @@
1
+ 'use strict';
2
+
3
+ var vue = require('vue');
4
+ var core = require('@class-kit/core');
5
+
6
+ const classIconPaths = {
7
+ chevronDown: ["M6 9l6 6 6-6"],
8
+ chevronLeft: ["M15 18l-6-6 6-6"],
9
+ chevronRight: ["M9 18l6-6-6-6"],
10
+ chevronUp: ["M18 15l-6-6-6 6"],
11
+ check: ["M20 6 9 17l-5-5"],
12
+ settings: [
13
+ "M12 15.5A3.5 3.5 0 1 0 12 8a3.5 3.5 0 0 0 0 7.5Z",
14
+ "M19.4 15a1.8 1.8 0 0 0 .36 1.98l.04.04a2.18 2.18 0 0 1-3.08 3.08l-.04-.04a1.8 1.8 0 0 0-1.98-.36 1.8 1.8 0 0 0-1 1.62V21a2.2 2.2 0 0 1-4.4 0v-.06a1.8 1.8 0 0 0-1-1.62 1.8 1.8 0 0 0-1.98.36l-.04.04A2.18 2.18 0 0 1 3.2 16.64l.04-.04A1.8 1.8 0 0 0 3.6 14.6a1.8 1.8 0 0 0-1.62-1H2a2.2 2.2 0 0 1 0-4.4h.06a1.8 1.8 0 0 0 1.62-1 1.8 1.8 0 0 0-.36-1.98l-.04-.04A2.18 2.18 0 0 1 6.36 3.1l.04.04a1.8 1.8 0 0 0 1.98.36h.08A1.8 1.8 0 0 0 9.4 1.88V1.8a2.2 2.2 0 0 1 4.4 0v.06a1.8 1.8 0 0 0 1 1.62 1.8 1.8 0 0 0 1.98-.36l.04-.04A2.18 2.18 0 0 1 19.9 6.16l-.04.04a1.8 1.8 0 0 0-.36 1.98v.08a1.8 1.8 0 0 0 1.62.94h.08a2.2 2.2 0 0 1 0 4.4h-.06A1.8 1.8 0 0 0 19.4 15Z",
15
+ ],
16
+ star: [
17
+ "M12 2l3.09 6.26 6.91 1-5 4.87 1.18 6.87L12 17.77 5.82 21 7 14.13l-5-4.87 6.91-1L12 2Z",
18
+ ],
19
+ x: ["M18 6 6 18", "M6 6l12 12"],
20
+ };
21
+ function classIcon(name, className = "cc-icon") {
22
+ return vue.h("svg", {
23
+ "aria-hidden": "true",
24
+ class: className,
25
+ fill: name === "star" ? "currentColor" : "none",
26
+ focusable: "false",
27
+ viewBox: "0 0 24 24",
28
+ }, classIconPaths[name].map((d) => vue.h("path", {
29
+ d,
30
+ "stroke-linecap": "round",
31
+ "stroke-linejoin": "round",
32
+ "stroke-width": name === "star" ? 0 : 2,
33
+ stroke: "currentColor",
34
+ })));
35
+ }
36
+ function resolveClassKitThemeName(theme) {
37
+ if (typeof theme === "string")
38
+ return theme;
39
+ return theme?.name ?? "minimal";
40
+ }
41
+ vue.defineComponent({
42
+ name: "ClassConfigProvider",
43
+ props: {
44
+ class: {
45
+ type: String,
46
+ default: "",
47
+ },
48
+ locale: {
49
+ type: Object,
50
+ default: undefined,
51
+ },
52
+ style: {
53
+ type: [String, Object, Array],
54
+ default: undefined,
55
+ },
56
+ theme: {
57
+ type: [String, Object],
58
+ default: "minimal",
59
+ },
60
+ },
61
+ setup(props, { slots }) {
62
+ const version = vue.ref(0);
63
+ const applyConfig = () => {
64
+ core.configureClassComponents({
65
+ locale: props.locale,
66
+ theme: props.theme,
67
+ });
68
+ version.value += 1;
69
+ };
70
+ vue.watch(() => [props.locale, props.theme], applyConfig, {
71
+ deep: true,
72
+ immediate: true,
73
+ });
74
+ return () => vue.h("div", {
75
+ class: ["cc-config-provider", props.class].filter(Boolean),
76
+ "data-cc-theme": resolveClassKitThemeName(props.theme),
77
+ style: props.style,
78
+ }, [
79
+ vue.h("div", { key: version.value, class: "cc-config-provider__content" }, slots.default?.()),
80
+ ]);
81
+ },
82
+ });
83
+ function renderDefaultLoadingIndicator() {
84
+ return vue.h("svg", {
85
+ class: "cc-loading__bolt",
86
+ focusable: "false",
87
+ viewBox: "0 0 96 96",
88
+ }, [
89
+ vue.h("ellipse", {
90
+ class: "cc-loading__bolt-shadow",
91
+ cx: "51",
92
+ cy: "74",
93
+ rx: "28",
94
+ ry: "8",
95
+ }),
96
+ vue.h("path", {
97
+ class: "cc-loading__bolt-side",
98
+ d: "M54 8 26 48h20L34 82l39-46H51L65 8Z",
99
+ }),
100
+ vue.h("path", {
101
+ class: "cc-loading__bolt-face",
102
+ d: "M48 6 20 46h20L28 80l39-46H45L59 6Z",
103
+ }),
104
+ vue.h("path", {
105
+ class: "cc-loading__bolt-highlight",
106
+ d: "M48 14 31 39h17L39 62l18-24H43l10-24Z",
107
+ }),
108
+ ]);
109
+ }
110
+ const ClassLoading = /*#__PURE__*/ vue.defineComponent({
111
+ name: "ClassLoading",
112
+ props: {
113
+ className: String,
114
+ text: {
115
+ type: String,
116
+ default: () => core.getClassComponentsLocale().loadingText,
117
+ },
118
+ },
119
+ setup(props, { attrs, slots }) {
120
+ return () => vue.h("div", {
121
+ ...attrs,
122
+ "aria-live": "polite",
123
+ class: ["cc-loading", props.className],
124
+ role: "status",
125
+ }, [
126
+ vue.h("span", { "aria-hidden": "true", class: "cc-loading__indicator" }, slots.indicator?.() ?? renderDefaultLoadingIndicator()),
127
+ props.text
128
+ ? vue.h("span", { class: "cc-loading__text" }, props.text)
129
+ : null,
130
+ ]);
131
+ },
132
+ });
133
+ function renderDefaultEmptyIcon() {
134
+ return vue.h("svg", {
135
+ class: "cc-empty__illustration",
136
+ focusable: "false",
137
+ viewBox: "0 0 96 96",
138
+ }, [
139
+ vue.h("ellipse", {
140
+ class: "cc-empty__illustration-shadow",
141
+ cx: "48",
142
+ cy: "76",
143
+ rx: "31",
144
+ ry: "8",
145
+ }),
146
+ vue.h("path", {
147
+ class: "cc-empty__tray-back",
148
+ d: "M24 48h48l9 18H15l9-18Z",
149
+ }),
150
+ vue.h("path", {
151
+ class: "cc-empty__tray-front",
152
+ d: "M15 66h66l-8 16H23l-8-16Z",
153
+ }),
154
+ vue.h("path", {
155
+ class: "cc-empty__tray-lip",
156
+ d: "M27 58h42",
157
+ }),
158
+ vue.h("path", {
159
+ class: "cc-empty__tray-glow",
160
+ d: "M32 70h32",
161
+ }),
162
+ vue.h("path", {
163
+ class: "cc-empty__mini-bolt-side",
164
+ d: "M54 10 36 38h13l-7 26 27-36H55l9-18Z",
165
+ }),
166
+ vue.h("path", {
167
+ class: "cc-empty__mini-bolt-face",
168
+ d: "M49 8 31 36h13l-7 26 27-36H50l9-18Z",
169
+ }),
170
+ vue.h("path", {
171
+ class: "cc-empty__mini-bolt-highlight",
172
+ d: "M49 16 39 32h10l-5 15 11-17h-9l7-14Z",
173
+ }),
174
+ vue.h("path", {
175
+ class: "cc-empty__spark",
176
+ d: "M23 32h8M27 28v8",
177
+ }),
178
+ vue.h("path", {
179
+ class: "cc-empty__spark cc-empty__spark--small",
180
+ d: "M71 44h6M74 41v6",
181
+ }),
182
+ ]);
183
+ }
184
+ const ClassEmpty = /*#__PURE__*/ vue.defineComponent({
185
+ name: "ClassEmpty",
186
+ props: {
187
+ className: String,
188
+ description: {
189
+ type: String,
190
+ default: () => core.getClassComponentsLocale().emptyText,
191
+ },
192
+ },
193
+ setup(props, { attrs, slots }) {
194
+ return () => vue.h("div", { ...attrs, class: ["cc-empty", props.className], role: "status" }, [
195
+ vue.h("span", { "aria-hidden": "true", class: "cc-empty__icon" }, slots.icon?.() ?? renderDefaultEmptyIcon()),
196
+ props.description
197
+ ? vue.h("span", { class: "cc-empty__description" }, props.description)
198
+ : null,
199
+ ]);
200
+ },
201
+ });
202
+ const ClassTable = /*#__PURE__*/ vue.defineComponent({
203
+ name: "ClassTable",
204
+ props: {
205
+ columns: {
206
+ type: Array,
207
+ required: true,
208
+ },
209
+ dataSource: {
210
+ type: Array,
211
+ default: () => [],
212
+ },
213
+ emptyText: {
214
+ type: String,
215
+ default: () => core.getClassComponentsLocale().tableEmptyText,
216
+ },
217
+ loading: Boolean,
218
+ loadingCoverHeader: Boolean,
219
+ loadingText: {
220
+ type: String,
221
+ default: () => core.getClassComponentsLocale().tableLoadingText,
222
+ },
223
+ overscan: { type: Number, default: 6 },
224
+ rowSelection: Boolean,
225
+ rowHeight: { type: Number, default: 44 },
226
+ selectedKeys: {
227
+ type: Array,
228
+ default: () => [],
229
+ },
230
+ columnSettingsSelectedIcon: {
231
+ type: null,
232
+ default: () => classIcon("check"),
233
+ },
234
+ settingsIcon: {
235
+ type: null,
236
+ default: () => classIcon("settings"),
237
+ },
238
+ virtual: Boolean,
239
+ virtualHeight: { type: Number, default: 320 },
240
+ className: { type: String, default: "cc-table" },
241
+ },
242
+ emits: ["selectionChange"],
243
+ setup(props, { attrs, slots, emit }) {
244
+ const rootRef = vue.ref(null);
245
+ const bodyRef = vue.ref(null);
246
+ const settingsRef = vue.ref(null);
247
+ const settingsButtonRef = vue.ref(null);
248
+ const settingsMenuRef = vue.ref(null);
249
+ const containerWidth = vue.ref(0);
250
+ const controller = new core.TableController({
251
+ columns: props.columns,
252
+ containerWidth: 0,
253
+ rows: props.dataSource,
254
+ selectedKeys: props.selectedKeys,
255
+ });
256
+ const virtualController = new core.VirtualListController({
257
+ count: props.dataSource.length,
258
+ estimateSize: props.rowHeight,
259
+ overscan: props.overscan,
260
+ });
261
+ const state = vue.ref(controller.getState());
262
+ const settingsOpen = vue.ref(false);
263
+ const settingsVisible = vue.ref(false);
264
+ const settingsPhase = vue.ref("exit");
265
+ const settingsMenuStyle = vue.ref({});
266
+ const scrollTop = vue.ref(0);
267
+ const bodyScrollbarWidth = vue.ref(0);
268
+ let resizeObserver;
269
+ let bodyResizeObserver;
270
+ let settingsTimer;
271
+ const getContentWidth = () => Math.max(0, (rootRef.value?.clientWidth ?? 0) -
272
+ (props.rowSelection ? 44 : 0) -
273
+ (props.virtual ? bodyScrollbarWidth.value : 0));
274
+ const updateContainerWidth = () => {
275
+ containerWidth.value = getContentWidth();
276
+ };
277
+ const updateTable = () => {
278
+ state.value = controller.update({
279
+ columns: props.columns,
280
+ containerWidth: containerWidth.value,
281
+ rows: props.dataSource,
282
+ selectedKeys: props.selectedKeys,
283
+ });
284
+ virtualController.updateOptions({
285
+ count: state.value.rows.length,
286
+ estimateSize: props.rowHeight,
287
+ overscan: props.overscan,
288
+ });
289
+ };
290
+ const updateSettingsPosition = () => {
291
+ const trigger = settingsButtonRef.value;
292
+ if (!trigger || typeof window === "undefined")
293
+ return;
294
+ const rect = trigger.getBoundingClientRect();
295
+ const width = 220;
296
+ const gap = 6;
297
+ const padding = 8;
298
+ const preferredHeight = Math.min(320, Math.max(160, state.value.allColumns.length * 42 + 12));
299
+ const below = window.innerHeight - rect.bottom - padding;
300
+ const above = rect.top - padding;
301
+ const placement = below >= preferredHeight || below >= above ? "bottom" : "top";
302
+ const maxHeight = Math.min(preferredHeight, Math.max(120, (placement === "bottom" ? below : above) - gap));
303
+ settingsMenuStyle.value = {
304
+ left: `${Math.min(Math.max(padding, rect.right - width), Math.max(padding, window.innerWidth - width - padding))}px`,
305
+ maxHeight: `${maxHeight}px`,
306
+ top: `${placement === "bottom" ? rect.bottom + gap : Math.max(padding, rect.top - gap - maxHeight)}px`,
307
+ width: `${width}px`,
308
+ };
309
+ };
310
+ const showSettings = () => {
311
+ if (settingsTimer)
312
+ clearTimeout(settingsTimer);
313
+ settingsOpen.value = true;
314
+ settingsVisible.value = true;
315
+ settingsPhase.value = "exit";
316
+ updateSettingsPosition();
317
+ requestAnimationFrame(() => {
318
+ settingsPhase.value = "enter";
319
+ });
320
+ };
321
+ const hideSettings = () => {
322
+ settingsOpen.value = false;
323
+ settingsPhase.value = "exit";
324
+ if (settingsTimer)
325
+ clearTimeout(settingsTimer);
326
+ settingsTimer = setTimeout(() => {
327
+ settingsVisible.value = false;
328
+ }, 180);
329
+ };
330
+ const toggleSettings = () => {
331
+ if (settingsOpen.value)
332
+ hideSettings();
333
+ else
334
+ showSettings();
335
+ };
336
+ const closeSettingsOnOutside = (event) => {
337
+ const target = event.target;
338
+ if (!settingsOpen.value ||
339
+ settingsRef.value?.contains(target) ||
340
+ settingsMenuRef.value?.contains(target))
341
+ return;
342
+ hideSettings();
343
+ };
344
+ const syncVirtualBodyScroll = () => {
345
+ if (!props.virtual || !rootRef.value || !bodyRef.value)
346
+ return;
347
+ bodyRef.value.scrollLeft = rootRef.value.scrollLeft;
348
+ };
349
+ const updateBodyScrollbarWidth = () => {
350
+ if (!props.virtual || !bodyRef.value) {
351
+ bodyScrollbarWidth.value = 0;
352
+ updateContainerWidth();
353
+ return;
354
+ }
355
+ const nextWidth = Math.max(0, bodyRef.value.offsetWidth - bodyRef.value.clientWidth);
356
+ if (bodyScrollbarWidth.value !== nextWidth) {
357
+ bodyScrollbarWidth.value = nextWidth;
358
+ updateContainerWidth();
359
+ }
360
+ };
361
+ vue.watch(() => [
362
+ props.columns,
363
+ props.dataSource,
364
+ props.rowSelection,
365
+ props.selectedKeys,
366
+ containerWidth.value,
367
+ ], updateTable);
368
+ vue.watch(() => props.rowSelection, updateContainerWidth);
369
+ vue.watch(() => [props.rowHeight, props.overscan], () => {
370
+ virtualController.updateOptions({
371
+ count: state.value.rows.length,
372
+ estimateSize: props.rowHeight,
373
+ overscan: props.overscan,
374
+ });
375
+ });
376
+ vue.watch(() => [
377
+ props.virtual,
378
+ props.virtualHeight,
379
+ state.value.rows.length,
380
+ containerWidth.value,
381
+ ], () => void vue.nextTick(updateBodyScrollbarWidth));
382
+ vue.onMounted(() => {
383
+ updateContainerWidth();
384
+ updateBodyScrollbarWidth();
385
+ document.addEventListener("mousedown", closeSettingsOnOutside);
386
+ window.addEventListener("resize", updateSettingsPosition);
387
+ window.addEventListener("scroll", updateSettingsPosition, true);
388
+ if (typeof ResizeObserver === "undefined") {
389
+ window.addEventListener("resize", updateContainerWidth);
390
+ return;
391
+ }
392
+ if (rootRef.value) {
393
+ resizeObserver = new ResizeObserver(updateContainerWidth);
394
+ resizeObserver.observe(rootRef.value);
395
+ }
396
+ if (bodyRef.value) {
397
+ bodyResizeObserver = new ResizeObserver(updateBodyScrollbarWidth);
398
+ bodyResizeObserver.observe(bodyRef.value);
399
+ }
400
+ });
401
+ vue.onBeforeUnmount(() => {
402
+ resizeObserver?.disconnect();
403
+ bodyResizeObserver?.disconnect();
404
+ document.removeEventListener("mousedown", closeSettingsOnOutside);
405
+ window.removeEventListener("resize", updateSettingsPosition);
406
+ window.removeEventListener("scroll", updateSettingsPosition, true);
407
+ if (settingsTimer)
408
+ clearTimeout(settingsTimer);
409
+ if (typeof ResizeObserver === "undefined")
410
+ window.removeEventListener("resize", updateContainerWidth);
411
+ });
412
+ return () => {
413
+ const tableViewportWidth = rootRef.value?.clientWidth ??
414
+ containerWidth.value + (props.rowSelection ? 44 : 0);
415
+ const displayColumns = state.value.columns;
416
+ const dataGridTemplateColumns = `${props.rowSelection ? "44px " : ""}${displayColumns.map((column) => `${column.width}px`).join(" ")}`;
417
+ const headerScrollbarWidth = props.virtual ? bodyScrollbarWidth.value : 0;
418
+ const dataViewportWidth = Math.max(0, tableViewportWidth - headerScrollbarWidth);
419
+ const headerGridTemplateColumns = `${props.rowSelection ? "44px " : ""}${displayColumns.map((column) => `${column.width}px`).join(" ")}${headerScrollbarWidth > 0 ? ` ${headerScrollbarWidth}px` : ""}`;
420
+ const range = props.virtual
421
+ ? virtualController.getRange(scrollTop.value, props.virtualHeight)
422
+ : null;
423
+ const toggle = (key, checked) => {
424
+ state.value = controller.toggleRow(key, checked);
425
+ emit("selectionChange", state.value.selectedKeys);
426
+ };
427
+ const renderCheckbox = (checked, indeterminate, label, onChange, disabled = false) => vue.h("label", { "aria-label": label, class: "cc-choice cc-table__checkbox" }, [
428
+ vue.h("input", {
429
+ checked,
430
+ disabled,
431
+ ref: ((element) => {
432
+ if (element)
433
+ element.indeterminate = indeterminate;
434
+ }),
435
+ type: "checkbox",
436
+ onChange: (event) => onChange(event.target.checked),
437
+ }),
438
+ vue.h("span", { class: "cc-table__checkbox-label" }),
439
+ ]);
440
+ const visibleColumnCount = state.value.columns.length;
441
+ const tableContentWidth = () => (props.rowSelection ? 44 : 0) +
442
+ displayColumns.reduce((sum, column) => sum + column.width, 0);
443
+ const tableWidthStyle = {
444
+ width: `${Math.max(tableContentWidth(), dataViewportWidth)}px`,
445
+ };
446
+ const headerWidthStyle = {
447
+ width: `${Math.max(tableContentWidth() + headerScrollbarWidth, tableViewportWidth)}px`,
448
+ };
449
+ const bodyWidthStyle = props.virtual
450
+ ? { width: `${tableViewportWidth}px` }
451
+ : tableWidthStyle;
452
+ const hasHorizontalOverflow = tableContentWidth() + headerScrollbarWidth > tableViewportWidth + 1;
453
+ const getFixedEdge = (column) => {
454
+ if (!hasHorizontalOverflow)
455
+ return undefined;
456
+ if (column.fixed === "left") {
457
+ const leftFixed = displayColumns.filter((item) => item.fixed === "left");
458
+ return leftFixed[leftFixed.length - 1]?.key === column.key
459
+ ? "left"
460
+ : undefined;
461
+ }
462
+ if (column.fixed === "right") {
463
+ const rightFixed = displayColumns.filter((item) => item.fixed === "right");
464
+ return rightFixed[0]?.key === column.key ? "right" : undefined;
465
+ }
466
+ return undefined;
467
+ };
468
+ const hasLeftFixedColumns = state.value.columns.some((column) => column.fixed === "left");
469
+ const getColumnStickyStyle = (column, area = "body") => {
470
+ const visibleColumns = displayColumns;
471
+ const index = visibleColumns.findIndex((item) => item.key === column.key);
472
+ if (index < 0 || !column.fixed)
473
+ return {};
474
+ if (!hasHorizontalOverflow)
475
+ return {};
476
+ if (column.fixed === "left") {
477
+ const left = visibleColumns
478
+ .slice(0, index)
479
+ .filter((item) => item.fixed === "left")
480
+ .reduce((sum, item) => sum + item.width, props.rowSelection ? 44 : 0);
481
+ return {
482
+ left: `${left}px`,
483
+ position: "sticky",
484
+ zIndex: 3,
485
+ };
486
+ }
487
+ const right = visibleColumns
488
+ .slice(index + 1)
489
+ .filter((item) => item.fixed === "right")
490
+ .reduce((sum, item) => sum + item.width, area === "head" ? headerScrollbarWidth : 0);
491
+ return {
492
+ position: "sticky",
493
+ right: `${right}px`,
494
+ zIndex: 3,
495
+ };
496
+ };
497
+ const renderRow = (row, rowIndex) => {
498
+ const key = controller.getRowKey(row, rowIndex);
499
+ return vue.h("div", {
500
+ class: "cc-table__row",
501
+ key,
502
+ style: {
503
+ ...tableWidthStyle,
504
+ gridTemplateColumns: dataGridTemplateColumns,
505
+ minHeight: `${props.rowHeight}px`,
506
+ },
507
+ }, [
508
+ props.rowSelection
509
+ ? vue.h("div", {
510
+ class: "cc-table__selection cc-table__selection--fixed",
511
+ "data-fixed-edge": hasHorizontalOverflow && !hasLeftFixedColumns
512
+ ? "left"
513
+ : undefined,
514
+ }, renderCheckbox(state.value.selectedKeys.includes(key), false, `${core.getClassComponentsLocale().tableSelectRowLabel} ${String(key)}`, (checked) => toggle(key, checked)))
515
+ : null,
516
+ ...displayColumns.map((column) => vue.h("div", {
517
+ class: "cc-table__cell",
518
+ "data-fixed": hasHorizontalOverflow
519
+ ? column.fixed
520
+ : undefined,
521
+ "data-fixed-edge": getFixedEdge(column),
522
+ key: column.key,
523
+ style: getColumnStickyStyle(column),
524
+ }, slots.cell?.({ column, row, rowIndex }) ??
525
+ String(row[column.dataIndex] ?? ""))),
526
+ ]);
527
+ };
528
+ return vue.h("div", {
529
+ ...attrs,
530
+ class: props.className,
531
+ ref: rootRef,
532
+ style: attrs.style,
533
+ onScroll: syncVirtualBodyScroll,
534
+ }, [
535
+ vue.h("div", {
536
+ class: "cc-table__row cc-table__row--head",
537
+ style: {
538
+ ...headerWidthStyle,
539
+ gridTemplateColumns: headerGridTemplateColumns,
540
+ },
541
+ }, [
542
+ props.rowSelection
543
+ ? vue.h("div", {
544
+ class: "cc-table__selection cc-table__selection--head cc-table__selection--fixed",
545
+ "data-fixed-edge": hasHorizontalOverflow && !hasLeftFixedColumns
546
+ ? "left"
547
+ : undefined,
548
+ }, renderCheckbox(state.value.selectionStatus === "all", state.value.selectionStatus === "partial", core.getClassComponentsLocale().tableSelectAllLabel, (checked) => {
549
+ state.value = controller.toggleAllRows(checked);
550
+ emit("selectionChange", state.value.selectedKeys);
551
+ }))
552
+ : null,
553
+ ...displayColumns.map((column, index) => vue.h("div", {
554
+ class: "cc-table__cell cc-table__cell--head",
555
+ "data-fixed": hasHorizontalOverflow
556
+ ? column.fixed
557
+ : undefined,
558
+ "data-fixed-edge": getFixedEdge(column),
559
+ key: column.key,
560
+ style: getColumnStickyStyle(column, "head"),
561
+ }, [
562
+ column.title,
563
+ vue.h("span", {
564
+ class: "cc-table__resize",
565
+ onPointerdown: (event) => {
566
+ const availableWidth = getContentWidth();
567
+ let lastX = event.clientX;
568
+ const move = (moveEvent) => {
569
+ const delta = moveEvent.clientX - lastX;
570
+ lastX = moveEvent.clientX;
571
+ state.value = controller.resizeColumn(column.key, delta, availableWidth);
572
+ };
573
+ const end = () => {
574
+ window.removeEventListener("pointermove", move);
575
+ window.removeEventListener("pointerup", end);
576
+ };
577
+ window.addEventListener("pointermove", move);
578
+ window.addEventListener("pointerup", end);
579
+ },
580
+ }),
581
+ index === displayColumns.length - 1
582
+ ? vue.h("div", {
583
+ class: "cc-table__column-settings",
584
+ ref: settingsRef,
585
+ }, [
586
+ vue.h("button", {
587
+ "aria-expanded": settingsOpen.value,
588
+ "aria-label": core.getClassComponentsLocale()
589
+ .tableColumnSettingsLabel,
590
+ ref: settingsButtonRef,
591
+ type: "button",
592
+ onClick: toggleSettings,
593
+ }, props.settingsIcon),
594
+ settingsVisible.value
595
+ ? vue.h(vue.Teleport, { to: "body" }, vue.h("div", {
596
+ "aria-multiselectable": "true",
597
+ class: "cc-select__menu cc-table__column-menu",
598
+ "data-state": settingsPhase.value,
599
+ ref: settingsMenuRef,
600
+ role: "listbox",
601
+ style: settingsMenuStyle.value,
602
+ }, state.value.allColumns.map((column) => vue.h("label", {
603
+ class: "cc-select__option cc-table__column-option",
604
+ "data-disabled": !column.hidden &&
605
+ visibleColumnCount <= 1,
606
+ "data-selected": !column.hidden,
607
+ key: column.key,
608
+ role: "option",
609
+ }, [
610
+ renderCheckbox(!column.hidden, false, column.title, (checked) => {
611
+ state.value =
612
+ controller.toggleColumn(column.key, checked, getContentWidth());
613
+ }, !column.hidden &&
614
+ visibleColumnCount <= 1),
615
+ vue.h("span", null, column.title),
616
+ !column.hidden
617
+ ? vue.h("span", {
618
+ "aria-hidden": "true",
619
+ class: "cc-select__check",
620
+ }, props.columnSettingsSelectedIcon)
621
+ : null,
622
+ ]))))
623
+ : null,
624
+ ])
625
+ : null,
626
+ ])),
627
+ headerScrollbarWidth > 0
628
+ ? vue.h("div", {
629
+ class: "cc-table__scrollbar-spacer cc-table__scrollbar-spacer--head",
630
+ })
631
+ : null,
632
+ ]),
633
+ vue.h("div", {
634
+ class: props.virtual
635
+ ? "cc-table__body cc-table__body--virtual"
636
+ : "cc-table__body",
637
+ ref: bodyRef,
638
+ onScroll: (event) => {
639
+ const target = event.currentTarget;
640
+ if (!props.virtual)
641
+ return;
642
+ scrollTop.value = target.scrollTop;
643
+ if (rootRef.value &&
644
+ rootRef.value.scrollLeft !== target.scrollLeft) {
645
+ rootRef.value.scrollLeft = target.scrollLeft;
646
+ }
647
+ },
648
+ style: props.virtual
649
+ ? {
650
+ ...bodyWidthStyle,
651
+ maxHeight: `${props.virtualHeight}px`,
652
+ overflowX: "hidden",
653
+ overflowY: "auto",
654
+ }
655
+ : bodyWidthStyle,
656
+ }, !props.loading && state.value.rows.length === 0
657
+ ? [
658
+ vue.h("div", { class: "cc-table__state" }, slots.empty?.() ??
659
+ vue.h(ClassEmpty, {
660
+ className: "cc-table__empty",
661
+ description: props.emptyText,
662
+ })),
663
+ ]
664
+ : props.virtual && range
665
+ ? [
666
+ range.offsetBefore > 0
667
+ ? vue.h("div", {
668
+ style: { height: `${range.offsetBefore}px` },
669
+ })
670
+ : null,
671
+ ...range.items.map((item) => {
672
+ const row = state.value.rows[item.index];
673
+ return row ? renderRow(row, item.index) : null;
674
+ }),
675
+ range.offsetAfter > 0
676
+ ? vue.h("div", {
677
+ style: { height: `${range.offsetAfter}px` },
678
+ })
679
+ : null,
680
+ ]
681
+ : state.value.rows.map(renderRow)),
682
+ props.loading
683
+ ? vue.h("div", {
684
+ class: "cc-table__loading",
685
+ "data-cover-header": props.loadingCoverHeader,
686
+ }, slots.loading?.() ??
687
+ vue.h(ClassLoading, { text: props.loadingText }))
688
+ : null,
689
+ ]);
690
+ };
691
+ },
692
+ });
693
+
694
+ exports.ClassTable = ClassTable;
695
+ //# sourceMappingURL=table.cjs.map