@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.
- package/CHANGELOG.md +6 -0
- package/LICENSE +3 -0
- package/README.md +86 -0
- package/dist/components/affix.cjs +132 -0
- package/dist/components/affix.cjs.map +1 -0
- package/dist/components/affix.d.ts +2 -0
- package/dist/components/affix.d.ts.map +1 -0
- package/dist/components/affix.js +130 -0
- package/dist/components/affix.js.map +1 -0
- package/dist/components/backtop.cjs +180 -0
- package/dist/components/backtop.cjs.map +1 -0
- package/dist/components/backtop.d.ts +2 -0
- package/dist/components/backtop.d.ts.map +1 -0
- package/dist/components/backtop.js +178 -0
- package/dist/components/backtop.js.map +1 -0
- package/dist/components/badge.cjs +84 -0
- package/dist/components/badge.cjs.map +1 -0
- package/dist/components/badge.d.ts +2 -0
- package/dist/components/badge.d.ts.map +1 -0
- package/dist/components/badge.js +82 -0
- package/dist/components/badge.js.map +1 -0
- package/dist/components/barcode.cjs +122 -0
- package/dist/components/barcode.cjs.map +1 -0
- package/dist/components/barcode.d.ts +2 -0
- package/dist/components/barcode.d.ts.map +1 -0
- package/dist/components/barcode.js +120 -0
- package/dist/components/barcode.js.map +1 -0
- package/dist/components/breadcrumb.cjs +76 -0
- package/dist/components/breadcrumb.cjs.map +1 -0
- package/dist/components/breadcrumb.d.ts +2 -0
- package/dist/components/breadcrumb.d.ts.map +1 -0
- package/dist/components/breadcrumb.js +74 -0
- package/dist/components/breadcrumb.js.map +1 -0
- package/dist/components/button.cjs +104 -0
- package/dist/components/button.cjs.map +1 -0
- package/dist/components/button.d.ts +2 -0
- package/dist/components/button.d.ts.map +1 -0
- package/dist/components/button.js +102 -0
- package/dist/components/button.js.map +1 -0
- package/dist/components/calendar.cjs +173 -0
- package/dist/components/calendar.cjs.map +1 -0
- package/dist/components/calendar.d.ts +2 -0
- package/dist/components/calendar.d.ts.map +1 -0
- package/dist/components/calendar.js +171 -0
- package/dist/components/calendar.js.map +1 -0
- package/dist/components/canvas-editor.cjs +450 -0
- package/dist/components/canvas-editor.cjs.map +1 -0
- package/dist/components/canvas-editor.d.ts +2 -0
- package/dist/components/canvas-editor.d.ts.map +1 -0
- package/dist/components/canvas-editor.js +448 -0
- package/dist/components/canvas-editor.js.map +1 -0
- package/dist/components/canvas-image.cjs +124 -0
- package/dist/components/canvas-image.cjs.map +1 -0
- package/dist/components/canvas-image.d.ts +2 -0
- package/dist/components/canvas-image.d.ts.map +1 -0
- package/dist/components/canvas-image.js +122 -0
- package/dist/components/canvas-image.js.map +1 -0
- package/dist/components/chat-virtual-list.cjs +625 -0
- package/dist/components/chat-virtual-list.cjs.map +1 -0
- package/dist/components/chat-virtual-list.d.ts +2 -0
- package/dist/components/chat-virtual-list.d.ts.map +1 -0
- package/dist/components/chat-virtual-list.js +623 -0
- package/dist/components/chat-virtual-list.js.map +1 -0
- package/dist/components/checkbox.cjs +195 -0
- package/dist/components/checkbox.cjs.map +1 -0
- package/dist/components/checkbox.d.ts +2 -0
- package/dist/components/checkbox.d.ts.map +1 -0
- package/dist/components/checkbox.js +193 -0
- package/dist/components/checkbox.js.map +1 -0
- package/dist/components/checked.cjs +196 -0
- package/dist/components/checked.cjs.map +1 -0
- package/dist/components/checked.d.ts +2 -0
- package/dist/components/checked.d.ts.map +1 -0
- package/dist/components/checked.js +194 -0
- package/dist/components/checked.js.map +1 -0
- package/dist/components/color-picker.cjs +364 -0
- package/dist/components/color-picker.cjs.map +1 -0
- package/dist/components/color-picker.d.ts +2 -0
- package/dist/components/color-picker.d.ts.map +1 -0
- package/dist/components/color-picker.js +362 -0
- package/dist/components/color-picker.js.map +1 -0
- package/dist/components/comic-reader.cjs +166 -0
- package/dist/components/comic-reader.cjs.map +1 -0
- package/dist/components/comic-reader.d.ts +2 -0
- package/dist/components/comic-reader.d.ts.map +1 -0
- package/dist/components/comic-reader.js +164 -0
- package/dist/components/comic-reader.js.map +1 -0
- package/dist/components/config-provider.cjs +55 -0
- package/dist/components/config-provider.cjs.map +1 -0
- package/dist/components/config-provider.d.ts +2 -0
- package/dist/components/config-provider.d.ts.map +1 -0
- package/dist/components/config-provider.js +53 -0
- package/dist/components/config-provider.js.map +1 -0
- package/dist/components/config-table.cjs +697 -0
- package/dist/components/config-table.cjs.map +1 -0
- package/dist/components/config-table.d.ts +2 -0
- package/dist/components/config-table.d.ts.map +1 -0
- package/dist/components/config-table.js +695 -0
- package/dist/components/config-table.js.map +1 -0
- package/dist/components/countdown.cjs +122 -0
- package/dist/components/countdown.cjs.map +1 -0
- package/dist/components/countdown.d.ts +2 -0
- package/dist/components/countdown.d.ts.map +1 -0
- package/dist/components/countdown.js +120 -0
- package/dist/components/countdown.js.map +1 -0
- package/dist/components/danmaku.cjs +116 -0
- package/dist/components/danmaku.cjs.map +1 -0
- package/dist/components/danmaku.d.ts +2 -0
- package/dist/components/danmaku.d.ts.map +1 -0
- package/dist/components/danmaku.js +114 -0
- package/dist/components/danmaku.js.map +1 -0
- package/dist/components/date-picker.cjs +350 -0
- package/dist/components/date-picker.cjs.map +1 -0
- package/dist/components/date-picker.d.ts +2 -0
- package/dist/components/date-picker.d.ts.map +1 -0
- package/dist/components/date-picker.js +348 -0
- package/dist/components/date-picker.js.map +1 -0
- package/dist/components/date-range-picker.cjs +428 -0
- package/dist/components/date-range-picker.cjs.map +1 -0
- package/dist/components/date-range-picker.d.ts +2 -0
- package/dist/components/date-range-picker.d.ts.map +1 -0
- package/dist/components/date-range-picker.js +426 -0
- package/dist/components/date-range-picker.js.map +1 -0
- package/dist/components/design-effect.cjs +121 -0
- package/dist/components/design-effect.cjs.map +1 -0
- package/dist/components/design-effect.d.ts +2 -0
- package/dist/components/design-effect.d.ts.map +1 -0
- package/dist/components/design-effect.js +119 -0
- package/dist/components/design-effect.js.map +1 -0
- package/dist/components/drag-drop-board.cjs +399 -0
- package/dist/components/drag-drop-board.cjs.map +1 -0
- package/dist/components/drag-drop-board.d.ts +2 -0
- package/dist/components/drag-drop-board.d.ts.map +1 -0
- package/dist/components/drag-drop-board.js +397 -0
- package/dist/components/drag-drop-board.js.map +1 -0
- package/dist/components/draggable.cjs +193 -0
- package/dist/components/draggable.cjs.map +1 -0
- package/dist/components/draggable.d.ts +2 -0
- package/dist/components/draggable.d.ts.map +1 -0
- package/dist/components/draggable.js +191 -0
- package/dist/components/draggable.js.map +1 -0
- package/dist/components/ellipsis-text.cjs +176 -0
- package/dist/components/ellipsis-text.cjs.map +1 -0
- package/dist/components/ellipsis-text.d.ts +2 -0
- package/dist/components/ellipsis-text.d.ts.map +1 -0
- package/dist/components/ellipsis-text.js +174 -0
- package/dist/components/ellipsis-text.js.map +1 -0
- package/dist/components/empty.cjs +124 -0
- package/dist/components/empty.cjs.map +1 -0
- package/dist/components/empty.d.ts +2 -0
- package/dist/components/empty.d.ts.map +1 -0
- package/dist/components/empty.js +122 -0
- package/dist/components/empty.js.map +1 -0
- package/dist/components/field.cjs +265 -0
- package/dist/components/field.cjs.map +1 -0
- package/dist/components/field.d.ts +2 -0
- package/dist/components/field.d.ts.map +1 -0
- package/dist/components/field.js +263 -0
- package/dist/components/field.js.map +1 -0
- package/dist/components/file-preview.cjs +392 -0
- package/dist/components/file-preview.cjs.map +1 -0
- package/dist/components/file-preview.d.ts +3 -0
- package/dist/components/file-preview.d.ts.map +1 -0
- package/dist/components/file-preview.js +390 -0
- package/dist/components/file-preview.js.map +1 -0
- package/dist/components/floating-ball.cjs +203 -0
- package/dist/components/floating-ball.cjs.map +1 -0
- package/dist/components/floating-ball.d.ts +2 -0
- package/dist/components/floating-ball.d.ts.map +1 -0
- package/dist/components/floating-ball.js +201 -0
- package/dist/components/floating-ball.js.map +1 -0
- package/dist/components/form.cjs +146 -0
- package/dist/components/form.cjs.map +1 -0
- package/dist/components/form.d.ts +3 -0
- package/dist/components/form.d.ts.map +1 -0
- package/dist/components/form.js +141 -0
- package/dist/components/form.js.map +1 -0
- package/dist/components/gradient-text.cjs +103 -0
- package/dist/components/gradient-text.cjs.map +1 -0
- package/dist/components/gradient-text.d.ts +2 -0
- package/dist/components/gradient-text.d.ts.map +1 -0
- package/dist/components/gradient-text.js +101 -0
- package/dist/components/gradient-text.js.map +1 -0
- package/dist/components/input.cjs +264 -0
- package/dist/components/input.cjs.map +1 -0
- package/dist/components/input.d.ts +2 -0
- package/dist/components/input.d.ts.map +1 -0
- package/dist/components/input.js +262 -0
- package/dist/components/input.js.map +1 -0
- package/dist/components/lazy-image.cjs +203 -0
- package/dist/components/lazy-image.cjs.map +1 -0
- package/dist/components/lazy-image.d.ts +3 -0
- package/dist/components/lazy-image.d.ts.map +1 -0
- package/dist/components/lazy-image.js +201 -0
- package/dist/components/lazy-image.js.map +1 -0
- package/dist/components/live-room.cjs +644 -0
- package/dist/components/live-room.cjs.map +1 -0
- package/dist/components/live-room.d.ts +2 -0
- package/dist/components/live-room.d.ts.map +1 -0
- package/dist/components/live-room.js +642 -0
- package/dist/components/live-room.js.map +1 -0
- package/dist/components/loading.cjs +105 -0
- package/dist/components/loading.cjs.map +1 -0
- package/dist/components/loading.d.ts +2 -0
- package/dist/components/loading.d.ts.map +1 -0
- package/dist/components/loading.js +103 -0
- package/dist/components/loading.js.map +1 -0
- package/dist/components/marquee.cjs +267 -0
- package/dist/components/marquee.cjs.map +1 -0
- package/dist/components/marquee.d.ts +2 -0
- package/dist/components/marquee.d.ts.map +1 -0
- package/dist/components/marquee.js +265 -0
- package/dist/components/marquee.js.map +1 -0
- package/dist/components/masonry-virtual-list.cjs +241 -0
- package/dist/components/masonry-virtual-list.cjs.map +1 -0
- package/dist/components/masonry-virtual-list.d.ts +2 -0
- package/dist/components/masonry-virtual-list.d.ts.map +1 -0
- package/dist/components/masonry-virtual-list.js +239 -0
- package/dist/components/masonry-virtual-list.js.map +1 -0
- package/dist/components/modal.cjs +337 -0
- package/dist/components/modal.cjs.map +1 -0
- package/dist/components/modal.d.ts +2 -0
- package/dist/components/modal.d.ts.map +1 -0
- package/dist/components/modal.js +335 -0
- package/dist/components/modal.js.map +1 -0
- package/dist/components/multi-column-picker.cjs +284 -0
- package/dist/components/multi-column-picker.cjs.map +1 -0
- package/dist/components/multi-column-picker.d.ts +2 -0
- package/dist/components/multi-column-picker.d.ts.map +1 -0
- package/dist/components/multi-column-picker.js +282 -0
- package/dist/components/multi-column-picker.js.map +1 -0
- package/dist/components/novel-reader.cjs +401 -0
- package/dist/components/novel-reader.cjs.map +1 -0
- package/dist/components/novel-reader.d.ts +2 -0
- package/dist/components/novel-reader.d.ts.map +1 -0
- package/dist/components/novel-reader.js +399 -0
- package/dist/components/novel-reader.js.map +1 -0
- package/dist/components/number-input.cjs +399 -0
- package/dist/components/number-input.cjs.map +1 -0
- package/dist/components/number-input.d.ts +2 -0
- package/dist/components/number-input.d.ts.map +1 -0
- package/dist/components/number-input.js +397 -0
- package/dist/components/number-input.js.map +1 -0
- package/dist/components/pagination.cjs +144 -0
- package/dist/components/pagination.cjs.map +1 -0
- package/dist/components/pagination.d.ts +2 -0
- package/dist/components/pagination.d.ts.map +1 -0
- package/dist/components/pagination.js +142 -0
- package/dist/components/pagination.js.map +1 -0
- package/dist/components/password-input.cjs +344 -0
- package/dist/components/password-input.cjs.map +1 -0
- package/dist/components/password-input.d.ts +2 -0
- package/dist/components/password-input.d.ts.map +1 -0
- package/dist/components/password-input.js +342 -0
- package/dist/components/password-input.js.map +1 -0
- package/dist/components/popconfirm.cjs +198 -0
- package/dist/components/popconfirm.cjs.map +1 -0
- package/dist/components/popconfirm.d.ts +2 -0
- package/dist/components/popconfirm.d.ts.map +1 -0
- package/dist/components/popconfirm.js +196 -0
- package/dist/components/popconfirm.js.map +1 -0
- package/dist/components/popup.cjs +391 -0
- package/dist/components/popup.cjs.map +1 -0
- package/dist/components/popup.d.ts +2 -0
- package/dist/components/popup.d.ts.map +1 -0
- package/dist/components/popup.js +389 -0
- package/dist/components/popup.js.map +1 -0
- package/dist/components/progress-bar.cjs +276 -0
- package/dist/components/progress-bar.cjs.map +1 -0
- package/dist/components/progress-bar.d.ts +2 -0
- package/dist/components/progress-bar.d.ts.map +1 -0
- package/dist/components/progress-bar.js +274 -0
- package/dist/components/progress-bar.js.map +1 -0
- package/dist/components/qr-code.cjs +144 -0
- package/dist/components/qr-code.cjs.map +1 -0
- package/dist/components/qr-code.d.ts +2 -0
- package/dist/components/qr-code.d.ts.map +1 -0
- package/dist/components/qr-code.js +142 -0
- package/dist/components/qr-code.js.map +1 -0
- package/dist/components/radio-group.cjs +210 -0
- package/dist/components/radio-group.cjs.map +1 -0
- package/dist/components/radio-group.d.ts +3 -0
- package/dist/components/radio-group.d.ts.map +1 -0
- package/dist/components/radio-group.js +208 -0
- package/dist/components/radio-group.js.map +1 -0
- package/dist/components/rating.cjs +251 -0
- package/dist/components/rating.cjs.map +1 -0
- package/dist/components/rating.d.ts +2 -0
- package/dist/components/rating.d.ts.map +1 -0
- package/dist/components/rating.js +249 -0
- package/dist/components/rating.js.map +1 -0
- package/dist/components/rolling-number.cjs +99 -0
- package/dist/components/rolling-number.cjs.map +1 -0
- package/dist/components/rolling-number.d.ts +2 -0
- package/dist/components/rolling-number.d.ts.map +1 -0
- package/dist/components/rolling-number.js +97 -0
- package/dist/components/rolling-number.js.map +1 -0
- package/dist/components/select.cjs +475 -0
- package/dist/components/select.cjs.map +1 -0
- package/dist/components/select.d.ts +3 -0
- package/dist/components/select.d.ts.map +1 -0
- package/dist/components/select.js +473 -0
- package/dist/components/select.js.map +1 -0
- package/dist/components/signature.cjs +372 -0
- package/dist/components/signature.cjs.map +1 -0
- package/dist/components/signature.d.ts +2 -0
- package/dist/components/signature.d.ts.map +1 -0
- package/dist/components/signature.js +370 -0
- package/dist/components/signature.js.map +1 -0
- package/dist/components/skeleton.cjs +102 -0
- package/dist/components/skeleton.cjs.map +1 -0
- package/dist/components/skeleton.d.ts +2 -0
- package/dist/components/skeleton.d.ts.map +1 -0
- package/dist/components/skeleton.js +100 -0
- package/dist/components/skeleton.js.map +1 -0
- package/dist/components/slide-captcha.cjs +418 -0
- package/dist/components/slide-captcha.cjs.map +1 -0
- package/dist/components/slide-captcha.d.ts +2 -0
- package/dist/components/slide-captcha.d.ts.map +1 -0
- package/dist/components/slide-captcha.js +416 -0
- package/dist/components/slide-captcha.js.map +1 -0
- package/dist/components/swiper.cjs +441 -0
- package/dist/components/swiper.cjs.map +1 -0
- package/dist/components/swiper.d.ts +2 -0
- package/dist/components/swiper.d.ts.map +1 -0
- package/dist/components/swiper.js +439 -0
- package/dist/components/swiper.js.map +1 -0
- package/dist/components/switch.cjs +214 -0
- package/dist/components/switch.cjs.map +1 -0
- package/dist/components/switch.d.ts +2 -0
- package/dist/components/switch.d.ts.map +1 -0
- package/dist/components/switch.js +212 -0
- package/dist/components/switch.js.map +1 -0
- package/dist/components/table.cjs +695 -0
- package/dist/components/table.cjs.map +1 -0
- package/dist/components/table.d.ts +2 -0
- package/dist/components/table.d.ts.map +1 -0
- package/dist/components/table.js +693 -0
- package/dist/components/table.js.map +1 -0
- package/dist/components/tabs.cjs +330 -0
- package/dist/components/tabs.cjs.map +1 -0
- package/dist/components/tabs.d.ts +3 -0
- package/dist/components/tabs.d.ts.map +1 -0
- package/dist/components/tabs.js +328 -0
- package/dist/components/tabs.js.map +1 -0
- package/dist/components/tag.cjs +151 -0
- package/dist/components/tag.cjs.map +1 -0
- package/dist/components/tag.d.ts +2 -0
- package/dist/components/tag.d.ts.map +1 -0
- package/dist/components/tag.js +149 -0
- package/dist/components/tag.js.map +1 -0
- package/dist/components/textarea.cjs +266 -0
- package/dist/components/textarea.cjs.map +1 -0
- package/dist/components/textarea.d.ts +2 -0
- package/dist/components/textarea.d.ts.map +1 -0
- package/dist/components/textarea.js +264 -0
- package/dist/components/textarea.js.map +1 -0
- package/dist/components/tilt-card.cjs +221 -0
- package/dist/components/tilt-card.cjs.map +1 -0
- package/dist/components/tilt-card.d.ts +2 -0
- package/dist/components/tilt-card.d.ts.map +1 -0
- package/dist/components/tilt-card.js +219 -0
- package/dist/components/tilt-card.js.map +1 -0
- package/dist/components/timeline.cjs +87 -0
- package/dist/components/timeline.cjs.map +1 -0
- package/dist/components/timeline.d.ts +2 -0
- package/dist/components/timeline.d.ts.map +1 -0
- package/dist/components/timeline.js +85 -0
- package/dist/components/timeline.js.map +1 -0
- package/dist/components/toast.cjs +186 -0
- package/dist/components/toast.cjs.map +1 -0
- package/dist/components/toast.d.ts +2 -0
- package/dist/components/toast.d.ts.map +1 -0
- package/dist/components/toast.js +183 -0
- package/dist/components/toast.js.map +1 -0
- package/dist/components/tooltip.cjs +210 -0
- package/dist/components/tooltip.cjs.map +1 -0
- package/dist/components/tooltip.d.ts +2 -0
- package/dist/components/tooltip.d.ts.map +1 -0
- package/dist/components/tooltip.js +208 -0
- package/dist/components/tooltip.js.map +1 -0
- package/dist/components/typewriter-text.cjs +180 -0
- package/dist/components/typewriter-text.cjs.map +1 -0
- package/dist/components/typewriter-text.d.ts +2 -0
- package/dist/components/typewriter-text.d.ts.map +1 -0
- package/dist/components/typewriter-text.js +178 -0
- package/dist/components/typewriter-text.js.map +1 -0
- package/dist/components/upload.cjs +273 -0
- package/dist/components/upload.cjs.map +1 -0
- package/dist/components/upload.d.ts +2 -0
- package/dist/components/upload.d.ts.map +1 -0
- package/dist/components/upload.js +271 -0
- package/dist/components/upload.js.map +1 -0
- package/dist/components/verification-code.cjs +242 -0
- package/dist/components/verification-code.cjs.map +1 -0
- package/dist/components/verification-code.d.ts +2 -0
- package/dist/components/verification-code.d.ts.map +1 -0
- package/dist/components/verification-code.js +240 -0
- package/dist/components/verification-code.js.map +1 -0
- package/dist/components/video-detail-transition.cjs +637 -0
- package/dist/components/video-detail-transition.cjs.map +1 -0
- package/dist/components/video-detail-transition.d.ts +2 -0
- package/dist/components/video-detail-transition.d.ts.map +1 -0
- package/dist/components/video-detail-transition.js +635 -0
- package/dist/components/video-detail-transition.js.map +1 -0
- package/dist/components/video-player.cjs +384 -0
- package/dist/components/video-player.cjs.map +1 -0
- package/dist/components/video-player.d.ts +2 -0
- package/dist/components/video-player.d.ts.map +1 -0
- package/dist/components/video-player.js +382 -0
- package/dist/components/video-player.js.map +1 -0
- package/dist/components/virtual-list.cjs +503 -0
- package/dist/components/virtual-list.cjs.map +1 -0
- package/dist/components/virtual-list.d.ts +2 -0
- package/dist/components/virtual-list.d.ts.map +1 -0
- package/dist/components/virtual-list.js +501 -0
- package/dist/components/virtual-list.js.map +1 -0
- package/dist/components/virtual-select.cjs +538 -0
- package/dist/components/virtual-select.cjs.map +1 -0
- package/dist/components/virtual-select.d.ts +3 -0
- package/dist/components/virtual-select.d.ts.map +1 -0
- package/dist/components/virtual-select.js +536 -0
- package/dist/components/virtual-select.js.map +1 -0
- package/dist/components/virtual-table.cjs +696 -0
- package/dist/components/virtual-table.cjs.map +1 -0
- package/dist/components/virtual-table.d.ts +2 -0
- package/dist/components/virtual-table.d.ts.map +1 -0
- package/dist/components/virtual-table.js +694 -0
- package/dist/components/virtual-table.js.map +1 -0
- package/dist/import-transform-BiXH181o.js +144 -0
- package/dist/import-transform-BiXH181o.js.map +1 -0
- package/dist/import-transform-DLby8nRN.js +142 -0
- package/dist/import-transform-DLby8nRN.js.map +1 -0
- package/dist/import-transform.d.ts +6 -0
- package/dist/import-transform.d.ts.map +1 -0
- package/dist/index.cjs +11361 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +6649 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +11070 -0
- package/dist/index.js.map +1 -0
- package/dist/styles/base.css +455 -0
- package/dist/styles/components/affix.css +15 -0
- package/dist/styles/components/backtop.css +67 -0
- package/dist/styles/components/badge.css +33 -0
- package/dist/styles/components/barcode.css +33 -0
- package/dist/styles/components/breadcrumb.css +15 -0
- package/dist/styles/components/button.css +156 -0
- package/dist/styles/components/calendar.css +174 -0
- package/dist/styles/components/canvas-editor.css +327 -0
- package/dist/styles/components/canvas-image.css +40 -0
- package/dist/styles/components/chat-virtual-list.css +108 -0
- package/dist/styles/components/checkbox.css +318 -0
- package/dist/styles/components/checked.css +318 -0
- package/dist/styles/components/color-picker.css +377 -0
- package/dist/styles/components/comic-reader.css +135 -0
- package/dist/styles/components/config-provider.css +12 -0
- package/dist/styles/components/config-table.css +458 -0
- package/dist/styles/components/countdown.css +14 -0
- package/dist/styles/components/danmaku.css +56 -0
- package/dist/styles/components/date-picker.css +381 -0
- package/dist/styles/components/date-range-picker.css +454 -0
- package/dist/styles/components/design-effect.css +285 -0
- package/dist/styles/components/drag-drop-board.css +87 -0
- package/dist/styles/components/draggable.css +37 -0
- package/dist/styles/components/ellipsis-text.css +59 -0
- package/dist/styles/components/empty.css +168 -0
- package/dist/styles/components/field.css +221 -0
- package/dist/styles/components/file-preview.css +216 -0
- package/dist/styles/components/floating-ball.css +33 -0
- package/dist/styles/components/form.css +221 -0
- package/dist/styles/components/gradient-text.css +54 -0
- package/dist/styles/components/input.css +221 -0
- package/dist/styles/components/lazy-image.css +79 -0
- package/dist/styles/components/live-room.css +226 -0
- package/dist/styles/components/loading.css +98 -0
- package/dist/styles/components/marquee.css +281 -0
- package/dist/styles/components/masonry-virtual-list.css +29 -0
- package/dist/styles/components/modal.css +164 -0
- package/dist/styles/components/multi-column-picker.css +97 -0
- package/dist/styles/components/novel-reader.css +1163 -0
- package/dist/styles/components/number-input.css +221 -0
- package/dist/styles/components/pagination.css +43 -0
- package/dist/styles/components/password-input.css +289 -0
- package/dist/styles/components/popconfirm.css +156 -0
- package/dist/styles/components/popup.css +216 -0
- package/dist/styles/components/progress-bar.css +79 -0
- package/dist/styles/components/qr-code.css +62 -0
- package/dist/styles/components/radio-group.css +318 -0
- package/dist/styles/components/rating.css +260 -0
- package/dist/styles/components/rolling-number.css +37 -0
- package/dist/styles/components/select.css +342 -0
- package/dist/styles/components/signature.css +286 -0
- package/dist/styles/components/skeleton.css +70 -0
- package/dist/styles/components/slide-captcha.css +420 -0
- package/dist/styles/components/swiper.css +199 -0
- package/dist/styles/components/switch.css +294 -0
- package/dist/styles/components/table.css +458 -0
- package/dist/styles/components/tabs.css +156 -0
- package/dist/styles/components/tag.css +90 -0
- package/dist/styles/components/textarea.css +204 -0
- package/dist/styles/components/tilt-card.css +114 -0
- package/dist/styles/components/timeline.css +116 -0
- package/dist/styles/components/toast.css +204 -0
- package/dist/styles/components/tooltip.css +137 -0
- package/dist/styles/components/typewriter-text.css +95 -0
- package/dist/styles/components/upload.css +246 -0
- package/dist/styles/components/verification-code.css +240 -0
- package/dist/styles/components/video-detail-transition.css +169 -0
- package/dist/styles/components/video-player.css +93 -0
- package/dist/styles/components/virtual-list.css +206 -0
- package/dist/styles/components/virtual-select.css +472 -0
- package/dist/styles/components/virtual-table.css +458 -0
- package/dist/styles/components.css +8377 -0
- package/dist/styles/themes/amber.css +19 -0
- package/dist/styles/themes/emerald.css +19 -0
- package/dist/styles/themes/liquid-glass.css +55 -0
- package/dist/styles/themes/minimal.css +19 -0
- package/dist/styles/themes/rose.css +19 -0
- package/dist/styles/themes/sky.css +19 -0
- package/dist/styles/themes/violet.css +19 -0
- package/dist/styles.css +8377 -0
- package/dist/vite.cjs +27 -0
- package/dist/vite.cjs.map +1 -0
- package/dist/vite.d.ts +11 -0
- package/dist/vite.d.ts.map +1 -0
- package/dist/vite.js +22 -0
- package/dist/vite.js.map +1 -0
- package/dist/webpack-loader.cjs +18 -0
- package/dist/webpack-loader.cjs.map +1 -0
- package/dist/webpack-loader.d.ts +9 -0
- package/dist/webpack-loader.d.ts.map +1 -0
- package/dist/webpack-loader.js +14 -0
- package/dist/webpack-loader.js.map +1 -0
- package/dist/webpack.cjs +45 -0
- package/dist/webpack.cjs.map +1 -0
- package/dist/webpack.d.ts +21 -0
- package/dist/webpack.d.ts.map +1 -0
- package/dist/webpack.js +38 -0
- package/dist/webpack.js.map +1 -0
- package/package.json +104 -0
package/CHANGELOG.md
ADDED
package/LICENSE
ADDED
package/README.md
ADDED
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
# @class-kit/vue
|
|
2
|
+
|
|
3
|
+
Vue adapters for Class Kit.
|
|
4
|
+
|
|
5
|
+
```bash
|
|
6
|
+
pnpm add @class-kit/core @class-kit/vue
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
For Vite projects, enable the on-demand plugin and keep imports short:
|
|
10
|
+
|
|
11
|
+
```ts
|
|
12
|
+
import vue from "@vitejs/plugin-vue";
|
|
13
|
+
import { defineConfig } from "vite";
|
|
14
|
+
import { classKitVue } from "@class-kit/vue/vite";
|
|
15
|
+
|
|
16
|
+
export default defineConfig({
|
|
17
|
+
plugins: [vue(), classKitVue()],
|
|
18
|
+
});
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
For Webpack projects, use the matching plugin:
|
|
22
|
+
|
|
23
|
+
```js
|
|
24
|
+
const { classKitVueWebpack } = require("@class-kit/vue/webpack");
|
|
25
|
+
|
|
26
|
+
module.exports = {
|
|
27
|
+
plugins: [classKitVueWebpack()],
|
|
28
|
+
};
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
```ts
|
|
32
|
+
import { ClassButton, ClassConfigProvider } from "@class-kit/vue";
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
The Vite and Webpack plugins rewrite named imports to component subpaths and
|
|
36
|
+
inject matching component CSS. Without the plugin, import `@class-kit/vue/style.css`
|
|
37
|
+
once for full styles, or use `@class-kit/vue/components/*` plus
|
|
38
|
+
`@class-kit/vue/styles/components/*.css` manually.
|
|
39
|
+
|
|
40
|
+
The default theme is `minimal`. Wrap your app with `ClassConfigProvider` to
|
|
41
|
+
switch built-in themes and locale globally. Theme CSS files are split for lazy
|
|
42
|
+
loading:
|
|
43
|
+
|
|
44
|
+
```vue
|
|
45
|
+
<script setup lang="ts">
|
|
46
|
+
import "@class-kit/vue/styles/components.css";
|
|
47
|
+
import "@class-kit/vue/styles/themes/liquid-glass.css";
|
|
48
|
+
</script>
|
|
49
|
+
|
|
50
|
+
<template>
|
|
51
|
+
<ClassConfigProvider theme="liquid-glass">
|
|
52
|
+
<RouterView />
|
|
53
|
+
</ClassConfigProvider>
|
|
54
|
+
</template>
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
```ts
|
|
58
|
+
await import("@class-kit/vue/styles/themes/sky.css");
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
## Optional Peer Dependencies
|
|
62
|
+
|
|
63
|
+
QRCode and Barcode use optional peer dependencies:
|
|
64
|
+
|
|
65
|
+
```bash
|
|
66
|
+
pnpm add qrcode jsbarcode
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
Local Word and Excel preview also uses optional peer dependencies:
|
|
70
|
+
|
|
71
|
+
```bash
|
|
72
|
+
pnpm add mammoth xlsx
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
These libraries are optional so applications that do not use QRCode, Barcode,
|
|
76
|
+
or local document previews do not need to ship them. If a feature is used
|
|
77
|
+
without its optional dependency, Class Kit surfaces a runtime error that names
|
|
78
|
+
the missing package and the supported CDN/global fallback.
|
|
79
|
+
|
|
80
|
+
## Release Gate
|
|
81
|
+
|
|
82
|
+
Before publishing, run the workspace release gate:
|
|
83
|
+
|
|
84
|
+
```bash
|
|
85
|
+
pnpm release:check
|
|
86
|
+
```
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vue = require('vue');
|
|
4
|
+
var core = require('@class-kit/core');
|
|
5
|
+
|
|
6
|
+
function resolveClassKitThemeName(theme) {
|
|
7
|
+
if (typeof theme === "string")
|
|
8
|
+
return theme;
|
|
9
|
+
return theme?.name ?? "minimal";
|
|
10
|
+
}
|
|
11
|
+
vue.defineComponent({
|
|
12
|
+
name: "ClassConfigProvider",
|
|
13
|
+
props: {
|
|
14
|
+
class: {
|
|
15
|
+
type: String,
|
|
16
|
+
default: "",
|
|
17
|
+
},
|
|
18
|
+
locale: {
|
|
19
|
+
type: Object,
|
|
20
|
+
default: undefined,
|
|
21
|
+
},
|
|
22
|
+
style: {
|
|
23
|
+
type: [String, Object, Array],
|
|
24
|
+
default: undefined,
|
|
25
|
+
},
|
|
26
|
+
theme: {
|
|
27
|
+
type: [String, Object],
|
|
28
|
+
default: "minimal",
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
setup(props, { slots }) {
|
|
32
|
+
const version = vue.ref(0);
|
|
33
|
+
const applyConfig = () => {
|
|
34
|
+
core.configureClassComponents({
|
|
35
|
+
locale: props.locale,
|
|
36
|
+
theme: props.theme,
|
|
37
|
+
});
|
|
38
|
+
version.value += 1;
|
|
39
|
+
};
|
|
40
|
+
vue.watch(() => [props.locale, props.theme], applyConfig, {
|
|
41
|
+
deep: true,
|
|
42
|
+
immediate: true,
|
|
43
|
+
});
|
|
44
|
+
return () => vue.h("div", {
|
|
45
|
+
class: ["cc-config-provider", props.class].filter(Boolean),
|
|
46
|
+
"data-cc-theme": resolveClassKitThemeName(props.theme),
|
|
47
|
+
style: props.style,
|
|
48
|
+
}, [
|
|
49
|
+
vue.h("div", { key: version.value, class: "cc-config-provider__content" }, slots.default?.()),
|
|
50
|
+
]);
|
|
51
|
+
},
|
|
52
|
+
});
|
|
53
|
+
const ClassAffix = /*#__PURE__*/ vue.defineComponent({
|
|
54
|
+
name: "ClassAffix",
|
|
55
|
+
props: {
|
|
56
|
+
offsetTop: { type: Number, default: 0 },
|
|
57
|
+
target: [Object, Function, String],
|
|
58
|
+
className: { type: String, default: "cc-affix" },
|
|
59
|
+
},
|
|
60
|
+
setup(props, { attrs, slots }) {
|
|
61
|
+
const root = vue.ref(null);
|
|
62
|
+
const fixed = vue.ref(false);
|
|
63
|
+
const fixedStyle = vue.ref({});
|
|
64
|
+
const windowTarget = vue.ref(true);
|
|
65
|
+
let scrollTarget = window;
|
|
66
|
+
const resolveTarget = () => {
|
|
67
|
+
const propTarget = typeof props.target === "function" ? props.target() : props.target;
|
|
68
|
+
if (typeof propTarget === "string")
|
|
69
|
+
return document.querySelector(propTarget) ?? window;
|
|
70
|
+
return propTarget ?? window;
|
|
71
|
+
};
|
|
72
|
+
const onScroll = () => {
|
|
73
|
+
const element = scrollTarget;
|
|
74
|
+
const rootElement = root.value;
|
|
75
|
+
if (!rootElement)
|
|
76
|
+
return;
|
|
77
|
+
const rect = rootElement.getBoundingClientRect();
|
|
78
|
+
const top = rootElement
|
|
79
|
+
? element === window
|
|
80
|
+
? rootElement.getBoundingClientRect().top
|
|
81
|
+
: rootElement.getBoundingClientRect().top -
|
|
82
|
+
element.getBoundingClientRect().top
|
|
83
|
+
: 0;
|
|
84
|
+
fixed.value = new core.AffixController(props.offsetTop).resolve(top).fixed;
|
|
85
|
+
if (element === window) {
|
|
86
|
+
fixedStyle.value = {
|
|
87
|
+
height: `${rect.height}px`,
|
|
88
|
+
left: `${rect.left}px`,
|
|
89
|
+
position: "fixed",
|
|
90
|
+
top: `${props.offsetTop}px`,
|
|
91
|
+
width: `${rect.width}px`,
|
|
92
|
+
zIndex: 50,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
const detach = () => {
|
|
97
|
+
scrollTarget.removeEventListener("scroll", onScroll);
|
|
98
|
+
window.removeEventListener("resize", onScroll);
|
|
99
|
+
};
|
|
100
|
+
const attach = () => {
|
|
101
|
+
detach();
|
|
102
|
+
scrollTarget = resolveTarget();
|
|
103
|
+
windowTarget.value = scrollTarget === window;
|
|
104
|
+
scrollTarget.addEventListener("scroll", onScroll, { passive: true });
|
|
105
|
+
window.addEventListener("resize", onScroll);
|
|
106
|
+
onScroll();
|
|
107
|
+
};
|
|
108
|
+
vue.onMounted(attach);
|
|
109
|
+
vue.watch(() => props.target, attach);
|
|
110
|
+
vue.watch(() => props.offsetTop, onScroll);
|
|
111
|
+
vue.onBeforeUnmount(detach);
|
|
112
|
+
return () => vue.h("div", {
|
|
113
|
+
...attrs,
|
|
114
|
+
class: props.className,
|
|
115
|
+
"data-fixed": fixed.value,
|
|
116
|
+
"data-target": windowTarget.value ? "window" : "element",
|
|
117
|
+
ref: root,
|
|
118
|
+
style: {
|
|
119
|
+
...(windowTarget.value && fixed.value
|
|
120
|
+
? { height: fixedStyle.value.height }
|
|
121
|
+
: {}),
|
|
122
|
+
...(!windowTarget.value ? { top: `${props.offsetTop}px` } : {}),
|
|
123
|
+
},
|
|
124
|
+
}, vue.h("div", {
|
|
125
|
+
class: "cc-affix__inner",
|
|
126
|
+
style: windowTarget.value && fixed.value ? fixedStyle.value : undefined,
|
|
127
|
+
}, slots.default?.()));
|
|
128
|
+
},
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
exports.ClassAffix = ClassAffix;
|
|
132
|
+
//# sourceMappingURL=affix.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"affix.cjs","sources":["../../src/index.ts"],"names":["defineComponent","ref","configureClassComponents","watch","h","AffixController","onMounted","onBeforeUnmount"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"affix.d.ts","sourceRoot":"","sources":["../../src/components/affix.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC"}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { defineComponent, ref, watch, h, onMounted, onBeforeUnmount } from 'vue';
|
|
2
|
+
import { AffixController, configureClassComponents } from '@class-kit/core';
|
|
3
|
+
|
|
4
|
+
function resolveClassKitThemeName(theme) {
|
|
5
|
+
if (typeof theme === "string")
|
|
6
|
+
return theme;
|
|
7
|
+
return theme?.name ?? "minimal";
|
|
8
|
+
}
|
|
9
|
+
defineComponent({
|
|
10
|
+
name: "ClassConfigProvider",
|
|
11
|
+
props: {
|
|
12
|
+
class: {
|
|
13
|
+
type: String,
|
|
14
|
+
default: "",
|
|
15
|
+
},
|
|
16
|
+
locale: {
|
|
17
|
+
type: Object,
|
|
18
|
+
default: undefined,
|
|
19
|
+
},
|
|
20
|
+
style: {
|
|
21
|
+
type: [String, Object, Array],
|
|
22
|
+
default: undefined,
|
|
23
|
+
},
|
|
24
|
+
theme: {
|
|
25
|
+
type: [String, Object],
|
|
26
|
+
default: "minimal",
|
|
27
|
+
},
|
|
28
|
+
},
|
|
29
|
+
setup(props, { slots }) {
|
|
30
|
+
const version = ref(0);
|
|
31
|
+
const applyConfig = () => {
|
|
32
|
+
configureClassComponents({
|
|
33
|
+
locale: props.locale,
|
|
34
|
+
theme: props.theme,
|
|
35
|
+
});
|
|
36
|
+
version.value += 1;
|
|
37
|
+
};
|
|
38
|
+
watch(() => [props.locale, props.theme], applyConfig, {
|
|
39
|
+
deep: true,
|
|
40
|
+
immediate: true,
|
|
41
|
+
});
|
|
42
|
+
return () => h("div", {
|
|
43
|
+
class: ["cc-config-provider", props.class].filter(Boolean),
|
|
44
|
+
"data-cc-theme": resolveClassKitThemeName(props.theme),
|
|
45
|
+
style: props.style,
|
|
46
|
+
}, [
|
|
47
|
+
h("div", { key: version.value, class: "cc-config-provider__content" }, slots.default?.()),
|
|
48
|
+
]);
|
|
49
|
+
},
|
|
50
|
+
});
|
|
51
|
+
const ClassAffix = /*#__PURE__*/ defineComponent({
|
|
52
|
+
name: "ClassAffix",
|
|
53
|
+
props: {
|
|
54
|
+
offsetTop: { type: Number, default: 0 },
|
|
55
|
+
target: [Object, Function, String],
|
|
56
|
+
className: { type: String, default: "cc-affix" },
|
|
57
|
+
},
|
|
58
|
+
setup(props, { attrs, slots }) {
|
|
59
|
+
const root = ref(null);
|
|
60
|
+
const fixed = ref(false);
|
|
61
|
+
const fixedStyle = ref({});
|
|
62
|
+
const windowTarget = ref(true);
|
|
63
|
+
let scrollTarget = window;
|
|
64
|
+
const resolveTarget = () => {
|
|
65
|
+
const propTarget = typeof props.target === "function" ? props.target() : props.target;
|
|
66
|
+
if (typeof propTarget === "string")
|
|
67
|
+
return document.querySelector(propTarget) ?? window;
|
|
68
|
+
return propTarget ?? window;
|
|
69
|
+
};
|
|
70
|
+
const onScroll = () => {
|
|
71
|
+
const element = scrollTarget;
|
|
72
|
+
const rootElement = root.value;
|
|
73
|
+
if (!rootElement)
|
|
74
|
+
return;
|
|
75
|
+
const rect = rootElement.getBoundingClientRect();
|
|
76
|
+
const top = rootElement
|
|
77
|
+
? element === window
|
|
78
|
+
? rootElement.getBoundingClientRect().top
|
|
79
|
+
: rootElement.getBoundingClientRect().top -
|
|
80
|
+
element.getBoundingClientRect().top
|
|
81
|
+
: 0;
|
|
82
|
+
fixed.value = new AffixController(props.offsetTop).resolve(top).fixed;
|
|
83
|
+
if (element === window) {
|
|
84
|
+
fixedStyle.value = {
|
|
85
|
+
height: `${rect.height}px`,
|
|
86
|
+
left: `${rect.left}px`,
|
|
87
|
+
position: "fixed",
|
|
88
|
+
top: `${props.offsetTop}px`,
|
|
89
|
+
width: `${rect.width}px`,
|
|
90
|
+
zIndex: 50,
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
const detach = () => {
|
|
95
|
+
scrollTarget.removeEventListener("scroll", onScroll);
|
|
96
|
+
window.removeEventListener("resize", onScroll);
|
|
97
|
+
};
|
|
98
|
+
const attach = () => {
|
|
99
|
+
detach();
|
|
100
|
+
scrollTarget = resolveTarget();
|
|
101
|
+
windowTarget.value = scrollTarget === window;
|
|
102
|
+
scrollTarget.addEventListener("scroll", onScroll, { passive: true });
|
|
103
|
+
window.addEventListener("resize", onScroll);
|
|
104
|
+
onScroll();
|
|
105
|
+
};
|
|
106
|
+
onMounted(attach);
|
|
107
|
+
watch(() => props.target, attach);
|
|
108
|
+
watch(() => props.offsetTop, onScroll);
|
|
109
|
+
onBeforeUnmount(detach);
|
|
110
|
+
return () => h("div", {
|
|
111
|
+
...attrs,
|
|
112
|
+
class: props.className,
|
|
113
|
+
"data-fixed": fixed.value,
|
|
114
|
+
"data-target": windowTarget.value ? "window" : "element",
|
|
115
|
+
ref: root,
|
|
116
|
+
style: {
|
|
117
|
+
...(windowTarget.value && fixed.value
|
|
118
|
+
? { height: fixedStyle.value.height }
|
|
119
|
+
: {}),
|
|
120
|
+
...(!windowTarget.value ? { top: `${props.offsetTop}px` } : {}),
|
|
121
|
+
},
|
|
122
|
+
}, h("div", {
|
|
123
|
+
class: "cc-affix__inner",
|
|
124
|
+
style: windowTarget.value && fixed.value ? fixedStyle.value : undefined,
|
|
125
|
+
}, slots.default?.()));
|
|
126
|
+
},
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
export { ClassAffix };
|
|
130
|
+
//# sourceMappingURL=affix.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"affix.js","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,180 @@
|
|
|
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: "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": 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
|
+
const ClassBacktop = /*#__PURE__*/ vue.defineComponent({
|
|
84
|
+
name: "ClassBacktop",
|
|
85
|
+
props: {
|
|
86
|
+
className: { type: String, default: "cc-backtop" },
|
|
87
|
+
duration: Number,
|
|
88
|
+
target: [Object, Function, String],
|
|
89
|
+
visibilityHeight: { type: Number, default: 240 },
|
|
90
|
+
},
|
|
91
|
+
emits: ["click"],
|
|
92
|
+
setup(props, { attrs, emit, slots }) {
|
|
93
|
+
const visible = vue.ref(false);
|
|
94
|
+
const controller = new core.BacktopController(props.visibilityHeight);
|
|
95
|
+
let currentTarget = null;
|
|
96
|
+
let bindFrame = 0;
|
|
97
|
+
const resolveTarget = () => {
|
|
98
|
+
const propTarget = props.target;
|
|
99
|
+
if (typeof propTarget === "function")
|
|
100
|
+
return propTarget() ?? null;
|
|
101
|
+
if (typeof propTarget === "string")
|
|
102
|
+
return document.querySelector(propTarget) ?? window;
|
|
103
|
+
return propTarget ?? window;
|
|
104
|
+
};
|
|
105
|
+
const readScrollTop = (target) => target instanceof Window ? target.scrollY : target.scrollTop;
|
|
106
|
+
const writeScrollTop = (target, top) => {
|
|
107
|
+
if (target instanceof Window) {
|
|
108
|
+
target.scrollTo({ top });
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
target.scrollTop = top;
|
|
112
|
+
};
|
|
113
|
+
const scrollToTop = (target) => {
|
|
114
|
+
const duration = Math.max(0, Number.isFinite(props.duration ?? 0) ? (props.duration ?? 0) : 0);
|
|
115
|
+
if (duration <= 0) {
|
|
116
|
+
target.scrollTo({ top: 0, behavior: "smooth" });
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
const start = readScrollTop(target);
|
|
120
|
+
const startedAt = performance.now();
|
|
121
|
+
const easeOut = (value) => 1 - Math.pow(1 - value, 3);
|
|
122
|
+
const step = (now) => {
|
|
123
|
+
const progress = Math.min(1, (now - startedAt) / duration);
|
|
124
|
+
writeScrollTop(target, start * (1 - easeOut(progress)));
|
|
125
|
+
if (progress < 1)
|
|
126
|
+
requestAnimationFrame(step);
|
|
127
|
+
};
|
|
128
|
+
requestAnimationFrame(step);
|
|
129
|
+
};
|
|
130
|
+
const onScroll = () => {
|
|
131
|
+
const target = currentTarget ?? resolveTarget();
|
|
132
|
+
if (!target)
|
|
133
|
+
return;
|
|
134
|
+
visible.value = controller.resolve(readScrollTop(target), visible.value).visible;
|
|
135
|
+
};
|
|
136
|
+
const bindTarget = () => {
|
|
137
|
+
if (currentTarget)
|
|
138
|
+
currentTarget.removeEventListener("scroll", onScroll);
|
|
139
|
+
currentTarget = resolveTarget();
|
|
140
|
+
if (!currentTarget) {
|
|
141
|
+
if (bindFrame)
|
|
142
|
+
cancelAnimationFrame(bindFrame);
|
|
143
|
+
bindFrame = requestAnimationFrame(bindTarget);
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
onScroll();
|
|
147
|
+
currentTarget.addEventListener("scroll", onScroll, { passive: true });
|
|
148
|
+
};
|
|
149
|
+
vue.watch(() => props.visibilityHeight, (value) => {
|
|
150
|
+
visible.value = controller.update(value).visible;
|
|
151
|
+
onScroll();
|
|
152
|
+
});
|
|
153
|
+
vue.watch(() => props.target, bindTarget);
|
|
154
|
+
vue.onMounted(() => {
|
|
155
|
+
void vue.nextTick(() => bindTarget());
|
|
156
|
+
});
|
|
157
|
+
vue.onBeforeUnmount(() => {
|
|
158
|
+
if (bindFrame)
|
|
159
|
+
cancelAnimationFrame(bindFrame);
|
|
160
|
+
if (currentTarget)
|
|
161
|
+
currentTarget.removeEventListener("scroll", onScroll);
|
|
162
|
+
});
|
|
163
|
+
return () => visible.value
|
|
164
|
+
? vue.h("button", {
|
|
165
|
+
...attrs,
|
|
166
|
+
class: props.className,
|
|
167
|
+
type: "button",
|
|
168
|
+
onClick: (event) => {
|
|
169
|
+
emit("click", event);
|
|
170
|
+
const target = currentTarget ?? resolveTarget();
|
|
171
|
+
if (target)
|
|
172
|
+
scrollToTop(target);
|
|
173
|
+
},
|
|
174
|
+
}, slots.default?.() ?? classIcon("chevronUp"))
|
|
175
|
+
: null;
|
|
176
|
+
},
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
exports.ClassBacktop = ClassBacktop;
|
|
180
|
+
//# sourceMappingURL=backtop.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backtop.cjs","sources":["../../src/index.ts"],"names":["h","defineComponent","ref","configureClassComponents","watch","BacktopController","onMounted","nextTick","onBeforeUnmount"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backtop.d.ts","sourceRoot":"","sources":["../../src/components/backtop.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC"}
|