Skip to content

Commit a3dc029

Browse files
committed
Revert "chore(Checkbox): Remove the CSS modules feature flag from Checkbox (#5338)"
This reverts commit 4c7056b.
1 parent 598d91f commit a3dc029

File tree

3 files changed

+122
-17
lines changed

3 files changed

+122
-17
lines changed

.changeset/stupid-elephants-work.md

Lines changed: 0 additions & 5 deletions
This file was deleted.

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, options: {skipAs: true}})
12+
behavesAsComponent({Component: Checkbox})
1313

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

packages/react/src/Checkbox/Checkbox.tsx

Lines changed: 121 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,17 @@
11
import {clsx} from 'clsx'
2+
import styled from 'styled-components'
23
import {useProvidedRefOrCreate} from '../hooks'
34
import React, {useContext, useEffect, type ChangeEventHandler, type InputHTMLAttributes, type ReactElement} from 'react'
4-
import {type SxProp} from '../sx'
5+
import sx, {type SxProp} from '../sx'
56
import useLayoutEffect from '../utils/useIsomorphicLayoutEffect'
67
import type {FormValidationStatus} from '../utils/types/FormValidationStatus'
78
import {CheckboxGroupContext} from '../CheckboxGroup/CheckboxGroupContext'
9+
import getGlobalFocusStyles from '../internal/utils/getGlobalFocusStyles'
10+
import {get} from '../constants'
11+
import {sharedCheckboxAndRadioStyles} from '../internal/utils/sharedCheckboxAndRadioStyles'
812
import classes from './Checkbox.module.css'
913
import sharedClasses from './shared.module.css'
14+
import {useFeatureFlag} from '../FeatureFlags'
1015
import Box from '../Box'
1116

1217
export type CheckboxProps = {
@@ -38,6 +43,106 @@ export type CheckboxProps = {
3843
} & Exclude<InputHTMLAttributes<HTMLInputElement>, 'value'> &
3944
SxProp
4045

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+
41146
/**
42147
* An accessible, native checkbox component
43148
*/
@@ -58,6 +163,7 @@ const Checkbox = React.forwardRef<HTMLInputElement, CheckboxProps>(
58163
},
59164
ref,
60165
): ReactElement => {
166+
const enabled = useFeatureFlag('primer_react_css_modules_ga')
61167
const checkboxRef = useProvidedRefOrCreate(ref as React.RefObject<HTMLInputElement>)
62168
const checkboxGroupContext = useContext(CheckboxGroupContext)
63169
const handleOnChange: ChangeEventHandler<HTMLInputElement> = e => {
@@ -98,17 +204,21 @@ const Checkbox = React.forwardRef<HTMLInputElement, CheckboxProps>(
98204
}
99205
})
100206

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-
)
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)} />
110219
}
111-
return <input {...inputProps} className={clsx(className, sharedClasses.Input, classes.Checkbox)} />
220+
221+
return <StyledCheckbox {...inputProps} className={className} sx={sxProp} />
112222
},
113223
)
114224

0 commit comments

Comments
 (0)