@tamagui/switch 1.79.6 → 1.79.7
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 +95 -101
- package/dist/cjs/createSwitch.js.map +1 -1
- package/dist/cjs/createSwitch.native.js +95 -101
- package/dist/cjs/createSwitch.native.js.map +1 -1
- package/dist/esm/createSwitch.js +95 -101
- package/dist/esm/createSwitch.js.map +1 -1
- package/dist/esm/createSwitch.native.js +95 -101
- package/dist/esm/createSwitch.native.js.map +1 -1
- package/dist/jsx/createSwitch.js +86 -92
- package/dist/jsx/createSwitch.js.map +1 -1
- package/dist/jsx/createSwitch.native.js +86 -92
- package/dist/jsx/createSwitch.native.js.map +1 -1
- package/package.json +11 -11
- package/src/createSwitch.tsx +135 -141
- package/types/Switch.d.ts +10 -10
- package/types/createSwitch.d.ts +9 -6
- package/types/createSwitch.d.ts.map +1 -1
- package/types/index.d.ts +14 -8
- package/types/index.d.ts.map +1 -1
package/dist/jsx/createSwitch.js
CHANGED
|
@@ -61,98 +61,92 @@ function createSwitch({
|
|
|
61
61
|
ref={forwardedRef}
|
|
62
62
|
/>
|
|
63
63
|
);
|
|
64
|
-
}), SwitchComponent = Frame.
|
|
65
|
-
React.
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
{
|
|
109
|
-
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
checked
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
{
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
disabled={disabled}
|
|
151
|
-
style={{ transform: "translateX(-100%)" }}
|
|
152
|
-
/>}
|
|
153
|
-
</>);
|
|
154
|
-
})
|
|
155
|
-
), BubbleInput = (props) => {
|
|
64
|
+
}), SwitchComponent = Frame.styleable(function(propsIn, forwardedRef) {
|
|
65
|
+
const styledContext = React.useContext(SwitchContext), props = useProps(propsIn, {
|
|
66
|
+
noNormalize: !0,
|
|
67
|
+
noExpand: !0,
|
|
68
|
+
resolveValues: "none",
|
|
69
|
+
forComponent: Frame
|
|
70
|
+
}), {
|
|
71
|
+
labeledBy: ariaLabelledby,
|
|
72
|
+
name,
|
|
73
|
+
checked: checkedProp,
|
|
74
|
+
defaultChecked,
|
|
75
|
+
required,
|
|
76
|
+
disabled,
|
|
77
|
+
value = "on",
|
|
78
|
+
onCheckedChange,
|
|
79
|
+
size = styledContext.size ?? "$true",
|
|
80
|
+
unstyled = styledContext.unstyled ?? !1,
|
|
81
|
+
native: nativeProp,
|
|
82
|
+
nativeProps,
|
|
83
|
+
children,
|
|
84
|
+
...switchProps
|
|
85
|
+
} = props, native = Array.isArray(nativeProp) ? nativeProp : [nativeProp], shouldRenderMobileNative = !isWeb && nativeProp === !0 || !isWeb && native.includes("mobile") || native.includes("android") && Platform.OS === "android" || native.includes("ios") && Platform.OS === "ios", [button, setButton] = React.useState(null), composedRefs = useComposedRefs(forwardedRef, setButton), labelId = useLabelContext(button), labelledBy = ariaLabelledby || labelId, hasConsumerStoppedPropagationRef = React.useRef(!1), isFormControl = isWeb ? button ? !!button.closest("form") : !0 : !1, [frameWidth, setFrameWidth] = React.useState(0), [checked = !1, setChecked] = useControllableState({
|
|
86
|
+
prop: checkedProp,
|
|
87
|
+
defaultProp: defaultChecked || !1,
|
|
88
|
+
onChange: onCheckedChange,
|
|
89
|
+
transition: !0
|
|
90
|
+
});
|
|
91
|
+
return shouldRenderMobileNative ? <NativeSwitch
|
|
92
|
+
value={checkedProp}
|
|
93
|
+
onValueChange={onCheckedChange}
|
|
94
|
+
{...nativeProps}
|
|
95
|
+
/> : (isWeb || React.useEffect(() => {
|
|
96
|
+
if (props.id)
|
|
97
|
+
return registerFocusable(props.id, {
|
|
98
|
+
focus: () => {
|
|
99
|
+
setChecked((x) => !x);
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
}, [props.id, setChecked]), <>
|
|
103
|
+
{
|
|
104
|
+
/* @ts-ignore */
|
|
105
|
+
}
|
|
106
|
+
<Frame
|
|
107
|
+
tag="button"
|
|
108
|
+
unstyled={unstyled}
|
|
109
|
+
size={size}
|
|
110
|
+
checked={checked}
|
|
111
|
+
disabled={disabled}
|
|
112
|
+
frameWidth={frameWidth}
|
|
113
|
+
themeShallow
|
|
114
|
+
{...!disableActiveTheme && {
|
|
115
|
+
theme: checked ? "active" : null,
|
|
116
|
+
themeShallow: !0
|
|
117
|
+
}}
|
|
118
|
+
role="switch"
|
|
119
|
+
aria-checked={checked}
|
|
120
|
+
aria-labelledby={labelledBy}
|
|
121
|
+
aria-required={required}
|
|
122
|
+
data-state={getState(checked)}
|
|
123
|
+
data-disabled={disabled ? "" : void 0}
|
|
124
|
+
tabIndex={disabled ? void 0 : 0}
|
|
125
|
+
value={value}
|
|
126
|
+
{...switchProps}
|
|
127
|
+
ref={composedRefs}
|
|
128
|
+
onPress={composeEventHandlers(props.onPress, (event) => {
|
|
129
|
+
setChecked((prevChecked) => !prevChecked), isWeb && isFormControl && (hasConsumerStoppedPropagationRef.current = event.isPropagationStopped(), hasConsumerStoppedPropagationRef.current || event.stopPropagation());
|
|
130
|
+
})}
|
|
131
|
+
><YStack
|
|
132
|
+
alignSelf="stretch"
|
|
133
|
+
flex={1}
|
|
134
|
+
onLayout={(e) => {
|
|
135
|
+
setFrameWidth(e.nativeEvent.layout.width);
|
|
136
|
+
}}
|
|
137
|
+
>{typeof children == "function" ? children(checked) : children}</YStack></Frame>
|
|
138
|
+
{isWeb && isFormControl && <BubbleInput
|
|
139
|
+
control={button}
|
|
140
|
+
bubbles={!hasConsumerStoppedPropagationRef.current}
|
|
141
|
+
name={name}
|
|
142
|
+
value={value}
|
|
143
|
+
checked={checked}
|
|
144
|
+
required={required}
|
|
145
|
+
disabled={disabled}
|
|
146
|
+
style={{ transform: "translateX(-100%)" }}
|
|
147
|
+
/>}
|
|
148
|
+
</>);
|
|
149
|
+
}), BubbleInput = (props) => {
|
|
156
150
|
const { control, checked, bubbles = !0, ...inputProps } = props, ref = React.useRef(null), prevChecked = usePrevious(checked);
|
|
157
151
|
return React.useEffect(() => {
|
|
158
152
|
const input = ref.current, inputProto = window.HTMLInputElement.prototype, setChecked = Object.getOwnPropertyDescriptor(
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/createSwitch.tsx"],
|
|
4
|
-
"mappings": "AAAA,SAAS,uBAAuB;AAChC;AAAA,EAME;AAAA,EAEA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,yBAAyB;AAElC,SAAS,uBAAuB;AAChC,SAAS,cAAc;AACvB,SAAS,4BAA4B;AACrC,SAAS,mBAAmB;AAC5B,YAAY,WAAW;AACvB;AAAA,EACE,UAAU;AAAA,EAEV;AAAA,OACK;AAEP,SAAS,eAAe,oBAAoB,mBAAmB;AAC/D,SAAS,qBAAqB;AAmCvB,SAAS,aAAwE;AAAA,EACtF;AAAA,EACA,QAAQ;AAAA,EACR,QAAQ;AACV,GAIG;AACD,EAAI,QAAQ,IAAI,aAAa,kBACvB,UAAU,sBAAsB,MAAM,aAAa,WACrD,QAAQ;AAAA,IACN;AAAA,EACF,GAEE,UAAU,eAAe,MAAM,aAAa,WAC9C,QAAQ;AAAA,IACN;AAAA,EACF,IAIJ,MAAM,aAAa,UAAU,eAC7B,MAAM,aAAa,UAAU;AAE7B,QAAM,uBAAuB,MAAM,UAAU,SAAqB,OAAO,cAAc;AACrF,UAAM,EAAE,MAAM,UAAU,UAAU,cAAc,GAAG,WAAW,IAAI,OAC5D,UAAU,MAAM,WAAW,aAAa,GACxC;AAAA,MACJ;AAAA,MACA;AAAA,MACA,UAAU;AAAA,MACV;AAAA,MACA,MAAM;AAAA,IACR,IAAI,SACE,CAAC,YAAY,aAAa,IAAI,MAAM,SAAS,CAAC,GAC9C,iBAAiB,MAAM,OAAO,OAAO,EAAE,SACvC,WAAW,aAAa,YACxB,IAAI,iBAAkB,UAAU,IAAI,CAAC,WAAY,UAAU,WAAW,GACtE,WAAW,gBAAgB,mBAAmB;AAEpD;AAAA;AAAA,MAEE,CAAC;AAAA,YACM,aAAa,MAAS;AAAA,UACzB,UAAU,QAAQ,IAAI,qBAAqB;AAAA,UAC3C,MAAM,YAAY,eAAe;AAAA,UACjC,GAAI,CAAC,sBAAsB;AAAA,YACzB,OAAO,UAAU,WAAW;AAAA,UAC9B;AAAA,QACF;AAAA,QACA,YAAY,SAAS,OAAO;AAAA,QAC5B,eAAe,WAAW,KAAK;AAAA,QAC/B,WAAW,iBAAiB,aAAa;AAAA,QACzC,SAAS;AAAA,QACT,GAAG;AAAA,YACC;AAAA,QAEJ,UAAU;AAAA,UAAqB,MAAM;AAAA,UAAU,CAAC;AAAA;AAAA,YAE9C,cAAc,EAAE,YAAY,OAAO,KAAK;AAAA;AAAA,QAC1C;AAAA,QACA,KAAK;AAAA,MACP;AAAA;AAAA,EAEJ,CAAC,GAEK,kBAAkB,MAAM
|
|
4
|
+
"mappings": "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",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
|
@@ -61,98 +61,92 @@ function createSwitch({
|
|
|
61
61
|
ref={forwardedRef}
|
|
62
62
|
/>
|
|
63
63
|
);
|
|
64
|
-
}), SwitchComponent = Frame.
|
|
65
|
-
React.
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
{
|
|
109
|
-
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
checked
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
{
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
disabled={disabled}
|
|
151
|
-
style={{ transform: "translateX(-100%)" }}
|
|
152
|
-
/>}
|
|
153
|
-
</>);
|
|
154
|
-
})
|
|
155
|
-
), BubbleInput = (props) => {
|
|
64
|
+
}), SwitchComponent = Frame.styleable(function(propsIn, forwardedRef) {
|
|
65
|
+
const styledContext = React.useContext(SwitchContext), props = useProps(propsIn, {
|
|
66
|
+
noNormalize: !0,
|
|
67
|
+
noExpand: !0,
|
|
68
|
+
resolveValues: "none",
|
|
69
|
+
forComponent: Frame
|
|
70
|
+
}), {
|
|
71
|
+
labeledBy: ariaLabelledby,
|
|
72
|
+
name,
|
|
73
|
+
checked: checkedProp,
|
|
74
|
+
defaultChecked,
|
|
75
|
+
required,
|
|
76
|
+
disabled,
|
|
77
|
+
value = "on",
|
|
78
|
+
onCheckedChange,
|
|
79
|
+
size = styledContext.size ?? "$true",
|
|
80
|
+
unstyled = styledContext.unstyled ?? !1,
|
|
81
|
+
native: nativeProp,
|
|
82
|
+
nativeProps,
|
|
83
|
+
children,
|
|
84
|
+
...switchProps
|
|
85
|
+
} = props, native = Array.isArray(nativeProp) ? nativeProp : [nativeProp], shouldRenderMobileNative = !isWeb && nativeProp === !0 || !isWeb && native.includes("mobile") || native.includes("android") && Platform.OS === "android" || native.includes("ios") && Platform.OS === "ios", [button, setButton] = React.useState(null), composedRefs = useComposedRefs(forwardedRef, setButton), labelId = useLabelContext(button), labelledBy = ariaLabelledby || labelId, hasConsumerStoppedPropagationRef = React.useRef(!1), isFormControl = isWeb ? button ? !!button.closest("form") : !0 : !1, [frameWidth, setFrameWidth] = React.useState(0), [checked = !1, setChecked] = useControllableState({
|
|
86
|
+
prop: checkedProp,
|
|
87
|
+
defaultProp: defaultChecked || !1,
|
|
88
|
+
onChange: onCheckedChange,
|
|
89
|
+
transition: !0
|
|
90
|
+
});
|
|
91
|
+
return shouldRenderMobileNative ? <NativeSwitch
|
|
92
|
+
value={checkedProp}
|
|
93
|
+
onValueChange={onCheckedChange}
|
|
94
|
+
{...nativeProps}
|
|
95
|
+
/> : (isWeb || React.useEffect(() => {
|
|
96
|
+
if (props.id)
|
|
97
|
+
return registerFocusable(props.id, {
|
|
98
|
+
focus: () => {
|
|
99
|
+
setChecked((x) => !x);
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
}, [props.id, setChecked]), <>
|
|
103
|
+
{
|
|
104
|
+
/* @ts-ignore */
|
|
105
|
+
}
|
|
106
|
+
<Frame
|
|
107
|
+
tag="button"
|
|
108
|
+
unstyled={unstyled}
|
|
109
|
+
size={size}
|
|
110
|
+
checked={checked}
|
|
111
|
+
disabled={disabled}
|
|
112
|
+
frameWidth={frameWidth}
|
|
113
|
+
themeShallow
|
|
114
|
+
{...!disableActiveTheme && {
|
|
115
|
+
theme: checked ? "active" : null,
|
|
116
|
+
themeShallow: !0
|
|
117
|
+
}}
|
|
118
|
+
role="switch"
|
|
119
|
+
aria-checked={checked}
|
|
120
|
+
aria-labelledby={labelledBy}
|
|
121
|
+
aria-required={required}
|
|
122
|
+
data-state={getState(checked)}
|
|
123
|
+
data-disabled={disabled ? "" : void 0}
|
|
124
|
+
tabIndex={disabled ? void 0 : 0}
|
|
125
|
+
value={value}
|
|
126
|
+
{...switchProps}
|
|
127
|
+
ref={composedRefs}
|
|
128
|
+
onPress={composeEventHandlers(props.onPress, (event) => {
|
|
129
|
+
setChecked((prevChecked) => !prevChecked), isWeb && isFormControl && (hasConsumerStoppedPropagationRef.current = event.isPropagationStopped(), hasConsumerStoppedPropagationRef.current || event.stopPropagation());
|
|
130
|
+
})}
|
|
131
|
+
><YStack
|
|
132
|
+
alignSelf="stretch"
|
|
133
|
+
flex={1}
|
|
134
|
+
onLayout={(e) => {
|
|
135
|
+
setFrameWidth(e.nativeEvent.layout.width);
|
|
136
|
+
}}
|
|
137
|
+
>{typeof children == "function" ? children(checked) : children}</YStack></Frame>
|
|
138
|
+
{isWeb && isFormControl && <BubbleInput
|
|
139
|
+
control={button}
|
|
140
|
+
bubbles={!hasConsumerStoppedPropagationRef.current}
|
|
141
|
+
name={name}
|
|
142
|
+
value={value}
|
|
143
|
+
checked={checked}
|
|
144
|
+
required={required}
|
|
145
|
+
disabled={disabled}
|
|
146
|
+
style={{ transform: "translateX(-100%)" }}
|
|
147
|
+
/>}
|
|
148
|
+
</>);
|
|
149
|
+
}), BubbleInput = (props) => {
|
|
156
150
|
const { control, checked, bubbles = !0, ...inputProps } = props, ref = React.useRef(null), prevChecked = usePrevious(checked);
|
|
157
151
|
return React.useEffect(() => {
|
|
158
152
|
const input = ref.current, inputProto = window.HTMLInputElement.prototype, setChecked = Object.getOwnPropertyDescriptor(
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/createSwitch.tsx"],
|
|
4
|
-
"mappings": "AAAA,SAAS,uBAAuB;AAChC;AAAA,EAME;AAAA,EAEA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,yBAAyB;AAElC,SAAS,uBAAuB;AAChC,SAAS,cAAc;AACvB,SAAS,4BAA4B;AACrC,SAAS,mBAAmB;AAC5B,YAAY,WAAW;AACvB;AAAA,EACE,UAAU;AAAA,EAEV;AAAA,OACK;AAEP,SAAS,eAAe,oBAAoB,mBAAmB;AAC/D,SAAS,qBAAqB;AAmCvB,SAAS,aAAwE;AAAA,EACtF;AAAA,EACA,QAAQ;AAAA,EACR,QAAQ;AACV,GAIG;AACD,EAAI,QAAQ,IAAI,aAAa,kBACvB,UAAU,sBAAsB,MAAM,aAAa,WACrD,QAAQ;AAAA,IACN;AAAA,EACF,GAEE,UAAU,eAAe,MAAM,aAAa,WAC9C,QAAQ;AAAA,IACN;AAAA,EACF,IAIJ,MAAM,aAAa,UAAU,eAC7B,MAAM,aAAa,UAAU;AAE7B,QAAM,uBAAuB,MAAM,UAAU,SAAqB,OAAO,cAAc;AACrF,UAAM,EAAE,MAAM,UAAU,UAAU,cAAc,GAAG,WAAW,IAAI,OAC5D,UAAU,MAAM,WAAW,aAAa,GACxC;AAAA,MACJ;AAAA,MACA;AAAA,MACA,UAAU;AAAA,MACV;AAAA,MACA,MAAM;AAAA,IACR,IAAI,SACE,CAAC,YAAY,aAAa,IAAI,MAAM,SAAS,CAAC,GAC9C,iBAAiB,MAAM,OAAO,OAAO,EAAE,SACvC,WAAW,aAAa,YACxB,IAAI,iBAAkB,UAAU,IAAI,CAAC,WAAY,UAAU,WAAW,GACtE,WAAW,gBAAgB,mBAAmB;AAEpD;AAAA;AAAA,MAEE,CAAC;AAAA,YACM,aAAa,MAAS;AAAA,UACzB,UAAU,QAAQ,IAAI,qBAAqB;AAAA,UAC3C,MAAM,YAAY,eAAe;AAAA,UACjC,GAAI,CAAC,sBAAsB;AAAA,YACzB,OAAO,UAAU,WAAW;AAAA,UAC9B;AAAA,QACF;AAAA,QACA,YAAY,SAAS,OAAO;AAAA,QAC5B,eAAe,WAAW,KAAK;AAAA,QAC/B,WAAW,iBAAiB,aAAa;AAAA,QACzC,SAAS;AAAA,QACT,GAAG;AAAA,YACC;AAAA,QAEJ,UAAU;AAAA,UAAqB,MAAM;AAAA,UAAU,CAAC;AAAA;AAAA,YAE9C,cAAc,EAAE,YAAY,OAAO,KAAK;AAAA;AAAA,QAC1C;AAAA,QACA,KAAK;AAAA,MACP;AAAA;AAAA,EAEJ,CAAC,GAEK,kBAAkB,MAAM
|
|
4
|
+
"mappings": "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",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tamagui/switch",
|
|
3
|
-
"version": "1.79.
|
|
3
|
+
"version": "1.79.7",
|
|
4
4
|
"sideEffects": [
|
|
5
5
|
"*.css"
|
|
6
6
|
],
|
|
@@ -31,22 +31,22 @@
|
|
|
31
31
|
}
|
|
32
32
|
},
|
|
33
33
|
"dependencies": {
|
|
34
|
-
"@tamagui/compose-refs": "1.79.
|
|
35
|
-
"@tamagui/core": "1.79.
|
|
36
|
-
"@tamagui/create-context": "1.79.
|
|
37
|
-
"@tamagui/focusable": "1.79.
|
|
38
|
-
"@tamagui/get-token": "1.79.
|
|
39
|
-
"@tamagui/label": "1.79.
|
|
40
|
-
"@tamagui/stacks": "1.79.
|
|
41
|
-
"@tamagui/use-controllable-state": "1.79.
|
|
42
|
-
"@tamagui/use-previous": "1.79.
|
|
34
|
+
"@tamagui/compose-refs": "1.79.7",
|
|
35
|
+
"@tamagui/core": "1.79.7",
|
|
36
|
+
"@tamagui/create-context": "1.79.7",
|
|
37
|
+
"@tamagui/focusable": "1.79.7",
|
|
38
|
+
"@tamagui/get-token": "1.79.7",
|
|
39
|
+
"@tamagui/label": "1.79.7",
|
|
40
|
+
"@tamagui/stacks": "1.79.7",
|
|
41
|
+
"@tamagui/use-controllable-state": "1.79.7",
|
|
42
|
+
"@tamagui/use-previous": "1.79.7"
|
|
43
43
|
},
|
|
44
44
|
"peerDependencies": {
|
|
45
45
|
"react": "*",
|
|
46
46
|
"react-native": "*"
|
|
47
47
|
},
|
|
48
48
|
"devDependencies": {
|
|
49
|
-
"@tamagui/build": "1.79.
|
|
49
|
+
"@tamagui/build": "1.79.7",
|
|
50
50
|
"react": "^18.2.0",
|
|
51
51
|
"react-native": "^0.72.1"
|
|
52
52
|
},
|