@tamagui/switch 1.82.0 → 1.82.2
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/createSwitch.js +104 -99
- package/dist/cjs/createSwitch.js.map +1 -1
- package/dist/cjs/createSwitch.native.js +104 -99
- package/dist/cjs/createSwitch.native.js.map +1 -1
- package/dist/esm/createSwitch.js +104 -99
- package/dist/esm/createSwitch.js.map +1 -1
- package/dist/esm/createSwitch.native.js +104 -99
- package/dist/esm/createSwitch.native.js.map +1 -1
- package/dist/jsx/createSwitch.js +94 -89
- package/dist/jsx/createSwitch.js.map +1 -1
- package/dist/jsx/createSwitch.native.js +94 -89
- package/dist/jsx/createSwitch.native.js.map +1 -1
- package/package.json +12 -12
- package/src/createSwitch.tsx +141 -139
- package/types/createSwitch.d.ts.map +1 -1
package/src/createSwitch.tsx
CHANGED
|
@@ -123,155 +123,157 @@ export function createSwitch<F extends SwitchComponent, T extends SwitchThumbCom
|
|
|
123
123
|
)
|
|
124
124
|
})
|
|
125
125
|
|
|
126
|
-
const SwitchComponent = Frame.styleable<SwitchExtraProps>(
|
|
127
|
-
propsIn,
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
...switchProps
|
|
152
|
-
} = props
|
|
126
|
+
const SwitchComponent = Frame.styleable<SwitchExtraProps>(
|
|
127
|
+
function SwitchFrame(propsIn, forwardedRef) {
|
|
128
|
+
const styledContext = React.useContext(SwitchContext)
|
|
129
|
+
const props = useProps(propsIn, {
|
|
130
|
+
noNormalize: true,
|
|
131
|
+
noExpand: true,
|
|
132
|
+
resolveValues: 'none',
|
|
133
|
+
forComponent: Frame,
|
|
134
|
+
})
|
|
135
|
+
const {
|
|
136
|
+
labeledBy: ariaLabelledby,
|
|
137
|
+
name,
|
|
138
|
+
checked: checkedProp,
|
|
139
|
+
defaultChecked,
|
|
140
|
+
required,
|
|
141
|
+
disabled,
|
|
142
|
+
value = 'on',
|
|
143
|
+
onCheckedChange,
|
|
144
|
+
size = styledContext.size ?? '$true',
|
|
145
|
+
unstyled = styledContext.unstyled ?? false,
|
|
146
|
+
native: nativeProp,
|
|
147
|
+
nativeProps,
|
|
148
|
+
children,
|
|
149
|
+
...switchProps
|
|
150
|
+
} = props
|
|
153
151
|
|
|
154
|
-
|
|
152
|
+
const native = Array.isArray(nativeProp) ? nativeProp : [nativeProp]
|
|
155
153
|
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
154
|
+
const shouldRenderMobileNative =
|
|
155
|
+
(!isWeb && nativeProp === true) ||
|
|
156
|
+
(!isWeb && native.includes('mobile')) ||
|
|
157
|
+
(native.includes('android') && Platform.OS === 'android') ||
|
|
158
|
+
(native.includes('ios') && Platform.OS === 'ios')
|
|
161
159
|
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
160
|
+
const [button, setButton] = React.useState<HTMLButtonElement | null>(null)
|
|
161
|
+
const composedRefs = useComposedRefs(forwardedRef, setButton)
|
|
162
|
+
const labelId = useLabelContext(button)
|
|
163
|
+
const labelledBy = ariaLabelledby || labelId
|
|
164
|
+
const hasConsumerStoppedPropagationRef = React.useRef(false)
|
|
165
|
+
// We set this to true by default so that events bubble to forms without JS (SSR)
|
|
166
|
+
const isFormControl = isWeb
|
|
167
|
+
? button
|
|
168
|
+
? Boolean(button.closest('form'))
|
|
169
|
+
: true
|
|
170
|
+
: false
|
|
173
171
|
|
|
174
|
-
|
|
172
|
+
const [frameWidth, setFrameWidth] = React.useState(0)
|
|
175
173
|
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
174
|
+
const [checked = false, setChecked] = useControllableState({
|
|
175
|
+
prop: checkedProp,
|
|
176
|
+
defaultProp: defaultChecked || false,
|
|
177
|
+
onChange: onCheckedChange,
|
|
178
|
+
transition: true,
|
|
179
|
+
})
|
|
182
180
|
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
181
|
+
if (shouldRenderMobileNative) {
|
|
182
|
+
return (
|
|
183
|
+
<NativeSwitch
|
|
184
|
+
value={checkedProp}
|
|
185
|
+
onValueChange={onCheckedChange}
|
|
186
|
+
{...nativeProps}
|
|
187
|
+
/>
|
|
188
|
+
)
|
|
189
|
+
}
|
|
192
190
|
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
191
|
+
if (!isWeb) {
|
|
192
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
|
193
|
+
React.useEffect(() => {
|
|
194
|
+
if (!props.id) return
|
|
195
|
+
return registerFocusable(props.id, {
|
|
196
|
+
focus: () => {
|
|
197
|
+
setChecked((x) => !x)
|
|
198
|
+
},
|
|
199
|
+
})
|
|
200
|
+
}, [props.id, setChecked])
|
|
201
|
+
}
|
|
204
202
|
|
|
205
|
-
|
|
203
|
+
const isInsideButton = React.useContext(ButtonNestingContext)
|
|
206
204
|
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
>
|
|
246
|
-
<YStack
|
|
247
|
-
alignSelf="stretch"
|
|
248
|
-
flex={1}
|
|
249
|
-
onLayout={(e) => {
|
|
250
|
-
setFrameWidth(e.nativeEvent.layout.width)
|
|
251
|
-
}}
|
|
205
|
+
return (
|
|
206
|
+
<>
|
|
207
|
+
<ButtonNestingContext.Provider value={true}>
|
|
208
|
+
{/* @ts-expect-error todo */}
|
|
209
|
+
<Frame
|
|
210
|
+
tag={isInsideButton ? 'span' : 'button'}
|
|
211
|
+
unstyled={unstyled}
|
|
212
|
+
size={size}
|
|
213
|
+
checked={checked}
|
|
214
|
+
disabled={disabled}
|
|
215
|
+
frameWidth={frameWidth}
|
|
216
|
+
themeShallow
|
|
217
|
+
{...(!disableActiveTheme && {
|
|
218
|
+
theme: checked ? 'active' : null,
|
|
219
|
+
themeShallow: true,
|
|
220
|
+
})}
|
|
221
|
+
role="switch"
|
|
222
|
+
aria-checked={checked}
|
|
223
|
+
aria-labelledby={labelledBy}
|
|
224
|
+
aria-required={required}
|
|
225
|
+
data-state={getState(checked)}
|
|
226
|
+
data-disabled={disabled ? '' : undefined}
|
|
227
|
+
// @ts-ignore
|
|
228
|
+
tabIndex={disabled ? undefined : 0}
|
|
229
|
+
// @ts-ignore
|
|
230
|
+
value={value}
|
|
231
|
+
{...switchProps}
|
|
232
|
+
ref={composedRefs}
|
|
233
|
+
onPress={composeEventHandlers(props.onPress, (event) => {
|
|
234
|
+
setChecked((prevChecked) => !prevChecked)
|
|
235
|
+
if (isWeb && isFormControl) {
|
|
236
|
+
hasConsumerStoppedPropagationRef.current = event.isPropagationStopped()
|
|
237
|
+
// if switch is in a form, stop propagation from the button so that we only propagate
|
|
238
|
+
// one click event (from the input). We propagate changes from an input so that native
|
|
239
|
+
// form validation works and form events reflect switch updates.
|
|
240
|
+
if (!hasConsumerStoppedPropagationRef.current) event.stopPropagation()
|
|
241
|
+
}
|
|
242
|
+
})}
|
|
252
243
|
>
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
244
|
+
<YStack
|
|
245
|
+
alignSelf="stretch"
|
|
246
|
+
flex={1}
|
|
247
|
+
onLayout={(e) => {
|
|
248
|
+
setFrameWidth(e.nativeEvent.layout.width)
|
|
249
|
+
}}
|
|
250
|
+
>
|
|
251
|
+
{typeof children === 'function' ? children(checked) : children}
|
|
252
|
+
</YStack>
|
|
253
|
+
</Frame>
|
|
254
|
+
</ButtonNestingContext.Provider>
|
|
255
|
+
{isWeb && isFormControl && (
|
|
256
|
+
<BubbleInput
|
|
257
|
+
control={button}
|
|
258
|
+
bubbles={!hasConsumerStoppedPropagationRef.current}
|
|
259
|
+
name={name}
|
|
260
|
+
value={value}
|
|
261
|
+
checked={checked}
|
|
262
|
+
required={required}
|
|
263
|
+
disabled={disabled}
|
|
264
|
+
// We transform because the input is absolutely positioned but we have
|
|
265
|
+
// rendered it **after** the button. This pulls it back to sit on top
|
|
266
|
+
// of the button.
|
|
267
|
+
style={{ transform: 'translateX(-100%)' }}
|
|
268
|
+
/>
|
|
269
|
+
)}
|
|
270
|
+
</>
|
|
271
|
+
)
|
|
272
|
+
},
|
|
273
|
+
{
|
|
274
|
+
disableTheme: true,
|
|
275
|
+
}
|
|
276
|
+
)
|
|
275
277
|
|
|
276
278
|
/* ---------------------------------------------------------------------------------------------- */
|
|
277
279
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createSwitch.d.ts","sourceRoot":"","sources":["../src/createSwitch.tsx"],"names":[],"mappings":"AAEA,OAAO,EACL,WAAW,EACX,UAAU,EACV,UAAU,EACV,iCAAiC,EAElC,MAAM,eAAe,CAAA;AAOtB,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,EAEL,WAAW,IAAI,iBAAiB,EAEjC,MAAM,cAAc,CAAA;AAKrB,KAAK,iBAAiB,GAAG;IACvB,IAAI,CAAC,EAAE,UAAU,GAAG,MAAM,CAAA;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,KAAK,eAAe,GAAG,UAAU,GAAG,iBAAiB,CAAA;AAErD,MAAM,MAAM,gBAAgB,GAAG;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,MAAM,CAAC,EAAE,WAAW,CAAC,QAAQ,GAAG,KAAK,GAAG,SAAS,CAAC,CAAA;IAClD,WAAW,CAAC,EAAE,iBAAiB,CAAA;IAC/B,eAAe,CAAC,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAAA;CACzC,CAAA;AAED,MAAM,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,GAAG,gBAAgB,EAAE,UAAU,CAAC,GAAG;IAC/E,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,CAAC,CAAC,OAAO,EAAE,OAAO,KAAK,KAAK,CAAC,SAAS,CAAC,CAAA;CACrE,CAAA;AAED,KAAK,eAAe,GAAG,iCAAiC,CACtD,WAAW,EACX,iBAAiB,GAAG,gBAAgB,CACrC,CAAA;AAED,KAAK,oBAAoB,GAAG,iCAAiC,CAC3D,eAAe,EACf,iBAAiB,CAClB,CAAA;AAED,wBAAgB,YAAY,CAAC,CAAC,SAAS,eAAe,EAAE,CAAC,SAAS,oBAAoB,EAAE,EACtF,kBAAkB,EAClB,KAAiC,EACjC,KAA0B,GAC3B,EAAE;IACD,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,KAAK,CAAC,EAAE,CAAC,CAAA;IACT,KAAK,CAAC,EAAE,CAAC,CAAA;CACV;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"createSwitch.d.ts","sourceRoot":"","sources":["../src/createSwitch.tsx"],"names":[],"mappings":"AAEA,OAAO,EACL,WAAW,EACX,UAAU,EACV,UAAU,EACV,iCAAiC,EAElC,MAAM,eAAe,CAAA;AAOtB,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,EAEL,WAAW,IAAI,iBAAiB,EAEjC,MAAM,cAAc,CAAA;AAKrB,KAAK,iBAAiB,GAAG;IACvB,IAAI,CAAC,EAAE,UAAU,GAAG,MAAM,CAAA;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,KAAK,eAAe,GAAG,UAAU,GAAG,iBAAiB,CAAA;AAErD,MAAM,MAAM,gBAAgB,GAAG;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,MAAM,CAAC,EAAE,WAAW,CAAC,QAAQ,GAAG,KAAK,GAAG,SAAS,CAAC,CAAA;IAClD,WAAW,CAAC,EAAE,iBAAiB,CAAA;IAC/B,eAAe,CAAC,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAAA;CACzC,CAAA;AAED,MAAM,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,GAAG,gBAAgB,EAAE,UAAU,CAAC,GAAG;IAC/E,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,CAAC,CAAC,OAAO,EAAE,OAAO,KAAK,KAAK,CAAC,SAAS,CAAC,CAAA;CACrE,CAAA;AAED,KAAK,eAAe,GAAG,iCAAiC,CACtD,WAAW,EACX,iBAAiB,GAAG,gBAAgB,CACrC,CAAA;AAED,KAAK,oBAAoB,GAAG,iCAAiC,CAC3D,eAAe,EACf,iBAAiB,CAClB,CAAA;AAED,wBAAgB,YAAY,CAAC,CAAC,SAAS,eAAe,EAAE,CAAC,SAAS,oBAAoB,EAAE,EACtF,kBAAkB,EAClB,KAAiC,EACjC,KAA0B,GAC3B,EAAE;IACD,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,KAAK,CAAC,EAAE,CAAC,CAAA;IACT,KAAK,CAAC,EAAE,CAAC,CAAA;CACV;;;;;;;;;EAkRA"}
|