From 300f5f9ba37f58f269987f69d54e132c9bdc6ed3 Mon Sep 17 00:00:00 2001 From: Jonathan Zempel Date: Fri, 10 Jan 2025 12:07:44 -0500 Subject: [PATCH] fix(theming): return hex from generated `getColor` values (#1999) --- .../theming/demo/stories/GetColorStory.tsx | 92 +++++++++++++++---- packages/theming/src/utils/getColor.ts | 4 +- 2 files changed, 75 insertions(+), 21 deletions(-) diff --git a/packages/theming/demo/stories/GetColorStory.tsx b/packages/theming/demo/stories/GetColorStory.tsx index 5863cf4c5a..03dd675f18 100644 --- a/packages/theming/demo/stories/GetColorStory.tsx +++ b/packages/theming/demo/stories/GetColorStory.tsx @@ -8,32 +8,40 @@ import React from 'react'; import { StoryFn } from '@storybook/react'; import styled, { useTheme } from 'styled-components'; -import { IGardenTheme, getCheckeredBackground, getColor } from '@zendeskgarden/react-theming'; +import { opacify } from 'color2k'; +import { + ColorParameters, + IGardenTheme, + getCheckeredBackground, + getColor +} from '@zendeskgarden/react-theming'; +import { LG, SM } from '@zendeskgarden/react-typography'; +import { Grid } from '@zendeskgarden/react-grid'; import { Tag } from '@zendeskgarden/react-tags'; -const StyledDiv = styled.div.attrs<{ background: string }>(p => ({ - style: { background: p.background } -}))<{ background: string }>` +const StyledDiv = styled.div.attrs<{ $background: string }>(p => ({ + style: { background: p.$background } +}))` display: flex; align-items: center; justify-content: center; + min-width: 32px; height: 208px; `; -interface IColorProps { - dark?: object; - hue?: string; - light?: object; - offset?: number; - shade?: number; - theme: IGardenTheme; - transparency?: number; - variable?: string; -} - -const Color = ({ dark, hue, light, offset, shade, theme, transparency, variable }: IColorProps) => { +const Color = ({ + dark, + hue, + light, + offset, + shade, + theme, + transparency, + variable +}: ColorParameters) => { let background; let tag; + let generatedHue; try { const backgroundColor = getColor({ @@ -57,19 +65,65 @@ const Color = ({ dark, hue, light, offset, shade, theme, transparency, variable {backgroundColor} ); + + if (!variable) { + const hues = [...Object.keys(theme.colors), ...Object.keys(theme.palette)].filter( + _hue => _hue !== 'base' && _hue !== 'variables' + ); + const selectedHue = (theme.colors.base === 'dark' ? dark?.hue : light?.hue) || hue || ''; + + if (!hues.includes(selectedHue)) { + generatedHue = [...Array(12).keys()].reduce>((retVal, index) => { + const _shade = (index + 1) * 100; + + retVal[_shade] = getColor({ theme, hue: opacify(backgroundColor, 1), shade: _shade }); + + return retVal; + }, {}); + + /* eslint-disable-next-line no-console */ + console.log(generatedHue); + } + } } catch (error) { background = 'transparent'; tag = ( - + {error instanceof Error ? error.message : String(error)} ); } - return {tag}; + return ( + <> + {tag} + {!!generatedHue && ( + <> + Generated hue + + + {Object.entries(generatedHue).map(([_shade, backgroundColor], index) => ( + + + + {backgroundColor} + + + {_shade} + + ))} + + + + )} + + ); }; -interface IArgs extends Omit { +interface IArgs extends Omit { theme: { colors: Omit; opacity: IGardenTheme['opacity']; diff --git a/packages/theming/src/utils/getColor.ts b/packages/theming/src/utils/getColor.ts index baa106614c..6c8e953970 100644 --- a/packages/theming/src/utils/getColor.ts +++ b/packages/theming/src/utils/getColor.ts @@ -5,7 +5,7 @@ * found at http://www.apache.org/licenses/LICENSE-2.0. */ -import { getScale, parseToRgba } from 'color2k'; +import { getScale, parseToRgba, toHex as _toHex } from 'color2k'; import { darken, getContrast, lighten, rgba } from 'polished'; import get from 'lodash.get'; import memoize from 'lodash.memoize'; @@ -151,7 +151,7 @@ const generateColorScale = memoize((color: string) => { const contrastRatios = []; for (let i = 0; i <= scaleSize; i++) { - const _color = scale(i); + const _color = _toHex(scale(i)); colors.push(_color); contrastRatios.push(getContrast('#FFF', _color)); }