@vendure/dashboard 3.3.6-master-202507041203 → 3.4.0-minor-202506250934

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 (390) hide show
  1. package/README.md +4 -41
  2. package/dist/plugin/utils/config-loader.d.ts +1 -70
  3. package/dist/plugin/utils/config-loader.js +9 -33
  4. package/dist/plugin/vite-plugin-config-loader.js +1 -6
  5. package/dist/plugin/vite-plugin-config.js +7 -6
  6. package/dist/plugin/vite-plugin-dashboard-metadata.d.ts +3 -1
  7. package/dist/plugin/vite-plugin-dashboard-metadata.js +8 -1
  8. package/dist/plugin/vite-plugin-vendure-dashboard.d.ts +0 -41
  9. package/dist/plugin/vite-plugin-vendure-dashboard.js +2 -5
  10. package/package.json +131 -131
  11. package/src/app/app-providers.tsx +6 -6
  12. package/src/app/main.tsx +9 -9
  13. package/src/app/routes/__root.tsx +2 -1
  14. package/src/app/routes/_authenticated/_administrators/administrators.graphql.ts +1 -10
  15. package/src/app/routes/_authenticated/_administrators/administrators.tsx +8 -15
  16. package/src/app/routes/_authenticated/_administrators/administrators_.$id.tsx +12 -16
  17. package/src/app/routes/_authenticated/_administrators/components/role-permissions-display.tsx +16 -16
  18. package/src/app/routes/_authenticated/_assets/assets.graphql.ts +2 -13
  19. package/src/app/routes/_authenticated/_assets/assets.tsx +4 -16
  20. package/src/app/routes/_authenticated/_assets/assets_.$id.tsx +38 -52
  21. package/src/app/routes/_authenticated/_channels/channels.graphql.ts +1 -10
  22. package/src/app/routes/_authenticated/_channels/channels.tsx +10 -17
  23. package/src/app/routes/_authenticated/_channels/channels_.$id.tsx +17 -21
  24. package/src/app/routes/_authenticated/_collections/collections.graphql.ts +3 -60
  25. package/src/app/routes/_authenticated/_collections/collections.tsx +124 -168
  26. package/src/app/routes/_authenticated/_collections/collections_.$id.tsx +16 -20
  27. package/src/app/routes/_authenticated/_collections/components/collection-contents-preview-table.tsx +8 -7
  28. package/src/app/routes/_authenticated/_collections/components/collection-contents-sheet.tsx +5 -9
  29. package/src/app/routes/_authenticated/_collections/components/collection-contents-table.tsx +9 -10
  30. package/src/app/routes/_authenticated/_collections/components/collection-filters-selector.tsx +7 -7
  31. package/src/app/routes/_authenticated/_countries/countries.graphql.ts +2 -11
  32. package/src/app/routes/_authenticated/_countries/countries.tsx +6 -13
  33. package/src/app/routes/_authenticated/_countries/countries_.$id.tsx +17 -21
  34. package/src/app/routes/_authenticated/_customer-groups/components/customer-group-members-sheet.tsx +5 -12
  35. package/src/app/routes/_authenticated/_customer-groups/components/customer-group-members-table.tsx +17 -22
  36. package/src/app/routes/_authenticated/_customer-groups/customer-groups.graphql.ts +2 -11
  37. package/src/app/routes/_authenticated/_customer-groups/customer-groups.tsx +6 -13
  38. package/src/app/routes/_authenticated/_customer-groups/customer-groups_.$id.tsx +15 -18
  39. package/src/app/routes/_authenticated/_customers/components/customer-address-card.tsx +19 -19
  40. package/src/app/routes/_authenticated/_customers/components/customer-address-form.tsx +10 -10
  41. package/src/app/routes/_authenticated/_customers/components/customer-history/customer-history-container.tsx +5 -5
  42. package/src/app/routes/_authenticated/_customers/components/customer-history/customer-history.tsx +7 -11
  43. package/src/app/routes/_authenticated/_customers/components/customer-history/use-customer-history.ts +4 -4
  44. package/src/app/routes/_authenticated/_customers/components/customer-order-table.tsx +73 -75
  45. package/src/app/routes/_authenticated/_customers/components/customer-status-badge.tsx +4 -4
  46. package/src/app/routes/_authenticated/_customers/customers.graphql.ts +2 -10
  47. package/src/app/routes/_authenticated/_customers/customers.tsx +6 -13
  48. package/src/app/routes/_authenticated/_customers/customers_.$id.tsx +15 -19
  49. package/src/app/routes/_authenticated/_facets/components/edit-facet-value.tsx +9 -9
  50. package/src/app/routes/_authenticated/_facets/components/facet-values-sheet.tsx +4 -4
  51. package/src/app/routes/_authenticated/_facets/components/facet-values-table.tsx +11 -15
  52. package/src/app/routes/_authenticated/_facets/facets.graphql.ts +1 -31
  53. package/src/app/routes/_authenticated/_facets/facets.tsx +7 -31
  54. package/src/app/routes/_authenticated/_facets/facets_.$id.tsx +13 -17
  55. package/src/app/routes/_authenticated/_global-settings/global-settings.graphql.ts +1 -1
  56. package/src/app/routes/_authenticated/_global-settings/global-settings.tsx +13 -13
  57. package/src/app/routes/_authenticated/_orders/components/customer-address-selector.tsx +14 -11
  58. package/src/app/routes/_authenticated/_orders/components/edit-order-table.tsx +55 -93
  59. package/src/app/routes/_authenticated/_orders/components/money-gross-net.tsx +9 -11
  60. package/src/app/routes/_authenticated/_orders/components/order-address.tsx +6 -5
  61. package/src/app/routes/_authenticated/_orders/components/order-history/order-history-container.tsx +62 -67
  62. package/src/app/routes/_authenticated/_orders/components/order-history/order-history.tsx +6 -11
  63. package/src/app/routes/_authenticated/_orders/components/order-history/use-order-history.ts +5 -9
  64. package/src/app/routes/_authenticated/_orders/components/order-line-custom-fields-form.tsx +7 -11
  65. package/src/app/routes/_authenticated/_orders/components/order-table-totals.tsx +22 -39
  66. package/src/app/routes/_authenticated/_orders/components/order-table.tsx +4 -4
  67. package/src/app/routes/_authenticated/_orders/components/order-tax-summary.tsx +36 -37
  68. package/src/app/routes/_authenticated/_orders/components/payment-details.tsx +33 -18
  69. package/src/app/routes/_authenticated/_orders/components/shipping-method-selector.tsx +44 -43
  70. package/src/app/routes/_authenticated/_orders/orders.graphql.ts +3 -101
  71. package/src/app/routes/_authenticated/_orders/orders.tsx +20 -21
  72. package/src/app/routes/_authenticated/_orders/orders_.$id.tsx +16 -72
  73. package/src/app/routes/_authenticated/_orders/orders_.draft.$id.tsx +90 -188
  74. package/src/app/routes/_authenticated/_payment-methods/components/payment-eligibility-checker-selector.tsx +7 -10
  75. package/src/app/routes/_authenticated/_payment-methods/components/payment-handler-selector.tsx +11 -11
  76. package/src/app/routes/_authenticated/_payment-methods/payment-methods.graphql.ts +2 -29
  77. package/src/app/routes/_authenticated/_payment-methods/payment-methods.tsx +14 -36
  78. package/src/app/routes/_authenticated/_payment-methods/payment-methods_.$id.tsx +15 -22
  79. package/src/app/routes/_authenticated/_product-variants/components/variant-price-detail.tsx +6 -7
  80. package/src/app/routes/_authenticated/_product-variants/product-variants.graphql.ts +3 -64
  81. package/src/app/routes/_authenticated/_product-variants/product-variants.tsx +9 -39
  82. package/src/app/routes/_authenticated/_product-variants/product-variants_.$id.tsx +22 -33
  83. package/src/app/routes/_authenticated/_products/components/add-product-variant-dialog.tsx +10 -10
  84. package/src/app/routes/_authenticated/_products/components/create-product-options-dialog.tsx +41 -57
  85. package/src/app/routes/_authenticated/_products/components/create-product-variants-dialog.tsx +11 -11
  86. package/src/app/routes/_authenticated/_products/components/create-product-variants.tsx +14 -18
  87. package/src/app/routes/_authenticated/_products/components/option-value-input.tsx +15 -21
  88. package/src/app/routes/_authenticated/_products/components/product-option-select.tsx +34 -28
  89. package/src/app/routes/_authenticated/_products/components/product-variants-table.tsx +53 -84
  90. package/src/app/routes/_authenticated/_products/products.graphql.ts +2 -70
  91. package/src/app/routes/_authenticated/_products/products.tsx +7 -36
  92. package/src/app/routes/_authenticated/_products/products_.$id.tsx +24 -33
  93. package/src/app/routes/_authenticated/_profile/profile.graphql.ts +1 -1
  94. package/src/app/routes/_authenticated/_profile/profile.tsx +8 -8
  95. package/src/app/routes/_authenticated/_promotions/components/promotion-actions-selector.tsx +11 -14
  96. package/src/app/routes/_authenticated/_promotions/components/promotion-conditions-selector.tsx +11 -14
  97. package/src/app/routes/_authenticated/_promotions/promotions.graphql.ts +2 -27
  98. package/src/app/routes/_authenticated/_promotions/promotions.tsx +7 -31
  99. package/src/app/routes/_authenticated/_promotions/promotions_.$id.tsx +16 -20
  100. package/src/app/routes/_authenticated/_roles/components/expandable-permissions.tsx +5 -5
  101. package/src/app/routes/_authenticated/_roles/components/permissions-grid.tsx +17 -21
  102. package/src/app/routes/_authenticated/_roles/roles.graphql.ts +1 -10
  103. package/src/app/routes/_authenticated/_roles/roles.tsx +10 -17
  104. package/src/app/routes/_authenticated/_roles/roles_.$id.tsx +12 -16
  105. package/src/app/routes/_authenticated/_sellers/sellers.graphql.ts +1 -10
  106. package/src/app/routes/_authenticated/_sellers/sellers.tsx +6 -13
  107. package/src/app/routes/_authenticated/_sellers/sellers_.$id.tsx +13 -17
  108. package/src/app/routes/_authenticated/_shipping-methods/components/fulfillment-handler-selector.tsx +6 -6
  109. package/src/app/routes/_authenticated/_shipping-methods/components/shipping-calculator-selector.tsx +21 -23
  110. package/src/app/routes/_authenticated/_shipping-methods/components/shipping-eligibility-checker-selector.tsx +21 -25
  111. package/src/app/routes/_authenticated/_shipping-methods/components/test-shipping-method-dialog.tsx +3 -3
  112. package/src/app/routes/_authenticated/_shipping-methods/shipping-methods.graphql.ts +2 -29
  113. package/src/app/routes/_authenticated/_shipping-methods/shipping-methods.tsx +6 -25
  114. package/src/app/routes/_authenticated/_shipping-methods/shipping-methods_.$id.tsx +13 -17
  115. package/src/app/routes/_authenticated/_stock-locations/stock-locations.graphql.ts +1 -26
  116. package/src/app/routes/_authenticated/_stock-locations/stock-locations.tsx +6 -25
  117. package/src/app/routes/_authenticated/_stock-locations/stock-locations_.$id.tsx +12 -16
  118. package/src/app/routes/_authenticated/_system/components/payload-dialog.tsx +4 -4
  119. package/src/app/routes/_authenticated/_system/healthchecks.tsx +4 -4
  120. package/src/app/routes/_authenticated/_system/job-queue.graphql.ts +1 -1
  121. package/src/app/routes/_authenticated/_system/job-queue.tsx +6 -10
  122. package/src/app/routes/_authenticated/_system/scheduled-tasks.tsx +28 -34
  123. package/src/app/routes/_authenticated/_tax-categories/tax-categories.graphql.ts +2 -11
  124. package/src/app/routes/_authenticated/_tax-categories/tax-categories.tsx +7 -14
  125. package/src/app/routes/_authenticated/_tax-categories/tax-categories_.$id.tsx +16 -20
  126. package/src/app/routes/_authenticated/_tax-rates/tax-rates.graphql.ts +2 -11
  127. package/src/app/routes/_authenticated/_tax-rates/tax-rates.tsx +8 -15
  128. package/src/app/routes/_authenticated/_tax-rates/tax-rates_.$id.tsx +18 -22
  129. package/src/app/routes/_authenticated/_zones/components/zone-countries-sheet.tsx +4 -4
  130. package/src/app/routes/_authenticated/_zones/components/zone-countries-table.tsx +8 -12
  131. package/src/app/routes/_authenticated/_zones/zones.graphql.ts +2 -11
  132. package/src/app/routes/_authenticated/_zones/zones.tsx +6 -13
  133. package/src/app/routes/_authenticated/_zones/zones_.$id.tsx +14 -18
  134. package/src/app/routes/_authenticated/index.tsx +4 -4
  135. package/src/app/routes/_authenticated.tsx +3 -3
  136. package/src/app/routes/login.tsx +2 -2
  137. package/src/app/styles.css +1 -4
  138. package/src/lib/components/data-display/boolean.tsx +1 -1
  139. package/src/lib/components/data-display/date-time.tsx +2 -2
  140. package/src/lib/components/data-display/json.tsx +1 -1
  141. package/src/lib/components/data-display/money.tsx +3 -2
  142. package/src/lib/components/data-input/affixed-input.tsx +8 -3
  143. package/src/lib/components/data-input/customer-group-input.tsx +2 -2
  144. package/src/lib/components/data-input/datetime-input.tsx +146 -129
  145. package/src/lib/components/data-input/facet-value-input.tsx +22 -30
  146. package/src/lib/components/data-input/money-input.tsx +12 -5
  147. package/src/lib/components/data-input/{rich-text-input.tsx → richt-text-input.tsx} +1 -1
  148. package/src/lib/components/data-table/add-filter-menu.tsx +18 -9
  149. package/src/lib/components/data-table/data-table-column-header.tsx +22 -4
  150. package/src/lib/components/data-table/data-table-faceted-filter.tsx +8 -8
  151. package/src/lib/components/data-table/data-table-filter-badge.tsx +8 -16
  152. package/src/lib/components/data-table/data-table-filter-dialog.tsx +8 -8
  153. package/src/lib/components/data-table/data-table-pagination.tsx +4 -4
  154. package/src/lib/components/data-table/data-table-view-options.tsx +21 -25
  155. package/src/lib/components/data-table/data-table.tsx +41 -85
  156. package/src/lib/components/data-table/filters/data-table-boolean-filter.tsx +8 -11
  157. package/src/lib/components/data-table/filters/data-table-datetime-filter.tsx +23 -14
  158. package/src/lib/components/data-table/filters/data-table-id-filter.tsx +10 -15
  159. package/src/lib/components/data-table/filters/data-table-number-filter.tsx +17 -18
  160. package/src/lib/components/data-table/filters/data-table-string-filter.tsx +12 -29
  161. package/src/lib/components/data-table/human-readable-operator.tsx +3 -3
  162. package/src/lib/components/data-table/refresh-button.tsx +15 -30
  163. package/src/lib/components/layout/app-layout.tsx +8 -8
  164. package/src/lib/components/layout/app-sidebar.tsx +5 -5
  165. package/src/lib/components/layout/channel-switcher.tsx +8 -8
  166. package/src/lib/components/layout/content-language-selector.tsx +10 -16
  167. package/src/lib/components/layout/generated-breadcrumbs.tsx +1 -1
  168. package/src/lib/components/layout/language-dialog.tsx +11 -5
  169. package/src/lib/components/layout/nav-main.tsx +4 -4
  170. package/src/lib/components/layout/nav-projects.tsx +2 -2
  171. package/src/lib/components/layout/nav-user.tsx +7 -7
  172. package/src/lib/components/layout/prerelease-popup.tsx +1 -1
  173. package/src/lib/components/login/login-form.tsx +5 -5
  174. package/src/lib/components/shared/alerts.tsx +3 -3
  175. package/src/lib/components/shared/animated-number.tsx +2 -2
  176. package/src/lib/components/shared/asset/asset-focal-point-editor.tsx +19 -29
  177. package/src/lib/components/shared/asset/asset-gallery.tsx +18 -23
  178. package/src/lib/components/shared/asset/asset-picker-dialog.tsx +66 -63
  179. package/src/lib/components/shared/asset/asset-preview-dialog.tsx +7 -3
  180. package/src/lib/components/shared/asset/asset-preview-selector.tsx +6 -4
  181. package/src/lib/components/shared/asset/asset-preview.tsx +15 -7
  182. package/src/lib/components/shared/asset/asset-properties.tsx +9 -7
  183. package/src/lib/components/shared/asset/focal-point-control.tsx +13 -5
  184. package/src/lib/components/shared/assigned-facet-values.tsx +5 -1
  185. package/src/lib/components/shared/channel-code-label.tsx +4 -3
  186. package/src/lib/components/shared/channel-selector.tsx +6 -6
  187. package/src/lib/components/shared/configurable-operation-arg-input.tsx +2 -2
  188. package/src/lib/components/shared/configurable-operation-input.tsx +16 -15
  189. package/src/lib/components/shared/confirmation-dialog.tsx +2 -2
  190. package/src/lib/components/shared/copyable-text.tsx +3 -2
  191. package/src/lib/components/shared/country-selector.tsx +18 -21
  192. package/src/lib/components/shared/currency-selector.tsx +5 -5
  193. package/src/lib/components/shared/custom-fields-form.tsx +51 -253
  194. package/src/lib/components/shared/customer-address-form.tsx +13 -18
  195. package/src/lib/components/shared/customer-group-selector.tsx +6 -6
  196. package/src/lib/components/shared/customer-selector.tsx +18 -24
  197. package/src/lib/components/shared/detail-page-button.tsx +1 -3
  198. package/src/lib/components/shared/entity-assets.tsx +34 -33
  199. package/src/lib/components/shared/error-page.tsx +6 -6
  200. package/src/lib/components/shared/facet-value-chip.tsx +5 -12
  201. package/src/lib/components/shared/facet-value-selector.tsx +63 -64
  202. package/src/lib/components/shared/form-field-wrapper.tsx +13 -22
  203. package/src/lib/components/shared/history-timeline/history-entry.tsx +6 -12
  204. package/src/lib/components/shared/history-timeline/history-note-checkbox.tsx +3 -3
  205. package/src/lib/components/shared/history-timeline/history-note-editor.tsx +4 -4
  206. package/src/lib/components/shared/history-timeline/history-note-input.tsx +3 -3
  207. package/src/lib/components/shared/history-timeline/history-timeline.tsx +8 -15
  208. package/src/lib/components/shared/language-selector.tsx +5 -5
  209. package/src/lib/components/shared/logo-mark.tsx +2 -2
  210. package/src/lib/components/shared/multi-select.tsx +5 -5
  211. package/src/lib/components/shared/navigation-confirmation.tsx +9 -24
  212. package/src/lib/components/shared/option-value-input.tsx +15 -17
  213. package/src/lib/components/shared/paginated-list-data-table.tsx +24 -100
  214. package/src/lib/components/shared/permission-guard.tsx +4 -4
  215. package/src/lib/components/shared/product-variant-selector.tsx +31 -32
  216. package/src/lib/components/shared/role-code-label.tsx +6 -10
  217. package/src/lib/components/shared/role-selector.tsx +4 -4
  218. package/src/lib/components/shared/seller-selector.tsx +17 -21
  219. package/src/lib/components/shared/stock-level-label.tsx +5 -5
  220. package/src/lib/components/shared/tax-category-selector.tsx +5 -5
  221. package/src/lib/components/shared/translatable-form-field.tsx +10 -5
  222. package/src/lib/components/shared/vendure-image.tsx +2 -31
  223. package/src/lib/components/shared/zone-selector.tsx +6 -5
  224. package/src/lib/components/ui/accordion.tsx +3 -3
  225. package/src/lib/components/ui/alert-dialog.tsx +10 -10
  226. package/src/lib/components/ui/alert.tsx +3 -3
  227. package/src/lib/components/ui/badge.tsx +2 -2
  228. package/src/lib/components/ui/breadcrumb.tsx +4 -4
  229. package/src/lib/components/ui/button.tsx +3 -10
  230. package/src/lib/components/ui/calendar.tsx +459 -392
  231. package/src/lib/components/ui/card.tsx +2 -2
  232. package/src/lib/components/ui/checkbox.tsx +2 -2
  233. package/src/lib/components/ui/command.tsx +6 -12
  234. package/src/lib/components/ui/dialog.tsx +2 -2
  235. package/src/lib/components/ui/dropdown-menu.tsx +7 -7
  236. package/src/lib/components/ui/form.tsx +4 -4
  237. package/src/lib/components/ui/hover-card.tsx +3 -3
  238. package/src/lib/components/ui/input.tsx +1 -1
  239. package/src/lib/components/ui/label.tsx +2 -2
  240. package/src/lib/components/ui/pagination.tsx +108 -87
  241. package/src/lib/components/ui/popover.tsx +3 -3
  242. package/src/lib/components/ui/scroll-area.tsx +2 -2
  243. package/src/lib/components/ui/select.tsx +129 -151
  244. package/src/lib/components/ui/separator.tsx +2 -2
  245. package/src/lib/components/ui/sheet.tsx +5 -5
  246. package/src/lib/components/ui/sidebar.tsx +10 -10
  247. package/src/lib/components/ui/skeleton.tsx +1 -1
  248. package/src/lib/components/ui/switch.tsx +2 -2
  249. package/src/lib/components/ui/table.tsx +2 -2
  250. package/src/lib/components/ui/tabs.tsx +3 -3
  251. package/src/lib/components/ui/textarea.tsx +1 -1
  252. package/src/lib/components/ui/tooltip.tsx +3 -3
  253. package/src/lib/framework/alert/alert-extensions.tsx +3 -2
  254. package/src/lib/framework/alert/alert-item.tsx +3 -5
  255. package/src/lib/framework/alert/types.ts +13 -0
  256. package/src/lib/framework/component-registry/component-registry.tsx +47 -33
  257. package/src/lib/framework/dashboard-widget/base-widget.tsx +13 -5
  258. package/src/lib/framework/dashboard-widget/latest-orders-widget/index.tsx +8 -8
  259. package/src/lib/framework/dashboard-widget/latest-orders-widget/latest-orders-widget.graphql.ts +1 -1
  260. package/src/lib/framework/dashboard-widget/metrics-widget/index.tsx +7 -6
  261. package/src/lib/framework/dashboard-widget/metrics-widget/metrics-widget.graphql.ts +1 -1
  262. package/src/lib/framework/dashboard-widget/orders-summary/index.tsx +6 -7
  263. package/src/lib/framework/dashboard-widget/orders-summary/order-summary-widget.graphql.ts +1 -1
  264. package/src/lib/framework/dashboard-widget/types.ts +22 -0
  265. package/src/lib/framework/dashboard-widget/widget-extensions.tsx +1 -1
  266. package/src/lib/framework/defaults.ts +1 -1
  267. package/src/lib/framework/document-introspection/add-custom-fields.ts +2 -50
  268. package/src/lib/framework/document-introspection/get-document-structure.ts +10 -43
  269. package/src/lib/framework/document-introspection/hooks.ts +1 -4
  270. package/src/lib/framework/extension-api/define-dashboard-extension.ts +49 -31
  271. package/src/lib/framework/extension-api/extension-api-types.ts +98 -25
  272. package/src/lib/framework/extension-api/use-dashboard-extensions.ts +1 -2
  273. package/src/lib/framework/form-engine/form-schema-tools.ts +1 -1
  274. package/src/lib/framework/form-engine/use-generated-form.tsx +18 -57
  275. package/src/lib/framework/layout-engine/location-wrapper.tsx +8 -11
  276. package/src/lib/framework/layout-engine/page-layout.tsx +48 -66
  277. package/src/lib/framework/page/detail-page-route-loader.tsx +7 -26
  278. package/src/lib/framework/page/detail-page.tsx +37 -122
  279. package/src/lib/framework/page/list-page.tsx +11 -9
  280. package/src/lib/framework/page/use-detail-page.ts +7 -38
  281. package/src/lib/framework/page/use-extended-router.tsx +5 -4
  282. package/src/lib/framework/registry/registry-types.ts +5 -15
  283. package/src/lib/graphql/{fragments.ts → fragments.tsx} +2 -1
  284. package/src/lib/graphql/graphql-env.d.ts +13 -16
  285. package/src/lib/hooks/use-auth.tsx +1 -1
  286. package/src/lib/hooks/use-channel.ts +1 -1
  287. package/src/lib/hooks/use-grouped-permissions.ts +2 -3
  288. package/src/lib/hooks/use-page.tsx +2 -2
  289. package/src/lib/hooks/use-permissions.ts +2 -3
  290. package/src/lib/hooks/use-server-config.ts +1 -1
  291. package/src/lib/hooks/use-theme.ts +1 -1
  292. package/src/lib/hooks/use-user-settings.tsx +1 -1
  293. package/src/lib/index.ts +6 -65
  294. package/src/lib/lib/trans.tsx +3 -3
  295. package/src/lib/lib/utils.ts +0 -49
  296. package/src/lib/providers/auth.tsx +14 -37
  297. package/src/lib/providers/channel-provider.tsx +4 -4
  298. package/src/lib/providers/server-config.tsx +11 -13
  299. package/src/lib/providers/theme-provider.tsx +3 -2
  300. package/vite/utils/config-loader.ts +10 -120
  301. package/vite/vite-plugin-config-loader.ts +1 -6
  302. package/vite/vite-plugin-config.ts +7 -6
  303. package/vite/vite-plugin-dashboard-metadata.ts +9 -1
  304. package/vite/vite-plugin-vendure-dashboard.ts +4 -48
  305. package/dist/plugin/tests/barrel-exports/my-plugin/index.d.ts +0 -1
  306. package/dist/plugin/tests/barrel-exports/my-plugin/index.js +0 -17
  307. package/dist/plugin/tests/barrel-exports/my-plugin/src/my.plugin.d.ts +0 -2
  308. package/dist/plugin/tests/barrel-exports/my-plugin/src/my.plugin.js +0 -20
  309. package/dist/plugin/tests/barrel-exports/vendure-config.d.ts +0 -2
  310. package/dist/plugin/tests/barrel-exports/vendure-config.js +0 -19
  311. package/dist/plugin/tests/barrel-exports.spec.d.ts +0 -1
  312. package/dist/plugin/tests/barrel-exports.spec.js +0 -14
  313. package/dist/plugin/vite-plugin-tailwind-source.d.ts +0 -7
  314. package/dist/plugin/vite-plugin-tailwind-source.js +0 -49
  315. package/src/app/common/delete-bulk-action.tsx +0 -148
  316. package/src/app/common/duplicate-bulk-action.tsx +0 -134
  317. package/src/app/routes/_authenticated/_administrators/components/administrator-bulk-actions.tsx +0 -15
  318. package/src/app/routes/_authenticated/_assets/components/asset-bulk-actions.tsx +0 -45
  319. package/src/app/routes/_authenticated/_channels/components/channel-bulk-actions.tsx +0 -15
  320. package/src/app/routes/_authenticated/_collections/components/collection-bulk-actions.tsx +0 -123
  321. package/src/app/routes/_authenticated/_collections/components/move-collections-dialog.tsx +0 -430
  322. package/src/app/routes/_authenticated/_collections/components/move-single-collection.tsx +0 -33
  323. package/src/app/routes/_authenticated/_countries/components/country-bulk-actions.tsx +0 -15
  324. package/src/app/routes/_authenticated/_customer-groups/components/customer-group-bulk-actions.tsx +0 -15
  325. package/src/app/routes/_authenticated/_customers/components/customer-bulk-actions.tsx +0 -15
  326. package/src/app/routes/_authenticated/_facets/components/facet-bulk-actions.tsx +0 -104
  327. package/src/app/routes/_authenticated/_orders/components/add-manual-payment-dialog.tsx +0 -191
  328. package/src/app/routes/_authenticated/_orders/components/fulfill-order-dialog.tsx +0 -320
  329. package/src/app/routes/_authenticated/_orders/components/fulfillment-details.tsx +0 -173
  330. package/src/app/routes/_authenticated/_orders/utils/order-types.ts +0 -7
  331. package/src/app/routes/_authenticated/_orders/utils/order-utils.ts +0 -77
  332. package/src/app/routes/_authenticated/_payment-methods/components/payment-method-bulk-actions.tsx +0 -58
  333. package/src/app/routes/_authenticated/_product-variants/components/product-variant-bulk-actions.tsx +0 -110
  334. package/src/app/routes/_authenticated/_products/components/assign-facet-values-dialog.tsx +0 -281
  335. package/src/app/routes/_authenticated/_products/components/product-bulk-actions.tsx +0 -123
  336. package/src/app/routes/_authenticated/_promotions/components/promotion-bulk-actions.tsx +0 -82
  337. package/src/app/routes/_authenticated/_roles/components/role-bulk-actions.tsx +0 -15
  338. package/src/app/routes/_authenticated/_sellers/components/seller-bulk-actions.tsx +0 -15
  339. package/src/app/routes/_authenticated/_shipping-methods/components/shipping-method-bulk-actions.tsx +0 -61
  340. package/src/app/routes/_authenticated/_stock-locations/components/stock-location-bulk-actions.tsx +0 -58
  341. package/src/app/routes/_authenticated/_tax-categories/components/tax-category-bulk-actions.tsx +0 -15
  342. package/src/app/routes/_authenticated/_tax-rates/components/tax-rate-bulk-actions.tsx +0 -15
  343. package/src/app/routes/_authenticated/_zones/components/zone-bulk-actions.tsx +0 -15
  344. package/src/lib/components/data-input/index.ts +0 -11
  345. package/src/lib/components/data-input/relation-input.tsx +0 -153
  346. package/src/lib/components/data-input/relation-selector.tsx +0 -468
  347. package/src/lib/components/data-table/data-table-bulk-action-item.tsx +0 -101
  348. package/src/lib/components/data-table/data-table-bulk-actions.tsx +0 -95
  349. package/src/lib/components/labeled-data.tsx +0 -21
  350. package/src/lib/components/shared/asset/asset-bulk-actions.tsx +0 -94
  351. package/src/lib/components/shared/assign-to-channel-bulk-action.tsx +0 -71
  352. package/src/lib/components/shared/assign-to-channel-dialog.tsx +0 -155
  353. package/src/lib/components/shared/remove-from-channel-bulk-action.tsx +0 -90
  354. package/src/lib/framework/data-table/data-table-extensions.ts +0 -35
  355. package/src/lib/framework/document-extension/extend-detail-form-query.ts +0 -50
  356. package/src/lib/framework/document-extension/extend-document.spec.ts +0 -884
  357. package/src/lib/framework/document-extension/extend-document.ts +0 -159
  358. package/src/lib/framework/extension-api/display-component-extensions.tsx +0 -69
  359. package/src/lib/framework/extension-api/input-component-extensions.tsx +0 -69
  360. package/src/lib/framework/extension-api/logic/alerts.ts +0 -10
  361. package/src/lib/framework/extension-api/logic/data-table.ts +0 -60
  362. package/src/lib/framework/extension-api/logic/detail-forms.ts +0 -48
  363. package/src/lib/framework/extension-api/logic/form-components.ts +0 -13
  364. package/src/lib/framework/extension-api/logic/index.ts +0 -8
  365. package/src/lib/framework/extension-api/logic/layout.ts +0 -22
  366. package/src/lib/framework/extension-api/logic/navigation.ts +0 -37
  367. package/src/lib/framework/extension-api/logic/widgets.ts +0 -10
  368. package/src/lib/framework/extension-api/types/alerts.ts +0 -54
  369. package/src/lib/framework/extension-api/types/data-table.ts +0 -87
  370. package/src/lib/framework/extension-api/types/detail-forms.ts +0 -81
  371. package/src/lib/framework/extension-api/types/form-components.ts +0 -32
  372. package/src/lib/framework/extension-api/types/index.ts +0 -8
  373. package/src/lib/framework/extension-api/types/layout.ts +0 -78
  374. package/src/lib/framework/extension-api/types/navigation.ts +0 -19
  375. package/src/lib/framework/extension-api/types/widgets.ts +0 -97
  376. package/src/lib/framework/form-engine/custom-form-component-extensions.ts +0 -38
  377. package/src/lib/framework/form-engine/custom-form-component.tsx +0 -33
  378. package/src/lib/framework/form-engine/utils.ts +0 -58
  379. package/src/lib/framework/layout-engine/page-block-provider.tsx +0 -6
  380. package/src/lib/graphql/common-operations.ts +0 -18
  381. package/src/lib/hooks/use-extended-detail-query.ts +0 -37
  382. package/src/lib/hooks/use-extended-list-query.ts +0 -73
  383. package/src/lib/hooks/use-page-block.tsx +0 -10
  384. package/vite/tests/barrel-exports/my-plugin/index.ts +0 -1
  385. package/vite/tests/barrel-exports/my-plugin/src/my.plugin.ts +0 -8
  386. package/vite/tests/barrel-exports/package.json +0 -6
  387. package/vite/tests/barrel-exports/vendure-config.ts +0 -19
  388. package/vite/tests/barrel-exports.spec.ts +0 -21
  389. package/vite/vite-plugin-tailwind-source.ts +0 -65
  390. /package/src/lib/components/data-table/{types.ts → data-table-types.ts} +0 -0
