includio-cms 0.25.0 → 0.27.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 (411) hide show
  1. package/API.md +97 -4
  2. package/CHANGELOG.md +118 -0
  3. package/DOCS.md +1 -1
  4. package/README.md +2 -0
  5. package/ROADMAP.md +14 -0
  6. package/dist/admin/auth-client.d.ts +42 -42
  7. package/dist/admin/client/account/lang.d.ts +1 -0
  8. package/dist/admin/client/account/lang.js +4 -2
  9. package/dist/admin/client/account/profile-section.svelte +2 -2
  10. package/dist/admin/client/account/security-section.svelte +27 -4
  11. package/dist/admin/client/account/sessions-section.svelte +1 -1
  12. package/dist/admin/client/admin/admin-after-login-layout-content.svelte +1 -1
  13. package/dist/admin/client/admin/admin-layout.svelte +12 -2
  14. package/dist/admin/client/admin/admin-layout.svelte.d.ts +2 -1
  15. package/dist/admin/client/admin/dashboard-page.svelte +34 -10
  16. package/dist/admin/client/collection/bulk-actions-bar.svelte +86 -44
  17. package/dist/admin/client/collection/bulk-actions-bar.svelte.d.ts +3 -1
  18. package/dist/admin/client/collection/collection-entries.svelte +52 -36
  19. package/dist/admin/client/collection/collection-entries.svelte.d.ts +3 -0
  20. package/dist/admin/client/collection/collection.svelte +28 -14
  21. package/dist/admin/client/collection/collection.svelte.d.ts +3 -0
  22. package/dist/admin/client/collection/data-table.svelte +240 -130
  23. package/dist/admin/client/collection/data-table.svelte.d.ts +9 -0
  24. package/dist/admin/client/collection/date-cell.svelte +4 -4
  25. package/dist/admin/client/collection/row-actions.svelte +2 -1
  26. package/dist/admin/client/collection/sortable-header.svelte +33 -9
  27. package/dist/admin/client/collection/state-display.svelte +102 -0
  28. package/dist/admin/client/collection/state-display.svelte.d.ts +12 -0
  29. package/dist/admin/client/collection/status-badge.svelte +99 -11
  30. package/dist/admin/client/collection/status-badge.svelte.d.ts +15 -1
  31. package/dist/admin/client/collection/table-pagination.svelte +21 -6
  32. package/dist/admin/client/collection/table-toolbar.svelte +105 -80
  33. package/dist/admin/client/collection/table-toolbar.svelte.d.ts +11 -8
  34. package/dist/admin/client/entry/entry-form.svelte +36 -11
  35. package/dist/admin/client/entry/entry-form.svelte.d.ts +1 -0
  36. package/dist/admin/client/entry/entry-header.svelte +22 -15
  37. package/dist/admin/client/entry/entry-header.svelte.d.ts +1 -0
  38. package/dist/admin/client/entry/entry.svelte +269 -165
  39. package/dist/admin/client/entry/header/a11y-header-badge.svelte +47 -0
  40. package/dist/admin/client/entry/header/a11y-header-badge.svelte.d.ts +8 -0
  41. package/dist/admin/client/entry/header/publish-panel.svelte +69 -13
  42. package/dist/admin/client/entry/header/save-indicator.svelte +57 -28
  43. package/dist/admin/client/entry/header/save-indicator.svelte.d.ts +1 -0
  44. package/dist/admin/client/entry/header/status-badge.svelte +60 -15
  45. package/dist/admin/client/entry/header/status-badge.svelte.d.ts +1 -2
  46. package/dist/admin/client/entry/header/version-history-sheet.svelte +1 -1
  47. package/dist/admin/client/entry/hybrid/hybrid-layout.svelte +74 -23
  48. package/dist/admin/client/entry/hybrid/hybrid-preview.svelte +1 -1
  49. package/dist/admin/client/entry/utils.d.ts +14 -0
  50. package/dist/admin/client/entry/utils.js +28 -0
  51. package/dist/admin/client/form/form-submission/form-submission.svelte +2 -2
  52. package/dist/admin/client/form/form-submissions.svelte +143 -194
  53. package/dist/admin/client/form/form-submissions.svelte.d.ts +2 -0
  54. package/dist/admin/client/login/lang.d.ts +3 -0
  55. package/dist/admin/client/login/lang.js +10 -4
  56. package/dist/admin/client/login/login-form.svelte +8 -1
  57. package/dist/admin/client/login/reset-password-page.svelte +24 -3
  58. package/dist/admin/client/login/schema.d.ts +14 -2
  59. package/dist/admin/client/login/schema.js +19 -8
  60. package/dist/admin/client/maintenance/maintenance-page.svelte +16 -17
  61. package/dist/admin/client/media/media-page.svelte +1 -1
  62. package/dist/admin/client/shop/coupon-edit-page.svelte +117 -13
  63. package/dist/admin/client/shop/coupon-form.svelte +282 -138
  64. package/dist/admin/client/shop/coupon-form.svelte.d.ts +1 -9
  65. package/dist/admin/client/shop/coupon-new-page.svelte +40 -10
  66. package/dist/admin/client/shop/coupon-new-page.svelte.d.ts +2 -17
  67. package/dist/admin/client/shop/coupon-schema.d.ts +28 -0
  68. package/dist/admin/client/shop/coupon-schema.js +53 -0
  69. package/dist/admin/client/shop/coupons-list-page.svelte +262 -118
  70. package/dist/admin/client/shop/coupons-list-page.svelte.d.ts +16 -1
  71. package/dist/admin/client/shop/refund-dialog.svelte +37 -1
  72. package/dist/admin/client/shop/refund-dialog.svelte.d.ts +3 -0
  73. package/dist/admin/client/shop/shipping-method-edit-page.svelte +108 -59
  74. package/dist/admin/client/shop/shipping-method-form.svelte +36 -9
  75. package/dist/admin/client/shop/shipping-method-new-page.svelte +44 -13
  76. package/dist/admin/client/shop/shipping-methods-list-page.svelte +101 -59
  77. package/dist/admin/client/shop/shop-order-detail-page.svelte +220 -84
  78. package/dist/admin/client/shop/shop-orders-list-page.svelte +302 -152
  79. package/dist/admin/client/shop/shop-orders-list-page.svelte.d.ts +18 -1
  80. package/dist/admin/client/shop/shop-products-list-page.svelte +355 -118
  81. package/dist/admin/client/shop/shop-products-list-page.svelte.d.ts +19 -1
  82. package/dist/admin/client/users/accept-invite-page.svelte +24 -3
  83. package/dist/admin/client/users/create-user-dialog.svelte +3 -8
  84. package/dist/admin/client/users/lang.d.ts +2 -0
  85. package/dist/admin/client/users/lang.js +4 -0
  86. package/dist/admin/client/users/pending-invitations.svelte +2 -9
  87. package/dist/admin/client/users/user-name-cell.svelte +20 -0
  88. package/dist/admin/client/users/user-name-cell.svelte.d.ts +9 -0
  89. package/dist/admin/client/users/user-role-badge.svelte +16 -0
  90. package/dist/admin/client/users/user-role-badge.svelte.d.ts +7 -0
  91. package/dist/admin/client/users/user-row-actions.svelte +72 -0
  92. package/dist/admin/client/users/user-row-actions.svelte.d.ts +20 -0
  93. package/dist/admin/client/users/user-sessions-sheet.svelte +2 -11
  94. package/dist/admin/client/users/users-page.svelte +283 -497
  95. package/dist/admin/client/users/users-page.svelte.d.ts +12 -1
  96. package/dist/admin/components/dashboard/form-submissions-widget.svelte +59 -74
  97. package/dist/admin/components/dashboard/recent-activity.svelte +17 -5
  98. package/dist/admin/components/dashboard/recent-entries.svelte +19 -7
  99. package/dist/admin/components/dialogs/confirmation-dialog.svelte +105 -0
  100. package/dist/admin/components/dialogs/confirmation-dialog.svelte.d.ts +13 -0
  101. package/dist/admin/components/fields/block-picker-modal.svelte +6 -0
  102. package/dist/admin/components/fields/blocks-field.svelte +46 -1
  103. package/dist/admin/components/fields/boolean-field.svelte +1 -1
  104. package/dist/admin/components/fields/field-renderer.svelte +29 -22
  105. package/dist/admin/components/fields/file-field.svelte +344 -30
  106. package/dist/admin/components/fields/icon-field.svelte +86 -0
  107. package/dist/admin/components/fields/icon-field.svelte.d.ts +8 -0
  108. package/dist/admin/components/fields/icon-picker-dialog.svelte +174 -0
  109. package/dist/admin/components/fields/icon-picker-dialog.svelte.d.ts +11 -0
  110. package/dist/admin/components/fields/media-field.svelte +16 -2
  111. package/dist/admin/components/fields/object-field.svelte +27 -7
  112. package/dist/admin/components/fields/radio-field.svelte +22 -0
  113. package/dist/admin/components/fields/relation-field.svelte +123 -97
  114. package/dist/admin/components/fields/relation-picker-dialog.svelte +2 -2
  115. package/dist/admin/components/fields/seo-field.svelte +60 -30
  116. package/dist/admin/components/fields/shop-field.svelte +219 -24
  117. package/dist/admin/components/fields/simple-array-field.svelte +321 -151
  118. package/dist/admin/components/fields/simple-array-field.svelte.d.ts +3 -0
  119. package/dist/admin/components/fields/slug-field.svelte +146 -21
  120. package/dist/admin/components/fields/text-field-wrapper.svelte +37 -20
  121. package/dist/admin/components/fields/text-field.svelte +7 -2
  122. package/dist/admin/components/fields/url-field-wrapper.svelte +10 -0
  123. package/dist/admin/components/fields/url-field.svelte +36 -23
  124. package/dist/admin/components/forms/form-error-summary.svelte +143 -0
  125. package/dist/admin/components/forms/form-error-summary.svelte.d.ts +27 -0
  126. package/dist/admin/components/layout/app-sidebar.svelte +7 -2
  127. package/dist/admin/components/layout/detail-page-shell.svelte +71 -0
  128. package/dist/admin/components/layout/detail-page-shell.svelte.d.ts +24 -0
  129. package/dist/admin/components/layout/lang.d.ts +5 -0
  130. package/dist/admin/components/layout/lang.js +10 -0
  131. package/dist/admin/components/layout/layout-renderer.svelte +71 -2
  132. package/dist/admin/components/layout/layout-renderer.svelte.d.ts +1 -0
  133. package/dist/admin/components/layout/layout-tabs.svelte +173 -0
  134. package/dist/admin/components/layout/layout-tabs.svelte.d.ts +24 -0
  135. package/dist/admin/components/layout/nav-breadcrumbs.svelte +25 -7
  136. package/dist/admin/components/layout/nav-collections.svelte +23 -36
  137. package/dist/admin/components/layout/nav-forms.svelte +19 -35
  138. package/dist/admin/components/layout/nav-main.svelte +3 -28
  139. package/dist/admin/components/layout/nav-search.svelte +70 -2
  140. package/dist/admin/components/layout/nav-section.svelte +77 -0
  141. package/dist/admin/components/layout/nav-section.svelte.d.ts +22 -0
  142. package/dist/admin/components/layout/nav-shop.svelte +3 -27
  143. package/dist/admin/components/layout/nav-singletons.svelte +16 -28
  144. package/dist/admin/components/layout/page-header.stories.svelte +93 -0
  145. package/dist/admin/components/layout/page-header.stories.svelte.d.ts +27 -0
  146. package/dist/admin/components/layout/page-header.svelte +68 -0
  147. package/dist/admin/components/layout/page-header.svelte.d.ts +17 -0
  148. package/dist/admin/components/layout/site-header.svelte +9 -0
  149. package/dist/admin/components/layout/site-header.svelte.d.ts +2 -17
  150. package/dist/admin/components/media/file/file-name-input.svelte +6 -2
  151. package/dist/admin/components/media/file/file-preview.svelte +130 -17
  152. package/dist/admin/components/media/file-upload.svelte +16 -7
  153. package/dist/admin/components/media/file-upload.svelte.d.ts +1 -0
  154. package/dist/admin/components/media/files-list.svelte +153 -53
  155. package/dist/admin/components/media/files-list.svelte.d.ts +1 -0
  156. package/dist/admin/components/media/media-library.svelte +577 -198
  157. package/dist/admin/components/media/media-library.svelte.d.ts +4 -0
  158. package/dist/admin/components/media/media-selector.svelte +4 -2
  159. package/dist/admin/components/media/media-selector.svelte.d.ts +1 -0
  160. package/dist/admin/components/media/tag-sidebar.svelte +4 -4
  161. package/dist/admin/components/tiptap/FigureNodeView.svelte +10 -0
  162. package/dist/admin/components/tiptap/bubble-menu.svelte +104 -0
  163. package/dist/admin/components/tiptap/bubble-menu.svelte.d.ts +19 -0
  164. package/dist/admin/components/tiptap/content-editor.svelte +28 -24
  165. package/dist/admin/components/tiptap/editor-toolbar.svelte +7 -7
  166. package/dist/admin/components/tiptap/extensions.js +5 -1
  167. package/dist/admin/components/tiptap/image-dialog.svelte +5 -1
  168. package/dist/admin/components/tiptap/link-dialog.svelte +2 -0
  169. package/dist/admin/components/tiptap/tiptap-editor.svelte +18 -20
  170. package/dist/admin/components/tiptap/video-dialog.svelte +1 -1
  171. package/dist/admin/components/variant-form/VariantAttributeRenderer.svelte +109 -0
  172. package/dist/admin/components/variant-form/VariantAttributeRenderer.svelte.d.ts +9 -0
  173. package/dist/admin/helpers/build-icon-set-map.d.ts +8 -0
  174. package/dist/admin/helpers/build-icon-set-map.js +16 -0
  175. package/dist/admin/helpers/index.d.ts +2 -0
  176. package/dist/admin/helpers/index.js +2 -0
  177. package/dist/admin/i18n/errors.d.ts +140 -0
  178. package/dist/admin/i18n/errors.js +151 -0
  179. package/dist/admin/remote/entry.remote.d.ts +59 -4
  180. package/dist/admin/remote/entry.remote.js +239 -62
  181. package/dist/admin/remote/shop.remote.d.ts +87 -48
  182. package/dist/admin/remote/shop.remote.js +70 -8
  183. package/dist/admin/shared/password-generate.d.ts +6 -0
  184. package/dist/admin/shared/password-generate.js +40 -0
  185. package/dist/admin/shared/password-schema.d.ts +6 -0
  186. package/dist/admin/shared/password-schema.js +10 -3
  187. package/dist/admin/state/icon-sets.svelte.d.ts +9 -0
  188. package/dist/admin/state/icon-sets.svelte.js +20 -0
  189. package/dist/admin/styles/admin.css +23 -6
  190. package/dist/admin/styles/tokens.md +244 -0
  191. package/dist/admin/utils/accordionActivation.d.ts +13 -0
  192. package/dist/admin/utils/accordionActivation.js +35 -0
  193. package/dist/admin/utils/entryLabel.d.ts +23 -0
  194. package/dist/admin/utils/entryLabel.js +51 -12
  195. package/dist/admin/utils/field-a11y.d.ts +29 -0
  196. package/dist/admin/utils/field-a11y.js +23 -0
  197. package/dist/admin/utils/fieldPathElement.d.ts +9 -0
  198. package/dist/admin/utils/fieldPathElement.js +18 -0
  199. package/dist/admin/utils/fileDisplay.d.ts +10 -0
  200. package/dist/admin/utils/fileDisplay.js +26 -0
  201. package/dist/admin/utils/flattenFormErrors.d.ts +19 -0
  202. package/dist/admin/utils/flattenFormErrors.js +102 -0
  203. package/dist/admin/utils/formatters.d.ts +12 -0
  204. package/dist/admin/utils/{formatDate.js → formatters.js} +23 -2
  205. package/dist/admin/utils/scrollWithin.d.ts +9 -0
  206. package/dist/admin/utils/scrollWithin.js +32 -0
  207. package/dist/admin/utils/tabActivation.d.ts +12 -0
  208. package/dist/admin/utils/tabActivation.js +24 -0
  209. package/dist/cli/scaffold/admin.js +2 -2
  210. package/dist/cms/runtime/schema.d.ts +1 -0
  211. package/dist/cms/runtime/schema.js +1 -0
  212. package/dist/cms/runtime/types.d.ts +80 -7
  213. package/dist/components/ui/accordion/accordion-content.svelte +17 -3
  214. package/dist/components/ui/accordion/accordion.stories.svelte +21 -1
  215. package/dist/components/ui/alert/alert.stories.svelte +14 -0
  216. package/dist/components/ui/alert-dialog/alert-dialog.stories.svelte +45 -0
  217. package/dist/components/ui/alert-dialog/alert-dialog.stories.svelte.d.ts +27 -0
  218. package/dist/components/ui/avatar/avatar.stories.svelte +27 -0
  219. package/dist/components/ui/badge/badge.stories.svelte +15 -0
  220. package/dist/components/ui/breadcrumb/breadcrumb.stories.svelte +47 -0
  221. package/dist/components/ui/breadcrumb/breadcrumb.svelte +1 -1
  222. package/dist/components/ui/button/button.stories.svelte +53 -6
  223. package/dist/components/ui/button/button.svelte +39 -5
  224. package/dist/components/ui/button/button.svelte.d.ts +4 -0
  225. package/dist/components/ui/button-group/button-group.stories.svelte +44 -0
  226. package/dist/components/ui/button-group/button-group.stories.svelte.d.ts +27 -0
  227. package/dist/components/ui/calendar/calendar.stories.svelte +36 -0
  228. package/dist/components/ui/calendar/calendar.stories.svelte.d.ts +27 -0
  229. package/dist/components/ui/card/card.stories.svelte +7 -0
  230. package/dist/components/ui/carousel/carousel.stories.svelte +43 -0
  231. package/dist/components/ui/carousel/carousel.stories.svelte.d.ts +27 -0
  232. package/dist/components/ui/checkbox/checkbox.stories.svelte +67 -0
  233. package/dist/components/ui/checkbox/checkbox.stories.svelte.d.ts +27 -0
  234. package/dist/components/ui/checkbox/checkbox.svelte +1 -1
  235. package/dist/components/ui/command/command.stories.svelte +18 -0
  236. package/dist/components/ui/data-table/data-table.stories.svelte +61 -0
  237. package/dist/components/ui/data-table/data-table.stories.svelte.d.ts +18 -0
  238. package/dist/components/ui/dialog/dialog-content.svelte +5 -0
  239. package/dist/components/ui/dialog/dialog-content.svelte.d.ts +2 -0
  240. package/dist/components/ui/dialog/dialog.stories.svelte +35 -0
  241. package/dist/components/ui/dropdown-menu/dropdown-menu.stories.svelte +74 -0
  242. package/dist/components/ui/dropdown-menu/dropdown-menu.stories.svelte.d.ts +27 -0
  243. package/dist/components/ui/field/field-context.svelte.d.ts +22 -0
  244. package/dist/components/ui/field/field-context.svelte.js +9 -0
  245. package/dist/components/ui/field/field-control.svelte +18 -0
  246. package/dist/components/ui/field/field-control.svelte.d.ts +8 -0
  247. package/dist/components/ui/field/field-description.svelte +12 -0
  248. package/dist/components/ui/field/field-error.svelte +14 -6
  249. package/dist/components/ui/field/field-label.svelte +10 -0
  250. package/dist/components/ui/field/field.stories.svelte +95 -9
  251. package/dist/components/ui/field/field.svelte +57 -0
  252. package/dist/components/ui/field/field.svelte.d.ts +2 -0
  253. package/dist/components/ui/field/index.d.ts +3 -1
  254. package/dist/components/ui/field/index.js +4 -2
  255. package/dist/components/ui/form/form-field-errors.svelte +1 -1
  256. package/dist/components/ui/form/form.stories.svelte +25 -0
  257. package/dist/components/ui/form/form.stories.svelte.d.ts +26 -0
  258. package/dist/components/ui/input/input.stories.svelte +26 -0
  259. package/dist/components/ui/input-group/input-group-input.svelte.d.ts +1 -1
  260. package/dist/components/ui/input-group/input-group.stories.svelte +43 -0
  261. package/dist/components/ui/input-group/input-group.stories.svelte.d.ts +27 -0
  262. package/dist/components/ui/item/item.stories.svelte +61 -0
  263. package/dist/components/ui/item/item.stories.svelte.d.ts +27 -0
  264. package/dist/components/ui/label/label.stories.svelte +7 -0
  265. package/dist/components/ui/live-region/index.d.ts +1 -0
  266. package/dist/components/ui/live-region/index.js +1 -0
  267. package/dist/components/ui/live-region/live-region-demo.svelte +32 -0
  268. package/dist/components/ui/live-region/live-region-demo.svelte.d.ts +7 -0
  269. package/dist/components/ui/live-region/live-region.stories.svelte +23 -0
  270. package/dist/components/ui/live-region/live-region.stories.svelte.d.ts +26 -0
  271. package/dist/components/ui/live-region/live-region.svelte +12 -0
  272. package/dist/components/ui/live-region/live-region.svelte.d.ts +8 -0
  273. package/dist/components/ui/popover/popover.stories.svelte +34 -0
  274. package/dist/components/ui/radio-group/radio-group.stories.svelte +58 -0
  275. package/dist/components/ui/radio-group/radio-group.stories.svelte.d.ts +27 -0
  276. package/dist/components/ui/resizable/resizable.stories.svelte +56 -0
  277. package/dist/components/ui/resizable/resizable.stories.svelte.d.ts +27 -0
  278. package/dist/components/ui/select/select.stories.svelte +49 -0
  279. package/dist/components/ui/separator/separator.stories.svelte +18 -0
  280. package/dist/components/ui/sheet/sheet.stories.svelte +34 -0
  281. package/dist/components/ui/sidebar/sidebar-input.svelte.d.ts +1 -1
  282. package/dist/components/ui/sidebar/sidebar-menu-button.svelte +1 -0
  283. package/dist/components/ui/sidebar/sidebar-trigger.svelte +1 -1
  284. package/dist/components/ui/sidebar/sidebar.stories.svelte +72 -0
  285. package/dist/components/ui/sidebar/sidebar.stories.svelte.d.ts +27 -0
  286. package/dist/components/ui/skeleton/skeleton.stories.svelte +39 -0
  287. package/dist/components/ui/skeleton/skeleton.stories.svelte.d.ts +27 -0
  288. package/dist/components/ui/skeleton/skeleton.svelte +6 -0
  289. package/dist/components/ui/sonner/index.d.ts +1 -1
  290. package/dist/components/ui/sonner/index.js +1 -1
  291. package/dist/components/ui/sonner/sonner.stories.svelte +7 -0
  292. package/dist/components/ui/sonner/sonner.svelte +17 -1
  293. package/dist/components/ui/sonner/sonner.svelte.d.ts +6 -0
  294. package/dist/components/ui/spinner/spinner.stories.svelte +30 -0
  295. package/dist/components/ui/spinner/spinner.stories.svelte.d.ts +27 -0
  296. package/dist/components/ui/switch/switch.stories.svelte +56 -0
  297. package/dist/components/ui/switch/switch.stories.svelte.d.ts +27 -0
  298. package/dist/components/ui/table/table-cell.svelte +1 -1
  299. package/dist/components/ui/table/table-head.svelte +1 -1
  300. package/dist/components/ui/table/table.stories.svelte +68 -0
  301. package/dist/components/ui/table/table.stories.svelte.d.ts +27 -0
  302. package/dist/components/ui/table/table.svelte +1 -1
  303. package/dist/components/ui/tabs/tabs.stories.svelte +48 -0
  304. package/dist/components/ui/tabs/tabs.stories.svelte.d.ts +27 -0
  305. package/dist/components/ui/textarea/textarea.stories.svelte +21 -0
  306. package/dist/components/ui/toggle/toggle.stories.svelte +23 -0
  307. package/dist/components/ui/toggle-group/toggle-group.stories.svelte +43 -0
  308. package/dist/components/ui/tooltip/tooltip.stories.svelte +46 -6
  309. package/dist/core/cms.d.ts +11 -2
  310. package/dist/core/cms.js +29 -0
  311. package/dist/core/fields/fieldSchemaToTs.d.ts +7 -0
  312. package/dist/core/fields/fieldSchemaToTs.js +241 -90
  313. package/dist/core/fields/layoutUtils.d.ts +4 -1
  314. package/dist/core/fields/layoutUtils.js +41 -4
  315. package/dist/core/fields/resolveSeo.d.ts +70 -0
  316. package/dist/core/fields/resolveSeo.js +88 -0
  317. package/dist/core/fields/seoFieldDescriptor.d.ts +43 -0
  318. package/dist/core/fields/seoFieldDescriptor.js +74 -0
  319. package/dist/core/fields/slugPath.d.ts +13 -0
  320. package/dist/core/fields/slugPath.js +32 -0
  321. package/dist/core/fields/urlUtils.d.ts +8 -0
  322. package/dist/core/fields/urlUtils.js +27 -0
  323. package/dist/core/index.d.ts +1 -0
  324. package/dist/core/index.js +1 -0
  325. package/dist/core/server/entries/operations/create.js +13 -0
  326. package/dist/core/server/entries/operations/get.d.ts +7 -0
  327. package/dist/core/server/entries/operations/get.js +10 -6
  328. package/dist/core/server/entries/operations/slugUniqueness.d.ts +37 -0
  329. package/dist/core/server/entries/operations/slugUniqueness.js +116 -0
  330. package/dist/core/server/entries/operations/update.d.ts +6 -1
  331. package/dist/core/server/entries/operations/update.js +24 -1
  332. package/dist/core/server/fields/slugResolver.d.ts +3 -13
  333. package/dist/core/server/fields/slugResolver.js +8 -37
  334. package/dist/core/server/generator/fields.d.ts +2 -0
  335. package/dist/core/server/generator/fields.js +44 -18
  336. package/dist/core/server/generator/formFields.js +2 -1
  337. package/dist/core/server/generator/generator.js +6 -5
  338. package/dist/core/server/generator/utils.d.ts +1 -0
  339. package/dist/core/server/generator/utils.js +4 -0
  340. package/dist/db-postgres/schema/shop/order.d.ts +37 -1
  341. package/dist/db-postgres/schema/shop/order.js +3 -1
  342. package/dist/db-postgres/schema/shop/payment.d.ts +20 -0
  343. package/dist/db-postgres/schema/shop/payment.js +4 -1
  344. package/dist/db-postgres/schema/shop/product.d.ts +20 -0
  345. package/dist/db-postgres/schema/shop/product.js +3 -1
  346. package/dist/db-postgres/schema/shop/productVariant.d.ts +12 -2
  347. package/dist/db-postgres/schema/shop/productVariant.js +22 -0
  348. package/dist/shop/cart/types.d.ts +1 -0
  349. package/dist/shop/client/index.d.ts +54 -0
  350. package/dist/shop/client/index.js +5 -1
  351. package/dist/shop/expiry.d.ts +35 -0
  352. package/dist/shop/expiry.js +68 -0
  353. package/dist/shop/http/balance-handler.d.ts +20 -0
  354. package/dist/shop/http/balance-handler.js +91 -0
  355. package/dist/shop/http/cart-handler.js +19 -0
  356. package/dist/shop/http/checkout-handler.js +19 -1
  357. package/dist/shop/http/index.d.ts +2 -0
  358. package/dist/shop/http/index.js +2 -0
  359. package/dist/shop/http/upcoming-handler.d.ts +16 -0
  360. package/dist/shop/http/upcoming-handler.js +65 -0
  361. package/dist/shop/http/webhook-handler.js +46 -9
  362. package/dist/shop/index.d.ts +4 -1
  363. package/dist/shop/index.js +7 -1
  364. package/dist/shop/server/balance-payment.d.ts +40 -0
  365. package/dist/shop/server/balance-payment.js +140 -0
  366. package/dist/shop/server/cart-hydrate.js +2 -0
  367. package/dist/shop/server/init.d.ts +14 -0
  368. package/dist/shop/server/init.js +35 -0
  369. package/dist/shop/server/orders.d.ts +35 -0
  370. package/dist/shop/server/orders.js +155 -2
  371. package/dist/shop/server/payment-policy.d.ts +35 -0
  372. package/dist/shop/server/payment-policy.js +55 -0
  373. package/dist/shop/server/payments.d.ts +29 -0
  374. package/dist/shop/server/payments.js +64 -0
  375. package/dist/shop/server/populate.d.ts +1 -1
  376. package/dist/shop/server/refund.d.ts +17 -12
  377. package/dist/shop/server/refund.js +96 -13
  378. package/dist/shop/server/shop-data.d.ts +6 -1
  379. package/dist/shop/server/shop-data.js +44 -7
  380. package/dist/shop/template.d.ts +13 -0
  381. package/dist/shop/template.js +98 -0
  382. package/dist/shop/types.d.ts +142 -1
  383. package/dist/shop/variant-attributes.d.ts +28 -0
  384. package/dist/shop/variant-attributes.js +69 -0
  385. package/dist/sveltekit/server/handle.js +17 -0
  386. package/dist/sveltekit/server/index.d.ts +1 -0
  387. package/dist/sveltekit/server/index.js +2 -0
  388. package/dist/types/cms.d.ts +4 -3
  389. package/dist/types/cms.schema.d.ts +1 -1
  390. package/dist/types/cms.schema.js +13 -2
  391. package/dist/types/fields.d.ts +56 -2
  392. package/dist/types/index.d.ts +2 -2
  393. package/dist/types/index.js +1 -1
  394. package/dist/types/layout.d.ts +35 -2
  395. package/dist/types/plugins.d.ts +40 -0
  396. package/dist/types/plugins.js +4 -1
  397. package/dist/updates/0.26.0/index.d.ts +2 -0
  398. package/dist/updates/0.26.0/index.js +51 -0
  399. package/dist/updates/0.26.1/index.d.ts +2 -0
  400. package/dist/updates/0.26.1/index.js +19 -0
  401. package/dist/updates/0.27.0/index.d.ts +2 -0
  402. package/dist/updates/0.27.0/index.js +50 -0
  403. package/dist/updates/index.js +7 -1
  404. package/package.json +29 -7
  405. package/dist/admin/client/collection/empty-state.svelte +0 -28
  406. package/dist/admin/client/collection/empty-state.svelte.d.ts +0 -9
  407. package/dist/admin/client/form/submission-status-badge.svelte +0 -41
  408. package/dist/admin/client/form/submission-status-badge.svelte.d.ts +0 -7
  409. package/dist/admin/components/media/file-preview.svelte +0 -51
  410. package/dist/admin/components/media/file-preview.svelte.d.ts +0 -6
  411. package/dist/admin/utils/formatDate.d.ts +0 -5
