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.
Files changed (349) hide show
  1. package/API.md +57 -4
  2. package/CHANGELOG.md +53 -0
  3. package/DOCS.md +1 -1
  4. package/README.md +2 -0
  5. package/ROADMAP.md +6 -0
  6. package/dist/admin/client/account/lang.d.ts +1 -0
  7. package/dist/admin/client/account/lang.js +4 -2
  8. package/dist/admin/client/account/profile-section.svelte +2 -2
  9. package/dist/admin/client/account/security-section.svelte +27 -4
  10. package/dist/admin/client/account/sessions-section.svelte +1 -1
  11. package/dist/admin/client/admin/admin-after-login-layout-content.svelte +1 -1
  12. package/dist/admin/client/admin/dashboard-page.svelte +34 -10
  13. package/dist/admin/client/collection/bulk-actions-bar.svelte +86 -44
  14. package/dist/admin/client/collection/bulk-actions-bar.svelte.d.ts +3 -1
  15. package/dist/admin/client/collection/collection-entries.svelte +52 -36
  16. package/dist/admin/client/collection/collection-entries.svelte.d.ts +3 -0
  17. package/dist/admin/client/collection/collection.svelte +28 -14
  18. package/dist/admin/client/collection/collection.svelte.d.ts +3 -0
  19. package/dist/admin/client/collection/data-table.svelte +279 -130
  20. package/dist/admin/client/collection/data-table.svelte.d.ts +11 -0
  21. package/dist/admin/client/collection/date-cell.svelte +4 -4
  22. package/dist/admin/client/collection/row-actions.svelte +2 -1
  23. package/dist/admin/client/collection/sortable-header.svelte +33 -9
  24. package/dist/admin/client/collection/state-display.svelte +102 -0
  25. package/dist/admin/client/collection/state-display.svelte.d.ts +12 -0
  26. package/dist/admin/client/collection/status-badge.svelte +99 -11
  27. package/dist/admin/client/collection/status-badge.svelte.d.ts +15 -1
  28. package/dist/admin/client/collection/table-pagination.svelte +21 -6
  29. package/dist/admin/client/collection/table-toolbar.svelte +105 -80
  30. package/dist/admin/client/collection/table-toolbar.svelte.d.ts +11 -8
  31. package/dist/admin/client/entry/entry-form.svelte +36 -11
  32. package/dist/admin/client/entry/entry-form.svelte.d.ts +1 -0
  33. package/dist/admin/client/entry/entry-header.svelte +22 -15
  34. package/dist/admin/client/entry/entry-header.svelte.d.ts +1 -0
  35. package/dist/admin/client/entry/entry.svelte +269 -165
  36. package/dist/admin/client/entry/header/a11y-header-badge.svelte +47 -0
  37. package/dist/admin/client/entry/header/a11y-header-badge.svelte.d.ts +8 -0
  38. package/dist/admin/client/entry/header/publish-panel.svelte +69 -13
  39. package/dist/admin/client/entry/header/save-indicator.svelte +57 -28
  40. package/dist/admin/client/entry/header/save-indicator.svelte.d.ts +1 -0
  41. package/dist/admin/client/entry/header/status-badge.svelte +60 -15
  42. package/dist/admin/client/entry/header/status-badge.svelte.d.ts +1 -2
  43. package/dist/admin/client/entry/header/version-history-sheet.svelte +1 -1
  44. package/dist/admin/client/entry/hybrid/hybrid-layout.svelte +74 -23
  45. package/dist/admin/client/entry/hybrid/hybrid-preview.svelte +1 -1
  46. package/dist/admin/client/entry/utils.d.ts +14 -0
  47. package/dist/admin/client/entry/utils.js +28 -0
  48. package/dist/admin/client/form/form-submission/form-submission.svelte +2 -2
  49. package/dist/admin/client/form/form-submissions.svelte +143 -194
  50. package/dist/admin/client/form/form-submissions.svelte.d.ts +2 -0
  51. package/dist/admin/client/login/lang.d.ts +3 -0
  52. package/dist/admin/client/login/lang.js +10 -4
  53. package/dist/admin/client/login/login-form.svelte +8 -1
  54. package/dist/admin/client/login/reset-password-page.svelte +24 -3
  55. package/dist/admin/client/login/schema.d.ts +14 -2
  56. package/dist/admin/client/login/schema.js +19 -8
  57. package/dist/admin/client/maintenance/maintenance-page.svelte +16 -17
  58. package/dist/admin/client/media/media-page.svelte +1 -1
  59. package/dist/admin/client/shop/coupon-edit-page.svelte +117 -13
  60. package/dist/admin/client/shop/coupon-form.svelte +282 -138
  61. package/dist/admin/client/shop/coupon-form.svelte.d.ts +1 -9
  62. package/dist/admin/client/shop/coupon-new-page.svelte +40 -10
  63. package/dist/admin/client/shop/coupon-new-page.svelte.d.ts +2 -17
  64. package/dist/admin/client/shop/coupon-schema.d.ts +28 -0
  65. package/dist/admin/client/shop/coupon-schema.js +53 -0
  66. package/dist/admin/client/shop/coupons-list-page.svelte +262 -118
  67. package/dist/admin/client/shop/coupons-list-page.svelte.d.ts +16 -1
  68. package/dist/admin/client/shop/shipping-method-edit-page.svelte +108 -59
  69. package/dist/admin/client/shop/shipping-method-form.svelte +36 -9
  70. package/dist/admin/client/shop/shipping-method-new-page.svelte +44 -13
  71. package/dist/admin/client/shop/shipping-methods-list-page.svelte +101 -59
  72. package/dist/admin/client/shop/shop-order-detail-page.svelte +113 -84
  73. package/dist/admin/client/shop/shop-orders-list-page.svelte +302 -152
  74. package/dist/admin/client/shop/shop-orders-list-page.svelte.d.ts +18 -1
  75. package/dist/admin/client/shop/shop-products-list-page.svelte +355 -118
  76. package/dist/admin/client/shop/shop-products-list-page.svelte.d.ts +19 -1
  77. package/dist/admin/client/users/accept-invite-page.svelte +24 -3
  78. package/dist/admin/client/users/create-user-dialog.svelte +3 -8
  79. package/dist/admin/client/users/lang.d.ts +2 -0
  80. package/dist/admin/client/users/lang.js +4 -0
  81. package/dist/admin/client/users/pending-invitations.svelte +2 -9
  82. package/dist/admin/client/users/user-name-cell.svelte +20 -0
  83. package/dist/admin/client/users/user-name-cell.svelte.d.ts +9 -0
  84. package/dist/admin/client/users/user-role-badge.svelte +16 -0
  85. package/dist/admin/client/users/user-role-badge.svelte.d.ts +7 -0
  86. package/dist/admin/client/users/user-row-actions.svelte +72 -0
  87. package/dist/admin/client/users/user-row-actions.svelte.d.ts +20 -0
  88. package/dist/admin/client/users/user-sessions-sheet.svelte +2 -11
  89. package/dist/admin/client/users/users-page.svelte +283 -497
  90. package/dist/admin/client/users/users-page.svelte.d.ts +12 -1
  91. package/dist/admin/components/dashboard/form-submissions-widget.svelte +59 -74
  92. package/dist/admin/components/dashboard/recent-activity.svelte +17 -5
  93. package/dist/admin/components/dashboard/recent-entries.svelte +19 -7
  94. package/dist/admin/components/dialogs/confirmation-dialog.svelte +105 -0
  95. package/dist/admin/components/dialogs/confirmation-dialog.svelte.d.ts +13 -0
  96. package/dist/admin/components/fields/block-picker-modal.svelte +6 -0
  97. package/dist/admin/components/fields/blocks-field.svelte +46 -1
  98. package/dist/admin/components/fields/boolean-field.svelte +1 -1
  99. package/dist/admin/components/fields/field-renderer.svelte +23 -21
  100. package/dist/admin/components/fields/file-field.svelte +344 -30
  101. package/dist/admin/components/fields/media-field.svelte +16 -2
  102. package/dist/admin/components/fields/radio-field.svelte +22 -0
  103. package/dist/admin/components/fields/relation-field.svelte +123 -97
  104. package/dist/admin/components/fields/relation-picker-dialog.svelte +2 -2
  105. package/dist/admin/components/fields/seo-field.svelte +60 -30
  106. package/dist/admin/components/fields/shop-field.svelte +9 -4
  107. package/dist/admin/components/fields/simple-array-field.svelte +321 -151
  108. package/dist/admin/components/fields/simple-array-field.svelte.d.ts +3 -0
  109. package/dist/admin/components/fields/slug-field.svelte +146 -21
  110. package/dist/admin/components/fields/text-field-wrapper.svelte +37 -20
  111. package/dist/admin/components/fields/text-field.svelte +7 -2
  112. package/dist/admin/components/fields/url-field-wrapper.svelte +10 -0
  113. package/dist/admin/components/fields/url-field.svelte +36 -23
  114. package/dist/admin/components/forms/form-error-summary.svelte +143 -0
  115. package/dist/admin/components/forms/form-error-summary.svelte.d.ts +27 -0
  116. package/dist/admin/components/layout/app-sidebar.svelte +7 -2
  117. package/dist/admin/components/layout/detail-page-shell.svelte +71 -0
  118. package/dist/admin/components/layout/detail-page-shell.svelte.d.ts +24 -0
  119. package/dist/admin/components/layout/lang.d.ts +5 -0
  120. package/dist/admin/components/layout/lang.js +10 -0
  121. package/dist/admin/components/layout/layout-renderer.svelte +71 -2
  122. package/dist/admin/components/layout/layout-renderer.svelte.d.ts +1 -0
  123. package/dist/admin/components/layout/layout-tabs.svelte +172 -0
  124. package/dist/admin/components/layout/layout-tabs.svelte.d.ts +24 -0
  125. package/dist/admin/components/layout/nav-breadcrumbs.svelte +25 -7
  126. package/dist/admin/components/layout/nav-collections.svelte +23 -36
  127. package/dist/admin/components/layout/nav-forms.svelte +19 -35
  128. package/dist/admin/components/layout/nav-main.svelte +3 -28
  129. package/dist/admin/components/layout/nav-search.svelte +70 -2
  130. package/dist/admin/components/layout/nav-section.svelte +77 -0
  131. package/dist/admin/components/layout/nav-section.svelte.d.ts +22 -0
  132. package/dist/admin/components/layout/nav-shop.svelte +3 -27
  133. package/dist/admin/components/layout/nav-singletons.svelte +16 -28
  134. package/dist/admin/components/layout/page-header.stories.svelte +93 -0
  135. package/dist/admin/components/layout/page-header.stories.svelte.d.ts +27 -0
  136. package/dist/admin/components/layout/page-header.svelte +68 -0
  137. package/dist/admin/components/layout/page-header.svelte.d.ts +17 -0
  138. package/dist/admin/components/layout/site-header.svelte +9 -0
  139. package/dist/admin/components/layout/site-header.svelte.d.ts +2 -17
  140. package/dist/admin/components/media/file/file-name-input.svelte +6 -2
  141. package/dist/admin/components/media/file/file-preview.svelte +130 -17
  142. package/dist/admin/components/media/file-upload.svelte +16 -7
  143. package/dist/admin/components/media/file-upload.svelte.d.ts +1 -0
  144. package/dist/admin/components/media/files-list.svelte +153 -53
  145. package/dist/admin/components/media/files-list.svelte.d.ts +1 -0
  146. package/dist/admin/components/media/media-library.svelte +577 -198
  147. package/dist/admin/components/media/media-library.svelte.d.ts +4 -0
  148. package/dist/admin/components/media/media-selector.svelte +4 -2
  149. package/dist/admin/components/media/media-selector.svelte.d.ts +1 -0
  150. package/dist/admin/components/media/tag-sidebar.svelte +4 -4
  151. package/dist/admin/components/tiptap/FigureNodeView.svelte +10 -0
  152. package/dist/admin/components/tiptap/bubble-menu.svelte +104 -0
  153. package/dist/admin/components/tiptap/bubble-menu.svelte.d.ts +19 -0
  154. package/dist/admin/components/tiptap/content-editor.svelte +28 -24
  155. package/dist/admin/components/tiptap/editor-toolbar.svelte +7 -7
  156. package/dist/admin/components/tiptap/extensions.js +5 -1
  157. package/dist/admin/components/tiptap/image-dialog.svelte +5 -1
  158. package/dist/admin/components/tiptap/link-dialog.svelte +2 -0
  159. package/dist/admin/components/tiptap/tiptap-editor.svelte +18 -20
  160. package/dist/admin/components/tiptap/video-dialog.svelte +1 -1
  161. package/dist/admin/i18n/errors.d.ts +140 -0
  162. package/dist/admin/i18n/errors.js +151 -0
  163. package/dist/admin/remote/entry.remote.d.ts +59 -4
  164. package/dist/admin/remote/entry.remote.js +239 -62
  165. package/dist/admin/remote/shop.remote.d.ts +37 -32
  166. package/dist/admin/remote/shop.remote.js +9 -2
  167. package/dist/admin/shared/password-generate.d.ts +6 -0
  168. package/dist/admin/shared/password-generate.js +40 -0
  169. package/dist/admin/shared/password-schema.d.ts +6 -0
  170. package/dist/admin/shared/password-schema.js +10 -3
  171. package/dist/admin/styles/admin.css +23 -6
  172. package/dist/admin/styles/tokens.md +244 -0
  173. package/dist/admin/utils/accordionActivation.d.ts +13 -0
  174. package/dist/admin/utils/accordionActivation.js +35 -0
  175. package/dist/admin/utils/entryLabel.d.ts +23 -0
  176. package/dist/admin/utils/entryLabel.js +51 -12
  177. package/dist/admin/utils/field-a11y.d.ts +29 -0
  178. package/dist/admin/utils/field-a11y.js +23 -0
  179. package/dist/admin/utils/fieldPathElement.d.ts +9 -0
  180. package/dist/admin/utils/fieldPathElement.js +18 -0
  181. package/dist/admin/utils/fileDisplay.d.ts +10 -0
  182. package/dist/admin/utils/fileDisplay.js +26 -0
  183. package/dist/admin/utils/flattenFormErrors.d.ts +19 -0
  184. package/dist/admin/utils/flattenFormErrors.js +102 -0
  185. package/dist/admin/utils/formatters.d.ts +12 -0
  186. package/dist/admin/utils/{formatDate.js → formatters.js} +23 -2
  187. package/dist/admin/utils/scrollWithin.d.ts +9 -0
  188. package/dist/admin/utils/scrollWithin.js +32 -0
  189. package/dist/admin/utils/tabActivation.d.ts +12 -0
  190. package/dist/admin/utils/tabActivation.js +24 -0
  191. package/dist/cms/runtime/schema.d.ts +1 -0
  192. package/dist/cms/runtime/schema.js +1 -0
  193. package/dist/cms/runtime/types.d.ts +80 -7
  194. package/dist/components/ui/accordion/accordion-content.svelte +17 -3
  195. package/dist/components/ui/accordion/accordion.stories.svelte +21 -1
  196. package/dist/components/ui/alert/alert.stories.svelte +14 -0
  197. package/dist/components/ui/alert-dialog/alert-dialog.stories.svelte +45 -0
  198. package/dist/components/ui/alert-dialog/alert-dialog.stories.svelte.d.ts +27 -0
  199. package/dist/components/ui/avatar/avatar.stories.svelte +27 -0
  200. package/dist/components/ui/badge/badge.stories.svelte +15 -0
  201. package/dist/components/ui/breadcrumb/breadcrumb.stories.svelte +47 -0
  202. package/dist/components/ui/breadcrumb/breadcrumb.svelte +1 -1
  203. package/dist/components/ui/button/button.stories.svelte +53 -6
  204. package/dist/components/ui/button/button.svelte +39 -5
  205. package/dist/components/ui/button/button.svelte.d.ts +4 -0
  206. package/dist/components/ui/button-group/button-group.stories.svelte +44 -0
  207. package/dist/components/ui/button-group/button-group.stories.svelte.d.ts +27 -0
  208. package/dist/components/ui/calendar/calendar.stories.svelte +36 -0
  209. package/dist/components/ui/calendar/calendar.stories.svelte.d.ts +27 -0
  210. package/dist/components/ui/card/card.stories.svelte +7 -0
  211. package/dist/components/ui/carousel/carousel.stories.svelte +43 -0
  212. package/dist/components/ui/carousel/carousel.stories.svelte.d.ts +27 -0
  213. package/dist/components/ui/checkbox/checkbox.stories.svelte +67 -0
  214. package/dist/components/ui/checkbox/checkbox.stories.svelte.d.ts +27 -0
  215. package/dist/components/ui/checkbox/checkbox.svelte +3 -3
  216. package/dist/components/ui/command/command.stories.svelte +18 -0
  217. package/dist/components/ui/data-table/data-table.stories.svelte +61 -0
  218. package/dist/components/ui/data-table/data-table.stories.svelte.d.ts +18 -0
  219. package/dist/components/ui/dialog/dialog-content.svelte +5 -0
  220. package/dist/components/ui/dialog/dialog-content.svelte.d.ts +2 -0
  221. package/dist/components/ui/dialog/dialog.stories.svelte +35 -0
  222. package/dist/components/ui/dropdown-menu/dropdown-menu.stories.svelte +74 -0
  223. package/dist/components/ui/dropdown-menu/dropdown-menu.stories.svelte.d.ts +27 -0
  224. package/dist/components/ui/field/field-context.svelte.d.ts +22 -0
  225. package/dist/components/ui/field/field-context.svelte.js +9 -0
  226. package/dist/components/ui/field/field-control.svelte +18 -0
  227. package/dist/components/ui/field/field-control.svelte.d.ts +8 -0
  228. package/dist/components/ui/field/field-description.svelte +12 -0
  229. package/dist/components/ui/field/field-error.svelte +14 -6
  230. package/dist/components/ui/field/field-label.svelte +10 -0
  231. package/dist/components/ui/field/field.stories.svelte +95 -9
  232. package/dist/components/ui/field/field.svelte +57 -0
  233. package/dist/components/ui/field/field.svelte.d.ts +2 -0
  234. package/dist/components/ui/field/index.d.ts +3 -1
  235. package/dist/components/ui/field/index.js +4 -2
  236. package/dist/components/ui/form/form-field-errors.svelte +1 -1
  237. package/dist/components/ui/form/form.stories.svelte +25 -0
  238. package/dist/components/ui/form/form.stories.svelte.d.ts +26 -0
  239. package/dist/components/ui/input/input.stories.svelte +26 -0
  240. package/dist/components/ui/input-group/input-group-input.svelte.d.ts +1 -1
  241. package/dist/components/ui/input-group/input-group.stories.svelte +43 -0
  242. package/dist/components/ui/input-group/input-group.stories.svelte.d.ts +27 -0
  243. package/dist/components/ui/item/item.stories.svelte +61 -0
  244. package/dist/components/ui/item/item.stories.svelte.d.ts +27 -0
  245. package/dist/components/ui/label/label.stories.svelte +7 -0
  246. package/dist/components/ui/live-region/index.d.ts +1 -0
  247. package/dist/components/ui/live-region/index.js +1 -0
  248. package/dist/components/ui/live-region/live-region-demo.svelte +32 -0
  249. package/dist/components/ui/live-region/live-region-demo.svelte.d.ts +7 -0
  250. package/dist/components/ui/live-region/live-region.stories.svelte +23 -0
  251. package/dist/components/ui/live-region/live-region.stories.svelte.d.ts +26 -0
  252. package/dist/components/ui/live-region/live-region.svelte +12 -0
  253. package/dist/components/ui/live-region/live-region.svelte.d.ts +8 -0
  254. package/dist/components/ui/popover/popover.stories.svelte +34 -0
  255. package/dist/components/ui/radio-group/radio-group.stories.svelte +58 -0
  256. package/dist/components/ui/radio-group/radio-group.stories.svelte.d.ts +27 -0
  257. package/dist/components/ui/resizable/resizable.stories.svelte +56 -0
  258. package/dist/components/ui/resizable/resizable.stories.svelte.d.ts +27 -0
  259. package/dist/components/ui/select/select.stories.svelte +49 -0
  260. package/dist/components/ui/separator/separator.stories.svelte +18 -0
  261. package/dist/components/ui/sheet/sheet.stories.svelte +34 -0
  262. package/dist/components/ui/sidebar/sidebar-input.svelte.d.ts +1 -1
  263. package/dist/components/ui/sidebar/sidebar-menu-button.svelte +1 -0
  264. package/dist/components/ui/sidebar/sidebar-trigger.svelte +1 -1
  265. package/dist/components/ui/sidebar/sidebar.stories.svelte +72 -0
  266. package/dist/components/ui/sidebar/sidebar.stories.svelte.d.ts +27 -0
  267. package/dist/components/ui/skeleton/skeleton.stories.svelte +39 -0
  268. package/dist/components/ui/skeleton/skeleton.stories.svelte.d.ts +27 -0
  269. package/dist/components/ui/skeleton/skeleton.svelte +6 -0
  270. package/dist/components/ui/sonner/index.d.ts +1 -1
  271. package/dist/components/ui/sonner/index.js +1 -1
  272. package/dist/components/ui/sonner/sonner.stories.svelte +7 -0
  273. package/dist/components/ui/sonner/sonner.svelte +17 -1
  274. package/dist/components/ui/sonner/sonner.svelte.d.ts +6 -0
  275. package/dist/components/ui/spinner/spinner.stories.svelte +30 -0
  276. package/dist/components/ui/spinner/spinner.stories.svelte.d.ts +27 -0
  277. package/dist/components/ui/switch/switch.stories.svelte +56 -0
  278. package/dist/components/ui/switch/switch.stories.svelte.d.ts +27 -0
  279. package/dist/components/ui/table/table-cell.svelte +1 -1
  280. package/dist/components/ui/table/table-head.svelte +1 -1
  281. package/dist/components/ui/table/table.stories.svelte +68 -0
  282. package/dist/components/ui/table/table.stories.svelte.d.ts +27 -0
  283. package/dist/components/ui/table/table.svelte +1 -1
  284. package/dist/components/ui/tabs/tabs.stories.svelte +48 -0
  285. package/dist/components/ui/tabs/tabs.stories.svelte.d.ts +27 -0
  286. package/dist/components/ui/textarea/textarea.stories.svelte +21 -0
  287. package/dist/components/ui/toggle/toggle.stories.svelte +23 -0
  288. package/dist/components/ui/toggle-group/toggle-group.stories.svelte +43 -0
  289. package/dist/components/ui/tooltip/tooltip.stories.svelte +46 -6
  290. package/dist/core/fields/fieldSchemaToTs.d.ts +7 -0
  291. package/dist/core/fields/fieldSchemaToTs.js +234 -90
  292. package/dist/core/fields/layoutUtils.d.ts +4 -1
  293. package/dist/core/fields/layoutUtils.js +41 -4
  294. package/dist/core/fields/resolveSeo.d.ts +70 -0
  295. package/dist/core/fields/resolveSeo.js +88 -0
  296. package/dist/core/fields/seoFieldDescriptor.d.ts +43 -0
  297. package/dist/core/fields/seoFieldDescriptor.js +74 -0
  298. package/dist/core/fields/slugPath.d.ts +13 -0
  299. package/dist/core/fields/slugPath.js +32 -0
  300. package/dist/core/fields/urlUtils.d.ts +8 -0
  301. package/dist/core/fields/urlUtils.js +27 -0
  302. package/dist/core/index.d.ts +1 -0
  303. package/dist/core/index.js +1 -0
  304. package/dist/core/server/entries/operations/create.js +13 -0
  305. package/dist/core/server/entries/operations/get.d.ts +7 -0
  306. package/dist/core/server/entries/operations/get.js +10 -6
  307. package/dist/core/server/entries/operations/slugUniqueness.d.ts +37 -0
  308. package/dist/core/server/entries/operations/slugUniqueness.js +116 -0
  309. package/dist/core/server/entries/operations/update.d.ts +6 -1
  310. package/dist/core/server/entries/operations/update.js +24 -1
  311. package/dist/core/server/fields/slugResolver.d.ts +3 -13
  312. package/dist/core/server/fields/slugResolver.js +8 -37
  313. package/dist/core/server/generator/fields.js +10 -17
  314. package/dist/core/server/generator/formFields.js +2 -1
  315. package/dist/core/server/generator/generator.js +4 -4
  316. package/dist/core/server/generator/utils.d.ts +1 -0
  317. package/dist/core/server/generator/utils.js +4 -0
  318. package/dist/paraglide/messages/_index.d.ts +3 -36
  319. package/dist/paraglide/messages/_index.js +3 -71
  320. package/dist/paraglide/messages/hello_world.d.ts +5 -0
  321. package/dist/paraglide/messages/hello_world.js +33 -0
  322. package/dist/paraglide/messages/login_hello.d.ts +16 -0
  323. package/dist/paraglide/messages/login_hello.js +34 -0
  324. package/dist/paraglide/messages/login_please_login.d.ts +16 -0
  325. package/dist/paraglide/messages/login_please_login.js +34 -0
  326. package/dist/shop/server/orders.d.ts +1 -0
  327. package/dist/shop/server/orders.js +14 -0
  328. package/dist/shop/server/shop-data.d.ts +2 -0
  329. package/dist/shop/server/shop-data.js +20 -5
  330. package/dist/sveltekit/server/handle.js +17 -0
  331. package/dist/types/cms.schema.js +4 -2
  332. package/dist/types/fields.d.ts +35 -0
  333. package/dist/types/index.d.ts +1 -1
  334. package/dist/types/layout.d.ts +35 -2
  335. package/dist/updates/0.26.0/index.d.ts +2 -0
  336. package/dist/updates/0.26.0/index.js +51 -0
  337. package/dist/updates/index.js +3 -1
  338. package/package.json +29 -7
  339. package/dist/admin/client/collection/empty-state.svelte +0 -28
  340. package/dist/admin/client/collection/empty-state.svelte.d.ts +0 -9
  341. package/dist/admin/client/form/submission-status-badge.svelte +0 -41
  342. package/dist/admin/client/form/submission-status-badge.svelte.d.ts +0 -7
  343. package/dist/admin/components/media/file-preview.svelte +0 -51
  344. package/dist/admin/components/media/file-preview.svelte.d.ts +0 -6
  345. package/dist/admin/utils/formatDate.d.ts +0 -5
  346. package/dist/paraglide/messages/en.d.ts +0 -5
  347. package/dist/paraglide/messages/en.js +0 -14
  348. package/dist/paraglide/messages/pl.d.ts +0 -5
  349. 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>
