Skip to content

Commit 4c7056b

Browse files
authored
chore(Checkbox): Remove the CSS modules feature flag from Checkbox (#5338)
* Remove CSS modules feature flag from Checkbox * Create stupid-elephants-work.md
1 parent 9885564 commit 4c7056b

File tree

3 files changed

+17
-122
lines changed

3 files changed

+17
-122
lines changed
Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
---
2+
"@primer/react": minor
3+
---
4+
5+
Remove the CSS modules feature flag from Checkbox

packages/react/src/Checkbox/Checkbox.test.tsx

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@ describe('Checkbox', () => {
99
beforeEach(() => {
1010
jest.resetAllMocks()
1111
})
12-
behavesAsComponent({Component: Checkbox})
12+
behavesAsComponent({Component: Checkbox, options: {skipAs: true}})
1313

1414
checkExports('Checkbox', {
1515
default: Checkbox,

packages/react/src/Checkbox/Checkbox.tsx

Lines changed: 11 additions & 121 deletions
Original file line numberDiff line numberDiff line change
@@ -1,17 +1,12 @@
11
import {clsx} from 'clsx'
2-
import styled from 'styled-components'
32
import {useProvidedRefOrCreate} from '../hooks'
43
import React, {useContext, useEffect, type ChangeEventHandler, type InputHTMLAttributes, type ReactElement} from 'react'
5-
import sx, {type SxProp} from '../sx'
4+
import {type SxProp} from '../sx'
65
import useLayoutEffect from '../utils/useIsomorphicLayoutEffect'
76
import type {FormValidationStatus} from '../utils/types/FormValidationStatus'
87
import {CheckboxGroupContext} from '../CheckboxGroup/CheckboxGroupContext'
9-
import getGlobalFocusStyles from '../internal/utils/getGlobalFocusStyles'
10-
import {get} from '../constants'
11-
import {sharedCheckboxAndRadioStyles} from '../internal/utils/sharedCheckboxAndRadioStyles'
128
import classes from './Checkbox.module.css'
139
import sharedClasses from './shared.module.css'
14-
import {useFeatureFlag} from '../FeatureFlags'
1510
import Box from '../Box'
1611

1712
export type CheckboxProps = {
@@ -43,106 +38,6 @@ export type CheckboxProps = {
4338
} & Exclude<InputHTMLAttributes<HTMLInputElement>, 'value'> &
4439
SxProp
4540

46-
const StyledCheckbox = styled.input`
47-
${sharedCheckboxAndRadioStyles};
48-
border-radius: ${get('radii.1')};
49-
transition:
50-
background-color,
51-
border-color 80ms cubic-bezier(0.33, 1, 0.68, 1); /* checked -> unchecked - add 120ms delay to fully see animation-out */
52-
53-
&::before {
54-
width: var(--base-size-16, 16px);
55-
height: var(--base-size-16, 16px);
56-
visibility: hidden;
57-
content: '';
58-
background-color: ${get('colors.fg.onEmphasis')};
59-
transition: visibility 0s linear 230ms;
60-
clip-path: inset(var(--base-size-16, 16px) 0 0 0);
61-
mask-image: url('');
62-
mask-size: 75%;
63-
mask-repeat: no-repeat;
64-
mask-position: center;
65-
66-
animation: checkmarkOut 80ms cubic-bezier(0.65, 0, 0.35, 1) forwards;
67-
}
68-
69-
&:checked,
70-
&:indeterminate {
71-
background: var(--control-checked-bgColor-rest, ${get('colors.accent.fg')});
72-
border-color: var(
73-
--control-checked-bgColor-rest,
74-
${get('colors.accent.fg')}
75-
); /* using bgColor here to avoid a border change in dark high contrast */
76-
77-
&::before {
78-
animation: checkmarkIn 80ms cubic-bezier(0.65, 0, 0.35, 1) forwards 80ms;
79-
}
80-
}
81-
82-
&:disabled {
83-
cursor: not-allowed;
84-
}
85-
86-
&:checked {
87-
transition:
88-
background-color,
89-
border-color 80ms cubic-bezier(0.32, 0, 0.67, 0) 0ms;
90-
91-
&::before {
92-
visibility: visible;
93-
transition: visibility 0s linear 0s;
94-
}
95-
96-
&:disabled {
97-
background-color: var(--control-checked-bgColor-disabled, ${get('colors.fg.muted')});
98-
border-color: var(--control-checked-borderColor-disabled, ${get('colors.fg.muted')});
99-
opacity: 1;
100-
101-
&::before {
102-
background-color: var(--control-checked-fgColor-disabled, ${get('colors.fg.onEmphasis')});
103-
}
104-
}
105-
106-
/* Windows High Contrast mode */
107-
@media (forced-colors: active) {
108-
background-color: canvastext;
109-
border-color: canvastext;
110-
}
111-
}
112-
113-
&:indeterminate {
114-
background: var(--control-checked-bgColor-rest, ${get('colors.accent.fg')});
115-
&::before {
116-
mask-image: url('');
117-
visibility: visible;
118-
}
119-
}
120-
121-
${getGlobalFocusStyles()};
122-
123-
${sx};
124-
125-
@keyframes checkmarkIn {
126-
from {
127-
clip-path: inset(var(--base-size-16, 16px) 0 0 0);
128-
}
129-
130-
to {
131-
clip-path: inset(0 0 0 0);
132-
}
133-
}
134-
135-
@keyframes checkmarkOut {
136-
from {
137-
clip-path: inset(0 0 0 0);
138-
}
139-
140-
to {
141-
clip-path: inset(var(--base-size-16, 16px) 0 0 0);
142-
}
143-
}
144-
`
145-
14641
/**
14742
* An accessible, native checkbox component
14843
*/
@@ -163,7 +58,6 @@ const Checkbox = React.forwardRef<HTMLInputElement, CheckboxProps>(
16358
},
16459
ref,
16560
): ReactElement => {
166-
const enabled = useFeatureFlag('primer_react_css_modules_ga')
16761
const checkboxRef = useProvidedRefOrCreate(ref as React.RefObject<HTMLInputElement>)
16862
const checkboxGroupContext = useContext(CheckboxGroupContext)
16963
const handleOnChange: ChangeEventHandler<HTMLInputElement> = e => {
@@ -204,21 +98,17 @@ const Checkbox = React.forwardRef<HTMLInputElement, CheckboxProps>(
20498
}
20599
})
206100

207-
if (enabled) {
208-
if (sxProp) {
209-
return (
210-
<Box
211-
as="input"
212-
{...inputProps}
213-
className={clsx(className, sharedClasses.Input, classes.Checkbox)}
214-
sx={sxProp}
215-
/>
216-
)
217-
}
218-
return <input {...inputProps} className={clsx(className, sharedClasses.Input, classes.Checkbox)} />
101+
if (sxProp) {
102+
return (
103+
<Box
104+
as="input"
105+
{...inputProps}
106+
className={clsx(className, sharedClasses.Input, classes.Checkbox)}
107+
sx={sxProp}
108+
/>
109+
)
219110
}
220-
221-
return <StyledCheckbox {...inputProps} className={className} sx={sxProp} />
111+
return <input {...inputProps} className={clsx(className, sharedClasses.Input, classes.Checkbox)} />
222112
},
223113
)
224114

0 commit comments

Comments
 (0)