@@ -1,188 +1,338 @@
1
1
  <script lang="ts">
2
2
  import { getRemotes } from '../../../sveltekit/index.js';
3
+ import { useInterfaceLanguage } from '../../state/interface-language.svelte.js';
4
+ import { getBreadcrumbs } from '../../state/breadcrumbs.svelte.js';
5
+ import { sidebarLang } from '../../components/layout/lang.js';
6
+ import { Button } from '../../../components/ui/button/index.js';
7
+ import DownloadIcon from '@tabler/icons-svelte/icons/download';
8
+ import { formatCentsPrice, formatDateTime } from '../../utils/formatters.js';
9
+ import PageHeader from '../../components/layout/page-header.svelte';
10
+ import DataTable from '../collection/data-table.svelte';
11
+ import TableToolbar from '../collection/table-toolbar.svelte';
12
+ import TablePagination from '../collection/table-pagination.svelte';
13
+ import StateDisplay from '../collection/state-display.svelte';
14
+ import StatusBadge from '../collection/status-badge.svelte';
15
+ import EntryLink from '../collection/entry-link.svelte';
16
+ import { renderComponent } from '../../../components/ui/data-table/render-helpers.js';
17
+ import type { ColumnDef, PaginationState } from '@tanstack/table-core';
18
+ import type { InterfaceLanguage } from '../../../types/languages.js';
19
+ import type { OrderStatus } from '../../../shop/types.js';
20
+
21
+ type OrderRow = {
22
+ id: string;
23
+ number: string;
24
+ status: OrderStatus;
25
+ customerName: string | null;
26
+ customerEmail: string;
27
+ totalGross: number;
28
+ currency: string;
29
+ paymentMethod: string | null;
30
+ createdAt: Date | string;
31
+ };
32
+
33
+ type Props = {
34
+ data?: OrderRow[];
35
+ state?: 'loading' | 'error' | 'ok';
36
+ totalOverride?: number;
37
+ };
38
+
39
+ let { data: injectedData, state: injectedState, totalOverride }: Props = $props();
40
+ const useInjectedData = $derived(injectedData !== undefined);
3
41
 
