vite-plugin-dashboard-metadata.ts 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. import path from 'path';
  2. import { Plugin } from 'vite';
  3. import { LoadVendureConfigResult } from './utils/config-loader.js';
  4. import { ConfigLoaderApi, getConfigLoaderApi } from './vite-plugin-config-loader.js';
  5. const virtualModuleId = 'virtual:dashboard-extensions';
  6. const resolvedVirtualModuleId = `\0${virtualModuleId}`;
  7. /**
  8. * This Vite plugin scans the configured plugins for any dashboard extensions and dynamically
  9. * generates an import statement for each one, wrapped up in a `runDashboardExtensions()`
  10. * function which can then be imported and executed in the Dashboard app.
  11. */
  12. export function dashboardMetadataPlugin(): Plugin {
  13. let configLoaderApi: ConfigLoaderApi;
  14. let loadVendureConfigResult: LoadVendureConfigResult;
  15. return {
  16. name: 'vendure:dashboard-extensions-metadata',
  17. configResolved({ plugins }) {
  18. configLoaderApi = getConfigLoaderApi(plugins);
  19. },
  20. resolveId(id) {
  21. if (id === virtualModuleId) {
  22. return resolvedVirtualModuleId;
  23. }
  24. },
  25. async load(id) {
  26. if (id === resolvedVirtualModuleId) {
  27. if (!loadVendureConfigResult) {
  28. loadVendureConfigResult = await configLoaderApi.getVendureConfig();
  29. }
  30. const { pluginInfo } = loadVendureConfigResult;
  31. const pluginsWithExtensions =
  32. pluginInfo
  33. ?.map(
  34. ({ dashboardEntryPath, pluginPath }) =>
  35. dashboardEntryPath && path.join(pluginPath, dashboardEntryPath),
  36. )
  37. .filter(x => x != null) ?? [];
  38. this.info(`Found ${pluginsWithExtensions.length} Dashboard extensions`);
  39. return `
  40. export async function runDashboardExtensions() {
  41. ${pluginsWithExtensions
  42. .map(extension => {
  43. return `await import(\`${extension}\`);`;
  44. })
  45. .join('\n')}
  46. }`;
  47. }
  48. },
  49. };
  50. }