From 1c17fa6e429e0ffee4a4209d90d67984237526a8 Mon Sep 17 00:00:00 2001 From: Vjacheslav Trushkin Date: Sun, 1 May 2022 21:58:47 +0300 Subject: [PATCH] Web component: fix custom dimensions when rendering span --- packages/icon/src/render/span.ts | 11 +++++++++-- packages/icon/tests/render-icon-test.ts | 2 +- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/packages/icon/src/render/span.ts b/packages/icon/src/render/span.ts index b9164db..fa39639 100644 --- a/packages/icon/src/render/span.ts +++ b/packages/icon/src/render/span.ts @@ -30,6 +30,13 @@ for (const prefix in propsToAddTo) { } } +/** + * Fix size: add 'px' to numbers + */ +function fixSize(value: string): string { + return value + (value.match(/^[-0-9.]+$/) ? 'px' : ''); +} + /** * Render node as */ @@ -60,8 +67,8 @@ export function renderSPAN( const svgStyle = node.style; const styles: Record = { '--svg': url, - 'width': renderAttribs.width, - 'height': renderAttribs.height, + 'width': fixSize(renderAttribs.width), + 'height': fixSize(renderAttribs.height), ...(useMask ? monotoneProps : coloredProps), }; diff --git a/packages/icon/tests/render-icon-test.ts b/packages/icon/tests/render-icon-test.ts index d5c8fe6..13e8e90 100644 --- a/packages/icon/tests/render-icon-test.ts +++ b/packages/icon/tests/render-icon-test.ts @@ -119,7 +119,7 @@ describe('Testing rendering loaded icon', () => { // Test HTML expect(node.innerHTML).toBe( - `` + `` ); }); });