4
42
  const remotes = getRemotes();
43
+ const interfaceLanguage = useInterfaceLanguage();
44
+ const breadcrumbs = getBreadcrumbs();
5
45
 
6
- const STATUSES = [
7
- { value: 'all', label: 'Wszystkie' },
8
- { value: 'new', label: 'Nowe' },
9
- { value: 'awaitingPayment', label: 'Oczekują na płatność' },
10
- { value: 'paid', label: 'Opłacone' },
11
- { value: 'preparing', label: 'W przygotowaniu' },
12
- { value: 'sent', label: 'Wysłane' },
13
- { value: 'done', label: 'Zrealizowane' },
14
- { value: 'cancelled', label: 'Anulowane' },
15
- { value: 'paymentRejected', label: 'Płatność odrzucona' },
16
- { value: 'refunded', label: 'Zwrócone' }
17
- ] as const;
46
+ $effect(() => {
47
+ const s = sidebarLang[interfaceLanguage.current].shop;
48
+ breadcrumbs.state = [{ label: s.title }, { label: s.orders }];
49
+ });
18
50
 
51
+ let statusFilter = $state<string | null>(null);
52
+ let searchQuery = $state('');
53
+ let appliedEmail = $state('');
54
+ let pagination = $state<PaginationState>({ pageIndex: 0, pageSize: 50 });
19
55
  let exporting = $state(false);
