@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,637 @@
1
+ 'use strict';
2
+
3
+ var vue = require('vue');
4
+ var core = require('@class-kit/core');
5
+
6
+ const formSymbol = /*#__PURE__*/ Symbol("ClassComponentsForm");
7
+ const formInteractivitySymbol = /*#__PURE__*/ Symbol("ClassComponentsFormInteractivity");
8
+ const classIconPaths = {
9
+ chevronDown: ["M6 9l6 6 6-6"],
10
+ chevronLeft: ["M15 18l-6-6 6-6"],
11
+ chevronRight: ["M9 18l6-6-6-6"],
12
+ chevronUp: ["M18 15l-6-6-6 6"],
13
+ check: ["M20 6 9 17l-5-5"],
14
+ settings: [
15
+ "M12 15.5A3.5 3.5 0 1 0 12 8a3.5 3.5 0 0 0 0 7.5Z",
16
+ "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",
17
+ ],
18
+ star: [
19
+ "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",
20
+ ],
21
+ x: ["M18 6 6 18", "M6 6l12 12"],
22
+ };
23
+ function classIcon(name, className = "cc-icon") {
24
+ return vue.h("svg", {
25
+ "aria-hidden": "true",
26
+ class: className,
27
+ fill: "none",
28
+ focusable: "false",
29
+ viewBox: "0 0 24 24",
30
+ }, classIconPaths[name].map((d) => vue.h("path", {
31
+ d,
32
+ "stroke-linecap": "round",
33
+ "stroke-linejoin": "round",
34
+ "stroke-width": 2,
35
+ stroke: "currentColor",
36
+ })));
37
+ }
38
+ function resolveClassKitThemeName(theme) {
39
+ if (typeof theme === "string")
40
+ return theme;
41
+ return theme?.name ?? "minimal";
42
+ }
43
+ vue.defineComponent({
44
+ name: "ClassConfigProvider",
45
+ props: {
46
+ class: {
47
+ type: String,
48
+ default: "",
49
+ },
50
+ locale: {
51
+ type: Object,
52
+ default: undefined,
53
+ },
54
+ style: {
55
+ type: [String, Object, Array],
56
+ default: undefined,
57
+ },
58
+ theme: {
59
+ type: [String, Object],
60
+ default: "minimal",
61
+ },
62
+ },
63
+ setup(props, { slots }) {
64
+ const version = vue.ref(0);
65
+ const applyConfig = () => {
66
+ core.configureClassComponents({
67
+ locale: props.locale,
68
+ theme: props.theme,
69
+ });
70
+ version.value += 1;
71
+ };
72
+ vue.watch(() => [props.locale, props.theme], applyConfig, {
73
+ deep: true,
74
+ immediate: true,
75
+ });
76
+ return () => vue.h("div", {
77
+ class: ["cc-config-provider", props.class].filter(Boolean),
78
+ "data-cc-theme": resolveClassKitThemeName(props.theme),
79
+ style: props.style,
80
+ }, [
81
+ vue.h("div", { key: version.value, class: "cc-config-provider__content" }, slots.default?.()),
82
+ ]);
83
+ },
84
+ });
85
+ function optionalBooleanProp() {
86
+ return { type: Boolean, default: undefined };
87
+ }
88
+ function useFormInteractivity() {
89
+ return vue.inject(formInteractivitySymbol, {
90
+ disabled: vue.ref(false),
91
+ readOnly: vue.ref(false),
92
+ });
93
+ }
94
+ function resolveFieldInteractivity(form, disabled, readOnly) {
95
+ const resolvedDisabled = disabled ?? form.disabled.value;
96
+ return {
97
+ disabled: resolvedDisabled,
98
+ readOnly: !resolvedDisabled && (readOnly ?? form.readOnly.value),
99
+ };
100
+ }
101
+ const ClassVideoPlayer = /*#__PURE__*/ vue.defineComponent({
102
+ name: "ClassVideoPlayer",
103
+ inheritAttrs: false,
104
+ props: {
105
+ sources: {
106
+ type: [Array, String, Object],
107
+ required: true,
108
+ },
109
+ autoplay: { type: Boolean, default: false },
110
+ controls: { type: Boolean, default: true },
111
+ loop: { type: Boolean, default: false },
112
+ muted: { type: Boolean, default: false },
113
+ poster: String,
114
+ preload: {
115
+ type: String,
116
+ default: "metadata",
117
+ },
118
+ className: { type: String, default: "cc-video-player" },
119
+ videoClass: { type: String, default: "cc-video-player__video" },
120
+ },
121
+ setup(props, { attrs }) {
122
+ const videoRef = vue.ref(null);
123
+ const currentTime = vue.ref(0);
124
+ const duration = vue.ref(0);
125
+ const playing = vue.ref(false);
126
+ const toggle = () => {
127
+ const video = videoRef.value;
128
+ if (!video)
129
+ return;
130
+ if (video.paused)
131
+ void video.play();
132
+ else
133
+ video.pause();
134
+ };
135
+ return () => {
136
+ const state = new core.VideoPlayerController({
137
+ autoplay: props.autoplay,
138
+ controls: props.controls,
139
+ loop: props.loop,
140
+ muted: props.muted,
141
+ poster: props.poster,
142
+ preload: props.preload,
143
+ sources: props.sources,
144
+ }).getState();
145
+ return vue.h("div", { class: props.className }, [
146
+ vue.h("video", {
147
+ ...attrs,
148
+ autoplay: state.autoplay,
149
+ class: props.videoClass,
150
+ controls: false,
151
+ loop: state.loop,
152
+ muted: state.muted,
153
+ ref: videoRef,
154
+ onDurationchange: (event) => {
155
+ duration.value =
156
+ event.currentTarget.duration || 0;
157
+ },
158
+ onPause: () => {
159
+ playing.value = false;
160
+ },
161
+ onPlay: () => {
162
+ playing.value = true;
163
+ },
164
+ onTimeupdate: (event) => {
165
+ currentTime.value = event.currentTarget.currentTime;
166
+ },
167
+ playsinline: true,
168
+ poster: state.poster,
169
+ preload: state.preload,
170
+ }, state.sources.map((source) => vue.h("source", {
171
+ key: source.src,
172
+ src: source.src,
173
+ type: source.type,
174
+ }))),
175
+ state.controls
176
+ ? vue.h("div", { class: "cc-video-player__controls" }, [
177
+ vue.h("button", {
178
+ "aria-label": playing.value ? "Pause video" : "Play video",
179
+ class: "cc-video-player__play",
180
+ "data-playing": playing.value,
181
+ type: "button",
182
+ onClick: toggle,
183
+ }, [
184
+ vue.h("span", {
185
+ "aria-hidden": "true",
186
+ class: "cc-video-player__play-icon",
187
+ }),
188
+ ]),
189
+ vue.h(ClassProgressBar, {
190
+ className: "cc-progress cc-video-player__progress",
191
+ max: duration.value || 0,
192
+ min: 0,
193
+ step: 0.1,
194
+ value: currentTime.value,
195
+ onChange: (next) => {
196
+ if (!videoRef.value || !Number.isFinite(next))
197
+ return;
198
+ videoRef.value.currentTime = next;
199
+ currentTime.value = next;
200
+ },
201
+ }),
202
+ vue.h("span", { class: "cc-video-player__time" }, `${Math.floor(currentTime.value)} / ${Math.floor(duration.value || 0)}s`),
203
+ ])
204
+ : null,
205
+ ]);
206
+ };
207
+ },
208
+ });
209
+ function resolveVideoDetailContainer(container) {
210
+ return typeof container === "function" ? container() : (container ?? null);
211
+ }
212
+ function videoDetailContainerRect(container) {
213
+ const element = resolveVideoDetailContainer(container);
214
+ if (!element)
215
+ return undefined;
216
+ const rect = element.getBoundingClientRect();
217
+ return {
218
+ borderRadius: typeof window === "undefined"
219
+ ? undefined
220
+ : window.getComputedStyle(element).borderRadius,
221
+ height: Math.max(1, rect.height),
222
+ left: rect.left,
223
+ top: rect.top,
224
+ width: Math.max(1, rect.width),
225
+ };
226
+ }
227
+ function videoDetailTargetRect(sourceRect, container) {
228
+ const containerRect = videoDetailContainerRect(container);
229
+ if (containerRect) {
230
+ return {
231
+ height: containerRect.height,
232
+ left: 0,
233
+ top: 0,
234
+ width: containerRect.width,
235
+ };
236
+ }
237
+ const width = typeof window === "undefined" ? 390 : window.innerWidth;
238
+ const viewportHeight = typeof window === "undefined"
239
+ ? Math.round((width * 16) / 9)
240
+ : window.innerHeight;
241
+ const areaTop = 0;
242
+ const areaHeight = viewportHeight;
243
+ const ratio = sourceRect ? sourceRect.height / sourceRect.width : 9 / 16;
244
+ const height = Math.max(1, Math.min(areaHeight, Math.round(width * ratio)));
245
+ return {
246
+ height,
247
+ left: 0,
248
+ top: areaTop + Math.round((areaHeight - height) / 2),
249
+ width,
250
+ };
251
+ }
252
+ function videoDetailOverlayStyle(backdropColor, container) {
253
+ const rect = videoDetailContainerRect(container);
254
+ return {
255
+ "--cc-video-detail-backdrop-color": backdropColor,
256
+ ...(rect
257
+ ? {
258
+ borderRadius: rect.borderRadius ?? 0,
259
+ height: `${rect.height}px`,
260
+ left: "0px",
261
+ overflow: "hidden",
262
+ position: "absolute",
263
+ top: "0px",
264
+ width: `${rect.width}px`,
265
+ }
266
+ : {}),
267
+ };
268
+ }
269
+ function videoDetailStyle(state, full, container) {
270
+ const target = videoDetailTargetRect(state.sourceRect, container);
271
+ const containerRect = videoDetailContainerRect(container);
272
+ const sourceRect = state.sourceRect && containerRect
273
+ ? {
274
+ ...state.sourceRect,
275
+ left: state.sourceRect.left - containerRect.left,
276
+ top: state.sourceRect.top - containerRect.top,
277
+ }
278
+ : state.sourceRect;
279
+ const rect = full ? target : (sourceRect ?? target);
280
+ return {
281
+ "--cc-video-detail-duration": `${state.animationDuration}ms`,
282
+ "--cc-video-detail-backdrop-color": state.backdropColor,
283
+ height: `${rect.height}px`,
284
+ left: `${rect.left}px`,
285
+ top: `${rect.top}px`,
286
+ width: `${rect.width}px`,
287
+ };
288
+ }
289
+ const ClassVideoDetailTransition = /*#__PURE__*/ vue.defineComponent({
290
+ name: "ClassVideoDetailTransition",
291
+ inheritAttrs: false,
292
+ props: {
293
+ animationDuration: { type: Number, default: 420 },
294
+ backdropColor: { type: String, default: "rgba(0, 0, 0, 0.96)" },
295
+ className: { type: String, default: "cc-video-detail-transition" },
296
+ closeIcon: {
297
+ type: null,
298
+ default: () => classIcon("x"),
299
+ },
300
+ columns: { type: Number, default: 2 },
301
+ container: {
302
+ type: [Function, Object],
303
+ default: undefined,
304
+ },
305
+ detailClass: {
306
+ type: String,
307
+ default: "cc-video-detail-transition__detail",
308
+ },
309
+ gridClass: { type: String, default: "cc-video-detail-transition__grid" },
310
+ itemClass: { type: String, default: "cc-video-detail-transition__item" },
311
+ items: { type: Array, required: true },
312
+ },
313
+ emits: ["close", "open"],
314
+ setup(props, { attrs, emit }) {
315
+ const controller = new core.VideoDetailTransitionController({
316
+ animationDuration: props.animationDuration,
317
+ backdropColor: props.backdropColor,
318
+ items: props.items,
319
+ });
320
+ const state = vue.ref(controller.getState());
321
+ const full = vue.ref(false);
322
+ const timers = [];
323
+ const clearTimers = () => {
324
+ timers.splice(0).forEach((timer) => window.clearTimeout(timer));
325
+ };
326
+ const schedule = (callback, delay) => {
327
+ timers.push(window.setTimeout(callback, delay));
328
+ };
329
+ vue.watch(() => [props.animationDuration, props.backdropColor, props.items], () => {
330
+ state.value = controller.updateOptions({
331
+ animationDuration: props.animationDuration,
332
+ backdropColor: props.backdropColor,
333
+ items: props.items,
334
+ });
335
+ }, { deep: true });
336
+ vue.onBeforeUnmount(clearTimers);
337
+ const open = (item, element) => {
338
+ const rect = element.getBoundingClientRect();
339
+ clearTimers();
340
+ full.value = false;
341
+ state.value = controller.open(item.id, {
342
+ height: rect.height,
343
+ left: rect.left,
344
+ top: rect.top,
345
+ width: rect.width,
346
+ });
347
+ emit("open", item);
348
+ requestAnimationFrame(() => {
349
+ requestAnimationFrame(() => {
350
+ full.value = true;
351
+ });
352
+ });
353
+ schedule(() => {
354
+ state.value = controller.entered();
355
+ }, props.animationDuration);
356
+ };
357
+ const close = () => {
358
+ if (!state.value.activeItem)
359
+ return;
360
+ clearTimers();
361
+ state.value = controller.close();
362
+ full.value = false;
363
+ schedule(() => {
364
+ state.value = controller.closeNow();
365
+ emit("close");
366
+ }, props.animationDuration);
367
+ };
368
+ return () => vue.h("div", {
369
+ ...attrs,
370
+ class: props.className,
371
+ style: [
372
+ attrs.style,
373
+ { "--cc-video-detail-columns": props.columns },
374
+ ],
375
+ }, [
376
+ vue.h("div", { class: props.gridClass }, state.value.items.map((item) => vue.h("button", {
377
+ class: props.itemClass,
378
+ key: item.id,
379
+ type: "button",
380
+ onClick: (event) => open(item, event.currentTarget),
381
+ }, [
382
+ vue.h("img", { alt: "", src: item.poster }),
383
+ vue.h("span", { class: "cc-video-detail-transition__meta" }, [
384
+ vue.h("strong", null, item.title),
385
+ item.duration ? vue.h("small", null, item.duration) : null,
386
+ ]),
387
+ ]))),
388
+ state.value.activeItem
389
+ ? vue.h("div", {
390
+ class: "cc-video-detail-transition__overlay",
391
+ "data-open": full.value || state.value.phase === "open",
392
+ style: videoDetailOverlayStyle(state.value.backdropColor, props.container),
393
+ }, [
394
+ vue.h("button", {
395
+ "aria-label": "关闭视频详情",
396
+ class: "cc-video-detail-transition__backdrop",
397
+ type: "button",
398
+ onClick: close,
399
+ }),
400
+ vue.h("article", {
401
+ class: props.detailClass,
402
+ "data-full": full.value || state.value.phase === "open",
403
+ "data-phase": state.value.phase,
404
+ style: videoDetailStyle(state.value, full.value || state.value.phase === "open", props.container),
405
+ }, [
406
+ vue.h(ClassVideoPlayer, {
407
+ autoplay: true,
408
+ controls: true,
409
+ muted: true,
410
+ poster: state.value.activeItem.poster,
411
+ sources: state.value.activeItem.sources,
412
+ className: "cc-video-detail-transition__player",
413
+ videoClass: "cc-video-detail-transition__video",
414
+ }),
415
+ vue.h("div", { class: "cc-video-detail-transition__content" }, [
416
+ vue.h("button", {
417
+ "aria-label": "关闭视频详情",
418
+ type: "button",
419
+ onClick: close,
420
+ }, props.closeIcon),
421
+ vue.h("strong", null, state.value.activeItem.title),
422
+ state.value.activeItem.description
423
+ ? vue.h("p", null, state.value.activeItem.description)
424
+ : null,
425
+ ]),
426
+ ]),
427
+ ])
428
+ : null,
429
+ ]);
430
+ },
431
+ });
432
+ const ClassProgressBar = /*#__PURE__*/ vue.defineComponent({
433
+ name: "ClassProgressBar",
434
+ inheritAttrs: false,
435
+ props: {
436
+ defaultValue: Number,
437
+ disabled: optionalBooleanProp(),
438
+ errorClass: String,
439
+ fieldClass: { type: String, default: "cc-field cc-progress-field" },
440
+ followPointer: { type: Boolean, default: true },
441
+ initialValue: Number,
442
+ interactive: { type: Boolean, default: true },
443
+ label: [String, Object],
444
+ labelClass: { type: String, default: "cc-field__label" },
445
+ max: { type: Number, default: 100 },
446
+ min: { type: Number, default: 0 },
447
+ name: String,
448
+ readOnly: optionalBooleanProp(),
449
+ readonly: optionalBooleanProp(),
450
+ rules: Array,
451
+ step: { type: Number, default: 1 },
452
+ validateOn: Array,
453
+ value: Number,
454
+ className: { type: String, default: "cc-progress" },
455
+ },
456
+ emits: ["change", "changeEnd", "update:value"],
457
+ setup(props, { attrs, emit }) {
458
+ const form = vue.inject(formSymbol, null);
459
+ const formInteractivity = useFormInteractivity();
460
+ const formState = vue.shallowRef(form?.getState() ?? null);
461
+ const trackRef = vue.ref(null);
462
+ const thumbRef = vue.ref(null);
463
+ const dragging = vue.ref(false);
464
+ const safeMin = vue.computed(() => Number.isFinite(props.min) ? props.min : 0);
465
+ const safeMax = vue.computed(() => Number.isFinite(props.max)
466
+ ? Math.max(safeMin.value, props.max)
467
+ : Math.max(safeMin.value, 100));
468
+ const safeStep = vue.computed(() => Number.isFinite(props.step) && props.step > 0 ? props.step : 1);
469
+ const formField = vue.computed(() => props.name ? formState.value?.fields[props.name] : undefined);
470
+ const formFieldValue = vue.computed(() => Number(formField.value?.value));
471
+ const usesFormField = vue.computed(() => Boolean(form && props.name));
472
+ const safeValue = vue.computed(() => usesFormField.value && Number.isFinite(formFieldValue.value)
473
+ ? formFieldValue.value
474
+ : Number.isFinite(props.value)
475
+ ? props.value
476
+ : undefined);
477
+ const safeDefaultValue = vue.computed(() => Number.isFinite(props.defaultValue) ? props.defaultValue : undefined);
478
+ const fieldInitialValue = vue.computed(() => Number.isFinite(props.initialValue)
479
+ ? props.initialValue
480
+ : safeDefaultValue.value);
481
+ const interactivity = vue.computed(() => resolveFieldInteractivity(formInteractivity, props.disabled, props.readOnly ?? props.readonly));
482
+ const locked = vue.computed(() => interactivity.value.disabled || interactivity.value.readOnly);
483
+ const controller = new core.ProgressController({
484
+ disabled: locked.value,
485
+ max: safeMax.value,
486
+ min: safeMin.value,
487
+ step: safeStep.value,
488
+ value: safeValue.value ?? fieldInitialValue.value ?? safeMin.value,
489
+ });
490
+ const state = vue.ref(controller.getState());
491
+ let unsubscribeField;
492
+ let unsubscribeForm;
493
+ vue.onMounted(() => {
494
+ if (!form || !props.name)
495
+ return;
496
+ unsubscribeForm = form.subscribe((nextState) => {
497
+ formState.value = nextState;
498
+ });
499
+ unsubscribeField = form.registerField(props.name, {
500
+ initialValue: fieldInitialValue.value ?? safeMin.value,
501
+ rules: props.rules,
502
+ validateOn: props.validateOn,
503
+ });
504
+ });
505
+ vue.onBeforeUnmount(() => {
506
+ unsubscribeField?.();
507
+ unsubscribeForm?.();
508
+ });
509
+ vue.watch(() => [
510
+ locked.value,
511
+ props.max,
512
+ props.min,
513
+ props.step,
514
+ props.value,
515
+ formFieldValue.value,
516
+ ], () => {
517
+ state.value = controller.updateOptions({
518
+ disabled: locked.value,
519
+ max: safeMax.value,
520
+ min: safeMin.value,
521
+ step: safeStep.value,
522
+ value: safeValue.value ?? state.value.value,
523
+ });
524
+ });
525
+ const commitValue = (nextValue, end = false) => {
526
+ state.value = controller.setValue(nextValue);
527
+ if (form && props.name)
528
+ void form.setValue(props.name, state.value.value);
529
+ emit("update:value", state.value.value);
530
+ emit("change", state.value.value);
531
+ if (end)
532
+ emit("changeEnd", state.value.value);
533
+ };
534
+ const updateFromClientX = (clientX, end = false) => {
535
+ const rect = trackRef.value?.getBoundingClientRect();
536
+ if (!rect)
537
+ return;
538
+ state.value = controller.valueFromClientX(clientX, rect, thumbRef.value?.offsetWidth ?? 0);
539
+ if (form && props.name)
540
+ void form.setValue(props.name, state.value.value);
541
+ emit("update:value", state.value.value);
542
+ emit("change", state.value.value);
543
+ if (end)
544
+ emit("changeEnd", state.value.value);
545
+ };
546
+ return () => {
547
+ const errors = formField.value?.errors ?? [];
548
+ const errorId = props.name ? `${props.name}-error` : undefined;
549
+ const progress = vue.h("div", {
550
+ ...attrs,
551
+ "aria-describedby": errors.length > 0 ? errorId : undefined,
552
+ "aria-disabled": interactivity.value.disabled,
553
+ "aria-readonly": interactivity.value.readOnly || undefined,
554
+ "aria-valuemax": state.value.max,
555
+ "aria-valuemin": state.value.min,
556
+ "aria-valuenow": state.value.value,
557
+ class: props.className,
558
+ "data-disabled": interactivity.value.disabled,
559
+ "data-dragging": dragging.value,
560
+ "data-interactive": props.interactive && !locked.value,
561
+ "data-readonly": interactivity.value.readOnly,
562
+ ref: trackRef,
563
+ role: "slider",
564
+ tabindex: locked.value || !props.interactive ? -1 : 0,
565
+ onKeydown: (event) => {
566
+ if (locked.value || !props.interactive)
567
+ return;
568
+ if (event.key === "ArrowLeft" || event.key === "ArrowDown")
569
+ commitValue(state.value.value - state.value.step);
570
+ if (event.key === "ArrowRight" || event.key === "ArrowUp")
571
+ commitValue(state.value.value + state.value.step);
572
+ if (event.key === "Home")
573
+ commitValue(state.value.min);
574
+ if (event.key === "End")
575
+ commitValue(state.value.max);
576
+ },
577
+ onPointerdown: (event) => {
578
+ if (locked.value || !props.interactive)
579
+ return;
580
+ event.preventDefault();
581
+ dragging.value = true;
582
+ updateFromClientX(event.clientX);
583
+ event.currentTarget.setPointerCapture(event.pointerId);
584
+ },
585
+ onPointermove: (event) => {
586
+ if (!props.interactive ||
587
+ !props.followPointer ||
588
+ locked.value ||
589
+ event.buttons !== 1)
590
+ return;
591
+ updateFromClientX(event.clientX);
592
+ },
593
+ onPointerup: (event) => {
594
+ if (locked.value || !props.interactive)
595
+ return;
596
+ dragging.value = false;
597
+ event.currentTarget.releasePointerCapture?.(event.pointerId);
598
+ updateFromClientX(event.clientX, true);
599
+ },
600
+ onPointercancel: () => {
601
+ dragging.value = false;
602
+ },
603
+ }, [
604
+ vue.h("span", { class: "cc-progress__track" }),
605
+ vue.h("span", {
606
+ class: "cc-progress__fill",
607
+ style: { width: `${state.value.percent}%` },
608
+ }),
609
+ vue.h("span", {
610
+ class: "cc-progress__thumb",
611
+ ref: thumbRef,
612
+ style: {
613
+ left: `calc(${state.value.percent / 100} * (100% - var(--cc-progress-thumb-size)))`,
614
+ },
615
+ }),
616
+ ]);
617
+ if (!props.name && !props.label)
618
+ return progress;
619
+ return vue.h("div", {
620
+ class: props.fieldClass,
621
+ "data-disabled": interactivity.value.disabled,
622
+ "data-readonly": interactivity.value.readOnly,
623
+ }, [
624
+ props.label
625
+ ? vue.h("span", { class: props.labelClass }, props.label)
626
+ : null,
627
+ progress,
628
+ errorId && errors.length > 0
629
+ ? vue.h("div", { class: props.errorClass ?? "cc-field__error", id: errorId }, errors.join(","))
630
+ : null,
631
+ ]);
632
+ };
633
+ },
634
+ });
635
+
636
+ exports.ClassVideoDetailTransition = ClassVideoDetailTransition;
637
+ //# sourceMappingURL=video-detail-transition.cjs.map