From d3b3cc415bb24b2434d4c509b34b6c7cc3326d60 Mon Sep 17 00:00:00 2001 From: Mister-Hope Date: Fri, 24 May 2024 00:00:55 +0800 Subject: [PATCH] feat(core): allow non-default-export client config file (#1564) Co-authored-by: meteorlxy --- e2e/docs/.vuepress/config.ts | 3 +++ e2e/docs/.vuepress/plugins/foo/fooPlugin.ts | 11 +++++++++++ .../plugins/foo/nonDefaultExportClientConfig.js | 2 ++ e2e/docs/.vuepress/plugins/foo/test.css | 3 +++ e2e/docs/client-config/non-default-export.md | 1 + e2e/tests/client-config/non-default-export.spec.ts | 11 +++++++++++ packages/core/src/app/prepare/prepareClientConfigs.ts | 6 ++++-- 7 files changed, 35 insertions(+), 2 deletions(-) create mode 100644 e2e/docs/.vuepress/plugins/foo/fooPlugin.ts create mode 100644 e2e/docs/.vuepress/plugins/foo/nonDefaultExportClientConfig.js create mode 100644 e2e/docs/.vuepress/plugins/foo/test.css create mode 100644 e2e/docs/client-config/non-default-export.md create mode 100644 e2e/tests/client-config/non-default-export.spec.ts diff --git a/e2e/docs/.vuepress/config.ts b/e2e/docs/.vuepress/config.ts index ca30feae74..363ef38117 100644 --- a/e2e/docs/.vuepress/config.ts +++ b/e2e/docs/.vuepress/config.ts @@ -3,6 +3,7 @@ import { viteBundler } from '@vuepress/bundler-vite' import { webpackBundler } from '@vuepress/bundler-webpack' import { defineUserConfig } from 'vuepress' import { path } from 'vuepress/utils' +import { fooPlugin } from './plugins/foo/fooPlugin.js' import { e2eTheme } from './theme/node/e2eTheme.js' const E2E_BASE = (process.env.E2E_BASE ?? '/') as '/' | `/${string}/` @@ -80,4 +81,6 @@ export default defineUserConfig({ } } }, + + plugins: [fooPlugin], }) diff --git a/e2e/docs/.vuepress/plugins/foo/fooPlugin.ts b/e2e/docs/.vuepress/plugins/foo/fooPlugin.ts new file mode 100644 index 0000000000..93ef0c8cff --- /dev/null +++ b/e2e/docs/.vuepress/plugins/foo/fooPlugin.ts @@ -0,0 +1,11 @@ +import { getDirname, path } from 'vuepress/utils' + +const __dirname = getDirname(import.meta.url) + +export const fooPlugin = { + name: 'test-plugin', + clientConfigFile: path.resolve( + __dirname, + './nonDefaultExportClientConfig.js', + ), +} diff --git a/e2e/docs/.vuepress/plugins/foo/nonDefaultExportClientConfig.js b/e2e/docs/.vuepress/plugins/foo/nonDefaultExportClientConfig.js new file mode 100644 index 0000000000..760529c3ed --- /dev/null +++ b/e2e/docs/.vuepress/plugins/foo/nonDefaultExportClientConfig.js @@ -0,0 +1,2 @@ +// test non-default-export clientConfig +import './test.css' diff --git a/e2e/docs/.vuepress/plugins/foo/test.css b/e2e/docs/.vuepress/plugins/foo/test.css new file mode 100644 index 0000000000..086105eaef --- /dev/null +++ b/e2e/docs/.vuepress/plugins/foo/test.css @@ -0,0 +1,3 @@ +#non-default-export { + font-size: 123px; +} diff --git a/e2e/docs/client-config/non-default-export.md b/e2e/docs/client-config/non-default-export.md new file mode 100644 index 0000000000..cf25bf5c20 --- /dev/null +++ b/e2e/docs/client-config/non-default-export.md @@ -0,0 +1 @@ +# non-default-export diff --git a/e2e/tests/client-config/non-default-export.spec.ts b/e2e/tests/client-config/non-default-export.spec.ts new file mode 100644 index 0000000000..b00265a6ae --- /dev/null +++ b/e2e/tests/client-config/non-default-export.spec.ts @@ -0,0 +1,11 @@ +import { expect, test } from '@playwright/test' + +test('should apply styles correctly if the client config file does not have default export', async ({ + page, +}) => { + await page.goto('client-config/non-default-export.html') + await expect(page.locator('#non-default-export')).toHaveCSS( + 'font-size', + '123px', + ) +}) diff --git a/packages/core/src/app/prepare/prepareClientConfigs.ts b/packages/core/src/app/prepare/prepareClientConfigs.ts index 6803da2296..59bb1f5624 100644 --- a/packages/core/src/app/prepare/prepareClientConfigs.ts +++ b/packages/core/src/app/prepare/prepareClientConfigs.ts @@ -11,12 +11,14 @@ export const prepareClientConfigs = async (app: App): Promise => { // generate client config files entry const content = `\ ${clientConfigFiles - .map((filePath, index) => `import clientConfig${index} from '${filePath}'`) + .map( + (filePath, index) => `import * as clientConfig${index} from '${filePath}'`, + ) .join('\n')} export const clientConfigs = [ ${clientConfigFiles.map((_, index) => ` clientConfig${index},`).join('\n')} -] +].map((m) => m.default).filter(Boolean) ` await app.writeTemp('internal/clientConfigs.js', content)