56
+ let emailDebounceTimer: ReturnType<typeof setTimeout> | null = null;
57
+
58
+ const ordersQuery = $derived(
59
+ useInjectedData
60
+ ? null
61
+ : remotes.listOrdersAdmin({
62
+ status: (statusFilter as OrderStatus | null) ?? undefined,
63
+ email: appliedEmail || undefined,
64
+ limit: pagination.pageSize,
65
+ offset: pagination.pageIndex * pagination.pageSize
66
+ })
67
+ );
68
+
69
+ const items = $derived<OrderRow[]>(
70
+ useInjectedData
71
+ ? (injectedData ?? [])
72
+ : ((ordersQuery?.current?.items as OrderRow[] | undefined) ?? [])
73
+ );
74
+ const total = $derived(
75
+ useInjectedData
76
+ ? (totalOverride ?? injectedData?.length ?? 0)
77
+ : (ordersQuery?.current?.total ?? 0)
78
+ );
79
+ const isLoading = $derived(
80
+ useInjectedData ? injectedState === 'loading' : !(ordersQuery?.ready ?? false)
81
+ );
82
+ const isError = $derived(
83
+ useInjectedData ? injectedState === 'error' : Boolean(ordersQuery?.error)
84
+ );
85
+
86
+ const pageCount = $derived(Math.max(1, Math.ceil(total / pagination.pageSize)));
87
+
88
+ const lang: Record<
89
+ InterfaceLanguage,
90
+ {
91
+ title: string;
92
+ search: string;
93
+ searchPlaceholder: string;
94
+ filterStatus: string;
95
+ columnNumber: string;
96
+ columnDate: string;
97
+ columnCustomer: string;
98
+ columnTotal: string;
99
+ columnPayment: string;
100
+ columnStatus: string;
101
+ emptyTitle: string;
102
+ emptyDescription: string;
103
+ exportCsv: string;
104
+ exporting: string;
105
+ exportError: string;
106
+ noResults: string;
107
+ statusAll: string;
108
+ statusNew: string;
109
+ statusAwaitingPayment: string;
110
+ statusPaid: string;
111
+ statusPreparing: string;
112
+ statusSent: string;
113
+ statusDone: string;
114
+ statusCancelled: string;
115
+ statusPaymentRejected: string;
116
+ statusRefunded: string;
117
+ }
118
+ > = {
119
+ en: {
120
+ title: 'Orders',
121
+ search: 'Search',
122
+ searchPlaceholder: 'Filter by customer email…',
123
+ filterStatus: 'Status',
124
+ columnNumber: 'Number',
125
+ columnDate: 'Date',
126
+ columnCustomer: 'Customer',
127
+ columnTotal: 'Total (gross)',
128
+ columnPayment: 'Payment',
129
+ columnStatus: 'Status',
130
+ emptyTitle: 'No orders yet',
131
+ emptyDescription: 'Orders will appear here as soon as customers place them.',
132
+ exportCsv: 'Export CSV',
133
+ exporting: 'Exporting…',
134
+ exportError: 'Export failed.',
135
+ noResults: 'No results.',
136
+ statusAll: 'All',
137
+ statusNew: 'New',
138
+ statusAwaitingPayment: 'Awaiting payment',
139
+ statusPaid: 'Paid',
140
+ statusPreparing: 'Preparing',
141
+ statusSent: 'Sent',
142
+ statusDone: 'Done',
143
+ statusCancelled: 'Cancelled',
144
+ statusPaymentRejected: 'Payment rejected',
145
+ statusRefunded: 'Refunded'
146
+ },
147
+ pl: {
148
+ title: 'Zamówienia',
149
+ search: 'Szukaj',
150
+ searchPlaceholder: 'Filtruj po e-mailu klienta…',
151
+ filterStatus: 'Status',
152
+ columnNumber: 'Numer',
153
+ columnDate: 'Data',
154
+ columnCustomer: 'Klient',
155
+ columnTotal: 'Suma (brutto)',
156
+ columnPayment: 'Płatność',
157
+ columnStatus: 'Status',
158
+ emptyTitle: 'Brak zamówień',
159
+ emptyDescription: 'Gdy klient złoży zamówienie, pojawi się tutaj.',
160
+ exportCsv: 'Eksport CSV',
161
+ exporting: 'Eksportuję…',
162
+ exportError: 'Eksport nie powiódł się.',
163
+ noResults: 'Brak wyników.',
164
+ statusAll: 'Wszystkie',
165
+ statusNew: 'Nowe',
166
+ statusAwaitingPayment: 'Oczekują na płatność',
167
+ statusPaid: 'Opłacone',
168
+ statusPreparing: 'W przygotowaniu',
169
+ statusSent: 'Wysłane',
170
+ statusDone: 'Zrealizowane',
171
+ statusCancelled: 'Anulowane',
172
+ statusPaymentRejected: 'Płatność odrzucona',
173
+ statusRefunded: 'Zwrócone'
174
+ }
175
+ };
176
+ const t = $derived(lang[interfaceLanguage.current]);
177
+
178
+ const dataFilters = $derived([
179
+ {
180
+ slug: 'status',
181
+ label: t.filterStatus,
182
+ options: [
183
+ { value: 'new', label: t.statusNew },
184
+ { value: 'awaitingPayment', label: t.statusAwaitingPayment },
185
+ { value: 'paid', label: t.statusPaid },
186
+ { value: 'preparing', label: t.statusPreparing },
187
+ { value: 'sent', label: t.statusSent },
188
+ { value: 'done', label: t.statusDone },
189
+ { value: 'cancelled', label: t.statusCancelled },
190
+ { value: 'paymentRejected', label: t.statusPaymentRejected },
191
+ { value: 'refunded', label: t.statusRefunded }
192
+ ]
193
+ }
194
+ ]);
195
+ const activeDataFilters = $derived({ status: statusFilter });
196
+
197
+ function scheduleEmailFilterUpdate(value: string) {
198
+ if (emailDebounceTimer) clearTimeout(emailDebounceTimer);
199
+ emailDebounceTimer = setTimeout(() => {
200
+ appliedEmail = value.trim();
201
+ pagination = { ...pagination, pageIndex: 0 };
202
+ }, 350);
203
+ }
20
204
 
