@tamagui/checkbox 1.74.19 → 1.74.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/Checkbox.js +81 -83
- package/dist/cjs/Checkbox.js.map +1 -1
- package/dist/cjs/Checkbox.native.js +89 -91
- package/dist/cjs/Checkbox.native.js.map +1 -1
- package/dist/esm/Checkbox.js +81 -83
- package/dist/esm/Checkbox.js.map +1 -1
- package/dist/esm/Checkbox.native.js +89 -91
- package/dist/esm/Checkbox.native.js.map +1 -1
- package/dist/jsx/Checkbox.js +72 -74
- package/dist/jsx/Checkbox.js.map +1 -1
- package/dist/jsx/Checkbox.native.js +80 -82
- package/dist/jsx/Checkbox.native.js.map +1 -1
- package/package.json +12 -12
- package/src/Checkbox.tsx +134 -137
- package/types/Checkbox.d.ts +1426 -321
- package/types/Checkbox.d.ts.map +1 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/Checkbox.tsx"],
|
|
4
|
-
"mappings": "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
|
|
4
|
+
"mappings": "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",
|
|
5
5
|
"names": ["Checkbox"]
|
|
6
6
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tamagui/checkbox",
|
|
3
|
-
"version": "1.74.
|
|
3
|
+
"version": "1.74.21",
|
|
4
4
|
"sideEffects": [
|
|
5
5
|
"*.css"
|
|
6
6
|
],
|
|
@@ -23,16 +23,16 @@
|
|
|
23
23
|
"clean:build": "tamagui-build clean:build"
|
|
24
24
|
},
|
|
25
25
|
"dependencies": {
|
|
26
|
-
"@tamagui/core": "1.74.
|
|
27
|
-
"@tamagui/create-context": "1.74.
|
|
28
|
-
"@tamagui/focusable": "1.74.
|
|
29
|
-
"@tamagui/font-size": "1.74.
|
|
30
|
-
"@tamagui/get-token": "1.74.
|
|
31
|
-
"@tamagui/helpers-tamagui": "1.74.
|
|
32
|
-
"@tamagui/label": "1.74.
|
|
33
|
-
"@tamagui/stacks": "1.74.
|
|
34
|
-
"@tamagui/use-controllable-state": "1.74.
|
|
35
|
-
"@tamagui/use-previous": "1.74.
|
|
26
|
+
"@tamagui/core": "1.74.21",
|
|
27
|
+
"@tamagui/create-context": "1.74.21",
|
|
28
|
+
"@tamagui/focusable": "1.74.21",
|
|
29
|
+
"@tamagui/font-size": "1.74.21",
|
|
30
|
+
"@tamagui/get-token": "1.74.21",
|
|
31
|
+
"@tamagui/helpers-tamagui": "1.74.21",
|
|
32
|
+
"@tamagui/label": "1.74.21",
|
|
33
|
+
"@tamagui/stacks": "1.74.21",
|
|
34
|
+
"@tamagui/use-controllable-state": "1.74.21",
|
|
35
|
+
"@tamagui/use-previous": "1.74.21"
|
|
36
36
|
},
|
|
37
37
|
"exports": {
|
|
38
38
|
"./package.json": "./package.json",
|
|
@@ -46,7 +46,7 @@
|
|
|
46
46
|
"react": "*"
|
|
47
47
|
},
|
|
48
48
|
"devDependencies": {
|
|
49
|
-
"@tamagui/build": "1.74.
|
|
49
|
+
"@tamagui/build": "1.74.21",
|
|
50
50
|
"react": "^18.2.0"
|
|
51
51
|
},
|
|
52
52
|
"publishConfig": {
|
package/src/Checkbox.tsx
CHANGED
|
@@ -266,8 +266,8 @@ const [CheckboxProvider, useCheckboxContext] =
|
|
|
266
266
|
createCheckboxContext<CheckboxContextValue>(CHECKBOX_NAME)
|
|
267
267
|
|
|
268
268
|
type CheckboxFrameProps = GetProps<typeof CheckboxFrame>
|
|
269
|
-
|
|
270
|
-
|
|
269
|
+
|
|
270
|
+
type CheckboxExtraProps = {
|
|
271
271
|
checked?: CheckedState
|
|
272
272
|
defaultChecked?: CheckedState
|
|
273
273
|
required?: boolean
|
|
@@ -285,148 +285,145 @@ export interface CheckboxProps
|
|
|
285
285
|
sizeAdjust?: number
|
|
286
286
|
}
|
|
287
287
|
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
288
|
+
export type CheckboxProps = Omit<CheckboxFrameProps, 'checked' | 'defaultChecked'> &
|
|
289
|
+
CheckboxExtraProps
|
|
290
|
+
|
|
291
|
+
const CheckboxComponent = CheckboxFrame.styleable<CheckboxExtraProps>(function Checkbox(
|
|
292
|
+
props: ScopedProps<CheckboxProps>,
|
|
293
|
+
forwardedRef
|
|
294
|
+
) {
|
|
295
|
+
const {
|
|
296
|
+
__scopeCheckbox,
|
|
297
|
+
labelledBy: ariaLabelledby,
|
|
298
|
+
name,
|
|
299
|
+
checked: checkedProp,
|
|
300
|
+
defaultChecked,
|
|
301
|
+
required,
|
|
302
|
+
scaleSize = 0.45,
|
|
303
|
+
sizeAdjust = 0,
|
|
304
|
+
disabled,
|
|
305
|
+
value = 'on',
|
|
306
|
+
onCheckedChange,
|
|
307
|
+
native,
|
|
308
|
+
scaleIcon,
|
|
309
|
+
...checkboxProps
|
|
310
|
+
} = props
|
|
311
|
+
const [button, setButton] = React.useState<HTMLButtonElement | null>(null)
|
|
312
|
+
const composedRefs = useComposedRefs(forwardedRef, (node) => setButton(node as any))
|
|
313
|
+
const hasConsumerStoppedPropagationRef = React.useRef(false)
|
|
314
|
+
const propsActive = useProps(props)
|
|
315
|
+
// We set this to true by default so that events bubble to forms without JS (SSR)
|
|
316
|
+
const isFormControl = isWeb ? (button ? Boolean(button.closest('form')) : true) : false
|
|
317
|
+
const [checked = false, setChecked] = useControllableState({
|
|
318
|
+
prop: checkedProp,
|
|
319
|
+
defaultProp: defaultChecked!,
|
|
320
|
+
onChange: onCheckedChange,
|
|
321
|
+
})
|
|
322
|
+
|
|
323
|
+
// TODO: this could be null - fix the type
|
|
324
|
+
const styledContext = React.useContext(CheckboxStyledContext)
|
|
325
|
+
const adjustedSize = getVariableValue(
|
|
326
|
+
getSize(propsActive.size ?? styledContext?.size ?? '$true', {
|
|
327
|
+
shift: sizeAdjust,
|
|
323
328
|
})
|
|
329
|
+
) as number
|
|
330
|
+
const size = scaleSize ? Math.round(adjustedSize * scaleSize) : adjustedSize
|
|
331
|
+
|
|
332
|
+
const labelId = useLabelContext(button)
|
|
333
|
+
const labelledBy = ariaLabelledby || labelId
|
|
324
334
|
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
335
|
+
if (process.env.TAMAGUI_TARGET === 'native') {
|
|
336
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
|
337
|
+
React.useEffect(() => {
|
|
338
|
+
if (!props.id) return
|
|
339
|
+
if (disabled) return
|
|
340
|
+
|
|
341
|
+
return registerFocusable(props.id, {
|
|
342
|
+
focusAndSelect: () => {
|
|
343
|
+
setChecked((x) => !x)
|
|
344
|
+
},
|
|
345
|
+
focus: () => {},
|
|
330
346
|
})
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
const labelId = useLabelContext(button)
|
|
335
|
-
const labelledBy = ariaLabelledby || labelId
|
|
336
|
-
|
|
337
|
-
if (process.env.TAMAGUI_TARGET === 'native') {
|
|
338
|
-
// eslint-disable-next-line react-hooks/rules-of-hooks
|
|
339
|
-
React.useEffect(() => {
|
|
340
|
-
if (!props.id) return
|
|
341
|
-
if (disabled) return
|
|
342
|
-
|
|
343
|
-
return registerFocusable(props.id, {
|
|
344
|
-
focusAndSelect: () => {
|
|
345
|
-
setChecked((x) => !x)
|
|
346
|
-
},
|
|
347
|
-
focus: () => {},
|
|
348
|
-
})
|
|
349
|
-
}, [props.id, setChecked, disabled])
|
|
350
|
-
}
|
|
347
|
+
}, [props.id, setChecked, disabled])
|
|
348
|
+
}
|
|
351
349
|
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
350
|
+
return (
|
|
351
|
+
<CheckboxProvider scope={__scopeCheckbox} state={checked} disabled={disabled}>
|
|
352
|
+
{isWeb && native ? (
|
|
353
|
+
<BubbleInput
|
|
354
|
+
control={button}
|
|
355
|
+
bubbles={!hasConsumerStoppedPropagationRef.current}
|
|
356
|
+
name={name}
|
|
357
|
+
value={value}
|
|
358
|
+
checked={checked}
|
|
359
|
+
required={required}
|
|
360
|
+
disabled={disabled}
|
|
361
|
+
id={props.id}
|
|
362
|
+
/>
|
|
363
|
+
) : (
|
|
364
|
+
<>
|
|
365
|
+
<CheckboxFrame
|
|
366
|
+
width={size}
|
|
367
|
+
height={size}
|
|
368
|
+
tag="button"
|
|
369
|
+
role="checkbox"
|
|
370
|
+
aria-labelledby={labelledBy}
|
|
371
|
+
aria-checked={isIndeterminate(checked) ? 'mixed' : checked}
|
|
372
|
+
aria-required={required}
|
|
373
|
+
data-state={getState(checked)}
|
|
374
|
+
data-disabled={disabled ? '' : undefined}
|
|
362
375
|
disabled={disabled}
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
aria-checked={isIndeterminate(checked) ? 'mixed' : checked}
|
|
374
|
-
aria-required={required}
|
|
375
|
-
data-state={getState(checked)}
|
|
376
|
-
data-disabled={disabled ? '' : undefined}
|
|
377
|
-
disabled={disabled}
|
|
378
|
-
{...checkboxProps}
|
|
379
|
-
ref={composedRefs}
|
|
380
|
-
{...(isWeb && {
|
|
381
|
-
type: 'button',
|
|
382
|
-
value,
|
|
383
|
-
onKeyDown: composeEventHandlers(
|
|
384
|
-
(props as React.HTMLProps<HTMLButtonElement>).onKeyDown,
|
|
385
|
-
(event) => {
|
|
386
|
-
// According to WAI ARIA, Checkboxes don't activate on enter keypress
|
|
387
|
-
if (event.key === 'Enter') event.preventDefault()
|
|
388
|
-
}
|
|
389
|
-
),
|
|
390
|
-
})}
|
|
391
|
-
onPress={composeEventHandlers(props.onPress as any, (event) => {
|
|
392
|
-
setChecked((prevChecked) =>
|
|
393
|
-
isIndeterminate(prevChecked) ? true : !prevChecked
|
|
394
|
-
)
|
|
395
|
-
if (isFormControl) {
|
|
396
|
-
hasConsumerStoppedPropagationRef.current = event.isPropagationStopped()
|
|
397
|
-
// if checkbox is in a form, stop propagation from the button so that we only propagate
|
|
398
|
-
// one click event (from the input). We propagate changes from an input so that native
|
|
399
|
-
// form validation works and form events reflect checkbox updates.
|
|
400
|
-
if (!hasConsumerStoppedPropagationRef.current) event.stopPropagation()
|
|
376
|
+
{...checkboxProps}
|
|
377
|
+
ref={composedRefs}
|
|
378
|
+
{...(isWeb && {
|
|
379
|
+
type: 'button',
|
|
380
|
+
value,
|
|
381
|
+
onKeyDown: composeEventHandlers(
|
|
382
|
+
(props as React.HTMLProps<HTMLButtonElement>).onKeyDown,
|
|
383
|
+
(event) => {
|
|
384
|
+
// According to WAI ARIA, Checkboxes don't activate on enter keypress
|
|
385
|
+
if (event.key === 'Enter') event.preventDefault()
|
|
401
386
|
}
|
|
402
|
-
|
|
387
|
+
),
|
|
388
|
+
})}
|
|
389
|
+
onPress={composeEventHandlers(props.onPress as any, (event) => {
|
|
390
|
+
setChecked((prevChecked) =>
|
|
391
|
+
isIndeterminate(prevChecked) ? true : !prevChecked
|
|
392
|
+
)
|
|
393
|
+
if (isFormControl) {
|
|
394
|
+
hasConsumerStoppedPropagationRef.current = event.isPropagationStopped()
|
|
395
|
+
// if checkbox is in a form, stop propagation from the button so that we only propagate
|
|
396
|
+
// one click event (from the input). We propagate changes from an input so that native
|
|
397
|
+
// form validation works and form events reflect checkbox updates.
|
|
398
|
+
if (!hasConsumerStoppedPropagationRef.current) event.stopPropagation()
|
|
399
|
+
}
|
|
400
|
+
})}
|
|
401
|
+
>
|
|
402
|
+
<CheckboxStyledContext.Provider
|
|
403
|
+
size={propsActive.size ?? styledContext?.size ?? '$true'}
|
|
404
|
+
scaleIcon={scaleIcon ?? styledContext?.scaleIcon ?? 1}
|
|
403
405
|
>
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
)}
|
|
426
|
-
</CheckboxProvider>
|
|
427
|
-
)
|
|
428
|
-
})
|
|
429
|
-
)
|
|
406
|
+
{propsActive.children}
|
|
407
|
+
</CheckboxStyledContext.Provider>
|
|
408
|
+
</CheckboxFrame>
|
|
409
|
+
|
|
410
|
+
{isWeb && isFormControl ? (
|
|
411
|
+
<BubbleInput
|
|
412
|
+
isHidden
|
|
413
|
+
control={button}
|
|
414
|
+
bubbles={!hasConsumerStoppedPropagationRef.current}
|
|
415
|
+
name={name}
|
|
416
|
+
value={value}
|
|
417
|
+
checked={checked}
|
|
418
|
+
required={required}
|
|
419
|
+
disabled={disabled}
|
|
420
|
+
/>
|
|
421
|
+
) : null}
|
|
422
|
+
</>
|
|
423
|
+
)}
|
|
424
|
+
</CheckboxProvider>
|
|
425
|
+
)
|
|
426
|
+
})
|
|
430
427
|
|
|
431
428
|
export const Checkbox = withStaticProperties(CheckboxComponent, {
|
|
432
429
|
Indicator: CheckboxIndicator,
|