From f373d7f6b59f43236dc713e1b421ef4631f392c0 Mon Sep 17 00:00:00 2001 From: Yevhen Noskov Date: Sat, 27 Jan 2024 04:32:39 +0200 Subject: [PATCH] Allow hyphens inside css classes (#1254) Co-authored-by: Remus Mate <3297808+mrm007@users.noreply.github.com> --- .changeset/strong-ducks-dream.md | 10 ++++++++++ packages/css/src/identifier.test.ts | 9 +++++++++ packages/css/src/identifier.ts | 2 +- site/docs/integrations/webpack.md | 2 +- 4 files changed, 21 insertions(+), 2 deletions(-) create mode 100644 .changeset/strong-ducks-dream.md diff --git a/.changeset/strong-ducks-dream.md b/.changeset/strong-ducks-dream.md new file mode 100644 index 000000000..4c8efd5b3 --- /dev/null +++ b/.changeset/strong-ducks-dream.md @@ -0,0 +1,10 @@ +--- +'@vanilla-extract/css': patch +'@vanilla-extract/esbuild-plugin': patch +'@vanilla-extract/next-plugin': patch +'@vanilla-extract/rollup-plugin': patch +'@vanilla-extract/vite-plugin': patch +'@vanilla-extract/webpack-plugin': patch +--- + +Allow hyphens in class names when using a custom identifier diff --git a/packages/css/src/identifier.test.ts b/packages/css/src/identifier.test.ts index 88a6e889a..0eebc6200 100644 --- a/packages/css/src/identifier.test.ts +++ b/packages/css/src/identifier.test.ts @@ -91,6 +91,15 @@ describe('identifier', () => { ); }); + it('should allow hyphens in a class name', () => { + expect(generateIdentifier('a-b')).toMatchInlineSnapshot( + `"abc_a-b_s0xkdr1_packagetest_file"`, + ); + expect(generateIdentifier('a-b-c')).toMatchInlineSnapshot( + `"abc_a-b-c_s0xkdr2_packagetest_file"`, + ); + }); + it('rejects invalid identifiers', () => { // getIdentOption() does not remove spaces from the debug info so the // resulting identifier should be invalid here. diff --git a/packages/css/src/identifier.ts b/packages/css/src/identifier.ts index 175f6a04b..1209cdc9e 100644 --- a/packages/css/src/identifier.ts +++ b/packages/css/src/identifier.ts @@ -75,7 +75,7 @@ export function generateIdentifier( packageName, }); - if (!identifier.match(/^[A-Z_][0-9A-Z_]+$/i)) { + if (!identifier.match(/^[A-Z_][0-9A-Z_-]+$/i)) { throw new Error( `Identifier function returned invalid indentifier: "${identifier}"`, ); diff --git a/site/docs/integrations/webpack.md b/site/docs/integrations/webpack.md index 6665aa12c..39e0a00a6 100644 --- a/site/docs/integrations/webpack.md +++ b/site/docs/integrations/webpack.md @@ -94,7 +94,7 @@ Different formatting of identifiers (e.g. class names, keyframes, CSS Vars, etc) - A custom identifier function takes an object parameter with properties `hash`, `filePath`, `debugId`, and `packageName`, and returns a customized identifier. e.g. ```ts -VanillaExtractPlugin({ +new VanillaExtractPlugin({ identifiers: ({ hash }) => `prefix_${hash}` }); ```