@@ -14,7 +14,7 @@
14
14
  bind:this={ref}
15
15
  data-slot="breadcrumb"
16
16
  class={className}
17
- aria-label="breadcrumb"
17
+ aria-label="Breadcrumb"
18
18
  {...restProps}
19
19
  >
20
20
  {@render children?.()}
@@ -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
- <svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round"><circle cx="12" cy="12" r="3"/><path d="M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1-2.47 3.24l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-4 0v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-3.24-2.47l.06-.06A1.65 1.65 0 0 0 4.68 15a1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1 0-4h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 3.24-2.47l.06.06A1.65 1.65 0 0 0 9 4.68V3a2 2 0 0 1 4 0v.09c.04.63.36 1.2 1 1.51a1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.47 3.24l-.06.06A1.65 1.65 0 0 0 19.4 9c.33.58.87.96 1.51 1H21a2 2 0 0 1 0 4h-.09c-.63.04-1.2.36-1.51 1z"/></svg>
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
- <svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5" stroke-linecap="round"><path d="M6 4h8a4 4 0 0 1 4 4 4 4 0 0 1-4 4H6z"/><path d="M6 12h9a4 4 0 0 1 4 4 4 4 0 0 1-4 4H6z"/></svg>
83
+ <Button variant="ghost" size="icon-sm" aria-label="Pogrubienie">
84
+ <BoldIcon />
38
85
  </Button>
39
- <Button variant="ghost" size="icon-sm">
40
- <svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round"><line x1="19" y1="4" x2="10" y2="4"/><line x1="14" y1="20" x2="5" y2="20"/><line x1="15" y1="4" x2="9" y2="20"/></svg>
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={disabled ? undefined : href}
64
- aria-disabled={disabled}
65
- role={disabled ? "link" : undefined}
66
- tabindex={disabled ? -1 : undefined}
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
- {disabled}
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
+ }