@leandrosk/dashboard 3.5.5-fork.2

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 (713) hide show
  1. package/README.md +118 -0
  2. package/dist/plugin/api/api-extensions.d.ts +1 -0
  3. package/dist/plugin/api/api-extensions.js +35 -0
  4. package/dist/plugin/api/metrics.resolver.d.ts +8 -0
  5. package/dist/plugin/api/metrics.resolver.js +40 -0
  6. package/dist/plugin/config/metrics-strategies.d.ts +39 -0
  7. package/dist/plugin/config/metrics-strategies.js +74 -0
  8. package/dist/plugin/constants.d.ts +8 -0
  9. package/dist/plugin/constants.js +35 -0
  10. package/dist/plugin/dashboard.plugin.d.ts +115 -0
  11. package/dist/plugin/dashboard.plugin.js +339 -0
  12. package/dist/plugin/default-page.html +193 -0
  13. package/dist/plugin/index.d.ts +2 -0
  14. package/dist/plugin/index.js +18 -0
  15. package/dist/plugin/package.json +3 -0
  16. package/dist/plugin/service/metrics.service.d.ts +15 -0
  17. package/dist/plugin/service/metrics.service.js +129 -0
  18. package/dist/plugin/types.d.ts +20 -0
  19. package/dist/plugin/types.js +9 -0
  20. package/dist/vite/constants.d.ts +5 -0
  21. package/dist/vite/constants.js +280 -0
  22. package/dist/vite/index.d.ts +1 -0
  23. package/dist/vite/index.js +1 -0
  24. package/dist/vite/types.d.ts +79 -0
  25. package/dist/vite/types.js +1 -0
  26. package/dist/vite/utils/ast-utils.d.ts +5 -0
  27. package/dist/vite/utils/ast-utils.js +29 -0
  28. package/dist/vite/utils/ast-utils.spec.d.ts +1 -0
  29. package/dist/vite/utils/ast-utils.spec.js +45 -0
  30. package/dist/vite/utils/compiler.d.ts +23 -0
  31. package/dist/vite/utils/compiler.js +191 -0
  32. package/dist/vite/utils/get-dashboard-paths.d.ts +5 -0
  33. package/dist/vite/utils/get-dashboard-paths.js +20 -0
  34. package/dist/vite/utils/logger.d.ts +3 -0
  35. package/dist/vite/utils/logger.js +39 -0
  36. package/dist/vite/utils/path-transformer.d.ts +20 -0
  37. package/dist/vite/utils/path-transformer.js +116 -0
  38. package/dist/vite/utils/plugin-discovery.d.ts +27 -0
  39. package/dist/vite/utils/plugin-discovery.js +399 -0
  40. package/dist/vite/utils/schema-generator.d.ts +10 -0
  41. package/dist/vite/utils/schema-generator.js +35 -0
  42. package/dist/vite/utils/tsconfig-utils.d.ts +9 -0
  43. package/dist/vite/utils/tsconfig-utils.js +51 -0
  44. package/dist/vite/utils/ui-config.d.ts +3 -0
  45. package/dist/vite/utils/ui-config.js +44 -0
  46. package/dist/vite/vite-plugin-admin-api-schema.d.ts +24 -0
  47. package/dist/vite/vite-plugin-admin-api-schema.js +82 -0
  48. package/dist/vite/vite-plugin-config-loader.d.ts +16 -0
  49. package/dist/vite/vite-plugin-config-loader.js +70 -0
  50. package/dist/vite/vite-plugin-config.d.ts +4 -0
  51. package/dist/vite/vite-plugin-config.js +60 -0
  52. package/dist/vite/vite-plugin-dashboard-metadata.d.ts +7 -0
  53. package/dist/vite/vite-plugin-dashboard-metadata.js +61 -0
  54. package/dist/vite/vite-plugin-gql-tada.d.ts +6 -0
  55. package/dist/vite/vite-plugin-gql-tada.js +51 -0
  56. package/dist/vite/vite-plugin-hmr.d.ts +8 -0
  57. package/dist/vite/vite-plugin-hmr.js +34 -0
  58. package/dist/vite/vite-plugin-lingui-babel.d.ts +40 -0
  59. package/dist/vite/vite-plugin-lingui-babel.js +168 -0
  60. package/dist/vite/vite-plugin-tailwind-source.d.ts +7 -0
  61. package/dist/vite/vite-plugin-tailwind-source.js +48 -0
  62. package/dist/vite/vite-plugin-theme.d.ts +55 -0
  63. package/dist/vite/vite-plugin-theme.js +130 -0
  64. package/dist/vite/vite-plugin-transform-index.d.ts +11 -0
  65. package/dist/vite/vite-plugin-transform-index.js +40 -0
  66. package/dist/vite/vite-plugin-translations.d.ts +31 -0
  67. package/dist/vite/vite-plugin-translations.js +177 -0
  68. package/dist/vite/vite-plugin-ui-config.d.ts +181 -0
  69. package/dist/vite/vite-plugin-ui-config.js +36 -0
  70. package/dist/vite/vite-plugin-vendure-dashboard.d.ts +142 -0
  71. package/dist/vite/vite-plugin-vendure-dashboard.js +170 -0
  72. package/index.html +14 -0
  73. package/lingui.config.js +39 -0
  74. package/package.json +184 -0
  75. package/src/app/app-providers.tsx +31 -0
  76. package/src/app/common/delete-bulk-action.tsx +149 -0
  77. package/src/app/common/duplicate-bulk-action.tsx +147 -0
  78. package/src/app/common/duplicate-entity-dialog.tsx +117 -0
  79. package/src/app/common/map-faceted-filter-fields.ts +21 -0
  80. package/src/app/common/set-document-direction.ts +7 -0
  81. package/src/app/common/use-page-title.test.ts +263 -0
  82. package/src/app/common/use-page-title.ts +86 -0
  83. package/src/app/main.tsx +134 -0
  84. package/src/app/routeTree.gen.ts +1284 -0
  85. package/src/app/routes/__root.tsx +23 -0
  86. package/src/app/routes/_authenticated/_administrators/administrators.graphql.ts +88 -0
  87. package/src/app/routes/_authenticated/_administrators/administrators.tsx +104 -0
  88. package/src/app/routes/_authenticated/_administrators/administrators_.$id.tsx +160 -0
  89. package/src/app/routes/_authenticated/_administrators/components/administrator-bulk-actions.tsx +15 -0
  90. package/src/app/routes/_authenticated/_administrators/components/role-permissions-display.tsx +133 -0
  91. package/src/app/routes/_authenticated/_assets/assets.graphql.ts +76 -0
  92. package/src/app/routes/_authenticated/_assets/assets.tsx +48 -0
  93. package/src/app/routes/_authenticated/_assets/assets_.$id.tsx +181 -0
  94. package/src/app/routes/_authenticated/_assets/components/asset-bulk-actions.tsx +47 -0
  95. package/src/app/routes/_authenticated/_assets/components/asset-tag-filter.tsx +206 -0
  96. package/src/app/routes/_authenticated/_assets/components/asset-tags-editor.tsx +226 -0
  97. package/src/app/routes/_authenticated/_assets/components/manage-tags-dialog.tsx +212 -0
  98. package/src/app/routes/_authenticated/_channels/channels.graphql.ts +102 -0
  99. package/src/app/routes/_authenticated/_channels/channels.tsx +81 -0
  100. package/src/app/routes/_authenticated/_channels/channels_.$id.tsx +251 -0
  101. package/src/app/routes/_authenticated/_channels/components/channel-bulk-actions.tsx +15 -0
  102. package/src/app/routes/_authenticated/_collections/collections.graphql.ts +191 -0
  103. package/src/app/routes/_authenticated/_collections/collections.tsx +458 -0
  104. package/src/app/routes/_authenticated/_collections/collections_.$id.tsx +267 -0
  105. package/src/app/routes/_authenticated/_collections/components/collection-bulk-actions.tsx +130 -0
  106. package/src/app/routes/_authenticated/_collections/components/collection-contents-preview-table.tsx +153 -0
  107. package/src/app/routes/_authenticated/_collections/components/collection-contents-sheet.tsx +50 -0
  108. package/src/app/routes/_authenticated/_collections/components/collection-contents-table.tsx +83 -0
  109. package/src/app/routes/_authenticated/_collections/components/collection-filters-selector.tsx +30 -0
  110. package/src/app/routes/_authenticated/_collections/components/move-collections-dialog.tsx +433 -0
  111. package/src/app/routes/_authenticated/_countries/components/country-bulk-actions.tsx +15 -0
  112. package/src/app/routes/_authenticated/_countries/countries.graphql.ts +82 -0
  113. package/src/app/routes/_authenticated/_countries/countries.tsx +72 -0
  114. package/src/app/routes/_authenticated/_countries/countries_.$id.tsx +123 -0
  115. package/src/app/routes/_authenticated/_customer-groups/components/customer-group-bulk-actions.tsx +15 -0
  116. package/src/app/routes/_authenticated/_customer-groups/components/customer-group-members-sheet.tsx +51 -0
  117. package/src/app/routes/_authenticated/_customer-groups/components/customer-group-members-table.tsx +134 -0
  118. package/src/app/routes/_authenticated/_customer-groups/customer-groups.graphql.ts +80 -0
  119. package/src/app/routes/_authenticated/_customer-groups/customer-groups.tsx +72 -0
  120. package/src/app/routes/_authenticated/_customer-groups/customer-groups_.$id.tsx +121 -0
  121. package/src/app/routes/_authenticated/_customers/components/customer-address-card.tsx +155 -0
  122. package/src/app/routes/_authenticated/_customers/components/customer-address-form.tsx +347 -0
  123. package/src/app/routes/_authenticated/_customers/components/customer-bulk-actions.tsx +15 -0
  124. package/src/app/routes/_authenticated/_customers/components/customer-group-controls.tsx +4 -0
  125. package/src/app/routes/_authenticated/_customers/components/customer-history/customer-history-container.tsx +78 -0
  126. package/src/app/routes/_authenticated/_customers/components/customer-history/customer-history-types.ts +5 -0
  127. package/src/app/routes/_authenticated/_customers/components/customer-history/customer-history-utils.tsx +124 -0
  128. package/src/app/routes/_authenticated/_customers/components/customer-history/customer-history.tsx +113 -0
  129. package/src/app/routes/_authenticated/_customers/components/customer-history/default-customer-history-components.tsx +178 -0
  130. package/src/app/routes/_authenticated/_customers/components/customer-history/index.ts +4 -0
  131. package/src/app/routes/_authenticated/_customers/components/customer-history/use-customer-history.ts +169 -0
  132. package/src/app/routes/_authenticated/_customers/components/customer-order-table.tsx +90 -0
  133. package/src/app/routes/_authenticated/_customers/components/customer-status-badge.tsx +33 -0
  134. package/src/app/routes/_authenticated/_customers/customers.graphql.ts +219 -0
  135. package/src/app/routes/_authenticated/_customers/customers.tsx +107 -0
  136. package/src/app/routes/_authenticated/_customers/customers_.$id.tsx +280 -0
  137. package/src/app/routes/_authenticated/_facets/components/facet-bulk-actions.tsx +99 -0
  138. package/src/app/routes/_authenticated/_facets/components/facet-value-bulk-actions.tsx +16 -0
  139. package/src/app/routes/_authenticated/_facets/components/facet-values-sheet.tsx +49 -0
  140. package/src/app/routes/_authenticated/_facets/components/facet-values-table.tsx +139 -0
  141. package/src/app/routes/_authenticated/_facets/facets.graphql.ts +182 -0
  142. package/src/app/routes/_authenticated/_facets/facets.tsx +121 -0
  143. package/src/app/routes/_authenticated/_facets/facets_.$facetId.values_.$id.tsx +158 -0
  144. package/src/app/routes/_authenticated/_facets/facets_.$id.tsx +152 -0
  145. package/src/app/routes/_authenticated/_global-settings/global-settings.graphql.ts +28 -0
  146. package/src/app/routes/_authenticated/_global-settings/global-settings.tsx +161 -0
  147. package/src/app/routes/_authenticated/_orders/components/add-manual-payment-dialog.tsx +189 -0
  148. package/src/app/routes/_authenticated/_orders/components/add-surcharge-form.tsx +139 -0
  149. package/src/app/routes/_authenticated/_orders/components/customer-address-selector.tsx +115 -0
  150. package/src/app/routes/_authenticated/_orders/components/draft-order-status.tsx +48 -0
  151. package/src/app/routes/_authenticated/_orders/components/edit-order-table.tsx +287 -0
  152. package/src/app/routes/_authenticated/_orders/components/fulfill-order-dialog.tsx +323 -0
  153. package/src/app/routes/_authenticated/_orders/components/fulfillment-details.tsx +181 -0
  154. package/src/app/routes/_authenticated/_orders/components/money-gross-net.tsx +20 -0
  155. package/src/app/routes/_authenticated/_orders/components/order-address.tsx +65 -0
  156. package/src/app/routes/_authenticated/_orders/components/order-detail-shared.tsx +332 -0
  157. package/src/app/routes/_authenticated/_orders/components/order-history/default-order-history-components.tsx +138 -0
  158. package/src/app/routes/_authenticated/_orders/components/order-history/index.ts +3 -0
  159. package/src/app/routes/_authenticated/_orders/components/order-history/order-history-container.tsx +80 -0
  160. package/src/app/routes/_authenticated/_orders/components/order-history/order-history-types.ts +5 -0
  161. package/src/app/routes/_authenticated/_orders/components/order-history/order-history-utils.tsx +189 -0
  162. package/src/app/routes/_authenticated/_orders/components/order-history/order-history.tsx +117 -0
  163. package/src/app/routes/_authenticated/_orders/components/order-history/use-order-history.ts +175 -0
  164. package/src/app/routes/_authenticated/_orders/components/order-line-custom-fields-form.tsx +60 -0
  165. package/src/app/routes/_authenticated/_orders/components/order-modification-preview-dialog.tsx +365 -0
  166. package/src/app/routes/_authenticated/_orders/components/order-modification-summary.tsx +277 -0
  167. package/src/app/routes/_authenticated/_orders/components/order-table-totals.tsx +100 -0
  168. package/src/app/routes/_authenticated/_orders/components/order-table.tsx +216 -0
  169. package/src/app/routes/_authenticated/_orders/components/order-tax-summary.tsx +40 -0
  170. package/src/app/routes/_authenticated/_orders/components/payment-details.tsx +293 -0
  171. package/src/app/routes/_authenticated/_orders/components/refund-order-dialog.tsx +372 -0
  172. package/src/app/routes/_authenticated/_orders/components/seller-orders-card.tsx +63 -0
  173. package/src/app/routes/_authenticated/_orders/components/settle-refund-dialog.tsx +80 -0
  174. package/src/app/routes/_authenticated/_orders/components/shipping-method-selector.tsx +64 -0
  175. package/src/app/routes/_authenticated/_orders/components/state-transition-control.tsx +99 -0
  176. package/src/app/routes/_authenticated/_orders/components/use-transition-order-to-state.tsx +151 -0
  177. package/src/app/routes/_authenticated/_orders/hooks/use-refund-order.ts +345 -0
  178. package/src/app/routes/_authenticated/_orders/orders.graphql.ts +817 -0
  179. package/src/app/routes/_authenticated/_orders/orders.tsx +120 -0
  180. package/src/app/routes/_authenticated/_orders/orders_.$aggregateOrderId_.seller-orders.$sellerOrderId.tsx +50 -0
  181. package/src/app/routes/_authenticated/_orders/orders_.$id.tsx +30 -0
  182. package/src/app/routes/_authenticated/_orders/orders_.$id_.modify.tsx +312 -0
  183. package/src/app/routes/_authenticated/_orders/orders_.draft.$id.tsx +513 -0
  184. package/src/app/routes/_authenticated/_orders/utils/order-detail-loaders.tsx +140 -0
  185. package/src/app/routes/_authenticated/_orders/utils/order-types.ts +10 -0
  186. package/src/app/routes/_authenticated/_orders/utils/order-utils.ts +219 -0
  187. package/src/app/routes/_authenticated/_orders/utils/refund-utils.ts +100 -0
  188. package/src/app/routes/_authenticated/_orders/utils/use-modify-order.ts +350 -0
  189. package/src/app/routes/_authenticated/_payment-methods/components/payment-eligibility-checker-selector.tsx +40 -0
  190. package/src/app/routes/_authenticated/_payment-methods/components/payment-handler-selector.tsx +39 -0
  191. package/src/app/routes/_authenticated/_payment-methods/components/payment-method-bulk-actions.tsx +58 -0
  192. package/src/app/routes/_authenticated/_payment-methods/payment-methods.graphql.ts +110 -0
  193. package/src/app/routes/_authenticated/_payment-methods/payment-methods.tsx +88 -0
  194. package/src/app/routes/_authenticated/_payment-methods/payment-methods_.$id.tsx +213 -0
  195. package/src/app/routes/_authenticated/_product-variants/components/add-currency-dropdown.tsx +49 -0
  196. package/src/app/routes/_authenticated/_product-variants/components/add-stock-location-dropdown.tsx +56 -0
  197. package/src/app/routes/_authenticated/_product-variants/components/product-variant-bulk-actions.tsx +110 -0
  198. package/src/app/routes/_authenticated/_product-variants/components/variant-price-detail.tsx +92 -0
  199. package/src/app/routes/_authenticated/_product-variants/product-variants.graphql.ts +213 -0
  200. package/src/app/routes/_authenticated/_product-variants/product-variants.tsx +115 -0
  201. package/src/app/routes/_authenticated/_product-variants/product-variants_.$id.tsx +490 -0
  202. package/src/app/routes/_authenticated/_products/components/add-option-group-dialog.tsx +127 -0
  203. package/src/app/routes/_authenticated/_products/components/add-product-variant-dialog.tsx +372 -0
  204. package/src/app/routes/_authenticated/_products/components/assign-facet-values-dialog.tsx +282 -0
  205. package/src/app/routes/_authenticated/_products/components/create-product-options-dialog.tsx +416 -0
  206. package/src/app/routes/_authenticated/_products/components/create-product-variants-dialog.tsx +190 -0
  207. package/src/app/routes/_authenticated/_products/components/create-product-variants.tsx +370 -0
  208. package/src/app/routes/_authenticated/_products/components/option-groups-editor.tsx +180 -0
  209. package/src/app/routes/_authenticated/_products/components/option-value-input.tsx +72 -0
  210. package/src/app/routes/_authenticated/_products/components/product-bulk-actions.tsx +117 -0
  211. package/src/app/routes/_authenticated/_products/components/product-option-group-badge.tsx +19 -0
  212. package/src/app/routes/_authenticated/_products/components/product-option-select.tsx +111 -0
  213. package/src/app/routes/_authenticated/_products/components/product-options-table.tsx +114 -0
  214. package/src/app/routes/_authenticated/_products/components/product-variants-table.tsx +120 -0
  215. package/src/app/routes/_authenticated/_products/product-option-groups.graphql.ts +103 -0
  216. package/src/app/routes/_authenticated/_products/products.graphql.ts +352 -0
  217. package/src/app/routes/_authenticated/_products/products.tsx +138 -0
  218. package/src/app/routes/_authenticated/_products/products_.$id.tsx +258 -0
  219. package/src/app/routes/_authenticated/_products/products_.$id_.variants.tsx +430 -0
  220. package/src/app/routes/_authenticated/_products/products_.$productId.option-groups.$id.tsx +177 -0
  221. package/src/app/routes/_authenticated/_products/products_.$productId.option-groups.$productOptionGroupId.options_.$id.tsx +204 -0
  222. package/src/app/routes/_authenticated/_profile/profile.graphql.ts +30 -0
  223. package/src/app/routes/_authenticated/_profile/profile.tsx +143 -0
  224. package/src/app/routes/_authenticated/_promotions/components/promotion-actions-selector.tsx +41 -0
  225. package/src/app/routes/_authenticated/_promotions/components/promotion-bulk-actions.tsx +72 -0
  226. package/src/app/routes/_authenticated/_promotions/components/promotion-conditions-selector.tsx +41 -0
  227. package/src/app/routes/_authenticated/_promotions/promotions.graphql.ts +121 -0
  228. package/src/app/routes/_authenticated/_promotions/promotions.tsx +94 -0
  229. package/src/app/routes/_authenticated/_promotions/promotions_.$id.tsx +261 -0
  230. package/src/app/routes/_authenticated/_roles/components/expandable-permissions.tsx +54 -0
  231. package/src/app/routes/_authenticated/_roles/components/permissions-table-grid.tsx +251 -0
  232. package/src/app/routes/_authenticated/_roles/components/role-bulk-actions.tsx +15 -0
  233. package/src/app/routes/_authenticated/_roles/roles.graphql.ts +76 -0
  234. package/src/app/routes/_authenticated/_roles/roles.tsx +99 -0
  235. package/src/app/routes/_authenticated/_roles/roles_.$id.tsx +146 -0
  236. package/src/app/routes/_authenticated/_sellers/components/seller-bulk-actions.tsx +15 -0
  237. package/src/app/routes/_authenticated/_sellers/sellers.graphql.ts +70 -0
  238. package/src/app/routes/_authenticated/_sellers/sellers.tsx +56 -0
  239. package/src/app/routes/_authenticated/_sellers/sellers_.$id.tsx +112 -0
  240. package/src/app/routes/_authenticated/_shipping-methods/components/fulfillment-handler-selector.tsx +56 -0
  241. package/src/app/routes/_authenticated/_shipping-methods/components/metadata-badges.tsx +15 -0
  242. package/src/app/routes/_authenticated/_shipping-methods/components/price-display.tsx +21 -0
  243. package/src/app/routes/_authenticated/_shipping-methods/components/shipping-calculator-selector.tsx +39 -0
  244. package/src/app/routes/_authenticated/_shipping-methods/components/shipping-eligibility-checker-selector.tsx +39 -0
  245. package/src/app/routes/_authenticated/_shipping-methods/components/shipping-method-bulk-actions.tsx +61 -0
  246. package/src/app/routes/_authenticated/_shipping-methods/components/shipping-method-test-result-wrapper.tsx +87 -0
  247. package/src/app/routes/_authenticated/_shipping-methods/components/test-address-form.tsx +256 -0
  248. package/src/app/routes/_authenticated/_shipping-methods/components/test-order-builder.tsx +244 -0
  249. package/src/app/routes/_authenticated/_shipping-methods/components/test-shipping-methods-result.tsx +97 -0
  250. package/src/app/routes/_authenticated/_shipping-methods/components/test-shipping-methods-sheet.tsx +41 -0
  251. package/src/app/routes/_authenticated/_shipping-methods/components/test-shipping-methods.tsx +74 -0
  252. package/src/app/routes/_authenticated/_shipping-methods/components/test-single-method-result.tsx +90 -0
  253. package/src/app/routes/_authenticated/_shipping-methods/components/test-single-shipping-method-sheet.tsx +56 -0
  254. package/src/app/routes/_authenticated/_shipping-methods/components/test-single-shipping-method.tsx +82 -0
  255. package/src/app/routes/_authenticated/_shipping-methods/components/use-shipping-method-test-state.ts +67 -0
  256. package/src/app/routes/_authenticated/_shipping-methods/shipping-methods.graphql.ts +137 -0
  257. package/src/app/routes/_authenticated/_shipping-methods/shipping-methods.tsx +76 -0
  258. package/src/app/routes/_authenticated/_shipping-methods/shipping-methods_.$id.tsx +209 -0
  259. package/src/app/routes/_authenticated/_stock-locations/components/stock-location-bulk-actions.tsx +58 -0
  260. package/src/app/routes/_authenticated/_stock-locations/stock-locations.graphql.ts +87 -0
  261. package/src/app/routes/_authenticated/_stock-locations/stock-locations.tsx +65 -0
  262. package/src/app/routes/_authenticated/_stock-locations/stock-locations_.$id.tsx +126 -0
  263. package/src/app/routes/_authenticated/_system/components/payload-dialog.tsx +41 -0
  264. package/src/app/routes/_authenticated/_system/healthchecks.tsx +100 -0
  265. package/src/app/routes/_authenticated/_system/job-queue.graphql.ts +54 -0
  266. package/src/app/routes/_authenticated/_system/job-queue.tsx +266 -0
  267. package/src/app/routes/_authenticated/_system/scheduled-tasks.tsx +249 -0
  268. package/src/app/routes/_authenticated/_tax-categories/components/tax-category-bulk-actions.tsx +15 -0
  269. package/src/app/routes/_authenticated/_tax-categories/tax-categories.graphql.ts +72 -0
  270. package/src/app/routes/_authenticated/_tax-categories/tax-categories.tsx +69 -0
  271. package/src/app/routes/_authenticated/_tax-categories/tax-categories_.$id.tsx +127 -0
  272. package/src/app/routes/_authenticated/_tax-rates/components/tax-rate-bulk-actions.tsx +15 -0
  273. package/src/app/routes/_authenticated/_tax-rates/tax-rates.graphql.ts +84 -0
  274. package/src/app/routes/_authenticated/_tax-rates/tax-rates.tsx +119 -0
  275. package/src/app/routes/_authenticated/_tax-rates/tax-rates_.$id.tsx +149 -0
  276. package/src/app/routes/_authenticated/_zones/components/zone-bulk-actions.tsx +63 -0
  277. package/src/app/routes/_authenticated/_zones/components/zone-countries-add.tsx +0 -0
  278. package/src/app/routes/_authenticated/_zones/components/zone-countries-sheet.tsx +34 -0
  279. package/src/app/routes/_authenticated/_zones/components/zone-countries-table.tsx +94 -0
  280. package/src/app/routes/_authenticated/_zones/zones.graphql.ts +105 -0
  281. package/src/app/routes/_authenticated/_zones/zones.tsx +64 -0
  282. package/src/app/routes/_authenticated/_zones/zones_.$id.tsx +110 -0
  283. package/src/app/routes/_authenticated/index.tsx +233 -0
  284. package/src/app/routes/_authenticated.tsx +35 -0
  285. package/src/app/routes/login.tsx +49 -0
  286. package/src/app/styles.css +100 -0
  287. package/src/app/tailwindcss-animate.css +275 -0
  288. package/src/i18n/common-strings.ts +123 -0
  289. package/src/i18n/locales/ar.po +5250 -0
  290. package/src/i18n/locales/bg.po +5287 -0
  291. package/src/i18n/locales/cs.po +5250 -0
  292. package/src/i18n/locales/de.po +5250 -0
  293. package/src/i18n/locales/el.po +5311 -0
  294. package/src/i18n/locales/en.po +5285 -0
  295. package/src/i18n/locales/es.po +5250 -0
  296. package/src/i18n/locales/fa.po +5250 -0
  297. package/src/i18n/locales/fr.po +5250 -0
  298. package/src/i18n/locales/he.po +5250 -0
  299. package/src/i18n/locales/hr.po +5250 -0
  300. package/src/i18n/locales/it.po +5250 -0
  301. package/src/i18n/locales/ja.po +5250 -0
  302. package/src/i18n/locales/ko.po +4628 -0
  303. package/src/i18n/locales/nb.po +5250 -0
  304. package/src/i18n/locales/ne.po +5250 -0
  305. package/src/i18n/locales/nl.po +4628 -0
  306. package/src/i18n/locales/pl.po +5250 -0
  307. package/src/i18n/locales/pt_BR.po +5250 -0
  308. package/src/i18n/locales/pt_PT.po +5250 -0
  309. package/src/i18n/locales/ru.po +5250 -0
  310. package/src/i18n/locales/sv.po +5250 -0
  311. package/src/i18n/locales/tr.po +5250 -0
  312. package/src/i18n/locales/uk.po +5250 -0
  313. package/src/i18n/locales/zh_Hans.po +5250 -0
  314. package/src/i18n/locales/zh_Hant.po +5250 -0
  315. package/src/lib/components/data-display/boolean.tsx +23 -0
  316. package/src/lib/components/data-display/date-time.tsx +19 -0
  317. package/src/lib/components/data-display/json.tsx +20 -0
  318. package/src/lib/components/data-display/money.tsx +14 -0
  319. package/src/lib/components/data-input/affixed-input.stories.tsx +93 -0
  320. package/src/lib/components/data-input/affixed-input.tsx +79 -0
  321. package/src/lib/components/data-input/boolean-input.stories.tsx +102 -0
  322. package/src/lib/components/data-input/boolean-input.tsx +16 -0
  323. package/src/lib/components/data-input/checkbox-input.stories.tsx +61 -0
  324. package/src/lib/components/data-input/checkbox-input.tsx +15 -0
  325. package/src/lib/components/data-input/combination-mode-input.tsx +64 -0
  326. package/src/lib/components/data-input/configurable-operation-list-input.tsx +59 -0
  327. package/src/lib/components/data-input/custom-field-list-input.tsx +294 -0
  328. package/src/lib/components/data-input/customer-group-input.tsx +61 -0
  329. package/src/lib/components/data-input/datetime-input.stories.tsx +62 -0
  330. package/src/lib/components/data-input/datetime-input.tsx +210 -0
  331. package/src/lib/components/data-input/default-relation-input.tsx +626 -0
  332. package/src/lib/components/data-input/facet-value-input.tsx +78 -0
  333. package/src/lib/components/data-input/index.ts +24 -0
  334. package/src/lib/components/data-input/money-input.stories.tsx +88 -0
  335. package/src/lib/components/data-input/money-input.tsx +117 -0
  336. package/src/lib/components/data-input/number-input.stories.tsx +103 -0
  337. package/src/lib/components/data-input/number-input.tsx +85 -0
  338. package/src/lib/components/data-input/password-form-input.stories.tsx +65 -0
  339. package/src/lib/components/data-input/password-form-input.tsx +23 -0
  340. package/src/lib/components/data-input/product-multi-selector-input.tsx +416 -0
  341. package/src/lib/components/data-input/relation-input.tsx +165 -0
  342. package/src/lib/components/data-input/relation-selector.tsx +476 -0
  343. package/src/lib/components/data-input/rich-text-input.stories.tsx +92 -0
  344. package/src/lib/components/data-input/rich-text-input.tsx +16 -0
  345. package/src/lib/components/data-input/select-with-options.tsx +112 -0
  346. package/src/lib/components/data-input/slug-input.stories.tsx +232 -0
  347. package/src/lib/components/data-input/slug-input.tsx +290 -0
  348. package/src/lib/components/data-input/string-list-input.tsx +268 -0
  349. package/src/lib/components/data-input/struct-form-input.tsx +352 -0
  350. package/src/lib/components/data-input/text-input.stories.tsx +52 -0
  351. package/src/lib/components/data-input/text-input.tsx +16 -0
  352. package/src/lib/components/data-input/textarea-input.stories.tsx +55 -0
  353. package/src/lib/components/data-input/textarea-input.tsx +23 -0
  354. package/src/lib/components/data-table/add-filter-menu.tsx +64 -0
  355. package/src/lib/components/data-table/column-header-wrapper.tsx +106 -0
  356. package/src/lib/components/data-table/data-table-bulk-action-item.tsx +141 -0
  357. package/src/lib/components/data-table/data-table-bulk-actions.tsx +100 -0
  358. package/src/lib/components/data-table/data-table-column-header.tsx +50 -0
  359. package/src/lib/components/data-table/data-table-context.tsx +98 -0
  360. package/src/lib/components/data-table/data-table-facet-value-faceted-filter.tsx +308 -0
  361. package/src/lib/components/data-table/data-table-faceted-filter.tsx +195 -0
  362. package/src/lib/components/data-table/data-table-filter-badge-editable.tsx +35 -0
  363. package/src/lib/components/data-table/data-table-filter-badge.tsx +115 -0
  364. package/src/lib/components/data-table/data-table-filter-dialog.tsx +92 -0
  365. package/src/lib/components/data-table/data-table-pagination.tsx +105 -0
  366. package/src/lib/components/data-table/data-table-utils.ts +313 -0
  367. package/src/lib/components/data-table/data-table-view-options.tsx +132 -0
  368. package/src/lib/components/data-table/data-table.stories.tsx +249 -0
  369. package/src/lib/components/data-table/data-table.tsx +554 -0
  370. package/src/lib/components/data-table/filters/data-table-boolean-filter.tsx +60 -0
  371. package/src/lib/components/data-table/filters/data-table-datetime-filter.tsx +159 -0
  372. package/src/lib/components/data-table/filters/data-table-id-filter.tsx +63 -0
  373. package/src/lib/components/data-table/filters/data-table-number-filter.tsx +123 -0
  374. package/src/lib/components/data-table/filters/data-table-string-filter.tsx +79 -0
  375. package/src/lib/components/data-table/global-views-bar.tsx +97 -0
  376. package/src/lib/components/data-table/global-views-sheet.tsx +11 -0
  377. package/src/lib/components/data-table/human-readable-operator.tsx +65 -0
  378. package/src/lib/components/data-table/manage-global-views-button.tsx +26 -0
  379. package/src/lib/components/data-table/my-views-button.tsx +47 -0
  380. package/src/lib/components/data-table/refresh-button.tsx +49 -0
  381. package/src/lib/components/data-table/save-view-button.tsx +45 -0
  382. package/src/lib/components/data-table/save-view-dialog.tsx +134 -0
  383. package/src/lib/components/data-table/types.ts +40 -0
  384. package/src/lib/components/data-table/use-all-bulk-actions.ts +19 -0
  385. package/src/lib/components/data-table/use-generated-columns.tsx +418 -0
  386. package/src/lib/components/data-table/user-views-sheet.tsx +11 -0
  387. package/src/lib/components/data-table/views-sheet.tsx +305 -0
  388. package/src/lib/components/date-range-picker.tsx +186 -0
  389. package/src/lib/components/labeled-data.tsx +21 -0
  390. package/src/lib/components/layout/app-layout.tsx +35 -0
  391. package/src/lib/components/layout/app-sidebar.tsx +37 -0
  392. package/src/lib/components/layout/channel-switcher.tsx +228 -0
  393. package/src/lib/components/layout/content-language-selector.tsx +46 -0
  394. package/src/lib/components/layout/dev-mode-indicator.tsx +18 -0
  395. package/src/lib/components/layout/generated-breadcrumbs.tsx +136 -0
  396. package/src/lib/components/layout/language-dialog.tsx +133 -0
  397. package/src/lib/components/layout/manage-languages-dialog.tsx +387 -0
  398. package/src/lib/components/layout/nav-item-wrapper.tsx +107 -0
  399. package/src/lib/components/layout/nav-main.tsx +331 -0
  400. package/src/lib/components/layout/nav-projects.tsx +81 -0
  401. package/src/lib/components/layout/nav-user.tsx +180 -0
  402. package/src/lib/components/login/login-form.tsx +124 -0
  403. package/src/lib/components/shared/alerts.tsx +52 -0
  404. package/src/lib/components/shared/animated-number.tsx +49 -0
  405. package/src/lib/components/shared/asset/asset-bulk-actions.tsx +109 -0
  406. package/src/lib/components/shared/asset/asset-focal-point-editor.tsx +103 -0
  407. package/src/lib/components/shared/asset/asset-gallery.stories.tsx +76 -0
  408. package/src/lib/components/shared/asset/asset-gallery.tsx +623 -0
  409. package/src/lib/components/shared/asset/asset-picker-dialog.stories.tsx +58 -0
  410. package/src/lib/components/shared/asset/asset-picker-dialog.tsx +109 -0
  411. package/src/lib/components/shared/asset/asset-preview-dialog.tsx +38 -0
  412. package/src/lib/components/shared/asset/asset-preview-selector.tsx +32 -0
  413. package/src/lib/components/shared/asset/asset-preview.tsx +114 -0
  414. package/src/lib/components/shared/asset/asset-properties.tsx +44 -0
  415. package/src/lib/components/shared/assign-to-channel-bulk-action.tsx +71 -0
  416. package/src/lib/components/shared/assign-to-channel-dialog.tsx +156 -0
  417. package/src/lib/components/shared/assigned-channels.tsx +108 -0
  418. package/src/lib/components/shared/assigned-facet-values.tsx +61 -0
  419. package/src/lib/components/shared/channel-chip.tsx +43 -0
  420. package/src/lib/components/shared/channel-code-label.tsx +6 -0
  421. package/src/lib/components/shared/channel-selector.tsx +51 -0
  422. package/src/lib/components/shared/configurable-operation-arg-input.tsx +29 -0
  423. package/src/lib/components/shared/configurable-operation-input.tsx +190 -0
  424. package/src/lib/components/shared/configurable-operation-multi-selector.tsx +308 -0
  425. package/src/lib/components/shared/configurable-operation-selector.tsx +161 -0
  426. package/src/lib/components/shared/confirmation-dialog.tsx +58 -0
  427. package/src/lib/components/shared/copyable-text.tsx +30 -0
  428. package/src/lib/components/shared/country-selector.tsx +108 -0
  429. package/src/lib/components/shared/currency-selector.tsx +33 -0
  430. package/src/lib/components/shared/custom-fields-form.tsx +305 -0
  431. package/src/lib/components/shared/customer-address-form.tsx +338 -0
  432. package/src/lib/components/shared/customer-group-chip.tsx +30 -0
  433. package/src/lib/components/shared/customer-group-selector.tsx +65 -0
  434. package/src/lib/components/shared/customer-selector.tsx +112 -0
  435. package/src/lib/components/shared/detail-page-button.stories.tsx +52 -0
  436. package/src/lib/components/shared/detail-page-button.tsx +59 -0
  437. package/src/lib/components/shared/entity-assets.tsx +411 -0
  438. package/src/lib/components/shared/error-page.tsx +31 -0
  439. package/src/lib/components/shared/facet-value-chip.tsx +59 -0
  440. package/src/lib/components/shared/facet-value-selector.stories.tsx +48 -0
  441. package/src/lib/components/shared/facet-value-selector.tsx +274 -0
  442. package/src/lib/components/shared/form-field-wrapper.tsx +111 -0
  443. package/src/lib/components/shared/history-timeline/history-entry-date.tsx +37 -0
  444. package/src/lib/components/shared/history-timeline/history-note-checkbox.tsx +28 -0
  445. package/src/lib/components/shared/history-timeline/history-note-editor.tsx +60 -0
  446. package/src/lib/components/shared/history-timeline/history-note-entry.tsx +65 -0
  447. package/src/lib/components/shared/history-timeline/history-note-input.tsx +39 -0
  448. package/src/lib/components/shared/history-timeline/history-timeline-with-grouping.tsx +144 -0
  449. package/src/lib/components/shared/history-timeline/history-timeline.tsx +16 -0
  450. package/src/lib/components/shared/history-timeline/use-history-note-editor.ts +26 -0
  451. package/src/lib/components/shared/icon-mark.tsx +18 -0
  452. package/src/lib/components/shared/language-selector.tsx +56 -0
  453. package/src/lib/components/shared/logo-mark.tsx +24 -0
  454. package/src/lib/components/shared/multi-select.tsx +159 -0
  455. package/src/lib/components/shared/navigation-confirmation.tsx +64 -0
  456. package/src/lib/components/shared/option-value-input.tsx +97 -0
  457. package/src/lib/components/shared/paginated-list-context.ts +10 -0
  458. package/src/lib/components/shared/paginated-list-data-table.stories.tsx +212 -0
  459. package/src/lib/components/shared/paginated-list-data-table.tsx +497 -0
  460. package/src/lib/components/shared/permission-guard.stories.tsx +46 -0
  461. package/src/lib/components/shared/permission-guard.tsx +51 -0
  462. package/src/lib/components/shared/product-variant-selector.tsx +136 -0
  463. package/src/lib/components/shared/remove-from-channel-bulk-action.tsx +93 -0
  464. package/src/lib/components/shared/rich-text-editor/image-dialog.tsx +223 -0
  465. package/src/lib/components/shared/rich-text-editor/link-dialog.tsx +151 -0
  466. package/src/lib/components/shared/rich-text-editor/responsive-toolbar.tsx +443 -0
  467. package/src/lib/components/shared/rich-text-editor/rich-text-editor.tsx +339 -0
  468. package/src/lib/components/shared/rich-text-editor/table-delete-menu.tsx +104 -0
  469. package/src/lib/components/shared/rich-text-editor/table-edit-icons.tsx +225 -0
  470. package/src/lib/components/shared/role-code-label.tsx +12 -0
  471. package/src/lib/components/shared/role-selector.tsx +56 -0
  472. package/src/lib/components/shared/seller-selector.tsx +111 -0
  473. package/src/lib/components/shared/stock-level-label.tsx +22 -0
  474. package/src/lib/components/shared/table-cell/order-table-cell-components.tsx +80 -0
  475. package/src/lib/components/shared/tax-category-selector.tsx +65 -0
  476. package/src/lib/components/shared/translatable-form-field.tsx +149 -0
  477. package/src/lib/components/shared/vendure-image.stories.tsx +167 -0
  478. package/src/lib/components/shared/vendure-image.tsx +307 -0
  479. package/src/lib/components/shared/zone-selector.tsx +65 -0
  480. package/src/lib/components/ui/accordion.stories.tsx +33 -0
  481. package/src/lib/components/ui/accordion.tsx +59 -0
  482. package/src/lib/components/ui/alert-dialog.stories.tsx +48 -0
  483. package/src/lib/components/ui/alert-dialog.tsx +128 -0
  484. package/src/lib/components/ui/alert.stories.tsx +35 -0
  485. package/src/lib/components/ui/alert.tsx +62 -0
  486. package/src/lib/components/ui/aspect-ratio.stories.tsx +28 -0
  487. package/src/lib/components/ui/aspect-ratio.tsx +9 -0
  488. package/src/lib/components/ui/badge.stories.tsx +28 -0
  489. package/src/lib/components/ui/badge.tsx +38 -0
  490. package/src/lib/components/ui/breadcrumb.stories.tsx +41 -0
  491. package/src/lib/components/ui/breadcrumb.tsx +102 -0
  492. package/src/lib/components/ui/button.stories.tsx +38 -0
  493. package/src/lib/components/ui/button.tsx +58 -0
  494. package/src/lib/components/ui/calendar.stories.tsx +22 -0
  495. package/src/lib/components/ui/calendar.tsx +447 -0
  496. package/src/lib/components/ui/card.stories.tsx +28 -0
  497. package/src/lib/components/ui/card.tsx +47 -0
  498. package/src/lib/components/ui/carousel.stories.tsx +34 -0
  499. package/src/lib/components/ui/carousel.tsx +241 -0
  500. package/src/lib/components/ui/chart.tsx +351 -0
  501. package/src/lib/components/ui/checkbox.stories.tsx +31 -0
  502. package/src/lib/components/ui/checkbox.tsx +27 -0
  503. package/src/lib/components/ui/collapsible.stories.tsx +39 -0
  504. package/src/lib/components/ui/collapsible.tsx +33 -0
  505. package/src/lib/components/ui/command.stories.tsx +44 -0
  506. package/src/lib/components/ui/command.tsx +139 -0
  507. package/src/lib/components/ui/context-menu.stories.tsx +38 -0
  508. package/src/lib/components/ui/context-menu.tsx +252 -0
  509. package/src/lib/components/ui/dialog.stories.tsx +52 -0
  510. package/src/lib/components/ui/dialog.tsx +116 -0
  511. package/src/lib/components/ui/drawer.stories.tsx +50 -0
  512. package/src/lib/components/ui/drawer.tsx +133 -0
  513. package/src/lib/components/ui/dropdown-menu.stories.tsx +41 -0
  514. package/src/lib/components/ui/dropdown-menu.tsx +223 -0
  515. package/src/lib/components/ui/form.tsx +141 -0
  516. package/src/lib/components/ui/grid-layout.tsx +376 -0
  517. package/src/lib/components/ui/hover-card.stories.tsx +38 -0
  518. package/src/lib/components/ui/hover-card.tsx +36 -0
  519. package/src/lib/components/ui/input-group.tsx +149 -0
  520. package/src/lib/components/ui/input-otp.stories.tsx +30 -0
  521. package/src/lib/components/ui/input-otp.tsx +77 -0
  522. package/src/lib/components/ui/input.stories.tsx +38 -0
  523. package/src/lib/components/ui/input.tsx +19 -0
  524. package/src/lib/components/ui/label.stories.tsx +24 -0
  525. package/src/lib/components/ui/label.tsx +21 -0
  526. package/src/lib/components/ui/menubar.stories.tsx +53 -0
  527. package/src/lib/components/ui/menubar.tsx +274 -0
  528. package/src/lib/components/ui/navigation-menu.stories.tsx +54 -0
  529. package/src/lib/components/ui/navigation-menu.tsx +168 -0
  530. package/src/lib/components/ui/pagination.stories.tsx +51 -0
  531. package/src/lib/components/ui/pagination.tsx +106 -0
  532. package/src/lib/components/ui/password-input.stories.tsx +32 -0
  533. package/src/lib/components/ui/password-input.tsx +29 -0
  534. package/src/lib/components/ui/popover.stories.tsx +33 -0
  535. package/src/lib/components/ui/popover.tsx +40 -0
  536. package/src/lib/components/ui/progress.stories.tsx +27 -0
  537. package/src/lib/components/ui/progress.tsx +29 -0
  538. package/src/lib/components/ui/radio-group.stories.tsx +34 -0
  539. package/src/lib/components/ui/radio-group.tsx +45 -0
  540. package/src/lib/components/ui/resizable.stories.tsx +32 -0
  541. package/src/lib/components/ui/resizable.tsx +54 -0
  542. package/src/lib/components/ui/scroll-area.stories.tsx +31 -0
  543. package/src/lib/components/ui/scroll-area.tsx +50 -0
  544. package/src/lib/components/ui/select.stories.tsx +36 -0
  545. package/src/lib/components/ui/select.tsx +183 -0
  546. package/src/lib/components/ui/separator.stories.tsx +35 -0
  547. package/src/lib/components/ui/separator.tsx +26 -0
  548. package/src/lib/components/ui/sheet.stories.tsx +50 -0
  549. package/src/lib/components/ui/sheet.tsx +118 -0
  550. package/src/lib/components/ui/sidebar-context.ts +16 -0
  551. package/src/lib/components/ui/sidebar.tsx +686 -0
  552. package/src/lib/components/ui/skeleton.stories.tsx +26 -0
  553. package/src/lib/components/ui/skeleton.tsx +13 -0
  554. package/src/lib/components/ui/slider.stories.tsx +37 -0
  555. package/src/lib/components/ui/slider.tsx +63 -0
  556. package/src/lib/components/ui/sonner.tsx +27 -0
  557. package/src/lib/components/ui/switch.stories.tsx +31 -0
  558. package/src/lib/components/ui/switch.tsx +26 -0
  559. package/src/lib/components/ui/table.stories.tsx +52 -0
  560. package/src/lib/components/ui/table.tsx +82 -0
  561. package/src/lib/components/ui/tabs.stories.tsx +29 -0
  562. package/src/lib/components/ui/tabs.tsx +48 -0
  563. package/src/lib/components/ui/textarea.stories.tsx +32 -0
  564. package/src/lib/components/ui/textarea.tsx +18 -0
  565. package/src/lib/components/ui/toggle-group.stories.tsx +31 -0
  566. package/src/lib/components/ui/toggle-group.tsx +73 -0
  567. package/src/lib/components/ui/toggle.stories.tsx +39 -0
  568. package/src/lib/components/ui/toggle.tsx +45 -0
  569. package/src/lib/components/ui/tooltip.stories.tsx +30 -0
  570. package/src/lib/components/ui/tooltip.tsx +51 -0
  571. package/src/lib/constants.ts +24 -0
  572. package/src/lib/framework/alert/alert-extensions.tsx +19 -0
  573. package/src/lib/framework/alert/alert-item.tsx +44 -0
  574. package/src/lib/framework/alert/alerts-indicator.tsx +22 -0
  575. package/src/lib/framework/alert/search-index-buffer-alert/search-index-buffer-alert.ts +41 -0
  576. package/src/lib/framework/component-registry/component-registry.tsx +18 -0
  577. package/src/lib/framework/component-registry/display-component.tsx +28 -0
  578. package/src/lib/framework/dashboard-widget/base-widget.tsx +92 -0
  579. package/src/lib/framework/dashboard-widget/latest-orders-widget/index.tsx +153 -0
  580. package/src/lib/framework/dashboard-widget/latest-orders-widget/latest-orders-widget.graphql.ts +35 -0
  581. package/src/lib/framework/dashboard-widget/metrics-widget/chart.tsx +50 -0
  582. package/src/lib/framework/dashboard-widget/metrics-widget/index.tsx +108 -0
  583. package/src/lib/framework/dashboard-widget/metrics-widget/metrics-widget.graphql.ts +20 -0
  584. package/src/lib/framework/dashboard-widget/orders-summary/index.tsx +113 -0
  585. package/src/lib/framework/dashboard-widget/orders-summary/order-summary-widget.graphql.ts +14 -0
  586. package/src/lib/framework/dashboard-widget/widget-extensions.tsx +19 -0
  587. package/src/lib/framework/dashboard-widget/widget-filters-context.tsx +18 -0
  588. package/src/lib/framework/data-table/data-table-extensions.ts +35 -0
  589. package/src/lib/framework/defaults.ts +270 -0
  590. package/src/lib/framework/document-extension/extend-detail-form-query.ts +50 -0
  591. package/src/lib/framework/document-extension/extend-document.spec.ts +884 -0
  592. package/src/lib/framework/document-extension/extend-document.ts +159 -0
  593. package/src/lib/framework/document-introspection/add-custom-fields.spec.ts +1458 -0
  594. package/src/lib/framework/document-introspection/add-custom-fields.ts +452 -0
  595. package/src/lib/framework/document-introspection/get-document-structure.spec.ts +581 -0
  596. package/src/lib/framework/document-introspection/get-document-structure.ts +669 -0
  597. package/src/lib/framework/document-introspection/hooks.ts +13 -0
  598. package/src/lib/framework/document-introspection/include-only-selected-list-fields.spec.ts +1840 -0
  599. package/src/lib/framework/document-introspection/include-only-selected-list-fields.ts +940 -0
  600. package/src/lib/framework/document-introspection/testing-utils.ts +161 -0
  601. package/src/lib/framework/extension-api/define-dashboard-extension.ts +99 -0
  602. package/src/lib/framework/extension-api/display-component-extensions.tsx +58 -0
  603. package/src/lib/framework/extension-api/extension-api-types.ts +92 -0
  604. package/src/lib/framework/extension-api/input-component-extensions.tsx +100 -0
  605. package/src/lib/framework/extension-api/logic/alerts.ts +11 -0
  606. package/src/lib/framework/extension-api/logic/data-table.ts +37 -0
  607. package/src/lib/framework/extension-api/logic/detail-forms.ts +35 -0
  608. package/src/lib/framework/extension-api/logic/form-components.ts +14 -0
  609. package/src/lib/framework/extension-api/logic/history-entries.ts +24 -0
  610. package/src/lib/framework/extension-api/logic/index.ts +10 -0
  611. package/src/lib/framework/extension-api/logic/layout.ts +22 -0
  612. package/src/lib/framework/extension-api/logic/login.ts +17 -0
  613. package/src/lib/framework/extension-api/logic/navigation.ts +41 -0
  614. package/src/lib/framework/extension-api/logic/widgets.ts +10 -0
  615. package/src/lib/framework/extension-api/types/alerts.ts +59 -0
  616. package/src/lib/framework/extension-api/types/data-table.ts +159 -0
  617. package/src/lib/framework/extension-api/types/detail-forms.ts +58 -0
  618. package/src/lib/framework/extension-api/types/form-components.ts +41 -0
  619. package/src/lib/framework/extension-api/types/history-entries.ts +120 -0
  620. package/src/lib/framework/extension-api/types/index.ts +10 -0
  621. package/src/lib/framework/extension-api/types/layout.ts +141 -0
  622. package/src/lib/framework/extension-api/types/login.ts +76 -0
  623. package/src/lib/framework/extension-api/types/navigation.ts +105 -0
  624. package/src/lib/framework/extension-api/types/widgets.ts +101 -0
  625. package/src/lib/framework/extension-api/use-dashboard-extensions.ts +27 -0
  626. package/src/lib/framework/extension-api/use-login-extensions.ts +26 -0
  627. package/src/lib/framework/form-engine/custom-form-component-extensions.ts +15 -0
  628. package/src/lib/framework/form-engine/custom-form-component.tsx +26 -0
  629. package/src/lib/framework/form-engine/default-input-for-type.tsx +35 -0
  630. package/src/lib/framework/form-engine/form-control-adapter.tsx +193 -0
  631. package/src/lib/framework/form-engine/form-engine-types.ts +167 -0
  632. package/src/lib/framework/form-engine/form-schema-tools.spec.ts +683 -0
  633. package/src/lib/framework/form-engine/form-schema-tools.ts +440 -0
  634. package/src/lib/framework/form-engine/overridden-form-component.tsx +51 -0
  635. package/src/lib/framework/form-engine/use-generated-form.tsx +242 -0
  636. package/src/lib/framework/form-engine/utils.spec.ts +419 -0
  637. package/src/lib/framework/form-engine/utils.ts +457 -0
  638. package/src/lib/framework/form-engine/value-transformers.ts +156 -0
  639. package/src/lib/framework/history-entry/history-entry-extensions.ts +11 -0
  640. package/src/lib/framework/history-entry/history-entry.tsx +129 -0
  641. package/src/lib/framework/layout-engine/custom-form-page.stories.tsx +344 -0
  642. package/src/lib/framework/layout-engine/dev-mode-button.tsx +24 -0
  643. package/src/lib/framework/layout-engine/layout-extensions.ts +27 -0
  644. package/src/lib/framework/layout-engine/location-wrapper.tsx +122 -0
  645. package/src/lib/framework/layout-engine/page-block-provider.tsx +6 -0
  646. package/src/lib/framework/layout-engine/page-layout.spec.tsx +138 -0
  647. package/src/lib/framework/layout-engine/page-layout.tsx +700 -0
  648. package/src/lib/framework/layout-engine/page-provider.tsx +10 -0
  649. package/src/lib/framework/layout-engine/page.stories.tsx +275 -0
  650. package/src/lib/framework/nav-menu/nav-menu-extensions.ts +112 -0
  651. package/src/lib/framework/page/detail-page-route-loader.tsx +69 -0
  652. package/src/lib/framework/page/detail-page.stories.tsx +151 -0
  653. package/src/lib/framework/page/detail-page.tsx +240 -0
  654. package/src/lib/framework/page/list-page.stories.tsx +256 -0
  655. package/src/lib/framework/page/list-page.tsx +621 -0
  656. package/src/lib/framework/page/page-api.ts +9 -0
  657. package/src/lib/framework/page/page-types.ts +51 -0
  658. package/src/lib/framework/page/use-detail-page.ts +341 -0
  659. package/src/lib/framework/page/use-extended-router.tsx +139 -0
  660. package/src/lib/framework/registry/global-registry.ts +50 -0
  661. package/src/lib/framework/registry/registry-types.ts +32 -0
  662. package/src/lib/graphql/api.ts +123 -0
  663. package/src/lib/graphql/common-operations.ts +37 -0
  664. package/src/lib/graphql/fragments.ts +71 -0
  665. package/src/lib/graphql/graphql-env.d.ts +540 -0
  666. package/src/lib/graphql/graphql.ts +15 -0
  667. package/src/lib/graphql/schema-enums.ts +13 -0
  668. package/src/lib/graphql/settings-store-operations.ts +17 -0
  669. package/src/lib/hooks/use-alerts-context.ts +10 -0
  670. package/src/lib/hooks/use-alerts.ts +84 -0
  671. package/src/lib/hooks/use-auth.tsx +21 -0
  672. package/src/lib/hooks/use-channel.ts +27 -0
  673. package/src/lib/hooks/use-custom-field-config.ts +27 -0
  674. package/src/lib/hooks/use-data-table-context.ts +11 -0
  675. package/src/lib/hooks/use-display-locale.ts +40 -0
  676. package/src/lib/hooks/use-drag-and-drop.ts +86 -0
  677. package/src/lib/hooks/use-dynamic-translations.ts +53 -0
  678. package/src/lib/hooks/use-extended-detail-query.ts +37 -0
  679. package/src/lib/hooks/use-extended-list-query.ts +80 -0
  680. package/src/lib/hooks/use-facet-value-browser.ts +292 -0
  681. package/src/lib/hooks/use-floating-bulk-actions.ts +83 -0
  682. package/src/lib/hooks/use-grouped-permissions.ts +55 -0
  683. package/src/lib/hooks/use-job-queue-polling.ts +160 -0
  684. package/src/lib/hooks/use-local-format.ts +175 -0
  685. package/src/lib/hooks/use-mobile.ts +19 -0
  686. package/src/lib/hooks/use-page-block.tsx +27 -0
  687. package/src/lib/hooks/use-page.tsx +10 -0
  688. package/src/lib/hooks/use-paginated-list.ts +28 -0
  689. package/src/lib/hooks/use-permissions.ts +40 -0
  690. package/src/lib/hooks/use-saved-views.ts +238 -0
  691. package/src/lib/hooks/use-server-config.ts +4 -0
  692. package/src/lib/hooks/use-sorted-languages.ts +41 -0
  693. package/src/lib/hooks/use-theme.ts +10 -0
  694. package/src/lib/hooks/use-ui-language-loader.ts +30 -0
  695. package/src/lib/hooks/use-user-settings.tsx +12 -0
  696. package/src/lib/hooks/use-widget-dimensions.ts +12 -0
  697. package/src/lib/hooks/use-widget-filters.ts +21 -0
  698. package/src/lib/index.ts +307 -0
  699. package/src/lib/lib/load-i18n-messages.ts +20 -0
  700. package/src/lib/lib/trans.tsx +20 -0
  701. package/src/lib/lib/utils.ts +111 -0
  702. package/src/lib/providers/alerts-provider.tsx +52 -0
  703. package/src/lib/providers/auth.tsx +232 -0
  704. package/src/lib/providers/channel-provider.tsx +245 -0
  705. package/src/lib/providers/i18n-provider.tsx +21 -0
  706. package/src/lib/providers/server-config.tsx +289 -0
  707. package/src/lib/providers/theme-provider.tsx +56 -0
  708. package/src/lib/providers/user-settings.tsx +244 -0
  709. package/src/lib/types/saved-views.ts +42 -0
  710. package/src/lib/utils/config-utils.ts +19 -0
  711. package/src/lib/utils/saved-views-utils.ts +40 -0
  712. package/src/lib/virtual.d.ts +44 -0
  713. package/src/vite-env.d.ts +2 -0