21
205
  async function handleExportCsv() {
22
206
  exporting = true;
23
207
  try {
208
+ const opts: { status?: OrderStatus; email?: string } = {};
209
+ if (statusFilter) opts.status = statusFilter as OrderStatus;
210
+ if (appliedEmail) opts.email = appliedEmail;
24
211
  const result = await remotes.exportOrdersCsv(
25
- statusFilter === 'all'
26
- ? appliedEmail
27
- ? { email: appliedEmail }
28
- : undefined
29
- : appliedEmail
30
- ? { status: statusFilter, email: appliedEmail }
31
- : { status: statusFilter }
212
+ Object.keys(opts).length > 0 ? opts : undefined
32
213
  );
33
214
  const blob = new Blob(['' + result.csv], { type: 'text/csv;charset=utf-8' });
34
215
  const url = URL.createObjectURL(blob);
35
216
  const a = document.createElement('a');
36
217
  const ts = new Date().toISOString().slice(0, 10);
37
218
  a.href = url;
38
- a.download = `zamowienia-${ts}.csv`;
219
+ a.download = `orders-${ts}.csv`;
39
220
  document.body.appendChild(a);
40
221
  a.click();
41
222
  a.remove();
42
223
  URL.revokeObjectURL(url);
43
224
  } catch (err) {
44
- alert(err instanceof Error ? err.message : 'Eksport nie powiódł się.');
225
+ alert(err instanceof Error ? err.message : t.exportError);
45
226
  } finally {
46
227
  exporting = false;
47
228
  }
48
229
  }