@@ -1,7 +0,0 @@
1
- import { ResultOf } from '@/vdb/graphql/graphql.js';
2
-
3
- import { orderDetailDocument } from '../orders.graphql.js';
4
-
5
- export type Order = NonNullable<ResultOf<typeof orderDetailDocument>['order']>;
6
- export type Payment = NonNullable<NonNullable<Order>['payments']>[number];
7
- export type Fulfillment = NonNullable<NonNullable<Order>['fulfillments']>[number];
@@ -1,77 +0,0 @@
1
- import { Fulfillment, Order, Payment } from './order-types.js';
2
-
3
- /**
4
- * Calculates the outstanding payment amount for an order
5
- */
6
- export function calculateOutstandingPaymentAmount(order: Order): number {
7
- if (!order) return 0;
8
-
9
- const paymentIsValid = (p: Payment): boolean =>
10
- p.state !== 'Cancelled' && p.state !== 'Declined' && p.state !== 'Error';
11
-
12
- let amountCovered = 0;
13
- for (const payment of order.payments?.filter(paymentIsValid) ?? []) {
14
- const refunds = payment.refunds.filter(r => r.state !== 'Failed') ?? [];
15
- const refundsTotal = refunds.reduce((sum, refund) => sum + (refund.total || 0), 0);
16
- amountCovered += payment.amount - refundsTotal;
17
- }
18
- return order.totalWithTax - amountCovered;
19
- }
20
-
21
- /**
22
- * Checks if an order has unsettled modifications
23
- */
24
- export function hasUnsettledModifications(order: Order): boolean {
25
- if (!order) return false;
26
- return order.modifications.some(m => !m.isSettled);
27
- }
28
-
29
- /**
30
- * Determines if the add manual payment button should be displayed
31
- */
32
- export function shouldShowAddManualPaymentButton(order: Order): boolean {
33
- if (!order) return false;
34
-
35
- return (
36
- order.type !== 'Aggregate' &&
37
- (order.state === 'ArrangingPayment' || order.state === 'ArrangingAdditionalPayment') &&
38
- (hasUnsettledModifications(order) || calculateOutstandingPaymentAmount(order) > 0)
39
- );
40
- }
41
-
42
- /**
43
- * Determines if we can add a fulfillment to an order
44
- */
45
- export function canAddFulfillment(order: Order): boolean {
46
- if (!order) return false;
47
-
48
- // Get all fulfillment lines from non-cancelled fulfillments
49
- const allFulfillmentLines: Fulfillment['lines'] = (order.fulfillments ?? [])
50
- .filter(fulfillment => fulfillment.state !== 'Cancelled')
51
- .reduce((all, fulfillment) => [...all, ...fulfillment.lines], [] as Fulfillment['lines']);
52
-
53
- // Check if all items are already fulfilled
54
- let allItemsFulfilled = true;
55
- for (const line of order.lines) {
56
- const totalFulfilledCount = allFulfillmentLines
57
- .filter(row => row.orderLineId === line.id)
58
- .reduce((sum, row) => sum + row.quantity, 0);
59
- if (totalFulfilledCount < line.quantity) {
60
- allItemsFulfilled = false;
61
- break;
62
- }
63
- }
64
-
65
- // Check if order is in a fulfillable state
66
- const isFulfillableState =
67
- order.nextStates.includes('Shipped') ||
68
- order.nextStates.includes('PartiallyShipped') ||
69
- order.nextStates.includes('Delivered');
70
-
71
- return (
72
- !allItemsFulfilled &&
73
- !hasUnsettledModifications(order) &&
74
- calculateOutstandingPaymentAmount(order) === 0 &&
75
- isFulfillableState
76
- );
77
- }
@@ -1,58 +0,0 @@
1
- import { AssignToChannelBulkAction } from '@/vdb/components/shared/assign-to-channel-bulk-action.js';
2
- import { RemoveFromChannelBulkAction } from '@/vdb/components/shared/remove-from-channel-bulk-action.js';
3
- import { BulkActionComponent } from '@/vdb/framework/extension-api/types/data-table.js';
4
- import { api } from '@/vdb/graphql/api.js';
5
- import { useChannel } from '@/vdb/hooks/use-channel.js';
6
- import { DeleteBulkAction } from '../../../../common/delete-bulk-action.js';
7
-
8
- import {
9
- assignPaymentMethodsToChannelDocument,
10
- deletePaymentMethodsDocument,
11
- removePaymentMethodsFromChannelDocument,
12
- } from '../payment-methods.graphql.js';
13
-
14
- export const DeletePaymentMethodsBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
15
- return (
16
- <DeleteBulkAction
17
- mutationDocument={deletePaymentMethodsDocument}
18
- entityName="payment methods"
19
- requiredPermissions={['DeletePaymentMethod']}
20
- selection={selection}
21
- table={table}
22
- />
23
- );
24
- };
25
-
26
- export const AssignPaymentMethodsToChannelBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
27
- return (
28
- <AssignToChannelBulkAction
29
- selection={selection}
30
- table={table}
31
- entityType="payment methods"
32
- mutationFn={api.mutate(assignPaymentMethodsToChannelDocument)}
33
- requiredPermissions={['UpdatePaymentMethod']}
34
- buildInput={(channelId: string) => ({
35
- paymentMethodIds: selection.map(s => s.id),
36
- channelId,
37
- })}
38
- />
39
- );
40
- };
41
-
42
- export const RemovePaymentMethodsFromChannelBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
43
- const { selectedChannel } = useChannel();
44
-
45
- return (
46
- <RemoveFromChannelBulkAction
47
- selection={selection}
48
- table={table}
49
- entityType="payment methods"
50
- mutationFn={api.mutate(removePaymentMethodsFromChannelDocument)}
51
- requiredPermissions={['UpdatePaymentMethod']}
52
- buildInput={() => ({
53
- paymentMethodIds: selection.map(s => s.id),
54
- channelId: selectedChannel?.id,
55
- })}
56
- />
57
- );
58
- };
@@ -1,110 +0,0 @@
1
- import { TagIcon } from 'lucide-react';
2
- import { useState } from 'react';
3
-
4
- import { DataTableBulkActionItem } from '@/vdb/components/data-table/data-table-bulk-action-item.js';
5
- import { AssignToChannelBulkAction } from '@/vdb/components/shared/assign-to-channel-bulk-action.js';
6
- import { usePriceFactor } from '@/vdb/components/shared/assign-to-channel-dialog.js';
7
- import { RemoveFromChannelBulkAction } from '@/vdb/components/shared/remove-from-channel-bulk-action.js';
8
- import { api } from '@/vdb/graphql/api.js';
9
- import { BulkActionComponent } from '@/vdb/framework/extension-api/types/data-table.js';
10
- import { useChannel } from '@/vdb/hooks/use-channel.js';
11
- import { usePaginatedList } from '@/vdb/components/shared/paginated-list-data-table.js';
12
- import { Trans } from '@/vdb/lib/trans.js';
13
- import { DeleteBulkAction } from '../../../../common/delete-bulk-action.js';
14
-
15
- import { AssignFacetValuesDialog } from '../../_products/components/assign-facet-values-dialog.js';
16
- import {
17
- assignProductVariantsToChannelDocument,
18
- deleteProductVariantsDocument,
19
- getProductVariantsWithFacetValuesByIdsDocument,
20
- productVariantDetailDocument,
21
- removeProductVariantsFromChannelDocument,
22
- updateProductVariantsDocument,
23
- } from '../product-variants.graphql.js';
24
-
25
- export const DeleteProductVariantsBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
26
- return (
27
- <DeleteBulkAction
28
- mutationDocument={deleteProductVariantsDocument}
29
- entityName="product variants"
30
- requiredPermissions={['DeleteCatalog', 'DeleteProduct']}
31
- selection={selection}
32
- table={table}
33
- />
34
- );
35
- };
36
-
37
- export const AssignProductVariantsToChannelBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
38
- const { priceFactor, priceFactorField } = usePriceFactor();
39
-
40
- return (
41
- <AssignToChannelBulkAction
42
- selection={selection}
43
- table={table}
44
- entityType="variants"
45
- mutationFn={api.mutate(assignProductVariantsToChannelDocument)}
46
- requiredPermissions={['UpdateCatalog', 'UpdateProduct']}
47
- buildInput={(channelId: string) => ({
48
- productVariantIds: selection.map(s => s.id),
49
- channelId,
50
- priceFactor,
51
- })}
52
- additionalFields={priceFactorField}
53
- />
54
- );
55
- };
56
-
57
- export const RemoveProductVariantsFromChannelBulkAction: BulkActionComponent<any> = ({
58
- selection,
59
- table,
60
- }) => {
61
- const { selectedChannel } = useChannel();
62
-
63
- return (
64
- <RemoveFromChannelBulkAction
65
- selection={selection}
66
- table={table}
67
- entityType="product variants"
68
- mutationFn={api.mutate(removeProductVariantsFromChannelDocument)}
69
- requiredPermissions={['UpdateCatalog', 'UpdateProduct']}
70
- buildInput={() => ({
71
- productVariantIds: selection.map(s => s.id),
72
- channelId: selectedChannel?.id,
73
- })}
74
- />
75
- );
76
- };
77
-
78
- export const AssignFacetValuesToProductVariantsBulkAction: BulkActionComponent<any> = ({
79
- selection,
80
- table,
81
- }) => {
82
- const { refetchPaginatedList } = usePaginatedList();
83
- const [dialogOpen, setDialogOpen] = useState(false);
84
-
85
- const handleSuccess = () => {
86
- refetchPaginatedList();
87
- table.resetRowSelection();
88
- };
89
-
90
- return (
91
- <>
92
- <DataTableBulkActionItem
93
- requiresPermission={['UpdateCatalog', 'UpdateProduct']}
94
- onClick={() => setDialogOpen(true)}
95
- label={<Trans>Edit facet values</Trans>}
96
- icon={TagIcon}
97
- />
98
- <AssignFacetValuesDialog
99
- open={dialogOpen}
100
- onOpenChange={setDialogOpen}
101
- entityIds={selection.map(s => s.id)}
102
- entityType="variants"
103
- queryFn={variables => api.query(getProductVariantsWithFacetValuesByIdsDocument, variables)}
104
- mutationFn={api.mutate(updateProductVariantsDocument)}
105
- detailDocument={productVariantDetailDocument}
106
- onSuccess={handleSuccess}
107
- />
108
- </>
109
- );
110
- };
@@ -1,281 +0,0 @@
1
- import { useMutation, useQuery, useQueryClient } from '@tanstack/react-query';
2
- import { useState } from 'react';
3
- import { toast } from 'sonner';
4
-
5
- import { FacetValueChip } from '@/vdb/components/shared/facet-value-chip.js';
6
- import { FacetValue, FacetValueSelector } from '@/vdb/components/shared/facet-value-selector.js';
7
- import { Button } from '@/vdb/components/ui/button.js';
8
- import {
9
- Dialog,
10
- DialogContent,
11
- DialogDescription,
12
- DialogFooter,
13
- DialogHeader,
14
- DialogTitle,
15
- } from '@/vdb/components/ui/dialog.js';
16
- import { ResultOf } from '@/vdb/graphql/graphql.js';
17
- import { Trans, useLingui } from '@/vdb/lib/trans.js';
18
-
19
- import { getDetailQueryOptions } from '@/vdb/framework/page/use-detail-page.js';
20
-
21
- interface EntityWithFacetValues {
22
- id: string;
23
- name: string;
24
- sku?: string;
25
- facetValues: Array<{
26
- id: string;
27
- name: string;
28
- code: string;
29
- facet: {
30
- id: string;
31
- name: string;
32
- code: string;
33
- };
34
- }>;
35
- }
36
-
37
- interface AssignFacetValuesDialogProps {
38
- open: boolean;
39
- onOpenChange: (open: boolean) => void;
40
- entityIds: string[];
41
- entityType: 'products' | 'variants';
42
- queryFn: (variables: any) => Promise<ResultOf<any>>;
43
- mutationFn: (variables: any) => Promise<ResultOf<any>>;
44
- detailDocument: any;
45
- onSuccess?: () => void;
46
- }
47
-
48
- export function AssignFacetValuesDialog({
49
- open,
50
- onOpenChange,
51
- entityIds,
52
- entityType,
53
- queryFn,
54
- mutationFn,
55
- detailDocument,
56
- onSuccess,
57
- }: AssignFacetValuesDialogProps) {
58
- const { i18n } = useLingui();
59
- const [selectedValues, setSelectedValues] = useState<FacetValue[]>([]);
60
- const [facetValuesRemoved, setFacetValuesRemoved] = useState(false);
61
- const [removedFacetValues, setRemovedFacetValues] = useState<Set<string>>(new Set());
62
- const queryClient = useQueryClient();
63
-
64
- // Fetch existing facet values for the entities
65
- const { data: entitiesData, isLoading } = useQuery({
66
- queryKey: [`${entityType}WithFacetValues`, entityIds],
67
- queryFn: () => queryFn({ ids: entityIds }),
68
- enabled: open && entityIds.length > 0,
69
- });
70
-
71
- const { mutate, isPending } = useMutation({
72
- mutationFn,
73
- onSuccess: () => {
74
- toast.success(i18n.t(`Successfully updated facet values for ${entityIds.length} ${entityType}`));
75
- onSuccess?.();
76
- onOpenChange(false);
77
- // Reset state
78
- setSelectedValues([]);
79
- setFacetValuesRemoved(false);
80
- setRemovedFacetValues(new Set());
81
- entityIds.forEach(id => {
82
- const { queryKey } = getDetailQueryOptions(detailDocument, { id });
83
- queryClient.removeQueries({ queryKey });
84
- });
85
- },
86
- onError: () => {
87
- toast.error(`Failed to update facet values for ${entityIds.length} ${entityType}`);
88
- },
89
- });
90
-
91
- const handleAssign = () => {
92
- if (selectedValues.length === 0 && !facetValuesRemoved) {
93
- toast.error('Please select at least one facet value or make changes to existing ones');
94
- return;
95
- }
96
-
97
- const items =
98
- entityType === 'products'
99
- ? (entitiesData as any)?.products?.items
100
- : (entitiesData as any)?.productVariants?.items;
101
-
102
- if (!items) {
103
- return;
104
- }
105
-
106
- const selectedFacetValueIds = selectedValues.map(sv => sv.id);
107
-
108
- mutate({
109
- input: items.map((entity: EntityWithFacetValues) => ({
110
- id: entity.id,
111
- facetValueIds: [
112
- ...new Set([
113
- ...entity.facetValues
114
- .filter((fv: any) => !removedFacetValues.has(fv.id))
115
- .map((fv: any) => fv.id),
116
- ...selectedFacetValueIds,
117
- ]),
118
- ],
119
- })),
120
- });
121
- };
122
-
123
- const handleFacetValueSelect = (facetValue: FacetValue) => {
124
- setSelectedValues(prev => [...prev, facetValue]);
125
- };
126
-
127
- const removeFacetValue = (entityId: string, facetValueId: string) => {
128
- setRemovedFacetValues(prev => new Set([...prev, facetValueId]));
129
- setFacetValuesRemoved(true);
130
- };
131
-
132
- const handleCancel = () => {
133
- onOpenChange(false);
134
- // Reset state
135
- setSelectedValues([]);
136
- setFacetValuesRemoved(false);
137
- setRemovedFacetValues(new Set());
138
- };
139
-
140
- // Filter out removed facet values for display
141
- const getDisplayFacetValues = (entity: EntityWithFacetValues) => {
142
- return entity.facetValues.filter(fv => !removedFacetValues.has(fv.id));
143
- };
144
-
145
- const items =
146
- entityType === 'products'
147
- ? (entitiesData as any)?.products?.items
148
- : (entitiesData as any)?.productVariants?.items;
149
-
150
- return (
151
- <Dialog open={open} onOpenChange={onOpenChange}>
152
- <DialogContent className="sm:max-w-[800px] max-h-[80vh] overflow-hidden flex flex-col">
153
- <DialogHeader>
154
- <DialogTitle>
155
- <Trans>Edit facet values</Trans>
156
- </DialogTitle>
157
- <DialogDescription>
158
- <Trans>
159
- Add or remove facet values for {entityIds.length} {entityType}
160
- </Trans>
161
- </DialogDescription>
162
- </DialogHeader>
163
-
164
- <div className="flex-1 overflow-hidden flex flex-col gap-4">
165
- {/* Add new facet values section */}
166
- <div className="flex items-center gap-2">
167
- <div className="text-sm font-medium">
168
- <Trans>Add facet value</Trans>
169
- </div>
170
- <FacetValueSelector
171
- onValueSelect={handleFacetValueSelect}
172
- placeholder="Search facet values..."
173
- />
174
- </div>
175
-
176
- {/* Entities table */}
177
- <div className="flex-1 overflow-auto">
178
- {isLoading ? (
179
- <div className="flex items-center justify-center py-8">
180
- <div className="text-sm text-muted-foreground">Loading...</div>
181
- </div>
182
- ) : items ? (
183
- <div className="border rounded-md">
184
- <table className="w-full">
185
- <thead className="bg-muted/50">
186
- <tr>
187
- <th className="text-left p-3 text-sm font-medium">
188
- <Trans>
189
- {entityType === 'products' ? 'Product' : 'Variant'}
190
- </Trans>
191
- </th>
192
- {entityType === 'variants' && (
193
- <th className="text-left p-3 text-sm font-medium">
194
- <Trans>SKU</Trans>
195
- </th>
196
- )}
197
- <th className="text-left p-3 text-sm font-medium">
198
- <Trans>Current facet values</Trans>
199
- </th>
200
- </tr>
201
- </thead>
202
- <tbody>
203
- {items.map((entity: EntityWithFacetValues) => {
204
- const displayFacetValues = getDisplayFacetValues(entity);
205
- return (
206
- <tr key={entity.id} className="border-t">
207
- <td className="p-3 align-top">
208
- <div className="font-medium">{entity.name}</div>
209
- </td>
210
- {entityType === 'variants' && (
211
- <td className="p-3 align-top">
212
- <div className="text-sm text-muted-foreground">
213
- {entity.sku}
214
- </div>
215
- </td>
216
- )}
217
- <td className="p-3">
218
- <div className="flex flex-wrap gap-2">
219
- {displayFacetValues.map(facetValue => (
220
- <FacetValueChip
221
- key={facetValue.id}
222
- facetValue={facetValue}
223
- removable={true}
224
- onRemove={() =>
225
- removeFacetValue(
226
- entity.id,
227
- facetValue.id,
228
- )
229
- }
230
- />
231
- ))}
232
- {displayFacetValues.length === 0 && (
233
- <div className="text-sm text-muted-foreground">
234
- <Trans>No facet values</Trans>
235
- </div>
236
- )}
237
- </div>
238
- </td>
239
- </tr>
240
- );
241
- })}
242
- </tbody>
243
- </table>
244
- </div>
245
- ) : null}
246
- </div>
247
-
248
- {/* Selected values summary */}
249
- {selectedValues.length > 0 && (
250
- <div className="border-t pt-4">
251
- <div className="text-sm font-medium mb-2">
252
- <Trans>New facet values to add:</Trans>
253
- </div>
254
- <div className="flex flex-wrap gap-2">
255
- {selectedValues.map(facetValue => (
256
- <FacetValueChip
257
- key={facetValue.id}
258
- facetValue={facetValue}
259
- removable={false}
260
- />
261
- ))}
262
- </div>
263
- </div>
264
- )}
265
- </div>
266
-
267
- <DialogFooter>
268
- <Button variant="outline" onClick={handleCancel}>
269
- <Trans>Cancel</Trans>
270
- </Button>
271
- <Button
272
- onClick={handleAssign}
273
- disabled={(selectedValues.length === 0 && !facetValuesRemoved) || isPending}
274
- >
275
- <Trans>Update</Trans>
276
- </Button>
277
- </DialogFooter>
278
- </DialogContent>
279
- </Dialog>
280
- );
281
- }
@@ -1,123 +0,0 @@
1
- import { TagIcon } from 'lucide-react';
2
- import { useState } from 'react';
3
-
4
- import { DataTableBulkActionItem } from '@/vdb/components/data-table/data-table-bulk-action-item.js';
5
- import { AssignToChannelBulkAction } from '@/vdb/components/shared/assign-to-channel-bulk-action.js';
6
- import { usePriceFactor } from '@/vdb/components/shared/assign-to-channel-dialog.js';
7
- import { usePaginatedList } from '@/vdb/components/shared/paginated-list-data-table.js';
8
- import { RemoveFromChannelBulkAction } from '@/vdb/components/shared/remove-from-channel-bulk-action.js';
9
- import { BulkActionComponent } from '@/vdb/framework/extension-api/types/data-table.js';
10
- import { api } from '@/vdb/graphql/api.js';
11
- import { useChannel } from '@/vdb/hooks/use-channel.js';
12
- import { Trans } from '@/vdb/lib/trans.js';
13
- import { DeleteBulkAction } from '../../../../common/delete-bulk-action.js';
14
- import { DuplicateBulkAction } from '../../../../common/duplicate-bulk-action.js';
15
- import {
16
- assignProductsToChannelDocument,
17
- deleteProductsDocument,
18
- getProductsWithFacetValuesByIdsDocument,
19
- productDetailDocument,
20
- removeProductsFromChannelDocument,
21
- updateProductsDocument,
22
- } from '../products.graphql.js';
23
- import { AssignFacetValuesDialog } from './assign-facet-values-dialog.js';
24
-
25
- export const DeleteProductsBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
26
- return (
27
- <DeleteBulkAction
28
- mutationDocument={deleteProductsDocument}
29
- entityName="products"
30
- requiredPermissions={['DeleteCatalog', 'DeleteProduct']}
31
- selection={selection}
32
- table={table}
33
- />
34
- );
35
- };
36
-
37
- export const AssignProductsToChannelBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
38
- const { priceFactor, priceFactorField } = usePriceFactor();
39
-
40
- return (
41
- <AssignToChannelBulkAction
42
- selection={selection}
43
- table={table}
44
- entityType="products"
45
- mutationFn={api.mutate(assignProductsToChannelDocument)}
46
- requiredPermissions={['UpdateCatalog', 'UpdateProduct']}
47
- buildInput={(channelId: string) => ({
48
- productIds: selection.map(s => s.id),
49
- channelId,
50
- priceFactor,
51
- })}
52
- additionalFields={priceFactorField}
53
- />
54
- );
55
- };
56
-
57
- export const RemoveProductsFromChannelBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
58
- const { selectedChannel } = useChannel();
59
-
60
- return (
61
- <RemoveFromChannelBulkAction
62
- selection={selection}
63
- table={table}
64
- entityType="products"
65
- mutationFn={api.mutate(removeProductsFromChannelDocument)}
66
- requiredPermissions={['UpdateCatalog', 'UpdateProduct']}
67
- buildInput={() => ({
68
- productIds: selection.map(s => s.id),
69
- channelId: selectedChannel?.id,
70
- })}
71
- />
72
- );
73
- };
74
-
75
- export const AssignFacetValuesToProductsBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
76
- const { refetchPaginatedList } = usePaginatedList();
77
- const [dialogOpen, setDialogOpen] = useState(false);
78
-
79
- const handleSuccess = () => {
80
- refetchPaginatedList();
81
- table.resetRowSelection();
82
- };
83
-
84
- return (
85
- <>
86
- <DataTableBulkActionItem
87
- requiresPermission={['UpdateCatalog', 'UpdateProduct']}
88
- onClick={() => setDialogOpen(true)}
89
- label={<Trans>Edit facet values</Trans>}
90
- icon={TagIcon}
91
- />
92
- <AssignFacetValuesDialog
93
- open={dialogOpen}
94
- onOpenChange={setDialogOpen}
95
- entityIds={selection.map(s => s.id)}
96
- entityType="products"
97
- queryFn={variables => api.query(getProductsWithFacetValuesByIdsDocument, variables)}
98
- mutationFn={api.mutate(updateProductsDocument)}
99
- detailDocument={productDetailDocument}
100
- onSuccess={handleSuccess}
101
- />
102
- </>
103
- );
104
- };
105
-
106
- export const DuplicateProductsBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
107
- return (
108
- <DuplicateBulkAction
109
- entityType="Product"
110
- duplicatorCode="product-duplicator"
111
- duplicatorArguments={[
112
- {
113
- name: 'includeVariants',
114
- value: 'true',
115
- },
116
- ]}
117
- requiredPermissions={['UpdateCatalog', 'UpdateProduct']}
118
- entityName="Product"
119
- selection={selection}
120
- table={table}
121
- />
122
- );
123
- };