From 33de175dc5d817b9e5b398fcce19d002236a44bc Mon Sep 17 00:00:00 2001 From: Siriwat K Date: Thu, 29 Aug 2024 10:22:26 +0700 Subject: [PATCH] Replace `endsWith` with `includes` to check adapter path (#214) --- packages/pigment-css-react/src/utils/preprocessor.ts | 4 ++++ packages/pigment-css-react/tests/testUtils.ts | 4 ++-- .../pigment-css-react/tests/utils/adapter-path.test.ts | 9 +++++++++ packages/pigment-css-unplugin/src/index.ts | 3 ++- packages/pigment-css-vite-plugin/src/vite-plugin.ts | 4 ++-- 5 files changed, 19 insertions(+), 5 deletions(-) create mode 100644 packages/pigment-css-react/tests/utils/adapter-path.test.ts diff --git a/packages/pigment-css-react/src/utils/preprocessor.ts b/packages/pigment-css-react/src/utils/preprocessor.ts index 816e68d7..762a9e52 100644 --- a/packages/pigment-css-react/src/utils/preprocessor.ts +++ b/packages/pigment-css-react/src/utils/preprocessor.ts @@ -65,3 +65,7 @@ export function preprocessor( return css; } + +export function matchAdapterPath(path: string) { + return path.includes('zero-styled'); +} diff --git a/packages/pigment-css-react/tests/testUtils.ts b/packages/pigment-css-react/tests/testUtils.ts index a66a14dc..db92b801 100644 --- a/packages/pigment-css-react/tests/testUtils.ts +++ b/packages/pigment-css-react/tests/testUtils.ts @@ -8,7 +8,7 @@ import { transform as wywTransform, createFileReporter, } from '@wyw-in-js/transform'; -import { PluginCustomOptions, preprocessor } from '@pigment-css/react/utils'; +import { matchAdapterPath, PluginCustomOptions, preprocessor } from '@pigment-css/react/utils'; import * as prettier from 'prettier'; import sxTransformPlugin from '../exports/sx-plugin'; @@ -70,7 +70,7 @@ export async function runTransformation(absolutePath: string, options?: Transfor return require.resolve(`../exports/styled`); } - if (source !== '@pigment-css/react' && !source.endsWith('/zero-styled')) { + if (source !== '@pigment-css/react' && !matchAdapterPath(source)) { return null; } return require.resolve(`../${pkgJson['wyw-in-js'].tags[tag]}`.replace('.js', '')); diff --git a/packages/pigment-css-react/tests/utils/adapter-path.test.ts b/packages/pigment-css-react/tests/utils/adapter-path.test.ts new file mode 100644 index 00000000..68459f1c --- /dev/null +++ b/packages/pigment-css-react/tests/utils/adapter-path.test.ts @@ -0,0 +1,9 @@ +import { expect } from 'chai'; +import { matchAdapterPath } from '@pigment-css/react/utils'; + +describe('matchAdapterPath', () => { + it('should match adapter path', () => { + expect(matchAdapterPath('../zero-styled')).to.equal(true); + expect(matchAdapterPath('../zero-styled/index.js')).to.equal(true); + }); +}); diff --git a/packages/pigment-css-unplugin/src/index.ts b/packages/pigment-css-unplugin/src/index.ts index 3460089a..62a6effe 100644 --- a/packages/pigment-css-unplugin/src/index.ts +++ b/packages/pigment-css-unplugin/src/index.ts @@ -20,6 +20,7 @@ import { generateTokenCss, generateThemeSource, extendTheme, + matchAdapterPath, type Theme as BaseTheme, type PluginCustomOptions, } from '@pigment-css/react/utils'; @@ -256,7 +257,7 @@ export const plugin = createUnplugin((options) => { if (tagResult) { return tagResult; } - if (source.endsWith('/zero-styled')) { + if (matchAdapterPath(source)) { return require.resolve(`${process.env.RUNTIME_PACKAGE_NAME}/exports/${tag}`); } return null; diff --git a/packages/pigment-css-vite-plugin/src/vite-plugin.ts b/packages/pigment-css-vite-plugin/src/vite-plugin.ts index 05d57fb5..af388815 100644 --- a/packages/pigment-css-vite-plugin/src/vite-plugin.ts +++ b/packages/pigment-css-vite-plugin/src/vite-plugin.ts @@ -20,7 +20,7 @@ import { type PluginOptions, type IFileReporterOptions, } from '@wyw-in-js/transform'; -import { type PluginCustomOptions } from '@pigment-css/react/utils'; +import { matchAdapterPath, type PluginCustomOptions } from '@pigment-css/react/utils'; export type VitePluginOptions = { debug?: IFileReporterOptions | false | null | undefined; @@ -238,7 +238,7 @@ export default function wywVitePlugin({ if (tagResult) { return tagResult; } - if (source.endsWith('/zero-styled')) { + if (matchAdapterPath(source)) { return `${process.env.RUNTIME_PACKAGE_NAME}/exports/${tag}`; } return null;