includio-cms 0.25.0 → 0.26.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/API.md +57 -4
- package/CHANGELOG.md +53 -0
- package/DOCS.md +1 -1
- package/README.md +2 -0
- package/ROADMAP.md +6 -0
- package/dist/admin/client/account/lang.d.ts +1 -0
- package/dist/admin/client/account/lang.js +4 -2
- package/dist/admin/client/account/profile-section.svelte +2 -2
- package/dist/admin/client/account/security-section.svelte +27 -4
- package/dist/admin/client/account/sessions-section.svelte +1 -1
- package/dist/admin/client/admin/admin-after-login-layout-content.svelte +1 -1
- package/dist/admin/client/admin/dashboard-page.svelte +34 -10
- package/dist/admin/client/collection/bulk-actions-bar.svelte +86 -44
- package/dist/admin/client/collection/bulk-actions-bar.svelte.d.ts +3 -1
- package/dist/admin/client/collection/collection-entries.svelte +52 -36
- package/dist/admin/client/collection/collection-entries.svelte.d.ts +3 -0
- package/dist/admin/client/collection/collection.svelte +28 -14
- package/dist/admin/client/collection/collection.svelte.d.ts +3 -0
- package/dist/admin/client/collection/data-table.svelte +279 -130
- package/dist/admin/client/collection/data-table.svelte.d.ts +11 -0
- package/dist/admin/client/collection/date-cell.svelte +4 -4
- package/dist/admin/client/collection/row-actions.svelte +2 -1
- package/dist/admin/client/collection/sortable-header.svelte +33 -9
- package/dist/admin/client/collection/state-display.svelte +102 -0
- package/dist/admin/client/collection/state-display.svelte.d.ts +12 -0
- package/dist/admin/client/collection/status-badge.svelte +99 -11
- package/dist/admin/client/collection/status-badge.svelte.d.ts +15 -1
- package/dist/admin/client/collection/table-pagination.svelte +21 -6
- package/dist/admin/client/collection/table-toolbar.svelte +105 -80
- package/dist/admin/client/collection/table-toolbar.svelte.d.ts +11 -8
- package/dist/admin/client/entry/entry-form.svelte +36 -11
- package/dist/admin/client/entry/entry-form.svelte.d.ts +1 -0
- package/dist/admin/client/entry/entry-header.svelte +22 -15
- package/dist/admin/client/entry/entry-header.svelte.d.ts +1 -0
- package/dist/admin/client/entry/entry.svelte +269 -165
- package/dist/admin/client/entry/header/a11y-header-badge.svelte +47 -0
- package/dist/admin/client/entry/header/a11y-header-badge.svelte.d.ts +8 -0
- package/dist/admin/client/entry/header/publish-panel.svelte +69 -13
- package/dist/admin/client/entry/header/save-indicator.svelte +57 -28
- package/dist/admin/client/entry/header/save-indicator.svelte.d.ts +1 -0
- package/dist/admin/client/entry/header/status-badge.svelte +60 -15
- package/dist/admin/client/entry/header/status-badge.svelte.d.ts +1 -2
- package/dist/admin/client/entry/header/version-history-sheet.svelte +1 -1
- package/dist/admin/client/entry/hybrid/hybrid-layout.svelte +74 -23
- package/dist/admin/client/entry/hybrid/hybrid-preview.svelte +1 -1
- package/dist/admin/client/entry/utils.d.ts +14 -0
- package/dist/admin/client/entry/utils.js +28 -0
- package/dist/admin/client/form/form-submission/form-submission.svelte +2 -2
- package/dist/admin/client/form/form-submissions.svelte +143 -194
- package/dist/admin/client/form/form-submissions.svelte.d.ts +2 -0
- package/dist/admin/client/login/lang.d.ts +3 -0
- package/dist/admin/client/login/lang.js +10 -4
- package/dist/admin/client/login/login-form.svelte +8 -1
- package/dist/admin/client/login/reset-password-page.svelte +24 -3
- package/dist/admin/client/login/schema.d.ts +14 -2
- package/dist/admin/client/login/schema.js +19 -8
- package/dist/admin/client/maintenance/maintenance-page.svelte +16 -17
- package/dist/admin/client/media/media-page.svelte +1 -1
- package/dist/admin/client/shop/coupon-edit-page.svelte +117 -13
- package/dist/admin/client/shop/coupon-form.svelte +282 -138
- package/dist/admin/client/shop/coupon-form.svelte.d.ts +1 -9
- package/dist/admin/client/shop/coupon-new-page.svelte +40 -10
- package/dist/admin/client/shop/coupon-new-page.svelte.d.ts +2 -17
- package/dist/admin/client/shop/coupon-schema.d.ts +28 -0
- package/dist/admin/client/shop/coupon-schema.js +53 -0
- package/dist/admin/client/shop/coupons-list-page.svelte +262 -118
- package/dist/admin/client/shop/coupons-list-page.svelte.d.ts +16 -1
- package/dist/admin/client/shop/shipping-method-edit-page.svelte +108 -59
- package/dist/admin/client/shop/shipping-method-form.svelte +36 -9
- package/dist/admin/client/shop/shipping-method-new-page.svelte +44 -13
- package/dist/admin/client/shop/shipping-methods-list-page.svelte +101 -59
- package/dist/admin/client/shop/shop-order-detail-page.svelte +113 -84
- package/dist/admin/client/shop/shop-orders-list-page.svelte +302 -152
- package/dist/admin/client/shop/shop-orders-list-page.svelte.d.ts +18 -1
- package/dist/admin/client/shop/shop-products-list-page.svelte +355 -118
- package/dist/admin/client/shop/shop-products-list-page.svelte.d.ts +19 -1
- package/dist/admin/client/users/accept-invite-page.svelte +24 -3
- package/dist/admin/client/users/create-user-dialog.svelte +3 -8
- package/dist/admin/client/users/lang.d.ts +2 -0
- package/dist/admin/client/users/lang.js +4 -0
- package/dist/admin/client/users/pending-invitations.svelte +2 -9
- package/dist/admin/client/users/user-name-cell.svelte +20 -0
- package/dist/admin/client/users/user-name-cell.svelte.d.ts +9 -0
- package/dist/admin/client/users/user-role-badge.svelte +16 -0
- package/dist/admin/client/users/user-role-badge.svelte.d.ts +7 -0
- package/dist/admin/client/users/user-row-actions.svelte +72 -0
- package/dist/admin/client/users/user-row-actions.svelte.d.ts +20 -0
- package/dist/admin/client/users/user-sessions-sheet.svelte +2 -11
- package/dist/admin/client/users/users-page.svelte +283 -497
- package/dist/admin/client/users/users-page.svelte.d.ts +12 -1
- package/dist/admin/components/dashboard/form-submissions-widget.svelte +59 -74
- package/dist/admin/components/dashboard/recent-activity.svelte +17 -5
- package/dist/admin/components/dashboard/recent-entries.svelte +19 -7
- package/dist/admin/components/dialogs/confirmation-dialog.svelte +105 -0
- package/dist/admin/components/dialogs/confirmation-dialog.svelte.d.ts +13 -0
- package/dist/admin/components/fields/block-picker-modal.svelte +6 -0
- package/dist/admin/components/fields/blocks-field.svelte +46 -1
- package/dist/admin/components/fields/boolean-field.svelte +1 -1
- package/dist/admin/components/fields/field-renderer.svelte +23 -21
- package/dist/admin/components/fields/file-field.svelte +344 -30
- package/dist/admin/components/fields/media-field.svelte +16 -2
- package/dist/admin/components/fields/radio-field.svelte +22 -0
- package/dist/admin/components/fields/relation-field.svelte +123 -97
- package/dist/admin/components/fields/relation-picker-dialog.svelte +2 -2
- package/dist/admin/components/fields/seo-field.svelte +60 -30
- package/dist/admin/components/fields/shop-field.svelte +9 -4
- package/dist/admin/components/fields/simple-array-field.svelte +321 -151
- package/dist/admin/components/fields/simple-array-field.svelte.d.ts +3 -0
- package/dist/admin/components/fields/slug-field.svelte +146 -21
- package/dist/admin/components/fields/text-field-wrapper.svelte +37 -20
- package/dist/admin/components/fields/text-field.svelte +7 -2
- package/dist/admin/components/fields/url-field-wrapper.svelte +10 -0
- package/dist/admin/components/fields/url-field.svelte +36 -23
- package/dist/admin/components/forms/form-error-summary.svelte +143 -0
- package/dist/admin/components/forms/form-error-summary.svelte.d.ts +27 -0
- package/dist/admin/components/layout/app-sidebar.svelte +7 -2
- package/dist/admin/components/layout/detail-page-shell.svelte +71 -0
- package/dist/admin/components/layout/detail-page-shell.svelte.d.ts +24 -0
- package/dist/admin/components/layout/lang.d.ts +5 -0
- package/dist/admin/components/layout/lang.js +10 -0
- package/dist/admin/components/layout/layout-renderer.svelte +71 -2
- package/dist/admin/components/layout/layout-renderer.svelte.d.ts +1 -0
- package/dist/admin/components/layout/layout-tabs.svelte +172 -0
- package/dist/admin/components/layout/layout-tabs.svelte.d.ts +24 -0
- package/dist/admin/components/layout/nav-breadcrumbs.svelte +25 -7
- package/dist/admin/components/layout/nav-collections.svelte +23 -36
- package/dist/admin/components/layout/nav-forms.svelte +19 -35
- package/dist/admin/components/layout/nav-main.svelte +3 -28
- package/dist/admin/components/layout/nav-search.svelte +70 -2
- package/dist/admin/components/layout/nav-section.svelte +77 -0
- package/dist/admin/components/layout/nav-section.svelte.d.ts +22 -0
- package/dist/admin/components/layout/nav-shop.svelte +3 -27
- package/dist/admin/components/layout/nav-singletons.svelte +16 -28
- package/dist/admin/components/layout/page-header.stories.svelte +93 -0
- package/dist/admin/components/layout/page-header.stories.svelte.d.ts +27 -0
- package/dist/admin/components/layout/page-header.svelte +68 -0
- package/dist/admin/components/layout/page-header.svelte.d.ts +17 -0
- package/dist/admin/components/layout/site-header.svelte +9 -0
- package/dist/admin/components/layout/site-header.svelte.d.ts +2 -17
- package/dist/admin/components/media/file/file-name-input.svelte +6 -2
- package/dist/admin/components/media/file/file-preview.svelte +130 -17
- package/dist/admin/components/media/file-upload.svelte +16 -7
- package/dist/admin/components/media/file-upload.svelte.d.ts +1 -0
- package/dist/admin/components/media/files-list.svelte +153 -53
- package/dist/admin/components/media/files-list.svelte.d.ts +1 -0
- package/dist/admin/components/media/media-library.svelte +577 -198
- package/dist/admin/components/media/media-library.svelte.d.ts +4 -0
- package/dist/admin/components/media/media-selector.svelte +4 -2
- package/dist/admin/components/media/media-selector.svelte.d.ts +1 -0
- package/dist/admin/components/media/tag-sidebar.svelte +4 -4
- package/dist/admin/components/tiptap/FigureNodeView.svelte +10 -0
- package/dist/admin/components/tiptap/bubble-menu.svelte +104 -0
- package/dist/admin/components/tiptap/bubble-menu.svelte.d.ts +19 -0
- package/dist/admin/components/tiptap/content-editor.svelte +28 -24
- package/dist/admin/components/tiptap/editor-toolbar.svelte +7 -7
- package/dist/admin/components/tiptap/extensions.js +5 -1
- package/dist/admin/components/tiptap/image-dialog.svelte +5 -1
- package/dist/admin/components/tiptap/link-dialog.svelte +2 -0
- package/dist/admin/components/tiptap/tiptap-editor.svelte +18 -20
- package/dist/admin/components/tiptap/video-dialog.svelte +1 -1
- package/dist/admin/i18n/errors.d.ts +140 -0
- package/dist/admin/i18n/errors.js +151 -0
- package/dist/admin/remote/entry.remote.d.ts +59 -4
- package/dist/admin/remote/entry.remote.js +239 -62
- package/dist/admin/remote/shop.remote.d.ts +37 -32
- package/dist/admin/remote/shop.remote.js +9 -2
- package/dist/admin/shared/password-generate.d.ts +6 -0
- package/dist/admin/shared/password-generate.js +40 -0
- package/dist/admin/shared/password-schema.d.ts +6 -0
- package/dist/admin/shared/password-schema.js +10 -3
- package/dist/admin/styles/admin.css +23 -6
- package/dist/admin/styles/tokens.md +244 -0
- package/dist/admin/utils/accordionActivation.d.ts +13 -0
- package/dist/admin/utils/accordionActivation.js +35 -0
- package/dist/admin/utils/entryLabel.d.ts +23 -0
- package/dist/admin/utils/entryLabel.js +51 -12
- package/dist/admin/utils/field-a11y.d.ts +29 -0
- package/dist/admin/utils/field-a11y.js +23 -0
- package/dist/admin/utils/fieldPathElement.d.ts +9 -0
- package/dist/admin/utils/fieldPathElement.js +18 -0
- package/dist/admin/utils/fileDisplay.d.ts +10 -0
- package/dist/admin/utils/fileDisplay.js +26 -0
- package/dist/admin/utils/flattenFormErrors.d.ts +19 -0
- package/dist/admin/utils/flattenFormErrors.js +102 -0
- package/dist/admin/utils/formatters.d.ts +12 -0
- package/dist/admin/utils/{formatDate.js → formatters.js} +23 -2
- package/dist/admin/utils/scrollWithin.d.ts +9 -0
- package/dist/admin/utils/scrollWithin.js +32 -0
- package/dist/admin/utils/tabActivation.d.ts +12 -0
- package/dist/admin/utils/tabActivation.js +24 -0
- package/dist/cms/runtime/schema.d.ts +1 -0
- package/dist/cms/runtime/schema.js +1 -0
- package/dist/cms/runtime/types.d.ts +80 -7
- package/dist/components/ui/accordion/accordion-content.svelte +17 -3
- package/dist/components/ui/accordion/accordion.stories.svelte +21 -1
- package/dist/components/ui/alert/alert.stories.svelte +14 -0
- package/dist/components/ui/alert-dialog/alert-dialog.stories.svelte +45 -0
- package/dist/components/ui/alert-dialog/alert-dialog.stories.svelte.d.ts +27 -0
- package/dist/components/ui/avatar/avatar.stories.svelte +27 -0
- package/dist/components/ui/badge/badge.stories.svelte +15 -0
- package/dist/components/ui/breadcrumb/breadcrumb.stories.svelte +47 -0
- package/dist/components/ui/breadcrumb/breadcrumb.svelte +1 -1
- package/dist/components/ui/button/button.stories.svelte +53 -6
- package/dist/components/ui/button/button.svelte +39 -5
- package/dist/components/ui/button/button.svelte.d.ts +4 -0
- package/dist/components/ui/button-group/button-group.stories.svelte +44 -0
- package/dist/components/ui/button-group/button-group.stories.svelte.d.ts +27 -0
- package/dist/components/ui/calendar/calendar.stories.svelte +36 -0
- package/dist/components/ui/calendar/calendar.stories.svelte.d.ts +27 -0
- package/dist/components/ui/card/card.stories.svelte +7 -0
- package/dist/components/ui/carousel/carousel.stories.svelte +43 -0
- package/dist/components/ui/carousel/carousel.stories.svelte.d.ts +27 -0
- package/dist/components/ui/checkbox/checkbox.stories.svelte +67 -0
- package/dist/components/ui/checkbox/checkbox.stories.svelte.d.ts +27 -0
- package/dist/components/ui/checkbox/checkbox.svelte +3 -3
- package/dist/components/ui/command/command.stories.svelte +18 -0
- package/dist/components/ui/data-table/data-table.stories.svelte +61 -0
- package/dist/components/ui/data-table/data-table.stories.svelte.d.ts +18 -0
- package/dist/components/ui/dialog/dialog-content.svelte +5 -0
- package/dist/components/ui/dialog/dialog-content.svelte.d.ts +2 -0
- package/dist/components/ui/dialog/dialog.stories.svelte +35 -0
- package/dist/components/ui/dropdown-menu/dropdown-menu.stories.svelte +74 -0
- package/dist/components/ui/dropdown-menu/dropdown-menu.stories.svelte.d.ts +27 -0
- package/dist/components/ui/field/field-context.svelte.d.ts +22 -0
- package/dist/components/ui/field/field-context.svelte.js +9 -0
- package/dist/components/ui/field/field-control.svelte +18 -0
- package/dist/components/ui/field/field-control.svelte.d.ts +8 -0
- package/dist/components/ui/field/field-description.svelte +12 -0
- package/dist/components/ui/field/field-error.svelte +14 -6
- package/dist/components/ui/field/field-label.svelte +10 -0
- package/dist/components/ui/field/field.stories.svelte +95 -9
- package/dist/components/ui/field/field.svelte +57 -0
- package/dist/components/ui/field/field.svelte.d.ts +2 -0
- package/dist/components/ui/field/index.d.ts +3 -1
- package/dist/components/ui/field/index.js +4 -2
- package/dist/components/ui/form/form-field-errors.svelte +1 -1
- package/dist/components/ui/form/form.stories.svelte +25 -0
- package/dist/components/ui/form/form.stories.svelte.d.ts +26 -0
- package/dist/components/ui/input/input.stories.svelte +26 -0
- package/dist/components/ui/input-group/input-group-input.svelte.d.ts +1 -1
- package/dist/components/ui/input-group/input-group.stories.svelte +43 -0
- package/dist/components/ui/input-group/input-group.stories.svelte.d.ts +27 -0
- package/dist/components/ui/item/item.stories.svelte +61 -0
- package/dist/components/ui/item/item.stories.svelte.d.ts +27 -0
- package/dist/components/ui/label/label.stories.svelte +7 -0
- package/dist/components/ui/live-region/index.d.ts +1 -0
- package/dist/components/ui/live-region/index.js +1 -0
- package/dist/components/ui/live-region/live-region-demo.svelte +32 -0
- package/dist/components/ui/live-region/live-region-demo.svelte.d.ts +7 -0
- package/dist/components/ui/live-region/live-region.stories.svelte +23 -0
- package/dist/components/ui/live-region/live-region.stories.svelte.d.ts +26 -0
- package/dist/components/ui/live-region/live-region.svelte +12 -0
- package/dist/components/ui/live-region/live-region.svelte.d.ts +8 -0
- package/dist/components/ui/popover/popover.stories.svelte +34 -0
- package/dist/components/ui/radio-group/radio-group.stories.svelte +58 -0
- package/dist/components/ui/radio-group/radio-group.stories.svelte.d.ts +27 -0
- package/dist/components/ui/resizable/resizable.stories.svelte +56 -0
- package/dist/components/ui/resizable/resizable.stories.svelte.d.ts +27 -0
- package/dist/components/ui/select/select.stories.svelte +49 -0
- package/dist/components/ui/separator/separator.stories.svelte +18 -0
- package/dist/components/ui/sheet/sheet.stories.svelte +34 -0
- package/dist/components/ui/sidebar/sidebar-input.svelte.d.ts +1 -1
- package/dist/components/ui/sidebar/sidebar-menu-button.svelte +1 -0
- package/dist/components/ui/sidebar/sidebar-trigger.svelte +1 -1
- package/dist/components/ui/sidebar/sidebar.stories.svelte +72 -0
- package/dist/components/ui/sidebar/sidebar.stories.svelte.d.ts +27 -0
- package/dist/components/ui/skeleton/skeleton.stories.svelte +39 -0
- package/dist/components/ui/skeleton/skeleton.stories.svelte.d.ts +27 -0
- package/dist/components/ui/skeleton/skeleton.svelte +6 -0
- package/dist/components/ui/sonner/index.d.ts +1 -1
- package/dist/components/ui/sonner/index.js +1 -1
- package/dist/components/ui/sonner/sonner.stories.svelte +7 -0
- package/dist/components/ui/sonner/sonner.svelte +17 -1
- package/dist/components/ui/sonner/sonner.svelte.d.ts +6 -0
- package/dist/components/ui/spinner/spinner.stories.svelte +30 -0
- package/dist/components/ui/spinner/spinner.stories.svelte.d.ts +27 -0
- package/dist/components/ui/switch/switch.stories.svelte +56 -0
- package/dist/components/ui/switch/switch.stories.svelte.d.ts +27 -0
- package/dist/components/ui/table/table-cell.svelte +1 -1
- package/dist/components/ui/table/table-head.svelte +1 -1
- package/dist/components/ui/table/table.stories.svelte +68 -0
- package/dist/components/ui/table/table.stories.svelte.d.ts +27 -0
- package/dist/components/ui/table/table.svelte +1 -1
- package/dist/components/ui/tabs/tabs.stories.svelte +48 -0
- package/dist/components/ui/tabs/tabs.stories.svelte.d.ts +27 -0
- package/dist/components/ui/textarea/textarea.stories.svelte +21 -0
- package/dist/components/ui/toggle/toggle.stories.svelte +23 -0
- package/dist/components/ui/toggle-group/toggle-group.stories.svelte +43 -0
- package/dist/components/ui/tooltip/tooltip.stories.svelte +46 -6
- package/dist/core/fields/fieldSchemaToTs.d.ts +7 -0
- package/dist/core/fields/fieldSchemaToTs.js +234 -90
- package/dist/core/fields/layoutUtils.d.ts +4 -1
- package/dist/core/fields/layoutUtils.js +41 -4
- package/dist/core/fields/resolveSeo.d.ts +70 -0
- package/dist/core/fields/resolveSeo.js +88 -0
- package/dist/core/fields/seoFieldDescriptor.d.ts +43 -0
- package/dist/core/fields/seoFieldDescriptor.js +74 -0
- package/dist/core/fields/slugPath.d.ts +13 -0
- package/dist/core/fields/slugPath.js +32 -0
- package/dist/core/fields/urlUtils.d.ts +8 -0
- package/dist/core/fields/urlUtils.js +27 -0
- package/dist/core/index.d.ts +1 -0
- package/dist/core/index.js +1 -0
- package/dist/core/server/entries/operations/create.js +13 -0
- package/dist/core/server/entries/operations/get.d.ts +7 -0
- package/dist/core/server/entries/operations/get.js +10 -6
- package/dist/core/server/entries/operations/slugUniqueness.d.ts +37 -0
- package/dist/core/server/entries/operations/slugUniqueness.js +116 -0
- package/dist/core/server/entries/operations/update.d.ts +6 -1
- package/dist/core/server/entries/operations/update.js +24 -1
- package/dist/core/server/fields/slugResolver.d.ts +3 -13
- package/dist/core/server/fields/slugResolver.js +8 -37
- package/dist/core/server/generator/fields.js +10 -17
- package/dist/core/server/generator/formFields.js +2 -1
- package/dist/core/server/generator/generator.js +4 -4
- package/dist/core/server/generator/utils.d.ts +1 -0
- package/dist/core/server/generator/utils.js +4 -0
- package/dist/paraglide/messages/_index.d.ts +3 -36
- package/dist/paraglide/messages/_index.js +3 -71
- package/dist/paraglide/messages/hello_world.d.ts +5 -0
- package/dist/paraglide/messages/hello_world.js +33 -0
- package/dist/paraglide/messages/login_hello.d.ts +16 -0
- package/dist/paraglide/messages/login_hello.js +34 -0
- package/dist/paraglide/messages/login_please_login.d.ts +16 -0
- package/dist/paraglide/messages/login_please_login.js +34 -0
- package/dist/shop/server/orders.d.ts +1 -0
- package/dist/shop/server/orders.js +14 -0
- package/dist/shop/server/shop-data.d.ts +2 -0
- package/dist/shop/server/shop-data.js +20 -5
- package/dist/sveltekit/server/handle.js +17 -0
- package/dist/types/cms.schema.js +4 -2
- package/dist/types/fields.d.ts +35 -0
- package/dist/types/index.d.ts +1 -1
- package/dist/types/layout.d.ts +35 -2
- package/dist/updates/0.26.0/index.d.ts +2 -0
- package/dist/updates/0.26.0/index.js +51 -0
- package/dist/updates/index.js +3 -1
- package/package.json +29 -7
- package/dist/admin/client/collection/empty-state.svelte +0 -28
- package/dist/admin/client/collection/empty-state.svelte.d.ts +0 -9
- package/dist/admin/client/form/submission-status-badge.svelte +0 -41
- package/dist/admin/client/form/submission-status-badge.svelte.d.ts +0 -7
- package/dist/admin/components/media/file-preview.svelte +0 -51
- package/dist/admin/components/media/file-preview.svelte.d.ts +0 -6
- package/dist/admin/utils/formatDate.d.ts +0 -5
- package/dist/paraglide/messages/en.d.ts +0 -5
- package/dist/paraglide/messages/en.js +0 -14
- package/dist/paraglide/messages/pl.d.ts +0 -5
- package/dist/paraglide/messages/pl.js +0 -14
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
<script module>
|
|
2
|
+
import { defineMeta } from '@storybook/addon-svelte-csf';
|
|
3
|
+
import * as AlertDialog from './index.js';
|
|
4
|
+
import { Root as AlertDialogRoot } from './index.js';
|
|
5
|
+
import { Button } from '../button/index.js';
|
|
6
|
+
|
|
7
|
+
const { Story } = defineMeta({
|
|
8
|
+
title: 'UI/Overlays/AlertDialog',
|
|
9
|
+
component: AlertDialogRoot,
|
|
10
|
+
tags: ['autodocs'],
|
|
11
|
+
parameters: {
|
|
12
|
+
docs: {
|
|
13
|
+
description: {
|
|
14
|
+
component: 'Modal blokujący do potwierdzenia akcji nieodwracalnej (usunięcie, archiwizacja). Tytuł musi opisywać konsekwencję, nie samo „Czy na pewno?".',
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
argTypes: {
|
|
19
|
+
open: {
|
|
20
|
+
control: 'boolean',
|
|
21
|
+
description: 'Sterowanie otwarciem (opcjonalne — Trigger sterouje sam).',
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
});
|
|
25
|
+
</script>
|
|
26
|
+
|
|
27
|
+
<Story name="Destructive confirmation">
|
|
28
|
+
<AlertDialog.Root>
|
|
29
|
+
<AlertDialog.Trigger>
|
|
30
|
+
{#snippet child({ props })}
|
|
31
|
+
<Button variant="destructive" {...props}>Usuń wpis</Button>
|
|
32
|
+
{/snippet}
|
|
33
|
+
</AlertDialog.Trigger>
|
|
34
|
+
<AlertDialog.Content>
|
|
35
|
+
<AlertDialog.Title>Usunąć wpis na stałe?</AlertDialog.Title>
|
|
36
|
+
<AlertDialog.Description>
|
|
37
|
+
Tej akcji nie można cofnąć. Wpis i jego wszystkie wersje znikną z bazy.
|
|
38
|
+
</AlertDialog.Description>
|
|
39
|
+
<AlertDialog.Footer>
|
|
40
|
+
<AlertDialog.Cancel>Anuluj</AlertDialog.Cancel>
|
|
41
|
+
<AlertDialog.Action>Usuń</AlertDialog.Action>
|
|
42
|
+
</AlertDialog.Footer>
|
|
43
|
+
</AlertDialog.Content>
|
|
44
|
+
</AlertDialog.Root>
|
|
45
|
+
</Story>
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export default AlertDialog;
|
|
2
|
+
type AlertDialog = SvelteComponent<{
|
|
3
|
+
[x: string]: never;
|
|
4
|
+
}, {
|
|
5
|
+
[evt: string]: CustomEvent<any>;
|
|
6
|
+
}, {}> & {
|
|
7
|
+
$$bindings?: string | undefined;
|
|
8
|
+
};
|
|
9
|
+
declare const AlertDialog: $$__sveltets_2_IsomorphicComponent<{
|
|
10
|
+
[x: string]: never;
|
|
11
|
+
}, {
|
|
12
|
+
[evt: string]: CustomEvent<any>;
|
|
13
|
+
}, {}, {}, string>;
|
|
14
|
+
import * as AlertDialog from './index.js';
|
|
15
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
16
|
+
new (options: import("svelte").ComponentConstructorOptions<Props>): import("svelte").SvelteComponent<Props, Events, Slots> & {
|
|
17
|
+
$$bindings?: Bindings;
|
|
18
|
+
} & Exports;
|
|
19
|
+
(internal: unknown, props: {
|
|
20
|
+
$$events?: Events;
|
|
21
|
+
$$slots?: Slots;
|
|
22
|
+
}): Exports & {
|
|
23
|
+
$set?: any;
|
|
24
|
+
$on?: any;
|
|
25
|
+
};
|
|
26
|
+
z_$$bindings?: Bindings;
|
|
27
|
+
}
|
|
@@ -6,6 +6,13 @@
|
|
|
6
6
|
title: 'UI/Data/Avatar',
|
|
7
7
|
component: Avatar,
|
|
8
8
|
tags: ['autodocs'],
|
|
9
|
+
parameters: {
|
|
10
|
+
docs: {
|
|
11
|
+
description: {
|
|
12
|
+
component: 'Wizytówka użytkownika lub encji. Zawsze podawaj `alt` na `AvatarImage` lub fallback z inicjałami.',
|
|
13
|
+
},
|
|
14
|
+
},
|
|
15
|
+
},
|
|
9
16
|
});
|
|
10
17
|
</script>
|
|
11
18
|
|
|
@@ -14,3 +21,23 @@
|
|
|
14
21
|
<AvatarFallback style="background:transparent;color:white;font-weight:700;font-size:12px;">PK</AvatarFallback>
|
|
15
22
|
</Avatar>
|
|
16
23
|
</Story>
|
|
24
|
+
|
|
25
|
+
<Story name="Initials only">
|
|
26
|
+
<Avatar>
|
|
27
|
+
<AvatarFallback>JK</AvatarFallback>
|
|
28
|
+
</Avatar>
|
|
29
|
+
</Story>
|
|
30
|
+
|
|
31
|
+
<Story name="Group (admin / editor / viewer)">
|
|
32
|
+
<div style="display:flex;align-items:center;gap:-4px;">
|
|
33
|
+
<Avatar style="background:var(--primary);color:white;">
|
|
34
|
+
<AvatarFallback style="background:transparent;color:white;">A</AvatarFallback>
|
|
35
|
+
</Avatar>
|
|
36
|
+
<Avatar style="background:var(--accent);">
|
|
37
|
+
<AvatarFallback style="background:transparent;">E</AvatarFallback>
|
|
38
|
+
</Avatar>
|
|
39
|
+
<Avatar style="background:var(--muted);">
|
|
40
|
+
<AvatarFallback style="background:transparent;">V</AvatarFallback>
|
|
41
|
+
</Avatar>
|
|
42
|
+
</div>
|
|
43
|
+
</Story>
|
|
@@ -6,6 +6,21 @@
|
|
|
6
6
|
title: 'UI/Feedback/Badge',
|
|
7
7
|
component: Badge,
|
|
8
8
|
tags: ['autodocs'],
|
|
9
|
+
parameters: {
|
|
10
|
+
docs: {
|
|
11
|
+
description: {
|
|
12
|
+
component:
|
|
13
|
+
'Drobna etykieta statusu lub tagu. Używaj `secondary` w listach (najmniej krzyczy), `default`/`destructive` zostaw dla treści wymagających uwagi.',
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
argTypes: {
|
|
18
|
+
variant: {
|
|
19
|
+
description: 'Wariant wizualny.',
|
|
20
|
+
control: 'select',
|
|
21
|
+
options: ['default', 'secondary', 'destructive', 'outline'],
|
|
22
|
+
},
|
|
23
|
+
},
|
|
9
24
|
});
|
|
10
25
|
</script>
|
|
11
26
|
|
|
@@ -6,6 +6,13 @@
|
|
|
6
6
|
title: 'UI/Navigation/Breadcrumb',
|
|
7
7
|
component: Breadcrumb,
|
|
8
8
|
tags: ['autodocs'],
|
|
9
|
+
parameters: {
|
|
10
|
+
docs: {
|
|
11
|
+
description: {
|
|
12
|
+
component: 'Ścieżka nawigacyjna. Ostatni element to `BreadcrumbPage` (bieżący widok) bez linka. Cały kontener oznaczony `aria-label="Breadcrumb"`.',
|
|
13
|
+
},
|
|
14
|
+
},
|
|
15
|
+
},
|
|
9
16
|
});
|
|
10
17
|
</script>
|
|
11
18
|
|
|
@@ -31,3 +38,43 @@
|
|
|
31
38
|
</BreadcrumbList>
|
|
32
39
|
</Breadcrumb>
|
|
33
40
|
</Story>
|
|
41
|
+
|
|
42
|
+
<Story name="Short (2 levels)">
|
|
43
|
+
<Breadcrumb>
|
|
44
|
+
<BreadcrumbList>
|
|
45
|
+
<BreadcrumbItem>
|
|
46
|
+
<BreadcrumbLink href="#">Strona główna</BreadcrumbLink>
|
|
47
|
+
</BreadcrumbItem>
|
|
48
|
+
<BreadcrumbSeparator />
|
|
49
|
+
<BreadcrumbItem>
|
|
50
|
+
<BreadcrumbPage>Bieżąca strona</BreadcrumbPage>
|
|
51
|
+
</BreadcrumbItem>
|
|
52
|
+
</BreadcrumbList>
|
|
53
|
+
</Breadcrumb>
|
|
54
|
+
</Story>
|
|
55
|
+
|
|
56
|
+
<Story name="Long (5 levels)">
|
|
57
|
+
<Breadcrumb>
|
|
58
|
+
<BreadcrumbList>
|
|
59
|
+
<BreadcrumbItem>
|
|
60
|
+
<BreadcrumbLink href="#">Admin</BreadcrumbLink>
|
|
61
|
+
</BreadcrumbItem>
|
|
62
|
+
<BreadcrumbSeparator />
|
|
63
|
+
<BreadcrumbItem>
|
|
64
|
+
<BreadcrumbLink href="#">Sklep</BreadcrumbLink>
|
|
65
|
+
</BreadcrumbItem>
|
|
66
|
+
<BreadcrumbSeparator />
|
|
67
|
+
<BreadcrumbItem>
|
|
68
|
+
<BreadcrumbLink href="#">Zamówienia</BreadcrumbLink>
|
|
69
|
+
</BreadcrumbItem>
|
|
70
|
+
<BreadcrumbSeparator />
|
|
71
|
+
<BreadcrumbItem>
|
|
72
|
+
<BreadcrumbLink href="#">2026</BreadcrumbLink>
|
|
73
|
+
</BreadcrumbItem>
|
|
74
|
+
<BreadcrumbSeparator />
|
|
75
|
+
<BreadcrumbItem>
|
|
76
|
+
<BreadcrumbPage>ZAM-2026-0001</BreadcrumbPage>
|
|
77
|
+
</BreadcrumbItem>
|
|
78
|
+
</BreadcrumbList>
|
|
79
|
+
</Breadcrumb>
|
|
80
|
+
</Story>
|
|
@@ -1,11 +1,46 @@
|
|
|
1
1
|
<script module>
|
|
2
2
|
import { defineMeta } from '@storybook/addon-svelte-csf';
|
|
3
3
|
import { Button } from './index.js';
|
|
4
|
+
import SettingsIcon from '@lucide/svelte/icons/settings';
|
|
5
|
+
import BoldIcon from '@lucide/svelte/icons/bold';
|
|
6
|
+
import ItalicIcon from '@lucide/svelte/icons/italic';
|
|
4
7
|
|
|
5
8
|
const { Story } = defineMeta({
|
|
6
9
|
title: 'UI/Actions/Button',
|
|
7
10
|
component: Button,
|
|
8
11
|
tags: ['autodocs'],
|
|
12
|
+
parameters: {
|
|
13
|
+
docs: {
|
|
14
|
+
description: {
|
|
15
|
+
component:
|
|
16
|
+
'Główny przycisk akcji. Wariantów używaj zgodnie ze znaczeniem: `default` dla głównej akcji, `outline`/`ghost` dla wtórnych, `destructive` dla operacji nieodwracalnych. Dla przycisków z samą ikoną zawsze podaj `aria-label`.',
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
argTypes: {
|
|
21
|
+
variant: {
|
|
22
|
+
description: 'Wariant wizualny dopasowany do znaczenia akcji.',
|
|
23
|
+
control: 'select',
|
|
24
|
+
options: ['default', 'destructive', 'outline', 'secondary', 'ghost', 'link'],
|
|
25
|
+
},
|
|
26
|
+
size: {
|
|
27
|
+
description: 'Rozmiar — `icon*` przeznaczone dla przycisków bez tekstu.',
|
|
28
|
+
control: 'select',
|
|
29
|
+
options: ['default', 'sm', 'lg', 'icon', 'icon-sm', 'icon-lg'],
|
|
30
|
+
},
|
|
31
|
+
loading: {
|
|
32
|
+
description: 'Stan ładowania — spinner + `aria-busy` + blokada interakcji.',
|
|
33
|
+
control: 'boolean',
|
|
34
|
+
},
|
|
35
|
+
disabled: {
|
|
36
|
+
description: 'Wyłącza przycisk i blokuje fokus.',
|
|
37
|
+
control: 'boolean',
|
|
38
|
+
},
|
|
39
|
+
href: {
|
|
40
|
+
description: 'Gdy ustawione, renderuje `<a>` zamiast `<button>` (link wyglądający jak przycisk).',
|
|
41
|
+
control: 'text',
|
|
42
|
+
},
|
|
43
|
+
},
|
|
9
44
|
});
|
|
10
45
|
</script>
|
|
11
46
|
|
|
@@ -25,19 +60,31 @@
|
|
|
25
60
|
<Button variant="destructive">Archiwizuj wpis</Button>
|
|
26
61
|
</Story>
|
|
27
62
|
|
|
63
|
+
<Story name="Loading">
|
|
64
|
+
<Button loading>Zapisywanie…</Button>
|
|
65
|
+
</Story>
|
|
66
|
+
|
|
67
|
+
<Story name="Loading Outline">
|
|
68
|
+
<Button variant="outline" loading>Synchronizacja</Button>
|
|
69
|
+
</Story>
|
|
70
|
+
|
|
71
|
+
<Story name="Disabled Link">
|
|
72
|
+
<Button href="/admin/entries" disabled>Zobacz wpisy</Button>
|
|
73
|
+
</Story>
|
|
74
|
+
|
|
28
75
|
<Story name="Icon">
|
|
29
|
-
<Button variant="ghost" size="icon">
|
|
30
|
-
<
|
|
76
|
+
<Button variant="ghost" size="icon" aria-label="Ustawienia">
|
|
77
|
+
<SettingsIcon />
|
|
31
78
|
</Button>
|
|
32
79
|
</Story>
|
|
33
80
|
|
|
34
81
|
<Story name="Toolbar">
|
|
35
82
|
<div style="display:flex;gap:2px;padding:8px;background:var(--muted);border-radius:8px;">
|
|
36
|
-
<Button variant="ghost" size="icon-sm">
|
|
37
|
-
<
|
|
83
|
+
<Button variant="ghost" size="icon-sm" aria-label="Pogrubienie">
|
|
84
|
+
<BoldIcon />
|
|
38
85
|
</Button>
|
|
39
|
-
<Button variant="ghost" size="icon-sm">
|
|
40
|
-
<
|
|
86
|
+
<Button variant="ghost" size="icon-sm" aria-label="Kursywa">
|
|
87
|
+
<ItalicIcon />
|
|
41
88
|
</Button>
|
|
42
89
|
</div>
|
|
43
90
|
</Story>
|
|
@@ -31,17 +31,25 @@
|
|
|
31
31
|
},
|
|
32
32
|
});
|
|
33
33
|
|
|
34
|
+
/** @public Lock zestawu w v0.26.0 — zmiana = breaking. */
|
|
34
35
|
export type ButtonVariant = VariantProps<typeof buttonVariants>["variant"];
|
|
36
|
+
/** @public Lock zestawu w v0.26.0 — zmiana = breaking. */
|
|
35
37
|
export type ButtonSize = VariantProps<typeof buttonVariants>["size"];
|
|
36
38
|
|
|
37
39
|
export type ButtonProps = WithElementRef<HTMLButtonAttributes> &
|
|
38
40
|
WithElementRef<HTMLAnchorAttributes> & {
|
|
39
41
|
variant?: ButtonVariant;
|
|
40
42
|
size?: ButtonSize;
|
|
43
|
+
/** Stan ładowania — pokazuje spinner, ustawia aria-busy + disabled. */
|
|
44
|
+
loading?: boolean;
|
|
41
45
|
};
|
|
46
|
+
|
|
47
|
+
const ICON_SIZES: ReadonlyArray<ButtonSize> = ["icon", "icon-sm", "icon-lg"];
|
|
42
48
|
</script>
|
|
43
49
|
|
|
44
50
|
<script lang="ts">
|
|
51
|
+
import Loader2 from "@lucide/svelte/icons/loader-2";
|
|
52
|
+
|
|
45
53
|
let {
|
|
46
54
|
class: className,
|
|
47
55
|
variant = "default",
|
|
@@ -50,9 +58,27 @@
|
|
|
50
58
|
href = undefined,
|
|
51
59
|
type = "button",
|
|
52
60
|
disabled,
|
|
61
|
+
loading = false,
|
|
53
62
|
children,
|
|
54
63
|
...restProps
|
|
55
64
|
}: ButtonProps = $props();
|
|
65
|
+
|
|
66
|
+
if (import.meta.env.DEV) {
|
|
67
|
+
$effect(() => {
|
|
68
|
+
if (!ICON_SIZES.includes(size)) return;
|
|
69
|
+
const hasLabel =
|
|
70
|
+
"aria-label" in restProps ||
|
|
71
|
+
"aria-labelledby" in restProps ||
|
|
72
|
+
"title" in restProps;
|
|
73
|
+
if (!hasLabel) {
|
|
74
|
+
console.warn(
|
|
75
|
+
"[ui/button] icon-only Button bez aria-label/aria-labelledby/title — niedostępny dla screen readerów.",
|
|
76
|
+
);
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const isDisabled = $derived(disabled || loading);
|
|
56
82
|
</script>
|
|
57
83
|
|
|
58
84
|
{#if href}
|
|
@@ -60,12 +86,16 @@
|
|
|
60
86
|
bind:this={ref}
|
|
61
87
|
data-slot="button"
|
|
62
88
|
class={cn(buttonVariants({ variant, size }), className)}
|
|
63
|
-
href={
|
|
64
|
-
aria-disabled={
|
|
65
|
-
|
|
66
|
-
|
|
89
|
+
href={isDisabled ? undefined : href}
|
|
90
|
+
aria-disabled={isDisabled}
|
|
91
|
+
aria-busy={loading || undefined}
|
|
92
|
+
role={isDisabled ? "link" : undefined}
|
|
93
|
+
tabindex={isDisabled ? -1 : undefined}
|
|
67
94
|
{...restProps}
|
|
68
95
|
>
|
|
96
|
+
{#if loading}
|
|
97
|
+
<Loader2 class="animate-spin" aria-hidden="true" />
|
|
98
|
+
{/if}
|
|
69
99
|
{@render children?.()}
|
|
70
100
|
</a>
|
|
71
101
|
{:else}
|
|
@@ -74,9 +104,13 @@
|
|
|
74
104
|
data-slot="button"
|
|
75
105
|
class={cn(buttonVariants({ variant, size }), className)}
|
|
76
106
|
{type}
|
|
77
|
-
{
|
|
107
|
+
disabled={isDisabled}
|
|
108
|
+
aria-busy={loading || undefined}
|
|
78
109
|
{...restProps}
|
|
79
110
|
>
|
|
111
|
+
{#if loading}
|
|
112
|
+
<Loader2 class="animate-spin" aria-hidden="true" />
|
|
113
|
+
{/if}
|
|
80
114
|
{@render children?.()}
|
|
81
115
|
</button>
|
|
82
116
|
{/if}
|
|
@@ -53,11 +53,15 @@ export declare const buttonVariants: import("tailwind-variants").TVReturnType<{
|
|
|
53
53
|
"icon-lg": string;
|
|
54
54
|
};
|
|
55
55
|
}, undefined, "focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive inline-flex shrink-0 items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium outline-none transition-all focus-visible:ring-[3px] disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none [&_svg]:shrink-0", unknown, unknown, undefined>>;
|
|
56
|
+
/** @public Lock zestawu w v0.26.0 — zmiana = breaking. */
|
|
56
57
|
export type ButtonVariant = VariantProps<typeof buttonVariants>["variant"];
|
|
58
|
+
/** @public Lock zestawu w v0.26.0 — zmiana = breaking. */
|
|
57
59
|
export type ButtonSize = VariantProps<typeof buttonVariants>["size"];
|
|
58
60
|
export type ButtonProps = WithElementRef<HTMLButtonAttributes> & WithElementRef<HTMLAnchorAttributes> & {
|
|
59
61
|
variant?: ButtonVariant;
|
|
60
62
|
size?: ButtonSize;
|
|
63
|
+
/** Stan ładowania — pokazuje spinner, ustawia aria-busy + disabled. */
|
|
64
|
+
loading?: boolean;
|
|
61
65
|
};
|
|
62
66
|
declare const Button: import("svelte").Component<ButtonProps, {}, "ref">;
|
|
63
67
|
type Button = ReturnType<typeof Button>;
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
<script module>
|
|
2
|
+
import { defineMeta } from '@storybook/addon-svelte-csf';
|
|
3
|
+
import * as ButtonGroup from './index.js';
|
|
4
|
+
import { Root as ButtonGroupRoot } from './index.js';
|
|
5
|
+
import { Button } from '../button/index.js';
|
|
6
|
+
|
|
7
|
+
const { Story } = defineMeta({
|
|
8
|
+
title: 'UI/Actions/ButtonGroup',
|
|
9
|
+
component: ButtonGroupRoot,
|
|
10
|
+
tags: ['autodocs'],
|
|
11
|
+
parameters: {
|
|
12
|
+
docs: {
|
|
13
|
+
description: {
|
|
14
|
+
component: 'Grupa powiązanych przycisków akcji (np. format toolbar, filtry). Ustaw `role="group"` + `aria-label`, żeby screen reader pogrupował.',
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
});
|
|
19
|
+
</script>
|
|
20
|
+
|
|
21
|
+
<Story name="Three actions">
|
|
22
|
+
<ButtonGroup.Root role="group" aria-label="Akcje wpisu">
|
|
23
|
+
<Button variant="outline">Edytuj</Button>
|
|
24
|
+
<Button variant="outline">Duplikuj</Button>
|
|
25
|
+
<Button variant="outline">Archiwizuj</Button>
|
|
26
|
+
</ButtonGroup.Root>
|
|
27
|
+
</Story>
|
|
28
|
+
|
|
29
|
+
<Story name="With separator">
|
|
30
|
+
<ButtonGroup.Root role="group" aria-label="Filtr i sortowanie">
|
|
31
|
+
<Button variant="outline">Filtruj</Button>
|
|
32
|
+
<ButtonGroup.Separator />
|
|
33
|
+
<Button variant="outline">Sortuj</Button>
|
|
34
|
+
</ButtonGroup.Root>
|
|
35
|
+
</Story>
|
|
36
|
+
|
|
37
|
+
<Story name="With text addon">
|
|
38
|
+
<ButtonGroup.Root role="group" aria-label="Status zamówienia">
|
|
39
|
+
<ButtonGroup.Text>Status:</ButtonGroup.Text>
|
|
40
|
+
<Button variant="outline">Wszystkie</Button>
|
|
41
|
+
<Button variant="outline">Nowe</Button>
|
|
42
|
+
<Button variant="outline">Opłacone</Button>
|
|
43
|
+
</ButtonGroup.Root>
|
|
44
|
+
</Story>
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export default ButtonGroup;
|
|
2
|
+
type ButtonGroup = SvelteComponent<{
|
|
3
|
+
[x: string]: never;
|
|
4
|
+
}, {
|
|
5
|
+
[evt: string]: CustomEvent<any>;
|
|
6
|
+
}, {}> & {
|
|
7
|
+
$$bindings?: string | undefined;
|
|
8
|
+
};
|
|
9
|
+
declare const ButtonGroup: $$__sveltets_2_IsomorphicComponent<{
|
|
10
|
+
[x: string]: never;
|
|
11
|
+
}, {
|
|
12
|
+
[evt: string]: CustomEvent<any>;
|
|
13
|
+
}, {}, {}, string>;
|
|
14
|
+
import * as ButtonGroup from './index.js';
|
|
15
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
16
|
+
new (options: import("svelte").ComponentConstructorOptions<Props>): import("svelte").SvelteComponent<Props, Events, Slots> & {
|
|
17
|
+
$$bindings?: Bindings;
|
|
18
|
+
} & Exports;
|
|
19
|
+
(internal: unknown, props: {
|
|
20
|
+
$$events?: Events;
|
|
21
|
+
$$slots?: Slots;
|
|
22
|
+
}): Exports & {
|
|
23
|
+
$set?: any;
|
|
24
|
+
$on?: any;
|
|
25
|
+
};
|
|
26
|
+
z_$$bindings?: Bindings;
|
|
27
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
<script module>
|
|
2
|
+
import { defineMeta } from '@storybook/addon-svelte-csf';
|
|
3
|
+
import { Calendar } from './index.js';
|
|
4
|
+
|
|
5
|
+
const { Story } = defineMeta({
|
|
6
|
+
title: 'UI/Forms/Calendar',
|
|
7
|
+
component: Calendar,
|
|
8
|
+
tags: ['autodocs'],
|
|
9
|
+
parameters: {
|
|
10
|
+
docs: {
|
|
11
|
+
description: {
|
|
12
|
+
component: 'Wybór daty lub zakresu dat. Domyślnie używaj `locale="pl-PL"`. Klawiatura: arrows, PageUp/Down, Home/End.',
|
|
13
|
+
},
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
argTypes: {
|
|
17
|
+
type: {
|
|
18
|
+
control: 'select',
|
|
19
|
+
options: ['single', 'multiple', 'range'],
|
|
20
|
+
description: 'Tryb zaznaczania — pojedyncza data, wiele lub zakres.',
|
|
21
|
+
},
|
|
22
|
+
locale: {
|
|
23
|
+
control: 'text',
|
|
24
|
+
description: 'Locale formatowania (`pl-PL`, `en-GB`, ...).',
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
});
|
|
28
|
+
</script>
|
|
29
|
+
|
|
30
|
+
<Story name="Default (PL locale)">
|
|
31
|
+
<Calendar type="single" locale="pl-PL" />
|
|
32
|
+
</Story>
|
|
33
|
+
|
|
34
|
+
<Story name="With caption dropdown">
|
|
35
|
+
<Calendar type="single" locale="pl-PL" captionLayout="dropdown" />
|
|
36
|
+
</Story>
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export default Calendar;
|
|
2
|
+
type Calendar = SvelteComponent<{
|
|
3
|
+
[x: string]: never;
|
|
4
|
+
}, {
|
|
5
|
+
[evt: string]: CustomEvent<any>;
|
|
6
|
+
}, {}> & {
|
|
7
|
+
$$bindings?: string | undefined;
|
|
8
|
+
};
|
|
9
|
+
declare const Calendar: $$__sveltets_2_IsomorphicComponent<{
|
|
10
|
+
[x: string]: never;
|
|
11
|
+
}, {
|
|
12
|
+
[evt: string]: CustomEvent<any>;
|
|
13
|
+
}, {}, {}, string>;
|
|
14
|
+
import { Calendar } from './index.js';
|
|
15
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
16
|
+
new (options: import("svelte").ComponentConstructorOptions<Props>): import("svelte").SvelteComponent<Props, Events, Slots> & {
|
|
17
|
+
$$bindings?: Bindings;
|
|
18
|
+
} & Exports;
|
|
19
|
+
(internal: unknown, props: {
|
|
20
|
+
$$events?: Events;
|
|
21
|
+
$$slots?: Slots;
|
|
22
|
+
}): Exports & {
|
|
23
|
+
$set?: any;
|
|
24
|
+
$on?: any;
|
|
25
|
+
};
|
|
26
|
+
z_$$bindings?: Bindings;
|
|
27
|
+
}
|
|
@@ -6,6 +6,13 @@
|
|
|
6
6
|
title: 'UI/Layout/Card',
|
|
7
7
|
component: Card,
|
|
8
8
|
tags: ['autodocs'],
|
|
9
|
+
parameters: {
|
|
10
|
+
docs: {
|
|
11
|
+
description: {
|
|
12
|
+
component: 'Kontener z subtelnym tłem i border-radius 12px. Używaj do grupowania powiązanych pól w edytorze lub kartach na dashboardzie.',
|
|
13
|
+
},
|
|
14
|
+
},
|
|
15
|
+
},
|
|
9
16
|
});
|
|
10
17
|
</script>
|
|
11
18
|
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
<script module>
|
|
2
|
+
import { defineMeta } from '@storybook/addon-svelte-csf';
|
|
3
|
+
import * as Carousel from './index.js';
|
|
4
|
+
import { Root as CarouselRoot } from './index.js';
|
|
5
|
+
|
|
6
|
+
const { Story } = defineMeta({
|
|
7
|
+
title: 'UI/Layout/Carousel',
|
|
8
|
+
component: CarouselRoot,
|
|
9
|
+
tags: ['autodocs'],
|
|
10
|
+
parameters: {
|
|
11
|
+
docs: {
|
|
12
|
+
description: {
|
|
13
|
+
component: 'Slider treści z nawigacją klawiaturową (strzałki). Jeśli auto-play — udostępnij pause/resume i nie wymuszaj ruchu po `prefers-reduced-motion`.',
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
argTypes: {
|
|
18
|
+
orientation: {
|
|
19
|
+
control: 'select',
|
|
20
|
+
options: ['horizontal', 'vertical'],
|
|
21
|
+
description: 'Kierunek przesuwania.',
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
});
|
|
25
|
+
</script>
|
|
26
|
+
|
|
27
|
+
<Story name="Three slides">
|
|
28
|
+
<Carousel.Root>
|
|
29
|
+
<Carousel.Content>
|
|
30
|
+
{#each ['Pierwszy', 'Drugi', 'Trzeci'] as label, i (i)}
|
|
31
|
+
<Carousel.Item>
|
|
32
|
+
<div
|
|
33
|
+
style="display:flex;align-items:center;justify-content:center;height:160px;background:var(--muted);border-radius:12px;font-size:24px;font-weight:600;"
|
|
34
|
+
>
|
|
35
|
+
{label}
|
|
36
|
+
</div>
|
|
37
|
+
</Carousel.Item>
|
|
38
|
+
{/each}
|
|
39
|
+
</Carousel.Content>
|
|
40
|
+
<Carousel.Previous />
|
|
41
|
+
<Carousel.Next />
|
|
42
|
+
</Carousel.Root>
|
|
43
|
+
</Story>
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export default Carousel;
|
|
2
|
+
type Carousel = SvelteComponent<{
|
|
3
|
+
[x: string]: never;
|
|
4
|
+
}, {
|
|
5
|
+
[evt: string]: CustomEvent<any>;
|
|
6
|
+
}, {}> & {
|
|
7
|
+
$$bindings?: string | undefined;
|
|
8
|
+
};
|
|
9
|
+
declare const Carousel: $$__sveltets_2_IsomorphicComponent<{
|
|
10
|
+
[x: string]: never;
|
|
11
|
+
}, {
|
|
12
|
+
[evt: string]: CustomEvent<any>;
|
|
13
|
+
}, {}, {}, string>;
|
|
14
|
+
import * as Carousel from './index.js';
|
|
15
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
16
|
+
new (options: import("svelte").ComponentConstructorOptions<Props>): import("svelte").SvelteComponent<Props, Events, Slots> & {
|
|
17
|
+
$$bindings?: Bindings;
|
|
18
|
+
} & Exports;
|
|
19
|
+
(internal: unknown, props: {
|
|
20
|
+
$$events?: Events;
|
|
21
|
+
$$slots?: Slots;
|
|
22
|
+
}): Exports & {
|
|
23
|
+
$set?: any;
|
|
24
|
+
$on?: any;
|
|
25
|
+
};
|
|
26
|
+
z_$$bindings?: Bindings;
|
|
27
|
+
}
|