49
230
 
50
- let statusFilter = $state<(typeof STATUSES)[number]['value']>('all');
51
- let emailFilter = $state('');
52
- let appliedEmail = $state('');
53
-
54
- const query = $derived(
55
- remotes.listOrdersAdmin({
56
- status: statusFilter === 'all' ? undefined : statusFilter,
57
- email: appliedEmail || undefined,
58
- limit: 200
59
- })
60
- );
61
-
62
- const STATUS_STYLES: Record<string, string> = {
63
- new: 'bg-blue-100 text-blue-800',
64
- awaitingPayment: 'bg-yellow-100 text-yellow-800',
65
- paid: 'bg-green-100 text-green-800',
66
- preparing: 'bg-purple-100 text-purple-800',
67
- sent: 'bg-indigo-100 text-indigo-800',
68
- done: 'bg-gray-100 text-gray-800',
69
- cancelled: 'bg-red-100 text-red-800',
70
- paymentRejected: 'bg-red-100 text-red-800',
71
- refunded: 'bg-orange-100 text-orange-800'
72
- };
73
-
74
- function formatPrice(smallest: number, currency: string) {
75
- return new Intl.NumberFormat('pl-PL', {
76
- style: 'currency',
77
- currency,
78
- minimumFractionDigits: 2
79
- }).format(smallest / 100);
80
- }
231
+ const columns = $derived.by<ColumnDef<OrderRow>[]>(() => [
232
+ {
233
+ accessorKey: 'number',
234
+ header: t.columnNumber,
235
+ cell: (info) =>
236
+ renderComponent(EntryLink, {
237
+ name: info.row.original.number,
238
+ url: `/admin/shop/orders/${info.row.original.id}`
239
+ })
240
+ },
241
+ {
242
+ accessorKey: 'createdAt',
243
+ header: t.columnDate,
244
+ cell: (info) => formatDateTime(info.row.original.createdAt, interfaceLanguage.current)
245
+ },
246
+ {
247
+ accessorKey: 'customerEmail',
248
+ header: t.columnCustomer,
249
+ cell: (info) => {
250
+ const row = info.row.original;
251
+ return renderComponent(EntryLink, {
252
+ name: row.customerName ?? row.customerEmail,
253
+ url: `/admin/shop/orders/${row.id}`,
254
+ slug: row.customerName ? row.customerEmail : undefined
255
+ });
256
+ }
257
+ },
258
+ {
259
+ accessorKey: 'totalGross',
260
+ header: t.columnTotal,
261
+ cell: (info) => formatCentsPrice(info.row.original.totalGross, info.row.original.currency)
262
+ },
263
+ {
264
+ accessorKey: 'paymentMethod',
265
+ header: t.columnPayment,
266
+ cell: (info) => info.row.original.paymentMethod ?? '—'
267
+ },
268
+ {
269
+ accessorKey: 'status',
270
+ header: t.columnStatus,
271
+ cell: (info) =>
272
+ renderComponent(StatusBadge, {
273
+ variant: 'order',
274
+ status: info.row.original.status
275
+ })
276
+ }
277
+ ]);
278
+ </script>
81
279
 
