From bd1ea96b11c053ea57f9a1c43a12f89ce30e0ae7 Mon Sep 17 00:00:00 2001 From: Pedro Bonamin Date: Fri, 29 Sep 2023 18:32:08 +0200 Subject: [PATCH] feat(radio): update radio input to match facelift designs --- cypress/e2e/ui/textInput.cy.ts | 2 +- src/primitives/radio/styles.ts | 6 ++-- src/theme/studioTheme/theme.ts | 2 +- src/theme/studioTheme/tints.ts | 2 +- stories/primitives/Radio.stories.tsx | 47 +++++++++++++++++++++++----- 5 files changed, 46 insertions(+), 13 deletions(-) diff --git a/cypress/e2e/ui/textInput.cy.ts b/cypress/e2e/ui/textInput.cy.ts index 4513c0edb..927203b96 100644 --- a/cypress/e2e/ui/textInput.cy.ts +++ b/cypress/e2e/ui/textInput.cy.ts @@ -7,7 +7,7 @@ context('Primitives/TextInput', () => { cy.get('#text-input-example + span').should( 'have.css', 'boxShadow', - 'rgb(34, 118, 252) 0px 0px 0px 1px inset, rgb(206, 210, 217) 0px 0px 0px 1px inset', + 'rgb(34, 218, 244) 0px 0px 0px 1px inset, rgb(230, 232, 236) 0px 0px 0px 1px inset', ) }) }) diff --git a/src/primitives/radio/styles.ts b/src/primitives/radio/styles.ts index dd7a02a27..06ea310f7 100644 --- a/src/primitives/radio/styles.ts +++ b/src/primitives/radio/styles.ts @@ -59,7 +59,7 @@ export function inputElementStyle(props: ThemeProps): ReturnType { height: ${rem(input.radio.markSize)}; width: ${rem(input.radio.markSize)}; border-radius: ${rem(input.radio.markSize / 2)}; - background: ${color.default.enabled.fg}; + background: ${color.default.enabled.bg2}; opacity: 0; } } @@ -89,7 +89,7 @@ export function inputElementStyle(props: ThemeProps): ReturnType { background: ${color.default.readOnly.bg}; &::after { - background: ${color.default.readOnly.fg}; + background: ${color.default.readOnly.border}; } } @@ -99,7 +99,7 @@ export function inputElementStyle(props: ThemeProps): ReturnType { background: ${color.default.disabled.bg}; &::after { - background: ${color.default.disabled.fg}; + background: ${color.default.disabled.border}; } } ` diff --git a/src/theme/studioTheme/theme.ts b/src/theme/studioTheme/theme.ts index 92669ccab..9b6ce0804 100644 --- a/src/theme/studioTheme/theme.ts +++ b/src/theme/studioTheme/theme.ts @@ -43,7 +43,7 @@ export const studioTheme: RootTheme = { radio: { size: 17, markSize: 9, - focusRing: {offset: 1, width: 1}, + focusRing: {offset: -1, width: 1}, }, switch: { width: 33, diff --git a/src/theme/studioTheme/tints.ts b/src/theme/studioTheme/tints.ts index d811fedd9..936dd2369 100644 --- a/src/theme/studioTheme/tints.ts +++ b/src/theme/studioTheme/tints.ts @@ -49,7 +49,7 @@ const defaultTints: { bg_accent: '500', bg_accent_hover: '400', bg_accent_active: '300', - bg_tint: '900', + bg_tint: '950', icon_default: '300', icon_inverted: hues.gray[900], border_base: '900', diff --git a/stories/primitives/Radio.stories.tsx b/stories/primitives/Radio.stories.tsx index 7a380a9b2..c939da153 100644 --- a/stories/primitives/Radio.stories.tsx +++ b/stories/primitives/Radio.stories.tsx @@ -2,6 +2,7 @@ import type {Meta, StoryObj} from '@storybook/react' import {ChangeEvent, useCallback, useState} from 'react' import {Flex, Radio, Stack} from '../../src/primitives' +import {matrixBuilder} from '../helpers/matrixBuilder' const meta: Meta = { argTypes: { @@ -52,13 +53,45 @@ export const InputStates: Story = { render: (props) => { return ( - - - - - - - + + {matrixBuilder({ + scheme: 'light', + columns: ['default', 'checked'], + rows: ['enabled', 'disabled', 'readOnly'], + title: '', + renderItem({row, column}) { + return ( + + + + ) + }, + })} + {matrixBuilder({ + scheme: 'dark', + columns: ['default', 'checked'], + rows: ['enabled', 'disabled', 'readOnly'], + title: '', + renderItem({row, column}) { + return ( + + + + ) + }, + })} )