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
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
type RowSelectionState,
|
|
7
7
|
type PaginationState,
|
|
8
8
|
type Table as TableType,
|
|
9
|
+
type Column,
|
|
9
10
|
getCoreRowModel,
|
|
10
11
|
getFilteredRowModel,
|
|
11
12
|
getSortedRowModel,
|
|
@@ -17,6 +18,7 @@
|
|
|
17
18
|
import type { InterfaceLanguage } from '../../../types/languages.js';
|
|
18
19
|
import { droppable, draggable, dndState } from '@thisux/sveltednd';
|
|
19
20
|
import { flip } from 'svelte/animate';
|
|
21
|
+
import StateDisplay from './state-display.svelte';
|
|
20
22
|
|
|
21
23
|
type DataTableProps<TData, TValue> = {
|
|
22
24
|
columns: ColumnDef<TData, TValue>[];
|
|
@@ -36,9 +38,20 @@
|
|
|
36
38
|
manualPagination?: boolean;
|
|
37
39
|
pageCount?: number;
|
|
38
40
|
rowCount?: number;
|
|
41
|
+
/** @deprecated since v0.26.0 — use `emptyTitle`/`emptyDescription` instead. */
|
|
39
42
|
emptyMessage?: string;
|
|
43
|
+
emptyTitle?: string;
|
|
44
|
+
emptyDescription?: string;
|
|
45
|
+
viewState?: 'idle' | 'loading' | 'error';
|
|
46
|
+
errorMessage?: string;
|
|
47
|
+
loadingMessage?: string;
|
|
48
|
+
onRetry?: () => void;
|
|
40
49
|
orderable?: boolean;
|
|
41
50
|
onReorder?: (fromIndex: number, toIndex: number) => void;
|
|
51
|
+
/** Pin first column when horizontally scrolling (helps on mobile with wide tables). Default true. */
|
|
52
|
+
stickyFirstColumn?: boolean;
|
|
53
|
+
/** Extend table to viewport edges on mobile via negative horizontal margin. Default true. */
|
|
54
|
+
mobileEdgeBleed?: boolean;
|
|
42
55
|
};
|
|
43
56
|
|
|
44
57
|
let {
|
|
@@ -60,16 +73,25 @@
|
|
|
60
73
|
pageCount: pageCountProp,
|
|
61
74
|
rowCount: rowCountProp,
|
|
62
75
|
emptyMessage,
|
|
76
|
+
emptyTitle,
|
|
77
|
+
emptyDescription,
|
|
78
|
+
viewState = 'idle',
|
|
79
|
+
errorMessage,
|
|
80
|
+
loadingMessage,
|
|
81
|
+
onRetry,
|
|
63
82
|
orderable = false,
|
|
64
|
-
onReorder
|
|
83
|
+
onReorder,
|
|
84
|
+
stickyFirstColumn = true,
|
|
85
|
+
mobileEdgeBleed = true
|
|
65
86
|
}: DataTableProps<TData, TValue> = $props();
|
|
66
87
|
|
|
67
88
|
let liveRegionMessage = $state('');
|
|
68
89
|
let dropProcessing = false;
|
|
69
90
|
|
|
70
|
-
const matchesReducedMotion =
|
|
71
|
-
|
|
72
|
-
|
|
91
|
+
const matchesReducedMotion =
|
|
92
|
+
typeof window !== 'undefined'
|
|
93
|
+
? window.matchMedia('(prefers-reduced-motion: reduce)').matches
|
|
94
|
+
: false;
|
|
73
95
|
|
|
74
96
|
const interfaceLanguage = useInterfaceLanguage();
|
|
75
97
|
|
|
@@ -78,6 +100,14 @@
|
|
|
78
100
|
pl: 'Brak wyników.'
|
|
79
101
|
};
|
|
80
102
|
|
|
103
|
+
function ariaSortFor(column: Column<TData, unknown>): 'none' | 'ascending' | 'descending' | undefined {
|
|
104
|
+
if (!column.getCanSort()) return undefined;
|
|
105
|
+
const dir = column.getIsSorted();
|
|
106
|
+
if (dir === 'asc') return 'ascending';
|
|
107
|
+
if (dir === 'desc') return 'descending';
|
|
108
|
+
return 'none';
|
|
109
|
+
}
|
|
110
|
+
|
|
81
111
|
const table = createSvelteTable({
|
|
82
112
|
get data() {
|
|
83
113
|
return data;
|
|
@@ -124,139 +154,258 @@
|
|
|
124
154
|
$effect(() => {
|
|
125
155
|
tableRef?.(table);
|
|
126
156
|
});
|
|
157
|
+
|
|
158
|
+
const resolvedEmptyTitle = $derived(
|
|
159
|
+
emptyTitle ?? emptyMessage ?? defaultEmptyMessages[interfaceLanguage.current]
|
|
160
|
+
);
|
|
127
161
|
</script>
|
|
128
162
|
|
|
129
|
-
{#if
|
|
130
|
-
<
|
|
131
|
-
{
|
|
163
|
+
{#if viewState === 'loading' || viewState === 'error'}
|
|
164
|
+
<StateDisplay
|
|
165
|
+
kind={viewState}
|
|
166
|
+
title={viewState === 'loading' ? loadingMessage : errorMessage}
|
|
167
|
+
onCta={viewState === 'error' ? onRetry : undefined}
|
|
168
|
+
/>
|
|
169
|
+
{:else}
|
|
170
|
+
{#if orderable}
|
|
171
|
+
<div aria-live="polite" aria-atomic="true" class="sr-only">{liveRegionMessage}</div>
|
|
172
|
+
{/if}
|
|
132
173
|
|
|
133
|
-
<
|
|
134
|
-
|
|
135
|
-
{
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
174
|
+
<div
|
|
175
|
+
class="data-table-shell"
|
|
176
|
+
data-sticky-first={stickyFirstColumn ? 'true' : undefined}
|
|
177
|
+
data-mobile-bleed={mobileEdgeBleed ? 'true' : undefined}
|
|
178
|
+
>
|
|
179
|
+
<Table.Root aria-roledescription={orderable ? 'sortable list' : undefined}>
|
|
180
|
+
<Table.Header class="bg-muted sticky top-0 z-10">
|
|
181
|
+
{#each table.getHeaderGroups() as headerGroup (headerGroup.id)}
|
|
182
|
+
<Table.Row class="border-b-0 hover:bg-transparent">
|
|
183
|
+
{#if orderable}
|
|
184
|
+
<Table.Head
|
|
185
|
+
class="text-[11px] font-bold uppercase tracking-[0.04em] text-muted-foreground h-10 w-10"
|
|
186
|
+
></Table.Head>
|
|
187
|
+
{/if}
|
|
188
|
+
{#each headerGroup.headers as header (header.id)}
|
|
189
|
+
<Table.Head
|
|
190
|
+
class="text-[11px] font-bold uppercase tracking-[0.04em] text-muted-foreground h-10"
|
|
191
|
+
aria-sort={ariaSortFor(header.column)}
|
|
192
|
+
>
|
|
193
|
+
{#if !header.isPlaceholder}
|
|
194
|
+
<FlexRender
|
|
195
|
+
content={header.column.columnDef.header}
|
|
196
|
+
context={header.getContext()}
|
|
197
|
+
/>
|
|
198
|
+
{/if}
|
|
199
|
+
</Table.Head>
|
|
200
|
+
{/each}
|
|
201
|
+
</Table.Row>
|
|
202
|
+
{/each}
|
|
203
|
+
</Table.Header>
|
|
204
|
+
<Table.Body>
|
|
205
|
+
{#if orderable}
|
|
206
|
+
{#each table.getRowModel().rows as row, i (row.id)}
|
|
207
|
+
{@const totalRows = table.getRowModel().rows.length}
|
|
208
|
+
<tr
|
|
209
|
+
use:droppable={{
|
|
210
|
+
container: i.toString(),
|
|
211
|
+
callbacks: {
|
|
212
|
+
onDrop: (state) => {
|
|
213
|
+
if (dropProcessing) return;
|
|
214
|
+
dropProcessing = true;
|
|
215
|
+
const fromIndex = parseInt(state.sourceContainer ?? '');
|
|
216
|
+
const toIndex = parseInt(state.targetContainer ?? '');
|
|
217
|
+
if (!isNaN(fromIndex) && !isNaN(toIndex)) {
|
|
218
|
+
onReorder?.(fromIndex, toIndex);
|
|
219
|
+
}
|
|
220
|
+
dndState.isDragging = false;
|
|
221
|
+
dndState.draggedItem = null;
|
|
222
|
+
dndState.sourceContainer = '';
|
|
223
|
+
dndState.targetContainer = null;
|
|
224
|
+
dndState.targetElement = null;
|
|
225
|
+
setTimeout(() => {
|
|
226
|
+
dropProcessing = false;
|
|
227
|
+
}, 50);
|
|
168
228
|
}
|
|
169
|
-
dndState.isDragging = false;
|
|
170
|
-
dndState.draggedItem = null;
|
|
171
|
-
dndState.sourceContainer = '';
|
|
172
|
-
dndState.targetContainer = null;
|
|
173
|
-
dndState.targetElement = null;
|
|
174
|
-
setTimeout(() => { dropProcessing = false; }, 50);
|
|
175
229
|
}
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
onReorder?.(i, i + 1);
|
|
219
|
-
liveRegionMessage = `Moved to position ${i + 2} of ${totalRows}`;
|
|
220
|
-
}}
|
|
230
|
+
}}
|
|
231
|
+
animate:flip={{ duration: matchesReducedMotion ? 0 : 200 }}
|
|
232
|
+
data-slot="table-row"
|
|
233
|
+
data-state={row.getIsSelected() ? 'selected' : undefined}
|
|
234
|
+
aria-selected={enableSelection && row.getIsSelected() ? true : undefined}
|
|
235
|
+
class="hover:bg-muted/50 data-[state=selected]:bg-muted border-b transition-colors hover:bg-lavender-lighter/50 data-[state=selected]:bg-lavender-lighter/30 {i ===
|
|
236
|
+
totalRows - 1
|
|
237
|
+
? 'border-b-0'
|
|
238
|
+
: ''}"
|
|
239
|
+
>
|
|
240
|
+
<Table.Cell class="py-3 w-10">
|
|
241
|
+
<div class="flex items-center gap-1">
|
|
242
|
+
<div
|
|
243
|
+
use:draggable={{
|
|
244
|
+
container: i.toString(),
|
|
245
|
+
dragData: { index: i }
|
|
246
|
+
}}
|
|
247
|
+
class="text-muted-foreground hover:text-foreground cursor-grab"
|
|
248
|
+
role="button"
|
|
249
|
+
tabindex="0"
|
|
250
|
+
aria-label={`Drag to reorder, row ${i + 1} of ${totalRows}`}
|
|
251
|
+
aria-roledescription="draggable"
|
|
252
|
+
>
|
|
253
|
+
<svg
|
|
254
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
255
|
+
width="16"
|
|
256
|
+
height="16"
|
|
257
|
+
viewBox="0 0 24 24"
|
|
258
|
+
fill="none"
|
|
259
|
+
stroke="currentColor"
|
|
260
|
+
stroke-width="2"
|
|
261
|
+
stroke-linecap="round"
|
|
262
|
+
stroke-linejoin="round"
|
|
263
|
+
><circle cx="9" cy="12" r="1" /><circle cx="9" cy="5" r="1" /><circle
|
|
264
|
+
cx="9"
|
|
265
|
+
cy="19"
|
|
266
|
+
r="1"
|
|
267
|
+
/><circle cx="15" cy="12" r="1" /><circle cx="15" cy="5" r="1" /><circle
|
|
268
|
+
cx="15"
|
|
269
|
+
cy="19"
|
|
270
|
+
r="1"
|
|
271
|
+
/></svg
|
|
221
272
|
>
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
273
|
+
</div>
|
|
274
|
+
<div class="flex flex-col">
|
|
275
|
+
{#if i > 0}
|
|
276
|
+
<button
|
|
277
|
+
type="button"
|
|
278
|
+
class="p-0.5 rounded text-muted-foreground hover:text-foreground"
|
|
279
|
+
aria-label={`Move up, row ${i + 1} of ${totalRows}`}
|
|
280
|
+
onclick={() => {
|
|
281
|
+
onReorder?.(i, i - 1);
|
|
282
|
+
liveRegionMessage = `Moved to position ${i} of ${totalRows}`;
|
|
283
|
+
}}
|
|
284
|
+
>
|
|
285
|
+
<svg
|
|
286
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
287
|
+
width="14"
|
|
288
|
+
height="14"
|
|
289
|
+
viewBox="0 0 24 24"
|
|
290
|
+
fill="none"
|
|
291
|
+
stroke="currentColor"
|
|
292
|
+
stroke-width="2"><path d="m18 15-6-6-6 6" /></svg
|
|
293
|
+
>
|
|
294
|
+
</button>
|
|
295
|
+
{/if}
|
|
296
|
+
{#if i < totalRows - 1}
|
|
297
|
+
<button
|
|
298
|
+
type="button"
|
|
299
|
+
class="p-0.5 rounded text-muted-foreground hover:text-foreground"
|
|
300
|
+
aria-label={`Move down, row ${i + 1} of ${totalRows}`}
|
|
301
|
+
onclick={() => {
|
|
302
|
+
onReorder?.(i, i + 1);
|
|
303
|
+
liveRegionMessage = `Moved to position ${i + 2} of ${totalRows}`;
|
|
304
|
+
}}
|
|
305
|
+
>
|
|
306
|
+
<svg
|
|
307
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
308
|
+
width="14"
|
|
309
|
+
height="14"
|
|
310
|
+
viewBox="0 0 24 24"
|
|
311
|
+
fill="none"
|
|
312
|
+
stroke="currentColor"
|
|
313
|
+
stroke-width="2"><path d="m6 9 6 6 6-6" /></svg
|
|
314
|
+
>
|
|
315
|
+
</button>
|
|
316
|
+
{/if}
|
|
317
|
+
</div>
|
|
225
318
|
</div>
|
|
226
|
-
</div>
|
|
227
|
-
</Table.Cell>
|
|
228
|
-
{#each row.getVisibleCells() as cell (cell.id)}
|
|
229
|
-
<Table.Cell class="py-3">
|
|
230
|
-
<FlexRender content={cell.column.columnDef.cell} context={cell.getContext()} />
|
|
231
319
|
</Table.Cell>
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
class="hover:bg-lavender-lighter/50 data-[state=selected]:bg-lavender-lighter/30 {i === table.getRowModel().rows.length - 1 ? 'border-b-0' : ''}"
|
|
246
|
-
>
|
|
247
|
-
{#each row.getVisibleCells() as cell (cell.id)}
|
|
248
|
-
<Table.Cell class="py-3">
|
|
249
|
-
<FlexRender content={cell.column.columnDef.cell} context={cell.getContext()} />
|
|
320
|
+
{#each row.getVisibleCells() as cell (cell.id)}
|
|
321
|
+
<Table.Cell class="py-3">
|
|
322
|
+
<FlexRender content={cell.column.columnDef.cell} context={cell.getContext()} />
|
|
323
|
+
</Table.Cell>
|
|
324
|
+
{/each}
|
|
325
|
+
</tr>
|
|
326
|
+
{:else}
|
|
327
|
+
<Table.Row>
|
|
328
|
+
<Table.Cell
|
|
329
|
+
colspan={columns.length + 1}
|
|
330
|
+
class="h-24 text-center text-muted-foreground p-0"
|
|
331
|
+
>
|
|
332
|
+
<StateDisplay kind="empty" title={resolvedEmptyTitle} description={emptyDescription} />
|
|
250
333
|
</Table.Cell>
|
|
251
|
-
|
|
252
|
-
|
|
334
|
+
</Table.Row>
|
|
335
|
+
{/each}
|
|
253
336
|
{:else}
|
|
254
|
-
|
|
255
|
-
<Table.
|
|
256
|
-
{
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
337
|
+
{#each table.getRowModel().rows as row, i (row.id)}
|
|
338
|
+
<Table.Row
|
|
339
|
+
data-state={row.getIsSelected() && 'selected'}
|
|
340
|
+
aria-selected={enableSelection && row.getIsSelected() ? true : undefined}
|
|
341
|
+
class="hover:bg-lavender-lighter/50 data-[state=selected]:bg-lavender-lighter/30 {i ===
|
|
342
|
+
table.getRowModel().rows.length - 1
|
|
343
|
+
? 'border-b-0'
|
|
344
|
+
: ''}"
|
|
345
|
+
>
|
|
346
|
+
{#each row.getVisibleCells() as cell (cell.id)}
|
|
347
|
+
<Table.Cell class="py-3">
|
|
348
|
+
<FlexRender content={cell.column.columnDef.cell} context={cell.getContext()} />
|
|
349
|
+
</Table.Cell>
|
|
350
|
+
{/each}
|
|
351
|
+
</Table.Row>
|
|
352
|
+
{:else}
|
|
353
|
+
<Table.Row>
|
|
354
|
+
<Table.Cell colspan={columns.length} class="h-24 text-center text-muted-foreground p-0">
|
|
355
|
+
<StateDisplay kind="empty" title={resolvedEmptyTitle} description={emptyDescription} />
|
|
356
|
+
</Table.Cell>
|
|
357
|
+
</Table.Row>
|
|
358
|
+
{/each}
|
|
359
|
+
{/if}
|
|
360
|
+
</Table.Body>
|
|
361
|
+
</Table.Root>
|
|
362
|
+
</div>
|
|
363
|
+
{/if}
|
|
364
|
+
|
|
365
|
+
<style>
|
|
366
|
+
/* Mobile edge bleed: table can scroll edge-to-edge on small screens. */
|
|
367
|
+
@media (max-width: 639px) {
|
|
368
|
+
.data-table-shell[data-mobile-bleed='true'] :global([data-slot='table-container']) {
|
|
369
|
+
margin-left: -1rem;
|
|
370
|
+
margin-right: -1rem;
|
|
371
|
+
border-left: 0;
|
|
372
|
+
border-right: 0;
|
|
373
|
+
border-radius: 0;
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
|
|
377
|
+
/* Sticky first column (helps reading wide tables when scrolling horizontally). */
|
|
378
|
+
.data-table-shell[data-sticky-first='true'] :global(thead th:first-child),
|
|
379
|
+
.data-table-shell[data-sticky-first='true'] :global(tbody td:first-child) {
|
|
380
|
+
position: sticky;
|
|
381
|
+
left: 0;
|
|
382
|
+
background: var(--background);
|
|
383
|
+
}
|
|
384
|
+
.data-table-shell[data-sticky-first='true'] :global(thead th:first-child) {
|
|
385
|
+
z-index: 11;
|
|
386
|
+
background: var(--muted, var(--background));
|
|
387
|
+
}
|
|
388
|
+
.data-table-shell[data-sticky-first='true'] :global(tbody td:first-child) {
|
|
389
|
+
z-index: 2;
|
|
390
|
+
}
|
|
391
|
+
/* Subtle right-edge shadow only when scrolled */
|
|
392
|
+
.data-table-shell[data-sticky-first='true'] :global([data-slot='table-container']) {
|
|
393
|
+
background:
|
|
394
|
+
linear-gradient(to right, var(--background), var(--background)) left center,
|
|
395
|
+
linear-gradient(to right, transparent, var(--background)) left center,
|
|
396
|
+
radial-gradient(farthest-side at 0 50%, rgba(0, 0, 0, 0.08), transparent) 0 center,
|
|
397
|
+
radial-gradient(farthest-side at 100% 50%, rgba(0, 0, 0, 0.08), transparent) 100% center;
|
|
398
|
+
background-repeat: no-repeat;
|
|
399
|
+
background-size:
|
|
400
|
+
20px 100%,
|
|
401
|
+
20px 100%,
|
|
402
|
+
10px 100%,
|
|
403
|
+
10px 100%;
|
|
404
|
+
background-attachment: local, local, scroll, scroll;
|
|
405
|
+
}
|
|
406
|
+
/* Selected row first-cell needs to keep selection bg over the sticky default */
|
|
407
|
+
.data-table-shell[data-sticky-first='true']
|
|
408
|
+
:global(tr[data-state='selected'] td:first-child) {
|
|
409
|
+
background: var(--accent, var(--background));
|
|
410
|
+
}
|
|
411
|
+
</style>
|
|
@@ -17,9 +17,20 @@ type DataTableProps<TData, TValue> = {
|
|
|
17
17
|
manualPagination?: boolean;
|
|
18
18
|
pageCount?: number;
|
|
19
19
|
rowCount?: number;
|
|
20
|
+
/** @deprecated since v0.26.0 — use `emptyTitle`/`emptyDescription` instead. */
|
|
20
21
|
emptyMessage?: string;
|
|
22
|
+
emptyTitle?: string;
|
|
23
|
+
emptyDescription?: string;
|
|
24
|
+
viewState?: 'idle' | 'loading' | 'error';
|
|
25
|
+
errorMessage?: string;
|
|
26
|
+
loadingMessage?: string;
|
|
27
|
+
onRetry?: () => void;
|
|
21
28
|
orderable?: boolean;
|
|
22
29
|
onReorder?: (fromIndex: number, toIndex: number) => void;
|
|
30
|
+
/** Pin first column when horizontally scrolling (helps on mobile with wide tables). Default true. */
|
|
31
|
+
stickyFirstColumn?: boolean;
|
|
32
|
+
/** Extend table to viewport edges on mobile via negative horizontal margin. Default true. */
|
|
33
|
+
mobileEdgeBleed?: boolean;
|
|
23
34
|
};
|
|
24
35
|
declare function $$render<TData, TValue>(): {
|
|
25
36
|
props: DataTableProps<TData, TValue>;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
<script lang="ts">
|
|
2
|
-
import { formatRelativeDate,
|
|
2
|
+
import { formatRelativeDate, formatDateTime, formatShortDateOnly } from '../../utils/formatters.js';
|
|
3
3
|
import { useInterfaceLanguage } from '../../state/interface-language.svelte.js';
|
|
4
4
|
|
|
5
5
|
type Props = {
|
|
@@ -15,11 +15,11 @@
|
|
|
15
15
|
format === 'relative'
|
|
16
16
|
? formatRelativeDate(date, interfaceLanguage.current)
|
|
17
17
|
: format === 'short'
|
|
18
|
-
?
|
|
19
|
-
:
|
|
18
|
+
? formatShortDateOnly(date, interfaceLanguage.current)
|
|
19
|
+
: formatDateTime(date, interfaceLanguage.current)
|
|
20
20
|
);
|
|
21
21
|
|
|
22
|
-
const absoluteDate = $derived(
|
|
22
|
+
const absoluteDate = $derived(formatDateTime(date, interfaceLanguage.current));
|
|
23
23
|
</script>
|
|
24
24
|
|
|
25
25
|
<span title={absoluteDate} class="text-muted-foreground text-sm whitespace-nowrap">
|
|
@@ -7,6 +7,7 @@
|
|
|
7
7
|
import Button from '../../../components/ui/button/button.svelte';
|
|
8
8
|
import * as DropdownMenu from '../../../components/ui/dropdown-menu/index.js';
|
|
9
9
|
import { useInterfaceLanguage } from '../../state/interface-language.svelte.js';
|
|
10
|
+
import { goto } from '$app/navigation';
|
|
10
11
|
import type { InterfaceLanguage } from '../../../types/languages.js';
|
|
11
12
|
|
|
12
13
|
type Props = {
|
|
@@ -45,7 +46,7 @@
|
|
|
45
46
|
{/snippet}
|
|
46
47
|
</DropdownMenu.Trigger>
|
|
47
48
|
<DropdownMenu.Content align="end" class="w-40">
|
|
48
|
-
<DropdownMenu.Item
|
|
49
|
+
<DropdownMenu.Item onclick={() => goto(entryUrl)}>
|
|
49
50
|
<ExternalLink class="mr-2 size-4" />
|
|
50
51
|
{t.open}
|
|
51
52
|
</DropdownMenu.Item>
|
|
@@ -4,6 +4,8 @@
|
|
|
4
4
|
import ArrowDown from '@tabler/icons-svelte/icons/arrow-down';
|
|
5
5
|
import ArrowsSort from '@tabler/icons-svelte/icons/arrows-sort';
|
|
6
6
|
import Button from '../../../components/ui/button/button.svelte';
|
|
7
|
+
import { useInterfaceLanguage } from '../../state/interface-language.svelte.js';
|
|
8
|
+
import type { InterfaceLanguage } from '../../../types/languages.js';
|
|
7
9
|
|
|
8
10
|
type Props = {
|
|
9
11
|
column: Column<TData, unknown>;
|
|
@@ -13,24 +15,45 @@
|
|
|
13
15
|
|
|
14
16
|
let { column, label, sorting = [] }: Props = $props();
|
|
15
17
|
|
|
16
|
-
const
|
|
18
|
+
const interfaceLanguage = useInterfaceLanguage();
|
|
19
|
+
|
|
20
|
+
const lang: Record<InterfaceLanguage, { asc: string; desc: string; unsorted: string }> = {
|
|
21
|
+
en: {
|
|
22
|
+
asc: 'sorted ascending',
|
|
23
|
+
desc: 'sorted descending',
|
|
24
|
+
unsorted: 'not sorted'
|
|
25
|
+
},
|
|
26
|
+
pl: {
|
|
27
|
+
asc: 'sortowane rosnąco',
|
|
28
|
+
desc: 'sortowane malejąco',
|
|
29
|
+
unsorted: 'nieposortowane'
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
const t = $derived(lang[interfaceLanguage.current]);
|
|
34
|
+
|
|
35
|
+
const sortDir = $derived(
|
|
36
|
+
sorting.find((s) => s.id === column.id)?.desc
|
|
37
|
+
? 'desc'
|
|
38
|
+
: sorting.find((s) => s.id === column.id)
|
|
39
|
+
? 'asc'
|
|
40
|
+
: false
|
|
41
|
+
);
|
|
42
|
+
|
|
43
|
+
const srLabel = $derived(sortDir === 'asc' ? t.asc : sortDir === 'desc' ? t.desc : t.unsorted);
|
|
17
44
|
|
|
18
45
|
function handleClick() {
|
|
19
46
|
if (!sortDir) {
|
|
20
|
-
column.toggleSorting(false);
|
|
47
|
+
column.toggleSorting(false);
|
|
21
48
|
} else if (sortDir === 'asc') {
|
|
22
|
-
column.toggleSorting(true);
|
|
49
|
+
column.toggleSorting(true);
|
|
23
50
|
} else {
|
|
24
|
-
column.clearSorting();
|
|
51
|
+
column.clearSorting();
|
|
25
52
|
}
|
|
26
53
|
}
|
|
27
54
|
</script>
|
|
28
55
|
|
|
29
|
-
<Button
|
|
30
|
-
variant="ghost"
|
|
31
|
-
class="-ml-3 h-8 px-2 hover:bg-transparent"
|
|
32
|
-
onclick={handleClick}
|
|
33
|
-
>
|
|
56
|
+
<Button variant="ghost" class="-ml-3 h-8 px-2 hover:bg-transparent" onclick={handleClick}>
|
|
34
57
|
{label}
|
|
35
58
|
{#if sortDir === 'asc'}
|
|
36
59
|
<ArrowUp class="ml-1 size-4" />
|
|
@@ -39,4 +62,5 @@
|
|
|
39
62
|
{:else}
|
|
40
63
|
<ArrowsSort class="ml-1 size-4 opacity-50" />
|
|
41
64
|
{/if}
|
|
65
|
+
<span class="sr-only"> ({srLabel})</span>
|
|
42
66
|
</Button>
|