From f442f7aab83fa4d07fdd69537aa485029abecec7 Mon Sep 17 00:00:00 2001 From: Siriwat K Date: Wed, 11 Sep 2024 16:28:31 +0700 Subject: [PATCH] Support null as a value for CSS object (#229) --- .../src/utils/cssFnValueToVariable.ts | 5 +++- .../styled/fixtures/styled-theme.input.js | 24 +++++++++++++++++++ .../styled/fixtures/styled-theme.output.css | 6 +++++ .../styled/fixtures/styled-theme.output.js | 15 ++++++++++++ .../tests/styled/styled.test.tsx | 1 + 5 files changed, 50 insertions(+), 1 deletion(-) diff --git a/packages/pigment-css-react/src/utils/cssFnValueToVariable.ts b/packages/pigment-css-react/src/utils/cssFnValueToVariable.ts index 0ac97ff3..459b2757 100644 --- a/packages/pigment-css-react/src/utils/cssFnValueToVariable.ts +++ b/packages/pigment-css-react/src/utils/cssFnValueToVariable.ts @@ -153,10 +153,13 @@ function iterateAndReplaceFunctions( includeThemeArg = false, ) { const css = styleObj as StyleObj; + if (!css) { + return; + } Object.keys(css).forEach((key) => { const value = css[key]; - if (typeof value === 'object') { + if (value && typeof value === 'object') { if (!Array.isArray(value)) { iterateAndReplaceFunctions( value, diff --git a/packages/pigment-css-react/tests/styled/fixtures/styled-theme.input.js b/packages/pigment-css-react/tests/styled/fixtures/styled-theme.input.js index d06b7864..19715b7a 100644 --- a/packages/pigment-css-react/tests/styled/fixtures/styled-theme.input.js +++ b/packages/pigment-css-react/tests/styled/fixtures/styled-theme.input.js @@ -52,3 +52,27 @@ process.env.NODE_ENV !== 'production' : void 0; process.env.NODE_ENV !== 'production' ? (App.muiName = 'App') : void 0; + +const OutlinedInputInput = styled(InputBaseInput, { + name: 'MuiOutlinedInput', + slot: 'Input', + overridesResolver: inputBaseInputOverridesResolver, +})(({ theme }) => ({ + padding: '16.5px 14px', + ...(!theme.vars && { + '&:-webkit-autofill': { + WebkitBoxShadow: theme.palette.mode === 'light' ? null : '0 0 0 100px #266798 inset', + WebkitTextFillColor: theme.palette.mode === 'light' ? null : '#fff', + caretColor: theme.palette.mode === 'light' ? null : '#fff', + borderRadius: 'inherit', + }, + }), +})); + +const Component2 = styled.div(({ theme }) => + theme.palette.mode === 'light' + ? null + : { + backgroundColor: theme.palette.primary.main, + }, +); diff --git a/packages/pigment-css-react/tests/styled/fixtures/styled-theme.output.css b/packages/pigment-css-react/tests/styled/fixtures/styled-theme.output.css index 2d6da655..629d9940 100644 --- a/packages/pigment-css-react/tests/styled/fixtures/styled-theme.output.css +++ b/packages/pigment-css-react/tests/styled/fixtures/styled-theme.output.css @@ -29,3 +29,9 @@ .s1emg10t .s13xim6i { display: none; } +.o1l8bn4d { + padding: 16.5px 14px; +} +.o1l8bn4d:-webkit-autofill { + border-radius: inherit; +} diff --git a/packages/pigment-css-react/tests/styled/fixtures/styled-theme.output.js b/packages/pigment-css-react/tests/styled/fixtures/styled-theme.output.js index 3e3eae8b..4e06eb3d 100644 --- a/packages/pigment-css-react/tests/styled/fixtures/styled-theme.output.js +++ b/packages/pigment-css-react/tests/styled/fixtures/styled-theme.output.js @@ -1,3 +1,7 @@ +import { styled as _styled5 } from '@pigment-css/react'; +import _theme3 from '@pigment-css/react/theme'; +import { styled as _styled4 } from '@pigment-css/react'; +import _theme2 from '@pigment-css/react/theme'; import { styled as _styled, styled as _styled2, styled as _styled3 } from '@pigment-css/react'; import _theme from '@pigment-css/react/theme'; import PropTypes from 'prop-types'; @@ -27,3 +31,14 @@ process.env.NODE_ENV !== 'production' }) : void 0; process.env.NODE_ENV !== 'production' ? (App.muiName = 'App') : void 0; +const _exp7 = /*#__PURE__*/ () => InputBaseInput; +const OutlinedInputInput = /*#__PURE__*/ _styled4(_exp7(), { + name: 'MuiOutlinedInput', + slot: 'Input', + overridesResolver: inputBaseInputOverridesResolver, +})({ + classes: ['o1l8bn4d'], +}); +const Component2 = /*#__PURE__*/ _styled5('div')({ + classes: ['c14kh110'], +}); diff --git a/packages/pigment-css-react/tests/styled/styled.test.tsx b/packages/pigment-css-react/tests/styled/styled.test.tsx index 76cbf626..c12f42ed 100644 --- a/packages/pigment-css-react/tests/styled/styled.test.tsx +++ b/packages/pigment-css-react/tests/styled/styled.test.tsx @@ -3,6 +3,7 @@ import { runTransformation, expect } from '../testUtils'; const theme = { palette: { + mode: 'light', primary: { main: 'red', },