From 2d160ccd7078caa79e84a8ca19c640e5dae800f8 Mon Sep 17 00:00:00 2001 From: Asman Umbetov Date: Mon, 18 Mar 2024 23:18:40 +0300 Subject: [PATCH] fix(#209) fixes issue with parsing of nested variables --- addon/src/parsers/postcss.parser.ts | 36 ++++++++++------------------- 1 file changed, 12 insertions(+), 24 deletions(-) diff --git a/addon/src/parsers/postcss.parser.ts b/addon/src/parsers/postcss.parser.ts index 836d94d..6c6f37f 100644 --- a/addon/src/parsers/postcss.parser.ts +++ b/addon/src/parsers/postcss.parser.ts @@ -184,36 +184,24 @@ function determineTokenValue( ): string { rawValue = rawValue.replace(/!default/g, "").replace(/!global/g, ""); - const cssVars = "(var\\(([a-zA-Z0-9-_]+)\\))"; - const scssVars = "(\\$([a-zA-Z0-9-_]+))"; - const lessVars = "(\\@([a-zA-Z0-9-_]+))"; - - const vars = [!preserveCSSVars && cssVars, scssVars, lessVars].filter( - Boolean - ) as string[]; - - const referencedVariableResult = new RegExp(`^(${vars.join("|")})$`).exec( - rawValue - ); - - const referencedVariable = - referencedVariableResult?.[3] || - referencedVariableResult?.[5] || - referencedVariableResult?.[7]; - - if (referencedVariable) { - const value = + const regex = /\bvar\(([^)]+)\)|(\$[a-zA-Z0-9-_]+|@[a-zA-Z0-9-_]+)/g; + let match; + let replacedString = rawValue; + while ((match = regex.exec(rawValue)) !== null) { + const variableMatch = match[0]; + const variableName = variableMatch.replace(/\(|\)|var\(|@|\$/g, ""); + const replacement = declarations.find( (declaration) => - declaration.prop === referencedVariable || - declaration.prop === `$${referencedVariable}` || - declaration.prop === `@${referencedVariable}` + declaration.prop === variableName || + declaration.prop === `$${variableName}` || + declaration.prop === `@${variableName}` )?.value || ""; - return determineTokenValue(value, declarations, preserveCSSVars); + replacedString = replacedString.replace(variableMatch, replacement); } - return rawValue; + return replacedString; } async function getNodes(files: File[]): Promise<{