From b76d4d57ef1c56d9d56c69a6ebbe325e8d7860db Mon Sep 17 00:00:00 2001 From: Roberto Redradix Date: Thu, 7 Sep 2023 10:50:17 +0200 Subject: [PATCH] refactor(core): serialize each CSS variable at a time --- packages/core/src/lib/outputters/css.ts | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/packages/core/src/lib/outputters/css.ts b/packages/core/src/lib/outputters/css.ts index 717b778..0c8d563 100644 --- a/packages/core/src/lib/outputters/css.ts +++ b/packages/core/src/lib/outputters/css.ts @@ -24,22 +24,25 @@ const serializeCssClass = (cssClassDefinition: CSSClassDefinition): string => { return [`${cssClassDefinition.selector} {`, ...cssValidProps, '}'].join('\n') } -const serializeCssCustomProperties = ( - cssCustomProperties: CSSCustomPropertyDefinition[], +const serializeCssCustomProperty = ( + cssCustomProperty: CSSCustomPropertyDefinition, + pad: number, ): string => { - const selector = ':root' - const cssDeclarations = cssCustomProperties.map( - ({ name, value }) => ` ${textToCssCustomProperyName(name)}: ${value};`, - ) + const { name, value } = cssCustomProperty + const padding = ' '.repeat(pad) - return [`${selector} {`, ...cssDeclarations, '}'].join('\n') + return `${padding}${textToCssCustomProperyName(name)}: ${value};` } const serializeCss = ( cssDefinitions: CSSClassDefinition[] | CSSCustomPropertyDefinition[], ): string => { if (areCssCustomPropertiesDefinitions(cssDefinitions)) { - return serializeCssCustomProperties(cssDefinitions) + const pad = 2 + const cssDeclarations = cssDefinitions.map((customPropertyDefinition) => + serializeCssCustomProperty(customPropertyDefinition, pad), + ) + return [`:root {`, ...cssDeclarations, '}'].join('\n') } else { return cssDefinitions.map(serializeCssClass).join('\n\n') }