Skip to content

Commit

Permalink
feat(suite): Add cursor: not-allowed to disabled components (#12945)
Browse files Browse the repository at this point in the history
  • Loading branch information
hstastna committed Jun 24, 2024
1 parent ef5b83e commit 307c74c
Show file tree
Hide file tree
Showing 8 changed files with 126 additions and 24 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,37 @@ export default meta;
export const Button: StoryObj<ButtonProps> = {
args: {
children: 'Button label',
variant: 'primary',
size: 'medium',
isDisabled: false,
isLoading: false,
isFullWidth: false,
iconAlignment: 'left',
title: 'Button title',
...framePropsStory.args,
},
argTypes: framePropsStory.argTypes,
argTypes: {
variant: {
control: {
type: 'radio',
},
options: ['primary', 'secondary', 'tertiary', 'info', 'warning', 'destructive'],
},
size: {
control: {
type: 'radio',
},
options: ['large', 'medium', 'small', 'tiny'],
},
icon: { control: 'text' },
iconSize: { control: 'number' },
iconAlignment: {
control: {
type: 'radio',
},
options: ['left', 'right'],
},
title: { control: 'text' },
...framePropsStory.argTypes,
},
};
3 changes: 1 addition & 2 deletions packages/components/src/components/buttons/Button/Button.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,7 @@ export const ButtonContainer = styled.button<ButtonContainerProps>`
&:disabled {
background: ${({ theme }) => theme.BG_GREY};
color: ${({ theme }) => theme.textDisabled};
pointer-events: none;
cursor: default;
cursor: not-allowed;
}
${withFrameProps}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,26 @@ export const Checkbox: StoryObj<CheckboxProps> = {
},
args: {
children: 'Checkbox',
variant: 'primary',
isChecked: false,
isDisabled: false,
labelAlignment: 'right',
...framePropsStory.args,
},

argTypes: framePropsStory.argTypes,
argTypes: {
variant: {
control: {
type: 'radio',
},
options: ['primary', 'warning', 'destructive'],
},
labelAlignment: {
control: {
type: 'radio',
},
options: ['left', 'right'],
},
...framePropsStory.argTypes,
},
};
16 changes: 14 additions & 2 deletions packages/components/src/components/form/Checkbox/Checkbox.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,11 @@ export const CheckContainer = styled.div<{ $variant: CheckboxVariant }>`
border-color: ${({ theme, $variant }) => theme[variantStyles[$variant].borderChecked]};
}
input:disabled + && {
cursor: not-allowed;
pointer-events: auto;
}
input:disabled:not(:checked) + && {
background: ${({ theme, $variant }) => theme[variantStyles[$variant].backgroundDisabled]};
border-color: ${({ theme, $variant }) => theme[variantStyles[$variant].borderDisabled]};
Expand Down Expand Up @@ -171,7 +176,10 @@ export const Checkbox = ({
const theme = useTheme();

const handleKeyUp = (event: KeyboardEvent<HTMLElement>) => {
if (event.code === KEYBOARD_CODE.SPACE || event.code === KEYBOARD_CODE.ENTER) {
if (
isDisabled !== true &&
(event.code === KEYBOARD_CODE.SPACE || event.code === KEYBOARD_CODE.ENTER)
) {
onClick(event);
}
};
Expand All @@ -180,11 +188,15 @@ export const Checkbox = ({
margin,
};

const onClickHandler = (event: SyntheticEvent) => {
if (isDisabled !== true) return onClick(event);
};

return (
<Container
$isDisabled={isDisabled}
$labelAlignment={labelAlignment}
onClick={onClick}
onClick={onClickHandler}
onKeyUp={handleKeyUp}
data-test={dataTest}
className={className}
Expand Down
38 changes: 23 additions & 15 deletions packages/components/src/components/form/Input/Input.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,34 +9,42 @@ const meta: Meta = {
args: {
value: 'Input',
label: 'Label',
bottomText: '',
isDisabled: false,
size: 'large',
inputState: null,
variant: null,
innerAddonAlign: 'right',
hasBottomPadding: true,
},
argTypes: {
labelRight: {
type: 'string',
bottomText: { control: 'text' },
labelHoverRight: { control: 'text' },
labelLeft: { control: 'text' },
labelRight: { control: 'text' },
innerAddon: { control: 'text' },
placeholder: { control: 'text' },
size: {
control: {
type: 'radio',
},
options: ['large', 'small'],
},
placeholder: {
type: 'string',
inputState: {
control: {
type: 'radio',
},
options: [null, 'warning', 'error'],
},
state: {
innerAddonAlign: {
control: {
options: {
'None (default)': null,
Success: 'success',
Warning: 'warning',
Error: 'error',
},
type: 'radio',
},
options: ['right', 'left'],
},
variant: {
showClearButton: {
control: {
options: { 'Large (default)': null, Small: 'small' },
type: 'radio',
},
options: [null, 'hover', 'always'],
},
},
} as Meta;
Expand Down
5 changes: 5 additions & 0 deletions packages/components/src/components/form/Input/Input.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,11 @@ const StyledInput = styled.input<StyledInputProps & { $isWithLabel: boolean }>`
height: ${({ $size }) => `${INPUT_HEIGHTS[$size as InputSize]}px`};
${baseInputStyle}
${({ $size }) => $size === 'small' && typography.hint};
&:disabled {
pointer-events: auto;
cursor: not-allowed;
}
`;

const InputWrapper = styled.div`
Expand Down
21 changes: 20 additions & 1 deletion packages/components/src/components/form/Radio/Radio.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,26 @@ export const RadioButton: StoryObj<RadioProps> = {
</RadioComponent>
);
},
args: { children: 'RadioButton' },
args: {
children: 'RadioButton',
variant: 'primary',
isChecked: false,
isDisabled: false,
},
argTypes: {
variant: {
control: {
type: 'radio',
},
options: ['primary', 'warning', 'destructive'],
},
labelAlignment: {
control: {
type: 'radio',
},
options: [null, 'left', 'right'],
},
},
};

export const RadioButtonGroup: StoryObj = {
Expand Down
15 changes: 13 additions & 2 deletions packages/components/src/components/form/Radio/Radio.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,10 @@ const RadioIcon = styled(CheckContainer)`
}
}
input:disabled + && {
cursor: not-allowed;
}
input:disabled:not(:checked) + && {
background: ${({ theme }) => theme.backgroundSurfaceElevation0};
border-color: ${({ theme, $variant }) => theme[variantStyles[$variant].borderDisabled]};
Expand Down Expand Up @@ -115,14 +119,21 @@ export const Radio = ({
children,
}: RadioProps) => {
const handleKeyUp = (event: KeyboardEvent<HTMLElement>) => {
if (event.code === KEYBOARD_CODE.SPACE || event.code === KEYBOARD_CODE.ENTER) {
if (
isDisabled !== true &&
(event.code === KEYBOARD_CODE.SPACE || event.code === KEYBOARD_CODE.ENTER)
) {
onClick(event);
}
};

const onClickHandler = (event: SyntheticEvent) => {
if (isDisabled !== true) return onClick(event);
};

return (
<Container
onClick={onClick}
onClick={onClickHandler}
onKeyUp={handleKeyUp}
$isDisabled={isDisabled}
$labelAlignment={labelAlignment}
Expand Down

0 comments on commit 307c74c

Please sign in to comment.