@vendure/dashboard 3.3.6-master-202507020959 → 3.3.6-master-202507030234
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +41 -4
- package/dist/plugin/vite-plugin-config.js +5 -7
- package/package.json +4 -4
- package/src/app/app-providers.tsx +6 -6
- package/src/app/common/delete-bulk-action.tsx +4 -4
- package/src/app/common/duplicate-bulk-action.tsx +5 -5
- package/src/app/main.tsx +9 -9
- package/src/app/routes/__root.tsx +1 -2
- package/src/app/routes/_authenticated/_administrators/administrators.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_administrators/administrators.tsx +8 -8
- package/src/app/routes/_authenticated/_administrators/administrators_.$id.tsx +11 -11
- package/src/app/routes/_authenticated/_administrators/components/administrator-bulk-actions.tsx +1 -1
- package/src/app/routes/_authenticated/_administrators/components/role-permissions-display.tsx +16 -16
- package/src/app/routes/_authenticated/_assets/assets.graphql.ts +2 -2
- package/src/app/routes/_authenticated/_assets/assets.tsx +12 -8
- package/src/app/routes/_authenticated/_assets/assets_.$id.tsx +14 -14
- package/src/app/routes/_authenticated/_assets/components/asset-bulk-actions.tsx +5 -5
- package/src/app/routes/_authenticated/_channels/channels.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_channels/channels.tsx +10 -10
- package/src/app/routes/_authenticated/_channels/channels_.$id.tsx +16 -16
- package/src/app/routes/_authenticated/_channels/components/channel-bulk-actions.tsx +1 -1
- package/src/app/routes/_authenticated/_collections/collections.graphql.ts +3 -3
- package/src/app/routes/_authenticated/_collections/collections.tsx +7 -7
- package/src/app/routes/_authenticated/_collections/collections_.$id.tsx +15 -15
- package/src/app/routes/_authenticated/_collections/components/collection-bulk-actions.tsx +4 -5
- package/src/app/routes/_authenticated/_collections/components/collection-contents-preview-table.tsx +7 -8
- package/src/app/routes/_authenticated/_collections/components/collection-contents-sheet.tsx +9 -5
- package/src/app/routes/_authenticated/_collections/components/collection-contents-table.tsx +10 -9
- package/src/app/routes/_authenticated/_collections/components/collection-filters-selector.tsx +7 -7
- package/src/app/routes/_authenticated/_countries/components/country-bulk-actions.tsx +1 -1
- package/src/app/routes/_authenticated/_countries/countries.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_countries/countries.tsx +6 -6
- package/src/app/routes/_authenticated/_countries/countries_.$id.tsx +12 -12
- package/src/app/routes/_authenticated/_customer-groups/components/customer-group-bulk-actions.tsx +1 -1
- package/src/app/routes/_authenticated/_customer-groups/components/customer-group-members-sheet.tsx +12 -5
- package/src/app/routes/_authenticated/_customer-groups/components/customer-group-members-table.tsx +22 -17
- package/src/app/routes/_authenticated/_customer-groups/customer-groups.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_customer-groups/customer-groups.tsx +6 -6
- package/src/app/routes/_authenticated/_customer-groups/customer-groups_.$id.tsx +10 -10
- package/src/app/routes/_authenticated/_customers/components/customer-address-card.tsx +19 -19
- package/src/app/routes/_authenticated/_customers/components/customer-address-form.tsx +10 -10
- package/src/app/routes/_authenticated/_customers/components/customer-bulk-actions.tsx +1 -1
- package/src/app/routes/_authenticated/_customers/components/customer-history/customer-history-container.tsx +5 -5
- package/src/app/routes/_authenticated/_customers/components/customer-history/customer-history.tsx +11 -7
- package/src/app/routes/_authenticated/_customers/components/customer-history/use-customer-history.ts +4 -4
- package/src/app/routes/_authenticated/_customers/components/customer-order-table.tsx +75 -73
- package/src/app/routes/_authenticated/_customers/components/customer-status-badge.tsx +4 -4
- package/src/app/routes/_authenticated/_customers/customers.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_customers/customers.tsx +6 -6
- package/src/app/routes/_authenticated/_customers/customers_.$id.tsx +14 -14
- package/src/app/routes/_authenticated/_facets/components/edit-facet-value.tsx +9 -9
- package/src/app/routes/_authenticated/_facets/components/facet-bulk-actions.tsx +6 -7
- package/src/app/routes/_authenticated/_facets/components/facet-values-sheet.tsx +4 -4
- package/src/app/routes/_authenticated/_facets/components/facet-values-table.tsx +15 -11
- package/src/app/routes/_authenticated/_facets/facets.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_facets/facets.tsx +7 -7
- package/src/app/routes/_authenticated/_facets/facets_.$id.tsx +12 -12
- package/src/app/routes/_authenticated/_global-settings/global-settings.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_global-settings/global-settings.tsx +12 -12
- package/src/app/routes/_authenticated/_orders/components/customer-address-selector.tsx +11 -14
- package/src/app/routes/_authenticated/_orders/components/edit-order-table.tsx +92 -54
- package/src/app/routes/_authenticated/_orders/components/money-gross-net.tsx +11 -9
- package/src/app/routes/_authenticated/_orders/components/order-address.tsx +3 -4
- package/src/app/routes/_authenticated/_orders/components/order-history/order-history-container.tsx +67 -62
- package/src/app/routes/_authenticated/_orders/components/order-history/order-history.tsx +11 -6
- package/src/app/routes/_authenticated/_orders/components/order-history/use-order-history.ts +4 -4
- package/src/app/routes/_authenticated/_orders/components/order-line-custom-fields-form.tsx +11 -7
- package/src/app/routes/_authenticated/_orders/components/order-table-totals.tsx +39 -19
- package/src/app/routes/_authenticated/_orders/components/order-table.tsx +4 -4
- package/src/app/routes/_authenticated/_orders/components/order-tax-summary.tsx +38 -36
- package/src/app/routes/_authenticated/_orders/components/payment-details.tsx +4 -4
- package/src/app/routes/_authenticated/_orders/components/shipping-method-selector.tsx +43 -44
- package/src/app/routes/_authenticated/_orders/orders.graphql.ts +2 -2
- package/src/app/routes/_authenticated/_orders/orders.tsx +21 -20
- package/src/app/routes/_authenticated/_orders/orders_.$id.tsx +9 -9
- package/src/app/routes/_authenticated/_orders/orders_.draft.$id.tsx +188 -90
- package/src/app/routes/_authenticated/_payment-methods/components/payment-eligibility-checker-selector.tsx +10 -7
- package/src/app/routes/_authenticated/_payment-methods/components/payment-handler-selector.tsx +11 -11
- package/src/app/routes/_authenticated/_payment-methods/components/payment-method-bulk-actions.tsx +4 -5
- package/src/app/routes/_authenticated/_payment-methods/payment-methods.graphql.ts +2 -2
- package/src/app/routes/_authenticated/_payment-methods/payment-methods.tsx +7 -7
- package/src/app/routes/_authenticated/_payment-methods/payment-methods_.$id.tsx +13 -13
- package/src/app/routes/_authenticated/_product-variants/components/product-variant-bulk-actions.tsx +7 -8
- package/src/app/routes/_authenticated/_product-variants/components/variant-price-detail.tsx +7 -6
- package/src/app/routes/_authenticated/_product-variants/product-variants.graphql.ts +2 -2
- package/src/app/routes/_authenticated/_product-variants/product-variants.tsx +6 -6
- package/src/app/routes/_authenticated/_product-variants/product-variants_.$id.tsx +19 -19
- package/src/app/routes/_authenticated/_products/components/add-product-variant-dialog.tsx +10 -10
- package/src/app/routes/_authenticated/_products/components/assign-facet-values-dialog.tsx +7 -7
- package/src/app/routes/_authenticated/_products/components/create-product-options-dialog.tsx +57 -41
- package/src/app/routes/_authenticated/_products/components/create-product-variants-dialog.tsx +11 -11
- package/src/app/routes/_authenticated/_products/components/create-product-variants.tsx +18 -14
- package/src/app/routes/_authenticated/_products/components/option-value-input.tsx +21 -15
- package/src/app/routes/_authenticated/_products/components/product-bulk-actions.tsx +7 -8
- package/src/app/routes/_authenticated/_products/components/product-option-select.tsx +28 -34
- package/src/app/routes/_authenticated/_products/components/product-variants-table.tsx +6 -6
- package/src/app/routes/_authenticated/_products/products.graphql.ts +2 -2
- package/src/app/routes/_authenticated/_products/products.tsx +6 -6
- package/src/app/routes/_authenticated/_products/products_.$id.tsx +16 -16
- package/src/app/routes/_authenticated/_profile/profile.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_profile/profile.tsx +8 -8
- package/src/app/routes/_authenticated/_promotions/components/promotion-actions-selector.tsx +14 -11
- package/src/app/routes/_authenticated/_promotions/components/promotion-bulk-actions.tsx +4 -5
- package/src/app/routes/_authenticated/_promotions/components/promotion-conditions-selector.tsx +14 -11
- package/src/app/routes/_authenticated/_promotions/promotions.graphql.ts +2 -2
- package/src/app/routes/_authenticated/_promotions/promotions.tsx +7 -7
- package/src/app/routes/_authenticated/_promotions/promotions_.$id.tsx +14 -14
- package/src/app/routes/_authenticated/_roles/components/expandable-permissions.tsx +5 -5
- package/src/app/routes/_authenticated/_roles/components/permissions-grid.tsx +21 -17
- package/src/app/routes/_authenticated/_roles/components/role-bulk-actions.tsx +1 -1
- package/src/app/routes/_authenticated/_roles/roles.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_roles/roles.tsx +10 -10
- package/src/app/routes/_authenticated/_roles/roles_.$id.tsx +11 -11
- package/src/app/routes/_authenticated/_sellers/components/seller-bulk-actions.tsx +1 -1
- package/src/app/routes/_authenticated/_sellers/sellers.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_sellers/sellers.tsx +7 -7
- package/src/app/routes/_authenticated/_sellers/sellers_.$id.tsx +10 -10
- package/src/app/routes/_authenticated/_shipping-methods/components/fulfillment-handler-selector.tsx +6 -6
- package/src/app/routes/_authenticated/_shipping-methods/components/shipping-calculator-selector.tsx +23 -21
- package/src/app/routes/_authenticated/_shipping-methods/components/shipping-eligibility-checker-selector.tsx +25 -21
- package/src/app/routes/_authenticated/_shipping-methods/components/shipping-method-bulk-actions.tsx +4 -5
- package/src/app/routes/_authenticated/_shipping-methods/components/test-shipping-method-dialog.tsx +3 -3
- package/src/app/routes/_authenticated/_shipping-methods/shipping-methods.graphql.ts +2 -2
- package/src/app/routes/_authenticated/_shipping-methods/shipping-methods.tsx +6 -6
- package/src/app/routes/_authenticated/_shipping-methods/shipping-methods_.$id.tsx +12 -12
- package/src/app/routes/_authenticated/_stock-locations/components/stock-location-bulk-actions.tsx +4 -5
- package/src/app/routes/_authenticated/_stock-locations/stock-locations.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_stock-locations/stock-locations.tsx +6 -6
- package/src/app/routes/_authenticated/_stock-locations/stock-locations_.$id.tsx +11 -11
- package/src/app/routes/_authenticated/_system/components/payload-dialog.tsx +4 -4
- package/src/app/routes/_authenticated/_system/healthchecks.tsx +4 -4
- package/src/app/routes/_authenticated/_system/job-queue.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_system/job-queue.tsx +10 -6
- package/src/app/routes/_authenticated/_system/scheduled-tasks.tsx +34 -28
- package/src/app/routes/_authenticated/_tax-categories/components/tax-category-bulk-actions.tsx +1 -1
- package/src/app/routes/_authenticated/_tax-categories/tax-categories.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_tax-categories/tax-categories.tsx +7 -7
- package/src/app/routes/_authenticated/_tax-categories/tax-categories_.$id.tsx +11 -11
- package/src/app/routes/_authenticated/_tax-rates/components/tax-rate-bulk-actions.tsx +1 -1
- package/src/app/routes/_authenticated/_tax-rates/tax-rates.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_tax-rates/tax-rates.tsx +8 -8
- package/src/app/routes/_authenticated/_tax-rates/tax-rates_.$id.tsx +14 -14
- package/src/app/routes/_authenticated/_zones/components/zone-bulk-actions.tsx +1 -1
- package/src/app/routes/_authenticated/_zones/components/zone-countries-sheet.tsx +4 -4
- package/src/app/routes/_authenticated/_zones/components/zone-countries-table.tsx +12 -8
- package/src/app/routes/_authenticated/_zones/zones.graphql.ts +1 -1
- package/src/app/routes/_authenticated/_zones/zones.tsx +6 -6
- package/src/app/routes/_authenticated/_zones/zones_.$id.tsx +10 -10
- package/src/app/routes/_authenticated/index.tsx +4 -4
- package/src/app/routes/_authenticated.tsx +3 -3
- package/src/app/routes/login.tsx +2 -2
- package/src/lib/components/data-display/boolean.tsx +1 -1
- package/src/lib/components/data-display/date-time.tsx +2 -2
- package/src/lib/components/data-display/json.tsx +1 -1
- package/src/lib/components/data-display/money.tsx +2 -3
- package/src/lib/components/data-input/affixed-input.tsx +3 -8
- package/src/lib/components/data-input/customer-group-input.tsx +2 -2
- package/src/lib/components/data-input/datetime-input.tsx +129 -146
- package/src/lib/components/data-input/facet-value-input.tsx +30 -22
- package/src/lib/components/data-input/money-input.tsx +3 -3
- package/src/lib/components/data-input/richt-text-input.tsx +1 -1
- package/src/lib/components/data-table/add-filter-menu.tsx +9 -18
- package/src/lib/components/data-table/data-table-bulk-action-item.tsx +3 -3
- package/src/lib/components/data-table/data-table-bulk-actions.tsx +7 -7
- package/src/lib/components/data-table/data-table-column-header.tsx +4 -22
- package/src/lib/components/data-table/data-table-faceted-filter.tsx +8 -8
- package/src/lib/components/data-table/data-table-filter-badge.tsx +1 -1
- package/src/lib/components/data-table/data-table-filter-dialog.tsx +4 -4
- package/src/lib/components/data-table/data-table-pagination.tsx +2 -2
- package/src/lib/components/data-table/data-table-view-options.tsx +25 -21
- package/src/lib/components/data-table/data-table.tsx +8 -8
- package/src/lib/components/data-table/filters/data-table-boolean-filter.tsx +11 -8
- package/src/lib/components/data-table/filters/data-table-datetime-filter.tsx +14 -23
- package/src/lib/components/data-table/filters/data-table-id-filter.tsx +15 -10
- package/src/lib/components/data-table/filters/data-table-number-filter.tsx +18 -17
- package/src/lib/components/data-table/filters/data-table-string-filter.tsx +29 -12
- package/src/lib/components/data-table/human-readable-operator.tsx +1 -1
- package/src/lib/components/data-table/refresh-button.tsx +5 -2
- package/src/lib/components/layout/app-layout.tsx +8 -8
- package/src/lib/components/layout/app-sidebar.tsx +5 -5
- package/src/lib/components/layout/channel-switcher.tsx +8 -8
- package/src/lib/components/layout/content-language-selector.tsx +16 -10
- package/src/lib/components/layout/generated-breadcrumbs.tsx +1 -1
- package/src/lib/components/layout/language-dialog.tsx +5 -11
- package/src/lib/components/layout/nav-main.tsx +4 -4
- package/src/lib/components/layout/nav-projects.tsx +2 -2
- package/src/lib/components/layout/nav-user.tsx +7 -7
- package/src/lib/components/layout/prerelease-popup.tsx +1 -1
- package/src/lib/components/login/login-form.tsx +5 -5
- package/src/lib/components/shared/alerts.tsx +3 -3
- package/src/lib/components/shared/animated-number.tsx +2 -2
- package/src/lib/components/shared/asset/asset-bulk-actions.tsx +12 -8
- package/src/lib/components/shared/asset/asset-focal-point-editor.tsx +29 -19
- package/src/lib/components/shared/asset/asset-gallery.tsx +12 -12
- package/src/lib/components/shared/asset/asset-picker-dialog.tsx +63 -66
- package/src/lib/components/shared/asset/asset-preview-dialog.tsx +3 -7
- package/src/lib/components/shared/asset/asset-preview-selector.tsx +4 -6
- package/src/lib/components/shared/asset/asset-preview.tsx +7 -15
- package/src/lib/components/shared/asset/asset-properties.tsx +7 -9
- package/src/lib/components/shared/asset/focal-point-control.tsx +5 -13
- package/src/lib/components/shared/assign-to-channel-bulk-action.tsx +4 -4
- package/src/lib/components/shared/assign-to-channel-dialog.tsx +8 -8
- package/src/lib/components/shared/channel-code-label.tsx +3 -4
- package/src/lib/components/shared/channel-selector.tsx +6 -6
- package/src/lib/components/shared/configurable-operation-arg-input.tsx +2 -2
- package/src/lib/components/shared/configurable-operation-input.tsx +15 -16
- package/src/lib/components/shared/confirmation-dialog.tsx +2 -2
- package/src/lib/components/shared/copyable-text.tsx +2 -3
- package/src/lib/components/shared/country-selector.tsx +21 -18
- package/src/lib/components/shared/currency-selector.tsx +5 -5
- package/src/lib/components/shared/custom-fields-form.tsx +9 -9
- package/src/lib/components/shared/customer-address-form.tsx +3 -3
- package/src/lib/components/shared/customer-group-selector.tsx +6 -6
- package/src/lib/components/shared/customer-selector.tsx +24 -18
- package/src/lib/components/shared/entity-assets.tsx +33 -34
- package/src/lib/components/shared/error-page.tsx +6 -6
- package/src/lib/components/shared/facet-value-chip.tsx +12 -5
- package/src/lib/components/shared/facet-value-selector.tsx +64 -63
- package/src/lib/components/shared/history-timeline/history-entry.tsx +12 -6
- package/src/lib/components/shared/history-timeline/history-note-checkbox.tsx +3 -3
- package/src/lib/components/shared/history-timeline/history-note-editor.tsx +4 -4
- package/src/lib/components/shared/history-timeline/history-note-input.tsx +3 -3
- package/src/lib/components/shared/history-timeline/history-timeline.tsx +15 -8
- package/src/lib/components/shared/language-selector.tsx +5 -5
- package/src/lib/components/shared/multi-select.tsx +5 -5
- package/src/lib/components/shared/navigation-confirmation.tsx +24 -9
- package/src/lib/components/shared/option-value-input.tsx +17 -15
- package/src/lib/components/shared/paginated-list-data-table.tsx +12 -12
- package/src/lib/components/shared/permission-guard.tsx +4 -4
- package/src/lib/components/shared/product-variant-selector.tsx +32 -31
- package/src/lib/components/shared/remove-from-channel-bulk-action.tsx +4 -4
- package/src/lib/components/shared/role-code-label.tsx +10 -6
- package/src/lib/components/shared/role-selector.tsx +4 -4
- package/src/lib/components/shared/seller-selector.tsx +21 -17
- package/src/lib/components/shared/stock-level-label.tsx +5 -5
- package/src/lib/components/shared/tax-category-selector.tsx +5 -5
- package/src/lib/components/shared/translatable-form-field.tsx +1 -1
- package/src/lib/components/shared/vendure-image.tsx +1 -1
- package/src/lib/components/shared/zone-selector.tsx +5 -6
- package/src/lib/components/ui/accordion.tsx +3 -3
- package/src/lib/components/ui/alert-dialog.tsx +10 -10
- package/src/lib/components/ui/alert.tsx +3 -3
- package/src/lib/components/ui/badge.tsx +2 -2
- package/src/lib/components/ui/breadcrumb.tsx +4 -4
- package/src/lib/components/ui/button.tsx +10 -3
- package/src/lib/components/ui/calendar.tsx +392 -459
- package/src/lib/components/ui/card.tsx +2 -2
- package/src/lib/components/ui/checkbox.tsx +2 -2
- package/src/lib/components/ui/command.tsx +12 -6
- package/src/lib/components/ui/dialog.tsx +2 -2
- package/src/lib/components/ui/dropdown-menu.tsx +7 -7
- package/src/lib/components/ui/form.tsx +4 -4
- package/src/lib/components/ui/hover-card.tsx +3 -3
- package/src/lib/components/ui/input.tsx +1 -1
- package/src/lib/components/ui/label.tsx +2 -2
- package/src/lib/components/ui/pagination.tsx +87 -108
- package/src/lib/components/ui/popover.tsx +3 -3
- package/src/lib/components/ui/scroll-area.tsx +2 -2
- package/src/lib/components/ui/select.tsx +2 -2
- package/src/lib/components/ui/separator.tsx +2 -2
- package/src/lib/components/ui/sheet.tsx +5 -5
- package/src/lib/components/ui/sidebar.tsx +10 -10
- package/src/lib/components/ui/skeleton.tsx +1 -1
- package/src/lib/components/ui/switch.tsx +2 -2
- package/src/lib/components/ui/table.tsx +2 -2
- package/src/lib/components/ui/tabs.tsx +3 -3
- package/src/lib/components/ui/textarea.tsx +1 -1
- package/src/lib/components/ui/tooltip.tsx +3 -3
- package/src/lib/framework/alert/alert-extensions.tsx +2 -3
- package/src/lib/framework/alert/alert-item.tsx +5 -3
- package/src/lib/framework/dashboard-widget/base-widget.tsx +5 -13
- package/src/lib/framework/dashboard-widget/latest-orders-widget/index.tsx +7 -8
- package/src/lib/framework/dashboard-widget/latest-orders-widget/latest-orders-widget.graphql.ts +1 -1
- package/src/lib/framework/dashboard-widget/metrics-widget/index.tsx +6 -7
- package/src/lib/framework/dashboard-widget/metrics-widget/metrics-widget.graphql.ts +1 -1
- package/src/lib/framework/dashboard-widget/orders-summary/index.tsx +6 -6
- package/src/lib/framework/dashboard-widget/orders-summary/order-summary-widget.graphql.ts +1 -1
- package/src/lib/framework/dashboard-widget/widget-extensions.tsx +1 -1
- package/src/lib/framework/data-table/data-table-extensions.ts +1 -1
- package/src/lib/framework/defaults.ts +1 -1
- package/src/lib/framework/document-extension/extend-detail-form-query.ts +2 -2
- package/src/lib/framework/document-extension/extend-document.spec.ts +1 -1
- package/src/lib/framework/document-extension/extend-document.ts +1 -1
- package/src/lib/framework/document-introspection/add-custom-fields.ts +2 -2
- package/src/lib/framework/document-introspection/hooks.ts +4 -1
- package/src/lib/framework/extension-api/display-component-extensions.tsx +4 -4
- package/src/lib/framework/extension-api/extension-api-types.ts +0 -3
- package/src/lib/framework/extension-api/input-component-extensions.tsx +5 -5
- package/src/lib/framework/extension-api/logic/detail-forms.ts +1 -1
- package/src/lib/framework/extension-api/types/data-table.ts +25 -2
- package/src/lib/framework/extension-api/types/detail-forms.ts +1 -1
- package/src/lib/framework/extension-api/types/widgets.ts +7 -4
- package/src/lib/framework/form-engine/form-schema-tools.ts +1 -1
- package/src/lib/framework/layout-engine/location-wrapper.tsx +11 -8
- package/src/lib/framework/layout-engine/page-block-provider.tsx +1 -1
- package/src/lib/framework/layout-engine/page-layout.tsx +26 -19
- package/src/lib/framework/page/detail-page-route-loader.tsx +3 -3
- package/src/lib/framework/page/detail-page.tsx +9 -9
- package/src/lib/framework/page/list-page.tsx +3 -3
- package/src/lib/framework/page/use-detail-page.ts +1 -1
- package/src/lib/framework/registry/registry-types.ts +7 -7
- package/src/lib/hooks/use-auth.tsx +1 -1
- package/src/lib/hooks/use-channel.ts +1 -2
- package/src/lib/hooks/use-extended-detail-query.ts +2 -3
- package/src/lib/hooks/use-extended-list-query.ts +3 -4
- package/src/lib/hooks/use-grouped-permissions.ts +1 -2
- package/src/lib/hooks/use-page-block.tsx +1 -1
- package/src/lib/hooks/use-page.tsx +1 -1
- package/src/lib/hooks/use-server-config.ts +1 -2
- package/src/lib/hooks/use-theme.ts +1 -2
- package/src/lib/hooks/use-user-settings.tsx +1 -1
- package/src/lib/index.ts +26 -6
- package/src/lib/lib/trans.tsx +3 -3
- package/src/lib/providers/auth.tsx +4 -4
- package/src/lib/providers/channel-provider.tsx +4 -4
- package/src/lib/providers/server-config.tsx +13 -11
- package/src/lib/providers/theme-provider.tsx +2 -3
- package/vite/vite-plugin-config.ts +5 -7
- package/src/lib/framework/alert/types.ts +0 -13
- package/src/lib/framework/dashboard-widget/types.ts +0 -22
- package/src/lib/framework/data-table/data-table-types.ts +0 -25
package/README.md
CHANGED
|
@@ -1,13 +1,50 @@
|
|
|
1
1
|
# Vendure Dashboard
|
|
2
2
|
|
|
3
|
-
This is
|
|
4
|
-
|
|
5
|
-
Current status: early work in progress
|
|
3
|
+
This is a React-based admin dashboard for Vendure. It is a standalone application that can be extended to suit the
|
|
4
|
+
needs of any Vendure project.
|
|
6
5
|
|
|
7
6
|
## Development
|
|
8
7
|
|
|
9
8
|
Run `npx vite` to start Vite in dev mode.
|
|
10
9
|
|
|
10
|
+
### Note on internal `@/vdb` imports
|
|
11
|
+
|
|
12
|
+
You will notice that the dashboard uses internal Vendure Dashboard imports prefixed with `@/vdb`. This is adapted from the
|
|
13
|
+
convention of Shadcn which uses a `@/*` path alias for internal imports.
|
|
14
|
+
|
|
15
|
+
**Why not just use relative imports?**
|
|
16
|
+
|
|
17
|
+
The problem with using relative imports is that they are handled differently by Vite when compiling the dashboard. This
|
|
18
|
+
manifests as things like React Context not working correctly. The underlying reason is that Vite will selectively
|
|
19
|
+
pre-compile source code and mixing the imports between alias and relative can result in 2 "versions" of the same code
|
|
20
|
+
being loaded, which causes issues with React Context and other things that rely on a single instance of a module.
|
|
21
|
+
|
|
22
|
+
For this reason, try to use the `@/vdb` alias for all internal Vendure Dashboard imports to the "src/lib" directory.
|
|
23
|
+
|
|
24
|
+
This is especially import for hooks (since many of them use React Context) and there is even a pre-commit hook
|
|
25
|
+
that will run [a script](./scripts/check-internal-imports.js) to ensure that you are not using relative imports for
|
|
26
|
+
internal Vendure Dashboard code.
|
|
27
|
+
|
|
28
|
+
**Type Safety for Consumers**
|
|
29
|
+
|
|
30
|
+
Because we ship source code in the npm package, consumers need to tell TypeScript how to resolve these internal
|
|
31
|
+
imports by adding the path alias to _their_ `tsconfig.json` file.
|
|
32
|
+
|
|
33
|
+
```json
|
|
34
|
+
{
|
|
35
|
+
"compilerOptions": {
|
|
36
|
+
"paths": {
|
|
37
|
+
"@/vdb/*": [
|
|
38
|
+
"./node_modules/@vendure/dashboard/src/lib/*"
|
|
39
|
+
]
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
Note: even without that path alias, the vite compilation will still work, but TypeScript types will not resolve correctly
|
|
46
|
+
when developing dashboard extensions.
|
|
47
|
+
|
|
11
48
|
## Testing
|
|
12
49
|
|
|
13
|
-
Run `npm run test` to run tests once, or `npx vitest` to run tests in watch mode
|
|
50
|
+
Run `npm run test` to run tests once, or `npx vitest` to run tests in watch mode
|
|
@@ -7,7 +7,7 @@ export function viteConfigPlugin({ packageRoot }) {
|
|
|
7
7
|
// Only set the vite `root` to the dashboard package when running the dev server.
|
|
8
8
|
// During a production build we still need to reference the dashboard source which
|
|
9
9
|
// lives in `node_modules`, but we don't want the build output to be emitted in there.
|
|
10
|
-
// Therefore we set `root` only for `serve` and, for `build`, we instead make sure that
|
|
10
|
+
// Therefore, we set `root` only for `serve` and, for `build`, we instead make sure that
|
|
11
11
|
// an `outDir` **outside** of `node_modules` is used (defaulting to the current working
|
|
12
12
|
// directory if the user did not provide one already).
|
|
13
13
|
config.root = packageRoot;
|
|
@@ -26,18 +26,16 @@ export function viteConfigPlugin({ packageRoot }) {
|
|
|
26
26
|
config.build = Object.assign(Object.assign({}, buildConfig), { outDir: normalizedOutDir });
|
|
27
27
|
}
|
|
28
28
|
config.resolve = {
|
|
29
|
-
alias: Object.assign(Object.assign({}, ((_c = (_b = config.resolve) === null || _b === void 0 ? void 0 : _b.alias) !== null && _c !== void 0 ? _c : {})), {
|
|
29
|
+
alias: Object.assign(Object.assign({}, ((_c = (_b = config.resolve) === null || _b === void 0 ? void 0 : _b.alias) !== null && _c !== void 0 ? _c : {})), {
|
|
30
|
+
// See the readme for an explanation of this alias.
|
|
31
|
+
'@/vdb': path.resolve(packageRoot, './src/lib'), '@/graphql': path.resolve(packageRoot, './src/lib/graphql') }),
|
|
30
32
|
};
|
|
31
33
|
// This is required to prevent Vite from pre-bundling the
|
|
32
34
|
// dashboard source when it resides in node_modules.
|
|
33
35
|
config.optimizeDeps = Object.assign(Object.assign({}, config.optimizeDeps), { exclude: [
|
|
34
36
|
...(((_d = config.optimizeDeps) === null || _d === void 0 ? void 0 : _d.exclude) || []),
|
|
35
37
|
'@vendure/dashboard',
|
|
36
|
-
'@/
|
|
37
|
-
'@/framework',
|
|
38
|
-
'@/lib',
|
|
39
|
-
'@/components',
|
|
40
|
-
'@/hooks',
|
|
38
|
+
'@/vdb',
|
|
41
39
|
'virtual:vendure-ui-config',
|
|
42
40
|
'virtual:admin-api-schema',
|
|
43
41
|
'virtual:dashboard-extensions',
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@vendure/dashboard",
|
|
3
3
|
"private": false,
|
|
4
|
-
"version": "3.3.6-master-
|
|
4
|
+
"version": "3.3.6-master-202507030234",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -86,8 +86,8 @@
|
|
|
86
86
|
"@types/react-dom": "^19.0.4",
|
|
87
87
|
"@types/react-grid-layout": "^1.3.5",
|
|
88
88
|
"@uidotdev/usehooks": "^2.4.1",
|
|
89
|
-
"@vendure/common": "^3.3.6-master-
|
|
90
|
-
"@vendure/core": "^3.3.6-master-
|
|
89
|
+
"@vendure/common": "^3.3.6-master-202507030234",
|
|
90
|
+
"@vendure/core": "^3.3.6-master-202507030234",
|
|
91
91
|
"@vitejs/plugin-react": "^4.3.4",
|
|
92
92
|
"awesome-graphql-client": "^2.1.0",
|
|
93
93
|
"class-variance-authority": "^0.7.1",
|
|
@@ -130,5 +130,5 @@
|
|
|
130
130
|
"lightningcss-linux-arm64-musl": "^1.29.3",
|
|
131
131
|
"lightningcss-linux-x64-musl": "^1.29.1"
|
|
132
132
|
},
|
|
133
|
-
"gitHead": "
|
|
133
|
+
"gitHead": "ca527d7a89a9cff83d965e384e5f3d27c24efe82"
|
|
134
134
|
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { AuthProvider } from '@/providers/auth.js';
|
|
2
|
-
import { ChannelProvider } from '@/providers/channel-provider.js';
|
|
3
|
-
import { I18nProvider } from '@/providers/i18n-provider.js';
|
|
4
|
-
import { ServerConfigProvider } from '@/providers/server-config.js';
|
|
5
|
-
import { ThemeProvider } from '@/providers/theme-provider.js';
|
|
6
|
-
import { UserSettingsProvider } from '@/providers/user-settings.js';
|
|
1
|
+
import { AuthProvider } from '@/vdb/providers/auth.js';
|
|
2
|
+
import { ChannelProvider } from '@/vdb/providers/channel-provider.js';
|
|
3
|
+
import { I18nProvider } from '@/vdb/providers/i18n-provider.js';
|
|
4
|
+
import { ServerConfigProvider } from '@/vdb/providers/server-config.js';
|
|
5
|
+
import { ThemeProvider } from '@/vdb/providers/theme-provider.js';
|
|
6
|
+
import { UserSettingsProvider } from '@/vdb/providers/user-settings.js';
|
|
7
7
|
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
|
|
8
8
|
import { ReactQueryDevtools } from '@tanstack/react-query-devtools';
|
|
9
9
|
import React from 'react';
|
|
@@ -2,10 +2,10 @@ import { useMutation, useQueryClient } from '@tanstack/react-query';
|
|
|
2
2
|
import { TrashIcon } from 'lucide-react';
|
|
3
3
|
import { toast } from 'sonner';
|
|
4
4
|
|
|
5
|
-
import { DataTableBulkActionItem } from '@/components/data-table/data-table-bulk-action-item.js';
|
|
6
|
-
import { api } from '@/graphql/api.js';
|
|
7
|
-
import { getMutationName, usePaginatedList } from '@/index.js';
|
|
8
|
-
import { Trans, useLingui } from '@/lib/trans.js';
|
|
5
|
+
import { DataTableBulkActionItem } from '@/vdb/components/data-table/data-table-bulk-action-item.js';
|
|
6
|
+
import { api } from '@/vdb/graphql/api.js';
|
|
7
|
+
import { getMutationName, usePaginatedList } from '@/vdb/index.js';
|
|
8
|
+
import { Trans, useLingui } from '@/vdb/lib/trans.js';
|
|
9
9
|
|
|
10
10
|
interface DeleteBulkActionProps {
|
|
11
11
|
/** The GraphQL mutation document to execute */
|
|
@@ -3,11 +3,11 @@ import { CopyIcon } from 'lucide-react';
|
|
|
3
3
|
import { useState } from 'react';
|
|
4
4
|
import { toast } from 'sonner';
|
|
5
5
|
|
|
6
|
-
import { DataTableBulkActionItem } from '@/components/data-table/data-table-bulk-action-item.js';
|
|
7
|
-
import { api } from '@/graphql/api.js';
|
|
8
|
-
import { duplicateEntityDocument } from '@/graphql/common-operations.js';
|
|
9
|
-
import { usePaginatedList } from '@/index.js';
|
|
10
|
-
import { Trans, useLingui } from '@/lib/trans.js';
|
|
6
|
+
import { DataTableBulkActionItem } from '@/vdb/components/data-table/data-table-bulk-action-item.js';
|
|
7
|
+
import { api } from '@/vdb/graphql/api.js';
|
|
8
|
+
import { duplicateEntityDocument } from '@/vdb/graphql/common-operations.js';
|
|
9
|
+
import { usePaginatedList } from '@/vdb/index.js';
|
|
10
|
+
import { Trans, useLingui } from '@/vdb/lib/trans.js';
|
|
11
11
|
|
|
12
12
|
interface DuplicateBulkActionProps {
|
|
13
13
|
entityType: 'Product' | 'Collection' | 'Facet' | 'Promotion';
|
package/src/app/main.tsx
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { Toaster } from '@/components/ui/sonner.js';
|
|
2
|
-
import { registerDefaults } from '@/framework/defaults.js';
|
|
3
|
-
import { setCustomFieldsMap } from '@/framework/document-introspection/add-custom-fields.js';
|
|
4
|
-
import { executeDashboardExtensionCallbacks } from '@/framework/extension-api/define-dashboard-extension.js';
|
|
5
|
-
import { useDashboardExtensions } from '@/framework/extension-api/use-dashboard-extensions.js';
|
|
6
|
-
import { useExtendedRouter } from '@/framework/page/use-extended-router.js';
|
|
7
|
-
import { useAuth } from '@/hooks/use-auth.js';
|
|
8
|
-
import { useServerConfig } from '@/hooks/use-server-config.js';
|
|
9
|
-
import { defaultLocale, dynamicActivate } from '@/providers/i18n-provider.js';
|
|
1
|
+
import { Toaster } from '@/vdb/components/ui/sonner.js';
|
|
2
|
+
import { registerDefaults } from '@/vdb/framework/defaults.js';
|
|
3
|
+
import { setCustomFieldsMap } from '@/vdb/framework/document-introspection/add-custom-fields.js';
|
|
4
|
+
import { executeDashboardExtensionCallbacks } from '@/vdb/framework/extension-api/define-dashboard-extension.js';
|
|
5
|
+
import { useDashboardExtensions } from '@/vdb/framework/extension-api/use-dashboard-extensions.js';
|
|
6
|
+
import { useExtendedRouter } from '@/vdb/framework/page/use-extended-router.js';
|
|
7
|
+
import { useAuth } from '@/vdb/hooks/use-auth.js';
|
|
8
|
+
import { useServerConfig } from '@/vdb/hooks/use-server-config.js';
|
|
9
|
+
import { defaultLocale, dynamicActivate } from '@/vdb/providers/i18n-provider.js';
|
|
10
10
|
import { createRouter, RouterProvider } from '@tanstack/react-router';
|
|
11
11
|
import React, { useEffect } from 'react';
|
|
12
12
|
import ReactDOM from 'react-dom/client';
|
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import { AuthContext } from '@/providers/auth.js';
|
|
1
|
+
import { AuthContext } from '@/vdb/providers/auth.js';
|
|
2
2
|
import { QueryClient } from '@tanstack/react-query';
|
|
3
3
|
import { createRootRouteWithContext, Outlet } from '@tanstack/react-router';
|
|
4
|
-
import { TanStackRouterDevtools } from '@tanstack/router-devtools';
|
|
5
4
|
|
|
6
5
|
export interface MyRouterContext {
|
|
7
6
|
auth: AuthContext;
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { DetailPageButton } from '@/components/shared/detail-page-button.js';
|
|
2
|
-
import { PermissionGuard } from '@/components/shared/permission-guard.js';
|
|
3
|
-
import { RoleCodeLabel } from '@/components/shared/role-code-label.js';
|
|
4
|
-
import { Badge } from '@/components/ui/badge.js';
|
|
5
|
-
import { Button } from '@/components/ui/button.js';
|
|
6
|
-
import { PageActionBarRight } from '@/framework/layout-engine/page-layout.js';
|
|
7
|
-
import { ListPage } from '@/framework/page/list-page.js';
|
|
8
|
-
import { Trans } from '@/lib/trans.js';
|
|
1
|
+
import { DetailPageButton } from '@/vdb/components/shared/detail-page-button.js';
|
|
2
|
+
import { PermissionGuard } from '@/vdb/components/shared/permission-guard.js';
|
|
3
|
+
import { RoleCodeLabel } from '@/vdb/components/shared/role-code-label.js';
|
|
4
|
+
import { Badge } from '@/vdb/components/ui/badge.js';
|
|
5
|
+
import { Button } from '@/vdb/components/ui/button.js';
|
|
6
|
+
import { PageActionBarRight } from '@/vdb/framework/layout-engine/page-layout.js';
|
|
7
|
+
import { ListPage } from '@/vdb/framework/page/list-page.js';
|
|
8
|
+
import { Trans } from '@/vdb/lib/trans.js';
|
|
9
9
|
import { createFileRoute, Link } from '@tanstack/react-router';
|
|
10
10
|
import { PlusIcon } from 'lucide-react';
|
|
11
11
|
import { administratorListDocument, deleteAdministratorDocument } from './administrators.graphql.js';
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { ErrorPage } from '@/components/shared/error-page.js';
|
|
2
|
-
import { FormFieldWrapper } from '@/components/shared/form-field-wrapper.js';
|
|
3
|
-
import { PermissionGuard } from '@/components/shared/permission-guard.js';
|
|
4
|
-
import { RoleSelector } from '@/components/shared/role-selector.js';
|
|
5
|
-
import { Button } from '@/components/ui/button.js';
|
|
6
|
-
import { Input } from '@/components/ui/input.js';
|
|
7
|
-
import { NEW_ENTITY_PATH } from '@/constants.js';
|
|
1
|
+
import { ErrorPage } from '@/vdb/components/shared/error-page.js';
|
|
2
|
+
import { FormFieldWrapper } from '@/vdb/components/shared/form-field-wrapper.js';
|
|
3
|
+
import { PermissionGuard } from '@/vdb/components/shared/permission-guard.js';
|
|
4
|
+
import { RoleSelector } from '@/vdb/components/shared/role-selector.js';
|
|
5
|
+
import { Button } from '@/vdb/components/ui/button.js';
|
|
6
|
+
import { Input } from '@/vdb/components/ui/input.js';
|
|
7
|
+
import { NEW_ENTITY_PATH } from '@/vdb/constants.js';
|
|
8
8
|
import {
|
|
9
9
|
CustomFieldsPageBlock,
|
|
10
10
|
Page,
|
|
@@ -13,10 +13,10 @@ import {
|
|
|
13
13
|
PageBlock,
|
|
14
14
|
PageLayout,
|
|
15
15
|
PageTitle,
|
|
16
|
-
} from '@/framework/layout-engine/page-layout.js';
|
|
17
|
-
import { detailPageRouteLoader } from '@/framework/page/detail-page-route-loader.js';
|
|
18
|
-
import { useDetailPage } from '@/framework/page/use-detail-page.js';
|
|
19
|
-
import { Trans, useLingui } from '@/lib/trans.js';
|
|
16
|
+
} from '@/vdb/framework/layout-engine/page-layout.js';
|
|
17
|
+
import { detailPageRouteLoader } from '@/vdb/framework/page/detail-page-route-loader.js';
|
|
18
|
+
import { useDetailPage } from '@/vdb/framework/page/use-detail-page.js';
|
|
19
|
+
import { Trans, useLingui } from '@/vdb/lib/trans.js';
|
|
20
20
|
import { createFileRoute, useNavigate } from '@tanstack/react-router';
|
|
21
21
|
import { toast } from 'sonner';
|
|
22
22
|
import {
|
package/src/app/routes/_authenticated/_administrators/components/administrator-bulk-actions.tsx
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { BulkActionComponent } from '@/framework/
|
|
1
|
+
import { BulkActionComponent } from '@/vdb/framework/extension-api/types/index.js';
|
|
2
2
|
import { DeleteBulkAction } from '../../../../common/delete-bulk-action.js';
|
|
3
3
|
import { deleteAdministratorsDocument } from '../administrators.graphql.js';
|
|
4
4
|
|
package/src/app/routes/_authenticated/_administrators/components/role-permissions-display.tsx
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { ChannelCodeLabel } from '@/components/shared/channel-code-label.js';
|
|
2
|
-
import { Checkbox } from '@/components/ui/checkbox.js';
|
|
3
|
-
import { Tabs, TabsContent, TabsList, TabsTrigger } from '@/components/ui/tabs.js';
|
|
4
|
-
import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from '@/components/ui/tooltip.js';
|
|
5
|
-
import { api } from '@/graphql/api.js';
|
|
6
|
-
import { graphql } from '@/graphql/graphql.js';
|
|
7
|
-
import { useGroupedPermissions } from '@/hooks/use-grouped-permissions.js';
|
|
8
|
-
import { useLingui } from '@/lib/trans.js';
|
|
1
|
+
import { ChannelCodeLabel } from '@/vdb/components/shared/channel-code-label.js';
|
|
2
|
+
import { Checkbox } from '@/vdb/components/ui/checkbox.js';
|
|
3
|
+
import { Tabs, TabsContent, TabsList, TabsTrigger } from '@/vdb/components/ui/tabs.js';
|
|
4
|
+
import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from '@/vdb/components/ui/tooltip.js';
|
|
5
|
+
import { api } from '@/vdb/graphql/api.js';
|
|
6
|
+
import { graphql } from '@/vdb/graphql/graphql.js';
|
|
7
|
+
import { useGroupedPermissions } from '@/vdb/hooks/use-grouped-permissions.js';
|
|
8
|
+
import { useLingui } from '@/vdb/lib/trans.js';
|
|
9
9
|
import { useQuery } from '@tanstack/react-query';
|
|
10
10
|
|
|
11
11
|
const rolesByIdDocument = graphql(`
|
|
@@ -28,7 +28,7 @@ interface RolePermissionsDisplayProps {
|
|
|
28
28
|
value: string[];
|
|
29
29
|
}
|
|
30
30
|
|
|
31
|
-
export function RolePermissionsDisplay({ value = [] }: RolePermissionsDisplayProps) {
|
|
31
|
+
export function RolePermissionsDisplay({ value = [] }: Readonly<RolePermissionsDisplayProps>) {
|
|
32
32
|
const { i18n } = useLingui();
|
|
33
33
|
const groupedPermissions = useGroupedPermissions();
|
|
34
34
|
|
|
@@ -46,9 +46,9 @@ export function RolePermissionsDisplay({ value = [] }: RolePermissionsDisplayPro
|
|
|
46
46
|
|
|
47
47
|
const roles = data?.roles.items ?? [];
|
|
48
48
|
|
|
49
|
-
const allChannels = roles
|
|
50
|
-
|
|
51
|
-
|
|
49
|
+
const allChannels = roles
|
|
50
|
+
.flatMap(role => role.channels)
|
|
51
|
+
.filter((channel, index, self) => index === self.findIndex(t => t.code === channel.code));
|
|
52
52
|
|
|
53
53
|
const isPermissionEnabled = (permissionName: string, channelCode: string) => {
|
|
54
54
|
// Check if any role has this permission for this channel
|
|
@@ -87,7 +87,9 @@ export function RolePermissionsDisplay({ value = [] }: RolePermissionsDisplayPro
|
|
|
87
87
|
{groupedPermissions.map((group, idx) => (
|
|
88
88
|
<tr
|
|
89
89
|
key={group.label}
|
|
90
|
-
className={
|
|
90
|
+
className={
|
|
91
|
+
idx !== groupedPermissions.length - 1 ? 'border-b' : undefined
|
|
92
|
+
}
|
|
91
93
|
>
|
|
92
94
|
<td className="p-4">
|
|
93
95
|
<div className="grid grid-cols-2 md:grid-cols-4 gap-4">
|
|
@@ -106,9 +108,7 @@ export function RolePermissionsDisplay({ value = [] }: RolePermissionsDisplayPro
|
|
|
106
108
|
<TooltipProvider>
|
|
107
109
|
<Tooltip>
|
|
108
110
|
<TooltipTrigger asChild>
|
|
109
|
-
<label
|
|
110
|
-
className="text-sm cursor-default"
|
|
111
|
-
>
|
|
111
|
+
<label className="text-sm cursor-default">
|
|
112
112
|
{i18n.t(permission.name)}
|
|
113
113
|
</label>
|
|
114
114
|
</TooltipTrigger>
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { assetFragment } from '@/graphql/fragments.js';
|
|
2
|
-
import { graphql } from '@/graphql/graphql.js';
|
|
1
|
+
import { assetFragment } from '@/vdb/graphql/fragments.js';
|
|
2
|
+
import { graphql } from '@/vdb/graphql/graphql.js';
|
|
3
3
|
|
|
4
4
|
export const assetDetailDocument = graphql(
|
|
5
5
|
`
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { AssetGallery } from '@/components/shared/asset/asset-gallery.js';
|
|
2
|
-
import { Page, PageBlock, PageTitle } from '@/framework/layout-engine/page-layout.js';
|
|
3
|
-
import { Trans } from '@/lib/trans.js';
|
|
1
|
+
import { AssetGallery } from '@/vdb/components/shared/asset/asset-gallery.js';
|
|
2
|
+
import { Page, PageBlock, PageTitle } from '@/vdb/framework/layout-engine/page-layout.js';
|
|
3
|
+
import { Trans } from '@/vdb/lib/trans.js';
|
|
4
4
|
import { createFileRoute } from '@tanstack/react-router';
|
|
5
5
|
import { DeleteAssetsBulkAction } from './components/asset-bulk-actions.js';
|
|
6
6
|
|
|
@@ -15,11 +15,15 @@ function RouteComponent() {
|
|
|
15
15
|
<Trans>Assets</Trans>
|
|
16
16
|
</PageTitle>
|
|
17
17
|
<PageBlock blockId="asset-gallery" column="main">
|
|
18
|
-
<AssetGallery
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
18
|
+
<AssetGallery
|
|
19
|
+
selectable={true}
|
|
20
|
+
multiSelect="manual"
|
|
21
|
+
bulkActions={[
|
|
22
|
+
{
|
|
23
|
+
order: 10,
|
|
24
|
+
component: DeleteAssetsBulkAction,
|
|
25
|
+
},
|
|
26
|
+
]}
|
|
23
27
|
/>
|
|
24
28
|
</PageBlock>
|
|
25
29
|
</Page>
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { AssetFocalPointEditor } from '@/components/shared/asset/asset-focal-point-editor.js';
|
|
2
|
-
import { AssetPreviewSelector } from '@/components/shared/asset/asset-preview-selector.js';
|
|
3
|
-
import { PreviewPreset } from '@/components/shared/asset/asset-preview.js';
|
|
4
|
-
import { AssetProperties } from '@/components/shared/asset/asset-properties.js';
|
|
5
|
-
import { Point } from '@/components/shared/asset/focal-point-control.js';
|
|
6
|
-
import { ErrorPage } from '@/components/shared/error-page.js';
|
|
7
|
-
import { PermissionGuard } from '@/components/shared/permission-guard.js';
|
|
8
|
-
import { VendureImage } from '@/components/shared/vendure-image.js';
|
|
9
|
-
import { Button } from '@/components/ui/button.js';
|
|
10
|
-
import { Label } from '@/components/ui/label.js';
|
|
1
|
+
import { AssetFocalPointEditor } from '@/vdb/components/shared/asset/asset-focal-point-editor.js';
|
|
2
|
+
import { AssetPreviewSelector } from '@/vdb/components/shared/asset/asset-preview-selector.js';
|
|
3
|
+
import { PreviewPreset } from '@/vdb/components/shared/asset/asset-preview.js';
|
|
4
|
+
import { AssetProperties } from '@/vdb/components/shared/asset/asset-properties.js';
|
|
5
|
+
import { Point } from '@/vdb/components/shared/asset/focal-point-control.js';
|
|
6
|
+
import { ErrorPage } from '@/vdb/components/shared/error-page.js';
|
|
7
|
+
import { PermissionGuard } from '@/vdb/components/shared/permission-guard.js';
|
|
8
|
+
import { VendureImage } from '@/vdb/components/shared/vendure-image.js';
|
|
9
|
+
import { Button } from '@/vdb/components/ui/button.js';
|
|
10
|
+
import { Label } from '@/vdb/components/ui/label.js';
|
|
11
11
|
import {
|
|
12
12
|
CustomFieldsPageBlock,
|
|
13
13
|
Page,
|
|
@@ -16,10 +16,10 @@ import {
|
|
|
16
16
|
PageBlock,
|
|
17
17
|
PageLayout,
|
|
18
18
|
PageTitle,
|
|
19
|
-
} from '@/framework/layout-engine/page-layout.js';
|
|
20
|
-
import { detailPageRouteLoader } from '@/framework/page/detail-page-route-loader.js';
|
|
21
|
-
import { useDetailPage } from '@/framework/page/use-detail-page.js';
|
|
22
|
-
import { Trans, useLingui } from '@/lib/trans.js';
|
|
19
|
+
} from '@/vdb/framework/layout-engine/page-layout.js';
|
|
20
|
+
import { detailPageRouteLoader } from '@/vdb/framework/page/detail-page-route-loader.js';
|
|
21
|
+
import { useDetailPage } from '@/vdb/framework/page/use-detail-page.js';
|
|
22
|
+
import { Trans, useLingui } from '@/vdb/lib/trans.js';
|
|
23
23
|
import { createFileRoute } from '@tanstack/react-router';
|
|
24
24
|
import { FocusIcon } from 'lucide-react';
|
|
25
25
|
import { useRef, useState } from 'react';
|
|
@@ -2,11 +2,11 @@ import { useMutation } from '@tanstack/react-query';
|
|
|
2
2
|
import { TrashIcon } from 'lucide-react';
|
|
3
3
|
import { toast } from 'sonner';
|
|
4
4
|
|
|
5
|
-
import { DataTableBulkActionItem } from '@/components/data-table/data-table-bulk-action-item.js';
|
|
6
|
-
import { api } from '@/graphql/api.js';
|
|
7
|
-
import { AssetFragment } from '@/graphql/fragments.js';
|
|
8
|
-
import { ResultOf } from '@/graphql/graphql.js';
|
|
9
|
-
import { Trans, useLingui } from '@/lib/trans.js';
|
|
5
|
+
import { DataTableBulkActionItem } from '@/vdb/components/data-table/data-table-bulk-action-item.js';
|
|
6
|
+
import { api } from '@/vdb/graphql/api.js';
|
|
7
|
+
import { AssetFragment } from '@/vdb/graphql/fragments.js';
|
|
8
|
+
import { ResultOf } from '@/vdb/graphql/graphql.js';
|
|
9
|
+
import { Trans, useLingui } from '@/vdb/lib/trans.js';
|
|
10
10
|
import { deleteAssetsDocument } from '../assets.graphql.js';
|
|
11
11
|
|
|
12
12
|
export const DeleteAssetsBulkAction = ({
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import { ChannelCodeLabel } from '@/components/shared/channel-code-label.js';
|
|
2
|
-
import { DetailPageButton } from '@/components/shared/detail-page-button.js';
|
|
3
|
-
import { PermissionGuard } from '@/components/shared/permission-guard.js';
|
|
4
|
-
import { Button } from '@/components/ui/button.js';
|
|
5
|
-
import { PageActionBarRight } from '@/framework/layout-engine/page-layout.js';
|
|
6
|
-
import { ListPage } from '@/framework/page/list-page.js';
|
|
7
|
-
import {
|
|
1
|
+
import { ChannelCodeLabel } from '@/vdb/components/shared/channel-code-label.js';
|
|
2
|
+
import { DetailPageButton } from '@/vdb/components/shared/detail-page-button.js';
|
|
3
|
+
import { PermissionGuard } from '@/vdb/components/shared/permission-guard.js';
|
|
4
|
+
import { Button } from '@/vdb/components/ui/button.js';
|
|
5
|
+
import { PageActionBarRight } from '@/vdb/framework/layout-engine/page-layout.js';
|
|
6
|
+
import { ListPage } from '@/vdb/framework/page/list-page.js';
|
|
7
|
+
import { useLocalFormat } from '@/vdb/hooks/use-local-format.js';
|
|
8
|
+
import { Trans } from '@/vdb/lib/trans.js';
|
|
8
9
|
import { createFileRoute, Link } from '@tanstack/react-router';
|
|
9
10
|
import { PlusIcon } from 'lucide-react';
|
|
10
11
|
import { channelListQuery, deleteChannelDocument } from './channels.graphql.js';
|
|
11
|
-
import { useLocalFormat } from '@/hooks/use-local-format.js';
|
|
12
12
|
import { DeleteChannelsBulkAction } from './components/channel-bulk-actions.js';
|
|
13
13
|
|
|
14
14
|
export const Route = createFileRoute('/_authenticated/_channels/channels')({
|
|
@@ -54,13 +54,13 @@ function ChannelListPage() {
|
|
|
54
54
|
header: 'Seller',
|
|
55
55
|
cell: ({ row }) => {
|
|
56
56
|
return row.original.seller?.name;
|
|
57
|
-
}
|
|
57
|
+
},
|
|
58
58
|
},
|
|
59
59
|
defaultLanguageCode: {
|
|
60
60
|
header: 'Default Language',
|
|
61
61
|
cell: ({ row }) => {
|
|
62
62
|
return formatLanguageName(row.original.defaultLanguageCode);
|
|
63
|
-
}
|
|
63
|
+
},
|
|
64
64
|
},
|
|
65
65
|
}}
|
|
66
66
|
bulkActions={[
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { ChannelCodeLabel } from '@/components/shared/channel-code-label.js';
|
|
2
|
-
import { CurrencySelector } from '@/components/shared/currency-selector.js';
|
|
3
|
-
import { ErrorPage } from '@/components/shared/error-page.js';
|
|
4
|
-
import { FormFieldWrapper } from '@/components/shared/form-field-wrapper.js';
|
|
5
|
-
import { LanguageSelector } from '@/components/shared/language-selector.js';
|
|
6
|
-
import { PermissionGuard } from '@/components/shared/permission-guard.js';
|
|
7
|
-
import { SellerSelector } from '@/components/shared/seller-selector.js';
|
|
8
|
-
import { ZoneSelector } from '@/components/shared/zone-selector.js';
|
|
9
|
-
import { Button } from '@/components/ui/button.js';
|
|
10
|
-
import { Input } from '@/components/ui/input.js';
|
|
11
|
-
import { Switch } from '@/components/ui/switch.js';
|
|
12
|
-
import { DEFAULT_CHANNEL_CODE, NEW_ENTITY_PATH } from '@/constants.js';
|
|
1
|
+
import { ChannelCodeLabel } from '@/vdb/components/shared/channel-code-label.js';
|
|
2
|
+
import { CurrencySelector } from '@/vdb/components/shared/currency-selector.js';
|
|
3
|
+
import { ErrorPage } from '@/vdb/components/shared/error-page.js';
|
|
4
|
+
import { FormFieldWrapper } from '@/vdb/components/shared/form-field-wrapper.js';
|
|
5
|
+
import { LanguageSelector } from '@/vdb/components/shared/language-selector.js';
|
|
6
|
+
import { PermissionGuard } from '@/vdb/components/shared/permission-guard.js';
|
|
7
|
+
import { SellerSelector } from '@/vdb/components/shared/seller-selector.js';
|
|
8
|
+
import { ZoneSelector } from '@/vdb/components/shared/zone-selector.js';
|
|
9
|
+
import { Button } from '@/vdb/components/ui/button.js';
|
|
10
|
+
import { Input } from '@/vdb/components/ui/input.js';
|
|
11
|
+
import { Switch } from '@/vdb/components/ui/switch.js';
|
|
12
|
+
import { DEFAULT_CHANNEL_CODE, NEW_ENTITY_PATH } from '@/vdb/constants.js';
|
|
13
13
|
import {
|
|
14
14
|
CustomFieldsPageBlock,
|
|
15
15
|
DetailFormGrid,
|
|
@@ -19,10 +19,10 @@ import {
|
|
|
19
19
|
PageBlock,
|
|
20
20
|
PageLayout,
|
|
21
21
|
PageTitle,
|
|
22
|
-
} from '@/framework/layout-engine/page-layout.js';
|
|
23
|
-
import { detailPageRouteLoader } from '@/framework/page/detail-page-route-loader.js';
|
|
24
|
-
import { useDetailPage } from '@/framework/page/use-detail-page.js';
|
|
25
|
-
import { Trans, useLingui } from '@/lib/trans.js';
|
|
22
|
+
} from '@/vdb/framework/layout-engine/page-layout.js';
|
|
23
|
+
import { detailPageRouteLoader } from '@/vdb/framework/page/detail-page-route-loader.js';
|
|
24
|
+
import { useDetailPage } from '@/vdb/framework/page/use-detail-page.js';
|
|
25
|
+
import { Trans, useLingui } from '@/vdb/lib/trans.js';
|
|
26
26
|
import { createFileRoute, useNavigate } from '@tanstack/react-router';
|
|
27
27
|
import { toast } from 'sonner';
|
|
28
28
|
import { channelDetailDocument, createChannelDocument, updateChannelDocument } from './channels.graphql.js';
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { BulkActionComponent } from '@/framework/data-table/data-table-types.js';
|
|
2
1
|
import { DeleteBulkAction } from '../../../../common/delete-bulk-action.js';
|
|
3
2
|
import { deleteChannelsDocument } from '../channels.graphql.js';
|
|
3
|
+
import { BulkActionComponent } from '@/vdb/framework/extension-api/types/index.js';
|
|
4
4
|
|
|
5
5
|
export const DeleteChannelsBulkAction: BulkActionComponent<any> = ({ selection, table }) => {
|
|
6
6
|
return (
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { api } from '@/graphql/api.js';
|
|
1
|
+
import { api } from '@/vdb/graphql/api.js';
|
|
2
2
|
import {
|
|
3
3
|
assetFragment,
|
|
4
4
|
configurableOperationDefFragment,
|
|
5
5
|
configurableOperationFragment,
|
|
6
|
-
} from '@/graphql/fragments.js';
|
|
7
|
-
import { graphql, ResultOf } from '@/graphql/graphql.js';
|
|
6
|
+
} from '@/vdb/graphql/fragments.js';
|
|
7
|
+
import { graphql, ResultOf } from '@/vdb/graphql/graphql.js';
|
|
8
8
|
import { DefinedInitialDataOptions, queryOptions } from '@tanstack/react-query';
|
|
9
9
|
|
|
10
10
|
export const collectionListDocument = graphql(
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { DetailPageButton } from '@/components/shared/detail-page-button.js';
|
|
2
|
-
import { PermissionGuard } from '@/components/shared/permission-guard.js';
|
|
3
|
-
import { Button } from '@/components/ui/button.js';
|
|
4
|
-
import { PageActionBarRight } from '@/framework/layout-engine/page-layout.js';
|
|
5
|
-
import { ListPage } from '@/framework/page/list-page.js';
|
|
6
|
-
import { api } from '@/graphql/api.js';
|
|
7
|
-
import { Trans } from '@/lib/trans.js';
|
|
1
|
+
import { DetailPageButton } from '@/vdb/components/shared/detail-page-button.js';
|
|
2
|
+
import { PermissionGuard } from '@/vdb/components/shared/permission-guard.js';
|
|
3
|
+
import { Button } from '@/vdb/components/ui/button.js';
|
|
4
|
+
import { PageActionBarRight } from '@/vdb/framework/layout-engine/page-layout.js';
|
|
5
|
+
import { ListPage } from '@/vdb/framework/page/list-page.js';
|
|
6
|
+
import { api } from '@/vdb/graphql/api.js';
|
|
7
|
+
import { Trans } from '@/vdb/lib/trans.js';
|
|
8
8
|
import { FetchQueryOptions, useQueries } from '@tanstack/react-query';
|
|
9
9
|
import { createFileRoute, Link } from '@tanstack/react-router';
|
|
10
10
|
import { ExpandedState, getExpandedRowModel } from '@tanstack/react-table';
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import { RichTextInput } from '@/components/data-input/richt-text-input.js';
|
|
2
|
-
import { EntityAssets } from '@/components/shared/entity-assets.js';
|
|
3
|
-
import { ErrorPage } from '@/components/shared/error-page.js';
|
|
4
|
-
import { FormFieldWrapper } from '@/components/shared/form-field-wrapper.js';
|
|
5
|
-
import { PermissionGuard } from '@/components/shared/permission-guard.js';
|
|
6
|
-
import { TranslatableFormFieldWrapper } from '@/components/shared/translatable-form-field.js';
|
|
7
|
-
import { Button } from '@/components/ui/button.js';
|
|
8
|
-
import { FormControl, FormDescription, FormItem, FormLabel, FormMessage } from '@/components/ui/form.js';
|
|
9
|
-
import { Input } from '@/components/ui/input.js';
|
|
10
|
-
import { Switch } from '@/components/ui/switch.js';
|
|
11
|
-
import { NEW_ENTITY_PATH } from '@/constants.js';
|
|
1
|
+
import { RichTextInput } from '@/vdb/components/data-input/richt-text-input.js';
|
|
2
|
+
import { EntityAssets } from '@/vdb/components/shared/entity-assets.js';
|
|
3
|
+
import { ErrorPage } from '@/vdb/components/shared/error-page.js';
|
|
4
|
+
import { FormFieldWrapper } from '@/vdb/components/shared/form-field-wrapper.js';
|
|
5
|
+
import { PermissionGuard } from '@/vdb/components/shared/permission-guard.js';
|
|
6
|
+
import { TranslatableFormFieldWrapper } from '@/vdb/components/shared/translatable-form-field.js';
|
|
7
|
+
import { Button } from '@/vdb/components/ui/button.js';
|
|
8
|
+
import { FormControl, FormDescription, FormItem, FormLabel, FormMessage } from '@/vdb/components/ui/form.js';
|
|
9
|
+
import { Input } from '@/vdb/components/ui/input.js';
|
|
10
|
+
import { Switch } from '@/vdb/components/ui/switch.js';
|
|
11
|
+
import { NEW_ENTITY_PATH } from '@/vdb/constants.js';
|
|
12
12
|
import {
|
|
13
13
|
CustomFieldsPageBlock,
|
|
14
14
|
DetailFormGrid,
|
|
@@ -18,10 +18,10 @@ import {
|
|
|
18
18
|
PageBlock,
|
|
19
19
|
PageLayout,
|
|
20
20
|
PageTitle,
|
|
21
|
-
} from '@/framework/layout-engine/page-layout.js';
|
|
22
|
-
import { detailPageRouteLoader } from '@/framework/page/detail-page-route-loader.js';
|
|
23
|
-
import { useDetailPage } from '@/framework/page/use-detail-page.js';
|
|
24
|
-
import { Trans, useLingui } from '@/lib/trans.js';
|
|
21
|
+
} from '@/vdb/framework/layout-engine/page-layout.js';
|
|
22
|
+
import { detailPageRouteLoader } from '@/vdb/framework/page/detail-page-route-loader.js';
|
|
23
|
+
import { useDetailPage } from '@/vdb/framework/page/use-detail-page.js';
|
|
24
|
+
import { Trans, useLingui } from '@/vdb/lib/trans.js';
|
|
25
25
|
import { createFileRoute, useNavigate } from '@tanstack/react-router';
|
|
26
26
|
import { toast } from 'sonner';
|
|
27
27
|
import {
|