@tamagui/switch 1.74.3 → 1.74.4
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/esm/Switch.native.js +75 -0
- package/dist/esm/Switch.native.js.map +6 -0
- package/dist/esm/SwitchContext.native.js +12 -0
- package/dist/esm/SwitchContext.native.js.map +6 -0
- package/dist/esm/createSwitch.native.js +207 -0
- package/dist/esm/createSwitch.native.js.map +6 -0
- package/dist/esm/index.native.js +13 -0
- package/dist/esm/index.native.js.map +6 -0
- package/package.json +11 -11
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { getVariableValue, styled } from "@tamagui/core";
|
|
2
|
+
import { getSize } from "@tamagui/get-token";
|
|
3
|
+
import { ThemeableStack, YStack } from "@tamagui/stacks";
|
|
4
|
+
import { SwitchContext } from "./SwitchContext";
|
|
5
|
+
const SwitchThumb = styled(ThemeableStack, {
|
|
6
|
+
name: "SwitchThumb",
|
|
7
|
+
context: SwitchContext,
|
|
8
|
+
variants: {
|
|
9
|
+
unstyled: {
|
|
10
|
+
false: {
|
|
11
|
+
size: "$true",
|
|
12
|
+
backgroundColor: "$background",
|
|
13
|
+
borderRadius: 1e3
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
checked: {
|
|
17
|
+
true: {}
|
|
18
|
+
},
|
|
19
|
+
size: {
|
|
20
|
+
"...size": (val) => {
|
|
21
|
+
const size = getSwitchHeight(val);
|
|
22
|
+
return {
|
|
23
|
+
height: size,
|
|
24
|
+
width: size
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
defaultVariants: {
|
|
30
|
+
unstyled: !1
|
|
31
|
+
}
|
|
32
|
+
}), getSwitchHeight = (val) => Math.round(getVariableValue(getSize(val)) * 0.65), getSwitchWidth = (val) => getSwitchHeight(val) * 2, SwitchFrame = styled(YStack, {
|
|
33
|
+
name: "Switch",
|
|
34
|
+
context: SwitchContext,
|
|
35
|
+
variants: {
|
|
36
|
+
unstyled: {
|
|
37
|
+
false: {
|
|
38
|
+
size: "$true",
|
|
39
|
+
borderRadius: 1e3,
|
|
40
|
+
backgroundColor: "$background",
|
|
41
|
+
borderWidth: 2,
|
|
42
|
+
borderColor: "$background",
|
|
43
|
+
focusStyle: {
|
|
44
|
+
outlineColor: "$borderColorFocus",
|
|
45
|
+
outlineStyle: "solid",
|
|
46
|
+
outlineWidth: 2
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
checked: {
|
|
51
|
+
true: {}
|
|
52
|
+
},
|
|
53
|
+
frameWidth: {
|
|
54
|
+
":number": () => null
|
|
55
|
+
},
|
|
56
|
+
size: {
|
|
57
|
+
"...size": (val) => {
|
|
58
|
+
const height = getSwitchHeight(val) + 4, width = getSwitchWidth(val) + 4;
|
|
59
|
+
return {
|
|
60
|
+
height,
|
|
61
|
+
minHeight: height,
|
|
62
|
+
width
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
},
|
|
67
|
+
defaultVariants: {
|
|
68
|
+
unstyled: !1
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
export {
|
|
72
|
+
SwitchFrame,
|
|
73
|
+
SwitchThumb
|
|
74
|
+
};
|
|
75
|
+
//# sourceMappingURL=Switch.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/Switch.tsx"],
|
|
4
|
+
"mappings": "AAAA,SAAqB,kBAAkB,cAAc;AACrD,SAAS,eAAe;AACxB,SAAS,gBAAgB,cAAc;AAEvC,SAAS,qBAAqB;AAEvB,MAAM,cAAc,OAAO,gBAAgB;AAAA,EAChD,MAAM;AAAA,EACN,SAAS;AAAA,EAET,UAAU;AAAA,IACR,UAAU;AAAA,MACR,OAAO;AAAA,QACL,MAAM;AAAA,QACN,iBAAiB;AAAA,QACjB,cAAc;AAAA,MAChB;AAAA,IACF;AAAA,IAEA,SAAS;AAAA,MACP,MAAM,CAAC;AAAA,IACT;AAAA,IAEA,MAAM;AAAA,MACJ,WAAW,CAAC,QAAQ;AAClB,cAAM,OAAO,gBAAgB,GAAG;AAChC,eAAO;AAAA,UACL,QAAQ;AAAA,UACR,OAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EAEA,iBAAiB;AAAA,IACf,UAAU;AAAA,EACZ;AACF,CAAC,GAEK,kBAAkB,CAAC,QACvB,KAAK,MAAM,iBAAiB,QAAQ,GAAG,CAAC,IAAI,IAAI,GAE5C,iBAAiB,CAAC,QAAoB,gBAAgB,GAAG,IAAI,GAEtD,cAAc,OAAO,QAAQ;AAAA,EACxC,MAAM;AAAA,EACN,SAAS;AAAA,EAET,UAAU;AAAA,IACR,UAAU;AAAA,MACR,OAAO;AAAA,QACL,MAAM;AAAA,QACN,cAAc;AAAA,QACd,iBAAiB;AAAA,QACjB,aAAa;AAAA,QACb,aAAa;AAAA,QAEb,YAAY;AAAA,UACV,cAAc;AAAA,UACd,cAAc;AAAA,UACd,cAAc;AAAA,QAChB;AAAA,MACF;AAAA,IACF;AAAA,IAEA,SAAS;AAAA,MACP,MAAM,CAAC;AAAA,IACT;AAAA,IAEA,YAAY;AAAA,MACV,WAAW,MAAM;AAAA,IACnB;AAAA,IAEA,MAAM;AAAA,MACJ,WAAW,CAAC,QAAQ;AAClB,cAAM,SAAS,gBAAgB,GAAG,IAAI,GAChC,QAAQ,eAAe,GAAG,IAAI;AACpC,eAAO;AAAA,UACL;AAAA,UACA,WAAW;AAAA,UACX;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EAEA,iBAAiB;AAAA,IACf,UAAU;AAAA,EACZ;AACF,CAAC;",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { createStyledContext } from "@tamagui/core";
|
|
2
|
+
const SwitchContext = createStyledContext({
|
|
3
|
+
checked: !1,
|
|
4
|
+
disabled: !1,
|
|
5
|
+
size: void 0,
|
|
6
|
+
frameWidth: 0,
|
|
7
|
+
unstyled: !1
|
|
8
|
+
});
|
|
9
|
+
export {
|
|
10
|
+
SwitchContext
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=SwitchContext.js.map
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
import { useComposedRefs } from "@tamagui/compose-refs";
|
|
2
|
+
import {
|
|
3
|
+
composeEventHandlers,
|
|
4
|
+
isWeb,
|
|
5
|
+
useProps,
|
|
6
|
+
withStaticProperties
|
|
7
|
+
} from "@tamagui/core";
|
|
8
|
+
import { registerFocusable } from "@tamagui/focusable";
|
|
9
|
+
import { useLabelContext } from "@tamagui/label";
|
|
10
|
+
import { YStack } from "@tamagui/stacks";
|
|
11
|
+
import { useControllableState } from "@tamagui/use-controllable-state";
|
|
12
|
+
import { usePrevious } from "@tamagui/use-previous";
|
|
13
|
+
import * as React from "react";
|
|
14
|
+
import {
|
|
15
|
+
Switch as NativeSwitch,
|
|
16
|
+
Platform
|
|
17
|
+
} from "react-native";
|
|
18
|
+
import { SwitchFrame as DefaultSwitchFrame, SwitchThumb } from "./Switch";
|
|
19
|
+
import { SwitchContext } from "./SwitchContext";
|
|
20
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
21
|
+
function createSwitch({
|
|
22
|
+
disableActiveTheme,
|
|
23
|
+
Frame = DefaultSwitchFrame,
|
|
24
|
+
Thumb = SwitchThumb
|
|
25
|
+
}) {
|
|
26
|
+
process.env.NODE_ENV === "development" && (Frame !== DefaultSwitchFrame && Frame.staticConfig.context && console.warn(
|
|
27
|
+
"Warning: createSwitch() needs to control context to pass checked state from Frame to Thumb, any custom context passed will be overridden."
|
|
28
|
+
), Thumb !== SwitchThumb && Thumb.staticConfig.context && console.warn(
|
|
29
|
+
"Warning: createSwitch() needs to control context to pass checked state from Frame to Thumb, any custom context passed will be overridden."
|
|
30
|
+
)), Frame.staticConfig.context = SwitchContext, Thumb.staticConfig.context = SwitchContext;
|
|
31
|
+
const SwitchThumbComponent = Thumb.styleable(function(props, forwardedRef) {
|
|
32
|
+
const { size: sizeProp, unstyled: unstyledProp, ...thumbProps } = props, context = React.useContext(SwitchContext), {
|
|
33
|
+
disabled,
|
|
34
|
+
checked,
|
|
35
|
+
unstyled: unstyledContext,
|
|
36
|
+
frameWidth,
|
|
37
|
+
size: sizeContext
|
|
38
|
+
} = context, [thumbWidth, setThumbWidth] = React.useState(0), initialChecked = React.useRef(checked).current, distance = frameWidth - thumbWidth, x = initialChecked ? checked ? 0 : -distance : checked ? distance : 0;
|
|
39
|
+
return (
|
|
40
|
+
// @ts-ignore
|
|
41
|
+
/* @__PURE__ */ jsx(
|
|
42
|
+
Thumb,
|
|
43
|
+
{
|
|
44
|
+
...(unstyledProp ?? unstyledContext ?? !1) === !1 && {
|
|
45
|
+
unstyled: !1,
|
|
46
|
+
size: sizeProp ?? sizeContext ?? "$true",
|
|
47
|
+
...!disableActiveTheme && {
|
|
48
|
+
theme: checked ? "active" : null
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
"data-state": getState(checked),
|
|
52
|
+
"data-disabled": disabled ? "" : void 0,
|
|
53
|
+
alignSelf: initialChecked ? "flex-end" : "flex-start",
|
|
54
|
+
checked,
|
|
55
|
+
x,
|
|
56
|
+
...thumbProps,
|
|
57
|
+
onLayout: composeEventHandlers(
|
|
58
|
+
props.onLayout,
|
|
59
|
+
(e) => (
|
|
60
|
+
// @ts-ignore
|
|
61
|
+
setThumbWidth(e.nativeEvent.layout.width)
|
|
62
|
+
)
|
|
63
|
+
),
|
|
64
|
+
ref: forwardedRef
|
|
65
|
+
}
|
|
66
|
+
)
|
|
67
|
+
);
|
|
68
|
+
}), SwitchComponent = Frame.extractable(
|
|
69
|
+
React.forwardRef(function(propsIn, forwardedRef) {
|
|
70
|
+
const styledContext = React.useContext(SwitchContext), props = useProps(propsIn, {
|
|
71
|
+
noNormalize: !0,
|
|
72
|
+
noExpand: !0,
|
|
73
|
+
resolveValues: "none",
|
|
74
|
+
forComponent: Frame
|
|
75
|
+
}), {
|
|
76
|
+
labeledBy: ariaLabelledby,
|
|
77
|
+
name,
|
|
78
|
+
checked: checkedProp,
|
|
79
|
+
defaultChecked,
|
|
80
|
+
required,
|
|
81
|
+
disabled,
|
|
82
|
+
value = "on",
|
|
83
|
+
onCheckedChange,
|
|
84
|
+
size = styledContext.size ?? "$true",
|
|
85
|
+
unstyled = styledContext.unstyled ?? !1,
|
|
86
|
+
native: nativeProp,
|
|
87
|
+
nativeProps,
|
|
88
|
+
children,
|
|
89
|
+
...switchProps
|
|
90
|
+
} = 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, (node) => setButton(node)), 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({
|
|
91
|
+
prop: checkedProp,
|
|
92
|
+
defaultProp: defaultChecked || !1,
|
|
93
|
+
onChange: onCheckedChange,
|
|
94
|
+
transition: !0
|
|
95
|
+
});
|
|
96
|
+
return shouldRenderMobileNative ? /* @__PURE__ */ jsx(
|
|
97
|
+
NativeSwitch,
|
|
98
|
+
{
|
|
99
|
+
value: checkedProp,
|
|
100
|
+
onValueChange: onCheckedChange,
|
|
101
|
+
...nativeProps
|
|
102
|
+
}
|
|
103
|
+
) : (isWeb || React.useEffect(() => {
|
|
104
|
+
if (props.id)
|
|
105
|
+
return registerFocusable(props.id, {
|
|
106
|
+
focus: () => {
|
|
107
|
+
setChecked((x) => !x);
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
}, [props.id, setChecked]), /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
111
|
+
/* @__PURE__ */ jsx(
|
|
112
|
+
Frame,
|
|
113
|
+
{
|
|
114
|
+
unstyled,
|
|
115
|
+
size,
|
|
116
|
+
checked,
|
|
117
|
+
disabled,
|
|
118
|
+
frameWidth,
|
|
119
|
+
themeShallow: !0,
|
|
120
|
+
...!disableActiveTheme && {
|
|
121
|
+
theme: checked ? "active" : null,
|
|
122
|
+
themeShallow: !0
|
|
123
|
+
},
|
|
124
|
+
role: "switch",
|
|
125
|
+
"aria-checked": checked,
|
|
126
|
+
"aria-labelledby": labelledBy,
|
|
127
|
+
"aria-required": required,
|
|
128
|
+
"data-state": getState(checked),
|
|
129
|
+
"data-disabled": disabled ? "" : void 0,
|
|
130
|
+
tabIndex: disabled ? void 0 : 0,
|
|
131
|
+
value,
|
|
132
|
+
...switchProps,
|
|
133
|
+
ref: composedRefs,
|
|
134
|
+
onPress: composeEventHandlers(props.onPress, (event) => {
|
|
135
|
+
setChecked((prevChecked) => !prevChecked), isWeb && isFormControl && (hasConsumerStoppedPropagationRef.current = event.isPropagationStopped(), hasConsumerStoppedPropagationRef.current || event.stopPropagation());
|
|
136
|
+
}),
|
|
137
|
+
children: /* @__PURE__ */ jsx(
|
|
138
|
+
YStack,
|
|
139
|
+
{
|
|
140
|
+
alignSelf: "stretch",
|
|
141
|
+
flex: 1,
|
|
142
|
+
onLayout: (e) => {
|
|
143
|
+
setFrameWidth(e.nativeEvent.layout.width);
|
|
144
|
+
},
|
|
145
|
+
children: typeof children == "function" ? children(checked) : children
|
|
146
|
+
}
|
|
147
|
+
)
|
|
148
|
+
}
|
|
149
|
+
),
|
|
150
|
+
isWeb && isFormControl && /* @__PURE__ */ jsx(
|
|
151
|
+
BubbleInput,
|
|
152
|
+
{
|
|
153
|
+
control: button,
|
|
154
|
+
bubbles: !hasConsumerStoppedPropagationRef.current,
|
|
155
|
+
name,
|
|
156
|
+
value,
|
|
157
|
+
checked,
|
|
158
|
+
required,
|
|
159
|
+
disabled,
|
|
160
|
+
style: { transform: "translateX(-100%)" }
|
|
161
|
+
}
|
|
162
|
+
)
|
|
163
|
+
] }));
|
|
164
|
+
})
|
|
165
|
+
), BubbleInput = (props) => {
|
|
166
|
+
const { control, checked, bubbles = !0, ...inputProps } = props, ref = React.useRef(null), prevChecked = usePrevious(checked);
|
|
167
|
+
return React.useEffect(() => {
|
|
168
|
+
const input = ref.current, inputProto = window.HTMLInputElement.prototype, setChecked = Object.getOwnPropertyDescriptor(
|
|
169
|
+
inputProto,
|
|
170
|
+
"checked"
|
|
171
|
+
).set;
|
|
172
|
+
if (prevChecked !== checked && setChecked) {
|
|
173
|
+
const event = new Event("click", { bubbles });
|
|
174
|
+
setChecked.call(input, checked), input.dispatchEvent(event);
|
|
175
|
+
}
|
|
176
|
+
}, [prevChecked, checked, bubbles]), // @ts-ignore
|
|
177
|
+
/* @__PURE__ */ jsx(
|
|
178
|
+
"input",
|
|
179
|
+
{
|
|
180
|
+
type: "checkbox",
|
|
181
|
+
"aria-hidden": !0,
|
|
182
|
+
defaultChecked: checked,
|
|
183
|
+
...inputProps,
|
|
184
|
+
tabIndex: -1,
|
|
185
|
+
ref,
|
|
186
|
+
style: {
|
|
187
|
+
...props.style,
|
|
188
|
+
// ...controlSize,
|
|
189
|
+
position: "absolute",
|
|
190
|
+
pointerEvents: "none",
|
|
191
|
+
opacity: 0,
|
|
192
|
+
margin: 0
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
);
|
|
196
|
+
};
|
|
197
|
+
function getState(checked) {
|
|
198
|
+
return checked ? "checked" : "unchecked";
|
|
199
|
+
}
|
|
200
|
+
return withStaticProperties(SwitchComponent, {
|
|
201
|
+
Thumb: SwitchThumbComponent
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
export {
|
|
205
|
+
createSwitch
|
|
206
|
+
};
|
|
207
|
+
//# sourceMappingURL=createSwitch.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/createSwitch.tsx"],
|
|
4
|
+
"mappings": "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",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { createSwitch } from "./createSwitch";
|
|
2
|
+
import { SwitchFrame, SwitchThumb } from "./Switch";
|
|
3
|
+
export * from "./Switch";
|
|
4
|
+
export * from "./SwitchContext";
|
|
5
|
+
export * from "./createSwitch";
|
|
6
|
+
const Switch = createSwitch({
|
|
7
|
+
Frame: SwitchFrame,
|
|
8
|
+
Thumb: SwitchThumb
|
|
9
|
+
});
|
|
10
|
+
export {
|
|
11
|
+
Switch
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tamagui/switch",
|
|
3
|
-
"version": "1.74.
|
|
3
|
+
"version": "1.74.4",
|
|
4
4
|
"sideEffects": [
|
|
5
5
|
"*.css"
|
|
6
6
|
],
|
|
@@ -31,22 +31,22 @@
|
|
|
31
31
|
}
|
|
32
32
|
},
|
|
33
33
|
"dependencies": {
|
|
34
|
-
"@tamagui/compose-refs": "1.74.
|
|
35
|
-
"@tamagui/core": "1.74.
|
|
36
|
-
"@tamagui/create-context": "1.74.
|
|
37
|
-
"@tamagui/focusable": "1.74.
|
|
38
|
-
"@tamagui/get-token": "1.74.
|
|
39
|
-
"@tamagui/label": "1.74.
|
|
40
|
-
"@tamagui/stacks": "1.74.
|
|
41
|
-
"@tamagui/use-controllable-state": "1.74.
|
|
42
|
-
"@tamagui/use-previous": "1.74.
|
|
34
|
+
"@tamagui/compose-refs": "1.74.4",
|
|
35
|
+
"@tamagui/core": "1.74.4",
|
|
36
|
+
"@tamagui/create-context": "1.74.4",
|
|
37
|
+
"@tamagui/focusable": "1.74.4",
|
|
38
|
+
"@tamagui/get-token": "1.74.4",
|
|
39
|
+
"@tamagui/label": "1.74.4",
|
|
40
|
+
"@tamagui/stacks": "1.74.4",
|
|
41
|
+
"@tamagui/use-controllable-state": "1.74.4",
|
|
42
|
+
"@tamagui/use-previous": "1.74.4"
|
|
43
43
|
},
|
|
44
44
|
"peerDependencies": {
|
|
45
45
|
"react": "*",
|
|
46
46
|
"react-native": "*"
|
|
47
47
|
},
|
|
48
48
|
"devDependencies": {
|
|
49
|
-
"@tamagui/build": "1.74.
|
|
49
|
+
"@tamagui/build": "1.74.4",
|
|
50
50
|
"react": "^18.2.0",
|
|
51
51
|
"react-native": "^0.72.1"
|
|
52
52
|
},
|