@@ -0,0 +1,621 @@
1
+ import {
2
+ AdditionalColumns,
3
+ CustomFieldKeysOfItem,
4
+ CustomizeColumnConfig,
5
+ FacetedFilterConfig,
6
+ ListQueryFields,
7
+ ListQueryOptionsShape,
8
+ ListQueryShape,
9
+ PaginatedListDataTable,
10
+ PaginatedListRefresherRegisterFn,
11
+ RowAction,
12
+ } from '@/vdb/components/shared/paginated-list-data-table.js';
13
+ import { useUserSettings } from '@/vdb/hooks/use-user-settings.js';
14
+ import { TypedDocumentNode } from '@graphql-typed-document-node/core';
15
+ import { AnyRoute, AnyRouter, useNavigate } from '@tanstack/react-router';
16
+ import { ColumnFiltersState, SortingState, Table } from '@tanstack/react-table';
17
+ import { TableOptions } from '@tanstack/table-core';
18
+
19
+ import { BulkAction } from '@/vdb/framework/extension-api/types/index.js';
20
+ import {
21
+ FullWidthPageBlock,
22
+ Page,
23
+ PageActionBar,
24
+ PageLayout,
25
+ PageTitle,
26
+ } from '../layout-engine/page-layout.js';
27
+
28
+ /**
29
+ * @description
30
+ * Props to configure the {@link ListPage} component.
31
+ *
32
+ * @docsCategory list-views
33
+ * @docsPage ListPage
34
+ * @since 3.3.0
35
+ */
36
+ export interface ListPageProps<
37
+ T extends TypedDocumentNode<U, V>,
38
+ U extends ListQueryShape,
39
+ V extends ListQueryOptionsShape,
40
+ AC extends AdditionalColumns<T>,
41
+ > {
42
+ /**
43
+ * @description
44
+ * A unique identifier for the list page. This is important to support
45
+ * customization functionality that relies on page IDs and makes your
46
+ * component extensible.
47
+ */
48
+ pageId?: string;
49
+ /**
50
+ @description
51
+ * The Tanstack Router `Route` object, which will be defined in the component file.
52
+ */
53
+ route: AnyRoute | (() => AnyRoute);
54
+ /**
55
+ @description
56
+ * The page title, which will display in the header area.
57
+ */
58
+ title: string | React.ReactElement;
59
+ /**
60
+ * @description
61
+ * This DocumentNode of the list query, i.e. a query that fetches
62
+ * PaginatedList data with "items" and "totalItems", such as:
63
+ *
64
+ * @example
65
+ * ```tsx
66
+ * export const collectionListDocument = graphql(`
67
+ * query CollectionList($options: CollectionListOptions) {
68
+ * collections(options: $options) {
69
+ * items {
70
+ * id
71
+ * createdAt
72
+ * updatedAt
73
+ * name
74
+ * slug
75
+ * breadcrumbs {
76
+ * id
77
+ * name
78
+ * slug
79
+ * }
80
+ * children {
81
+ * id
82
+ * name
83
+ * }
84
+ * # ... etc
85
+ * }
86
+ * totalItems
87
+ * }
88
+ * }
89
+ * `);
90
+ * // ...
91
+ * <ListPage
92
+ * pageId="collection-list"
93
+ * listQuery={collectionListDocument}
94
+ * // ...
95
+ * />
96
+ * ```
97
+ */
98
+ listQuery: T;
99
+ /**
100
+ * @description
101
+ * Providing the `deleteMutation` will automatically add a "delete" menu item to the
102
+ * actions column dropdown. Note that if this table already has a "delete" bulk action,
103
+ * you don't need to additionally provide a delete mutation, because the bulk action
104
+ * will be added to the action column dropdown already.
105
+ */
106
+ deleteMutation?: TypedDocumentNode<any, { id: string }>;
107
+ /**
108
+ * @description
109
+ * This prop can be used to intercept and transform the list query variables before they are
110
+ * sent to the Admin API.
111
+ *
112
+ * This allows you to implement specific logic that differs from the standard filter/sort
113
+ * handling.
114
+ *
115
+ * @example
116
+ * ```tsx
117
+ * <ListPage
118
+ * pageId="collection-list"
119
+ * title="Collections"
120
+ * listQuery={collectionListDocument}
121
+ * transformVariables={input => {
122
+ * const filterTerm = input.options?.filter?.name?.contains;
123
+ * // If there is a filter term set
124
+ * // we want to return all results. Else
125
+ * // we only want top-level Collections
126
+ * const isFiltering = !!filterTerm;
127
+ * return {
128
+ * options: {
129
+ * ...input.options,
130
+ * topLevelOnly: !isFiltering,
131
+ * },
132
+ * };
133
+ * }}
134
+ * />
135
+ * ```
136
+ */
137
+ transformVariables?: (variables: V) => V;
138
+ /**
139
+ * @description
140
+ * Allows you to customize how the search term is used in the list query options.
141
+ * For instance, when you want the term to filter on specific fields.
142
+ *
143
+ * @example
144
+ * ```tsx
145
+ * <ListPage
146
+ * pageId="administrator-list"
147
+ * title="Administrators"
148
+ * listQuery={administratorListDocument}
149
+ * onSearchTermChange={searchTerm => {
150
+ * return {
151
+ * firstName: { contains: searchTerm },
152
+ * lastName: { contains: searchTerm },
153
+ * emailAddress: { contains: searchTerm },
154
+ * };
155
+ * }}
156
+ * />
157
+ * ```
158
+ * @param searchTerm
159
+ */
160
+ onSearchTermChange?: (searchTerm: string) => NonNullable<V['options']>['filter'];
161
+ /**
162
+ * @description
163
+ * Allows you to customize the rendering and other aspects of individual columns.
164
+ *
165
+ * By default, an appropriate component will be chosen to render the column data
166
+ * based on the data type of the field. However, in many cases you want to have
167
+ * more control over how the column data is rendered.
168
+ *
169
+ * @example
170
+ * ```tsx
171
+ * <ListPage
172
+ * pageId="collection-list"
173
+ * listQuery={collectionListDocument}
174
+ * customizeColumns={{
175
+ * // The key "name" matches one of the top-level fields of the
176
+ * // list query type (Collection, in this example)
177
+ * name: {
178
+ * meta: {
179
+ * // The Dashboard optimizes the list query `collectionListDocument` to
180
+ * // only select field that are actually visible in the ListPage table.
181
+ * // However, sometimes you want to render data from other fields, i.e.
182
+ * // this column has a data dependency on the "children" and "breadcrumbs"
183
+ * // fields in order to correctly render the "name" field.
184
+ * // In this case, we can declare those data dependencies which means whenever
185
+ * // the "name" column is visible, it will ensure the "children" and "breadcrumbs"
186
+ * // fields are also selected in the query.
187
+ * dependencies: ['children', 'breadcrumbs'],
188
+ * },
189
+ * header: 'Collection Name',
190
+ * cell: ({ row }) => {
191
+ * const isExpanded = row.getIsExpanded();
192
+ * const hasChildren = !!row.original.children?.length;
193
+ * return (
194
+ * <div
195
+ * style={{ marginLeft: (row.original.breadcrumbs?.length - 2) * 20 + 'px' }}
196
+ * className="flex gap-2 items-center"
197
+ * >
198
+ * <Button
199
+ * size="icon"
200
+ * variant="secondary"
201
+ * onClick={row.getToggleExpandedHandler()}
202
+ * disabled={!hasChildren}
203
+ * className={!hasChildren ? 'opacity-20' : ''}
204
+ * >
205
+ * {isExpanded ? <FolderOpen /> : <Folder />}
206
+ * </Button>
207
+ * <DetailPageButton id={row.original.id} label={row.original.name} />
208
+ * </div>
209
+ * );
210
+ * },
211
+ * },
212
+ * // Use `meta.disabled` to completely exclude a column from the table,
213
+ * // including the column visibility toggle. This is useful when you need
214
+ * // to fetch certain fields for use in custom cell renderers, but don't
215
+ * // want those fields to appear as their own columns.
216
+ * productVariantCount: {
217
+ * meta: { disabled: true },
218
+ * },
219
+ * ```
220
+ */
221
+ customizeColumns?: CustomizeColumnConfig<T>;
222
+ /**
223
+ * @description
224
+ * Allows you to define extra columns that are not related to actual fields returned in
225
+ * the query result.
226
+ *
227
+ * For example, in the Administrator list, we define an additional "name" column composed
228
+ * of the `firstName` and `lastName` fields.
229
+ *
230
+ * @example
231
+ * ```tsx
232
+ * <ListPage
233
+ * pageId="administrator-list"
234
+ * title="Administrators"
235
+ * listQuery={administratorListDocument}
236
+ * additionalColumns={{
237
+ * name: {
238
+ * header: 'Name',
239
+ * cell: ({ row }) => (
240
+ * <DetailPageButton
241
+ * id={row.original.id}
242
+ * label={`${row.original.firstName} ${row.original.lastName}`}
243
+ * />
244
+ * ),
245
+ * },
246
+ * />
247
+ * ```
248
+ */
249
+ additionalColumns?: AC;
250
+ /**
251
+ * @description
252
+ * Allows you to specify the default order of columns in the table. When not defined, the
253
+ * order of fields in the list query document will be used.
254
+ */
255
+ defaultColumnOrder?: (keyof ListQueryFields<T> | keyof AC | CustomFieldKeysOfItem<ListQueryFields<T>>)[];
256
+ /**
257
+ * @description
258
+ * Allows you to specify the default sorting applied to the table.
259
+ *
260
+ * @example
261
+ * ```tsx
262
+ * defaultSort={[{ id: 'updatedAt', desc: true }]}
263
+ * ```
264
+ */
265
+ defaultSort?: SortingState;
266
+ /**
267
+ * @description
268
+ * Allows you to specify the default columns that are visible in the table.
269
+ * If you set them to `true`, then only those will show by default. If you set them to `false`,
270
+ * then _all other_ columns will be visible by default.
271
+ *
272
+ * @example
273
+ * ```tsx
274
+ * <ListPage
275
+ * pageId="country-list"
276
+ * listQuery={countriesListQuery}
277
+ * title="Countries"
278
+ * defaultVisibility={{
279
+ * name: true,
280
+ * code: true,
281
+ * enabled: true,
282
+ * }}
283
+ * />
284
+ * ```
285
+ */
286
+ defaultVisibility?: Partial<
287
+ Record<keyof ListQueryFields<T> | keyof AC | CustomFieldKeysOfItem<ListQueryFields<T>>, boolean>
288
+ >;
289
+ children?: React.ReactNode;
290
+ /**
291
+ * @description
292
+ * Allows you to define pre-set filters based on an array of possible selections
293
+ *
294
+ * @example
295
+ * ```tsx
296
+ * <ListPage
297
+ * pageId="payment-method-list"
298
+ * listQuery={paymentMethodListQuery}
299
+ * title="Payment Methods"
300
+ * facetedFilters={{
301
+ * enabled: {
302
+ * title: 'Enabled',
303
+ * options: [
304
+ * { label: 'Enabled', value: true },
305
+ * { label: 'Disabled', value: false },
306
+ * ],
307
+ * },
308
+ * }}
309
+ * />
310
+ * ```
311
+ */
312
+ facetedFilters?: FacetedFilterConfig<T>;
313
+ /**
314
+ * @description
315
+ * Allows you to specify additional "actions" that will be made available in the "actions" column.
316
+ * By default, the actions column includes all bulk actions defined in the `bulkActions` prop.
317
+ */
318
+ rowActions?: RowAction<ListQueryFields<T>>[];
319
+ /**
320
+ * @description
321
+ * Allows the returned list query data to be transformed in some way. This is an advanced feature
322
+ * that is not often required.
323
+ */
324
+ transformData?: (data: any[]) => any[];
325
+ /**
326
+ * @description
327
+ * Allows you to directly manipulate the Tanstack Table `TableOptions` object before the
328
+ * table is created. And advanced option that is not often required.
329
+ */
330
+ setTableOptions?: (table: TableOptions<any>) => TableOptions<any>;
331
+ /**
332
+ * @description
333
+ * Bulk actions are actions that can be applied to one or more table rows, and include things like
334
+ *
335
+ * - Deleting the rows
336
+ * - Assigning the rows to another channel
337
+ * - Bulk editing some aspect of the rows
338
+ *
339
+ * See the {@link BulkAction} docs for an example of how to build the component.
340
+ *
341
+ * @example
342
+ * ```tsx
343
+ * <ListPage
344
+ * pageId="product-list"
345
+ * listQuery={productListDocument}
346
+ * title="Products"
347
+ * bulkActions={[
348
+ * {
349
+ * component: AssignProductsToChannelBulkAction,
350
+ * order: 100,
351
+ * },
352
+ * {
353
+ * component: RemoveProductsFromChannelBulkAction,
354
+ * order: 200,
355
+ * },
356
+ * {
357
+ * component: DeleteProductsBulkAction,
358
+ * order: 300,
359
+ * },
360
+ * ]}
361
+ * />
362
+ * ```
363
+ */
364
+ bulkActions?: BulkAction[];
365
+ /**
366
+ * @description
367
+ * Register a function that allows you to assign a refresh function for
368
+ * this list. The function can be assigned to a ref and then called when
369
+ * the list needs to be refreshed.
370
+ */
371
+ registerRefresher?: PaginatedListRefresherRegisterFn;
372
+ /**
373
+ * @description
374
+ * Callback when items are reordered via drag and drop.
375
+ * Only applies to top-level items. When provided, enables drag-and-drop functionality.
376
+ *
377
+ * @param oldIndex - The original index of the dragged item
378
+ * @param newIndex - The new index where the item was dropped
379
+ * @param item - The data of the item that was moved
380
+ */
381
+ onReorder?: (oldIndex: number, newIndex: number, item: any) => void | Promise<void>;
382
+ /**
383
+ * @description
384
+ * When true, drag and drop will be disabled. This will only have an effect if the onReorder prop is also set Useful when filtering or searching.
385
+ * Defaults to false. Only relevant when `onReorder` is provided.
386
+ */
387
+ disableDragAndDrop?: boolean;
388
+ }
389
+
390
+ /**
391
+ * @description
392
+ * Auto-generates a list page with columns generated based on the provided query document fields.
393
+ *
394
+ * @example
395
+ * ```tsx
396
+ * import {
397
+ * Button,
398
+ * DashboardRouteDefinition,
399
+ * ListPage,
400
+ * PageActionBarRight,
401
+ * DetailPageButton,
402
+ * } from '@vendure/dashboard';
403
+ * import { Link } from '@tanstack/react-router';
404
+ * import { PlusIcon } from 'lucide-react';
405
+ *
406
+ * // This function is generated for you by the `vendureDashboardPlugin` in your Vite config.
407
+ * // It uses gql-tada to generate TypeScript types which give you type safety as you write
408
+ * // your queries and mutations.
409
+ * import { graphql } from '@/gql';
410
+ *
411
+ * // The fields you select here will be automatically used to generate the appropriate columns in the
412
+ * // data table below.
413
+ * const getArticleList = graphql(`
414
+ * query GetArticles($options: ArticleListOptions) {
415
+ * articles(options: $options) {
416
+ * items {
417
+ * id
418
+ * createdAt
419
+ * updatedAt
420
+ * isPublished
421
+ * title
422
+ * slug
423
+ * body
424
+ * customFields
425
+ * }
426
+ * totalItems
427
+ * }
428
+ * }
429
+ * `);
430
+ *
431
+ * const deleteArticleDocument = graphql(`
432
+ * mutation DeleteArticle($id: ID!) {
433
+ * deleteArticle(id: $id) {
434
+ * result
435
+ * }
436
+ * }
437
+ * `);
438
+ *
439
+ * export const articleList: DashboardRouteDefinition = {
440
+ * navMenuItem: {
441
+ * sectionId: 'catalog',
442
+ * id: 'articles',
443
+ * url: '/articles',
444
+ * title: 'CMS Articles',
445
+ * },
446
+ * path: '/articles',
447
+ * loader: () => ({
448
+ * breadcrumb: 'Articles',
449
+ * }),
450
+ * component: route => (
451
+ * <ListPage
452
+ * pageId="article-list"
453
+ * title="Articles"
454
+ * listQuery={getArticleList}
455
+ * deleteMutation={deleteArticleDocument}
456
+ * route={route}
457
+ * customizeColumns={{
458
+ * title: {
459
+ * cell: ({ row }) => {
460
+ * const post = row.original;
461
+ * return <DetailPageButton id={post.id} label={post.title} />;
462
+ * },
463
+ * },
464
+ * }}
465
+ * >
466
+ * <PageActionBarRight>
467
+ * <Button asChild>
468
+ * <Link to="./new">
469
+ * <PlusIcon className="mr-2 h-4 w-4" />
470
+ * New article
471
+ * </Link>
472
+ * </Button>
473
+ * </PageActionBarRight>
474
+ * </ListPage>
475
+ * ),
476
+ * };
477
+ * ```
478
+ * @docsCategory list-views
479
+ * @docsPage ListPage
480
+ * @docsWeight 0
481
+ * @since 3.3.0
482
+ */
483
+ export function ListPage<
484
+ T extends TypedDocumentNode<U, V>,
485
+ U extends Record<string, any> = any,
486
+ V extends ListQueryOptionsShape = ListQueryOptionsShape,
487
+ AC extends AdditionalColumns<T> = AdditionalColumns<T>,
488
+ >({
489
+ pageId,
490
+ title,
491
+ listQuery,
492
+ deleteMutation,
493
+ transformVariables,
494
+ customizeColumns,
495
+ additionalColumns,
496
+ defaultColumnOrder,
497
+ defaultSort,
498
+ route: routeOrFn,
499
+ defaultVisibility,
500
+ onSearchTermChange,
501
+ facetedFilters,
502
+ children,
503
+ rowActions,
504
+ transformData,
505
+ setTableOptions,
506
+ bulkActions,
507
+ registerRefresher,
508
+ onReorder,
509
+ disableDragAndDrop = false,
510
+ }: Readonly<ListPageProps<T, U, V, AC>>) {
511
+ const route = typeof routeOrFn === 'function' ? routeOrFn() : routeOrFn;
512
+ const routeSearch = route.useSearch();
513
+ const navigate = useNavigate<AnyRouter>({ from: route.fullPath });
514
+ const { setTableSettings, settings } = useUserSettings();
515
+ const tableSettings = pageId ? settings.tableSettings?.[pageId] : undefined;
516
+
517
+ const pagination = {
518
+ page: routeSearch.page ? parseInt(routeSearch.page) : 1,
519
+ itemsPerPage: routeSearch.perPage ? parseInt(routeSearch.perPage) : (tableSettings?.pageSize ?? 10),
520
+ };
521
+
522
+ const columnVisibility = pageId
523
+ ? (tableSettings?.columnVisibility ?? defaultVisibility)
524
+ : defaultVisibility;
525
+ const columnOrder = pageId ? (tableSettings?.columnOrder ?? defaultColumnOrder) : defaultColumnOrder;
526
+ const columnFilters = pageId ? tableSettings?.columnFilters : routeSearch.filters;
527
+
528
+ const sorting: SortingState = (routeSearch.sort ?? '')
529
+ .split(',')
530
+ .filter((s: string) => s.length)
531
+ .map((s: string) => {
532
+ return {
533
+ id: s.replace(/^-/, ''),
534
+ desc: s.startsWith('-'),
535
+ };
536
+ });
537
+
538
+ if (defaultSort && !sorting.length) {
539
+ sorting.push(...defaultSort);
540
+ }
541
+
542
+ function sortToString(sortingStates?: SortingState) {
543
+ return sortingStates?.map(s => `${s.desc ? '-' : ''}${s.id}`).join(',');
544
+ }
545
+
546
+ function persistListStateToUrl(
547
+ table: Table<any>,
548
+ listState: {
549
+ page?: number;
550
+ perPage?: number;
551
+ sort?: SortingState;
552
+ filters?: ColumnFiltersState;
553
+ },
554
+ ) {
555
+ const tableState = table.getState();
556
+ const page = listState.page || tableState.pagination.pageIndex + 1;
557
+ const perPage = listState.perPage || tableState.pagination.pageSize;
558
+ const sort = sortToString(listState.sort ?? tableState.sorting);
559
+ const filters = listState.filters ?? tableState.columnFilters;
560
+ navigate({
561
+ search: () => ({ sort, page, perPage, filters: filters.length ? filters : undefined }) as never,
562
+ });
563
+ }
564
+
565
+ const commonTableProps = {
566
+ listQuery,
567
+ deleteMutation,
568
+ transformVariables,
569
+ customizeColumns: customizeColumns as any,
570
+ additionalColumns: additionalColumns as any,
571
+ defaultColumnOrder: columnOrder as any,
572
+ defaultVisibility: columnVisibility as any,
573
+ onSearchTermChange,
574
+ page: pagination.page,
575
+ itemsPerPage: pagination.itemsPerPage,
576
+ sorting,
577
+ columnFilters,
578
+ onPageChange: (table: Table<any>, page: number, perPage: number) => {
579
+ persistListStateToUrl(table, { page, perPage });
580
+ if (pageId) {
581
+ setTableSettings(pageId, 'pageSize', perPage);
582
+ }
583
+ },
584
+ onSortChange: (table: Table<any>, sorting: SortingState) => {
585
+ persistListStateToUrl(table, { sort: sorting });
586
+ },
587
+ onFilterChange: (table: Table<any>, filters: ColumnFiltersState) => {
588
+ persistListStateToUrl(table, { filters });
589
+ if (pageId) {
590
+ setTableSettings(pageId, 'columnFilters', filters);
591
+ }
592
+ },
593
+ onColumnVisibilityChange: (table: Table<any>, columnVisibility: any) => {
594
+ if (pageId) {
595
+ setTableSettings(pageId, 'columnVisibility', columnVisibility);
596
+ }
597
+ },
598
+ facetedFilters,
599
+ rowActions,
600
+ bulkActions,
601
+ setTableOptions,
602
+ transformData,
603
+ registerRefresher,
604
+ };
605
+
606
+ return (
607
+ <Page pageId={pageId}>
608
+ <PageTitle>{title}</PageTitle>
609
+ <PageActionBar>{children}</PageActionBar>
610
+ <PageLayout>
611
+ <FullWidthPageBlock blockId="list-table">
612
+ <PaginatedListDataTable
613
+ {...commonTableProps}
614
+ onReorder={onReorder}
615
+ disableDragAndDrop={disableDragAndDrop}
616
+ />
617
+ </FullWidthPageBlock>
618
+ </PageLayout>
619
+ </Page>
620
+ );
621
+ }
@@ -0,0 +1,9 @@
1
+ import { DashboardRouteDefinition } from '../extension-api/types/navigation.js';
2
+
3
+ export const extensionRoutes = new Map<string, DashboardRouteDefinition>();
4
+
5
+ export function registerRoute(config: DashboardRouteDefinition) {
6
+ if (config.path) {
7
+ extensionRoutes.set(config.path, config);
8
+ }
9
+ }
@@ -0,0 +1,51 @@
1
+ import { ResultOf, TypedDocumentNode } from '@graphql-typed-document-node/core';
2
+
3
+ // Type that identifies a paginated list structure (has items array and totalItems)
4
+ type IsEntity<T> = T extends { id: string } ? true : false;
5
+
6
+ // Helper type to extract string keys from an object
7
+ type StringKeys<T> = T extends object ? Extract<keyof T, string> : never;
8
+
9
+ /**
10
+ * @description
11
+ * This type is used to extract the path to the entity from the query result.
12
+ *
13
+ * For example, if you have a query like this:
14
+ *
15
+ * ```graphql
16
+ * query GetEntity($id: ID!) {
17
+ * entity(id: $id) {
18
+ * id
19
+ * name
20
+ * }
21
+ * }
22
+ * ```
23
+ *
24
+ * The `DetailEntityPath` type will be `'entity'`.
25
+ */
26
+ export type DetailEntityPath<T extends TypedDocumentNode<any, any>> = {
27
+ [K in StringKeys<ResultOf<T>>]: NonNullable<ResultOf<T>[K]> extends object
28
+ ? IsEntity<NonNullable<ResultOf<T>[K]>> extends true
29
+ ? K
30
+ : never
31
+ : never;
32
+ }[StringKeys<ResultOf<T>>];
33
+
34
+ /**
35
+ * @description
36
+ * This type is used to extract the entity from the query result.
37
+ *
38
+ * For example, if you have a query like this:
39
+ *
40
+ * ```graphql
41
+ * query GetEntity($id: ID!) {
42
+ * entity(id: $id) {
43
+ * id
44
+ * name
45
+ * }
46
+ * }
47
+
48
+ * ```
49
+ * The `DetailEntity` type will be `{ id: string, name: string }`.
50
+ */
51
+ export type DetailEntity<T extends TypedDocumentNode<any, any>> = ResultOf<T>[DetailEntityPath<T>];