82
- function formatDate(d: Date | string) {
83
- return new Intl.DateTimeFormat('pl-PL', {
84
- dateStyle: 'short',
85
- timeStyle: 'short'
86
- }).format(new Date(d));
87
- }
280
+ <div class="p-5 pb-24 md:p-7">
281
+ <PageHeader title={t.title} count={!isLoading && !isError ? total : undefined}>
282
+ {#snippet secondaryActions()}
283
+ <Button variant="outline" size="sm" onclick={handleExportCsv} disabled={exporting}>
284
+ <DownloadIcon class="size-4" />
285
+ {exporting ? t.exporting : t.exportCsv}
286
+ </Button>
287
+ {/snippet}
288
+ </PageHeader>
88
289
 
89
- function applyEmailFilter() {
90
- appliedEmail = emailFilter.trim();
91
- }
92
- </script>
290
+ {#if isError}
291
+ <StateDisplay kind="error" />
292
+ {:else if isLoading && total === 0}
293
+ <StateDisplay kind="loading" />
294
+ {:else if total === 0 && !statusFilter && !appliedEmail}
295
+ <StateDisplay kind="empty" title={t.emptyTitle} description={t.emptyDescription} />
296
+ {:else}
297
+ <TableToolbar
298
+ searchQuery={searchQuery}
299
+ searchPlaceholder={t.searchPlaceholder}
300
+ searchLabel={t.search}
301
+ onSearchChange={(q) => {
302
+ searchQuery = q;
303
+ scheduleEmailFilterUpdate(q);
304
+ }}
305
+ hideStatusFilter
306
+ hideViewToggle
307
+ {dataFilters}
308
+ {activeDataFilters}
309
+ onDataFilterChange={(_slug, value) => {
310
+ statusFilter = value;
311
+ pagination = { ...pagination, pageIndex: 0 };
312
+ }}
313
+ />
93
314
 
94
- <div class="flex flex-wrap items-end justify-between gap-4 p-6">
95
- <div>
96
- <h1 class="text-2xl font-extrabold tracking-tight">Zamówienia</h1>
97
- <p class="text-muted-foreground text-sm">
98
- {#if query.ready}
99
- {query.current?.length ?? 0}
100
- {(query.current?.length ?? 0) === 1 ? 'zamówienie' : 'zamówień'}
101
- {:else}
102
- Ładowanie…
103
- {/if}
104
- </p>
105
- </div>
106
- <div class="flex flex-wrap items-end gap-3">
107
- <label class="block">
108
- <span class="text-muted-foreground mb-1 block text-xs font-semibold">Status</span>
109
- <select bind:value={statusFilter} class="border-border h-9 rounded-lg border px-3 text-sm">
110
- {#each STATUSES as s (s.value)}
111
- <option value={s.value}>{s.label}</option>
112
- {/each}
113
- </select>
114
- </label>
115
- <label class="block">
116
- <span class="text-muted-foreground mb-1 block text-xs font-semibold">Email klienta</span>
117
- <input
118
- type="email"
119
- bind:value={emailFilter}
120
- onchange={applyEmailFilter}
121
- onblur={applyEmailFilter}
122
- placeholder="filtruj po email"
123
- class="border-border h-9 rounded-lg border px-3 text-sm"
315
+ <div class="overflow-hidden rounded-xl border bg-card shadow-sm">
316
+ <DataTable
317
+ data={items}
318
+ {columns}
319
+ enablePagination
320
+ manualPagination
321
+ {pageCount}
322
+ rowCount={total}
323
+ {pagination}
324
+ onPaginationChange={(p) => (pagination = p)}
325
+ emptyTitle={t.noResults}
124
326
  />
125
- </label>
126
- <button
127
- type="button"
128
- onclick={handleExportCsv}
129
- disabled={exporting}
130
- class="border-border hover:bg-muted h-9 rounded-lg border px-3 text-sm disabled:opacity-50"
131
- title="Pobierz CSV z bieżącymi filtrami"
132
- >
133
- {exporting ? 'Eksportuję…' : 'Eksport CSV'}
134
- </button>
135
- </div>
136
- </div>
137
327
 
138
- <div class="px-6 pb-12">
139
- {#if !query.ready}
140
- <div class="text-muted-foreground">Ładowanie…</div>
141
- {:else if (query.current?.length ?? 0) === 0}
142
- <div class="bg-lavender-lighter/40 border-border rounded-xl border p-8 text-center text-sm">
143
- <p class="mb-2 font-semibold">Brak zamówień</p>
144
- <p class="text-muted-foreground">Gdy klient złoży zamówienie, pojawi się tutaj.</p>
145
- </div>
146
- {:else}
147
- <div class="border-border overflow-hidden rounded-xl border">
148
- <table class="w-full text-sm">
149
- <thead class="bg-muted/50 text-left text-xs tracking-wide uppercase">
150
- <tr>
151
- <th class="px-4 py-3 font-semibold">Numer</th>
152
- <th class="px-4 py-3 font-semibold">Data</th>
153
- <th class="px-4 py-3 font-semibold">Klient</th>
154
- <th class="px-4 py-3 font-semibold">Suma (brutto)</th>
155
- <th class="px-4 py-3 font-semibold">Płatność</th>
156
- <th class="px-4 py-3 font-semibold">Status</th>
157
- </tr>
158
- </thead>
159
- <tbody>
160
- {#each query.current ?? [] as o (o.id)}
161
- <tr class="border-border hover:bg-muted/30 border-t">
162
- <td class="px-4 py-3 font-mono text-xs">
163
- <a href={`/admin/shop/orders/${o.id}`} class="text-primary hover:underline">
164
- {o.number}
165
- </a>
166
- </td>
167
- <td class="text-muted-foreground px-4 py-3 text-xs">{formatDate(o.createdAt)}</td>
168
- <td class="px-4 py-3">
169
- <div class="font-medium">{o.customerName ?? '—'}</div>
170
- <div class="text-muted-foreground text-xs">{o.customerEmail}</div>
171
- </td>
172
- <td class="px-4 py-3 tabular-nums">{formatPrice(o.totalGross, o.currency)}</td>
173
- <td class="text-muted-foreground px-4 py-3 text-xs">{o.paymentMethod ?? '—'}</td>
174
- <td class="px-4 py-3">
175
- <span
176
- class="inline-flex rounded-full px-2 py-0.5 text-xs {STATUS_STYLES[o.status] ??
177
- 'bg-gray-100 text-gray-800'}"
178
- >
179
- {STATUSES.find((s) => s.value === o.status)?.label ?? o.status}
180
- </span>
181
- </td>
182
- </tr>
183
- {/each}
184
- </tbody>
185
- </table>
328
+ <TablePagination
329
+ pageIndex={pagination.pageIndex}
330
+ pageSize={pagination.pageSize}
331
+ {pageCount}
332
+ totalItems={total}
333
+ onPageChange={(p) => (pagination = { ...pagination, pageIndex: p })}
334
+ onPageSizeChange={(s) => (pagination = { pageIndex: 0, pageSize: s })}
335
+ />
186
336
  </div>
187
337
  {/if}
188
338
  </div>
@@ -1,3 +1,20 @@
1
- declare const ShopOrdersListPage: import("svelte").Component<Record<string, never>, {}, "">;
1
+ import type { OrderStatus } from '../../../shop/types.js';
2
+ type OrderRow = {
3
+ id: string;
4
+ number: string;
5
+ status: OrderStatus;
6
+ customerName: string | null;
7
+ customerEmail: string;
8
+ totalGross: number;
9
+ currency: string;
10
+ paymentMethod: string | null;
11
+ createdAt: Date | string;
12
+ };
13
+ type Props = {
14
+ data?: OrderRow[];
15
+ state?: 'loading' | 'error' | 'ok';
16
+ totalOverride?: number;
17
+ };
18
+ declare const ShopOrdersListPage: import("svelte").Component<Props, {}, "">;
2
19
  type ShopOrdersListPage = ReturnType<typeof ShopOrdersListPage>;
3
20
  export default ShopOrdersListPage;