@tamagui/switch 1.68.0 → 1.68.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/Switch.js +3 -9
- package/dist/cjs/Switch.js.map +1 -1
- package/dist/cjs/Switch.native.js +3 -9
- package/dist/cjs/Switch.native.js.map +1 -1
- package/dist/cjs/SwitchContext.js +32 -0
- package/dist/cjs/SwitchContext.js.map +6 -0
- package/dist/cjs/SwitchContext.native.js +33 -0
- package/dist/cjs/SwitchContext.native.js.map +6 -0
- package/dist/cjs/createSwitch.js +36 -24
- package/dist/cjs/createSwitch.js.map +2 -2
- package/dist/cjs/createSwitch.native.js +36 -24
- package/dist/cjs/createSwitch.native.js.map +2 -2
- package/dist/cjs/index.js +14 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/index.native.js +14 -1
- package/dist/cjs/index.native.js.map +1 -1
- package/dist/esm/Switch.js +1 -6
- package/dist/esm/Switch.js.map +1 -1
- package/dist/esm/SwitchContext.js +12 -0
- package/dist/esm/SwitchContext.js.map +6 -0
- package/dist/esm/createSwitch.js +36 -22
- package/dist/esm/createSwitch.js.map +2 -2
- package/dist/esm/index.js +10 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/jsx/Switch.js +1 -6
- package/dist/jsx/Switch.js.map +1 -1
- package/dist/jsx/Switch.native.js +1 -6
- package/dist/jsx/Switch.native.js.map +1 -1
- package/dist/jsx/SwitchContext.js +12 -0
- package/dist/jsx/SwitchContext.js.map +6 -0
- package/dist/jsx/SwitchContext.native.js +12 -0
- package/dist/jsx/SwitchContext.native.js.map +6 -0
- package/dist/jsx/createSwitch.js +35 -22
- package/dist/jsx/createSwitch.js.map +2 -2
- package/dist/jsx/createSwitch.native.js +35 -22
- package/dist/jsx/createSwitch.native.js.map +2 -2
- package/dist/jsx/index.js +10 -0
- package/dist/jsx/index.js.map +1 -1
- package/dist/jsx/index.native.js +10 -0
- package/dist/jsx/index.native.js.map +1 -1
- package/package.json +11 -11
- package/src/Switch.tsx +1 -7
- package/src/SwitchContext.tsx +15 -0
- package/src/createSwitch.tsx +80 -34
- package/src/index.ts +9 -0
- package/types/Switch.d.ts +0 -21
- package/types/Switch.d.ts.map +1 -1
- package/types/SwitchContext.d.ts +9 -0
- package/types/SwitchContext.d.ts.map +1 -0
- package/types/createSwitch.d.ts +12 -13
- package/types/createSwitch.d.ts.map +1 -1
- package/types/index.d.ts +24 -0
- package/types/index.d.ts.map +1 -1
package/dist/esm/createSwitch.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { useComposedRefs } from "@tamagui/compose-refs";
|
|
2
2
|
import {
|
|
3
3
|
composeEventHandlers,
|
|
4
|
-
createStyledContext,
|
|
5
4
|
getVariableValue,
|
|
6
5
|
isWeb,
|
|
7
6
|
useProps,
|
|
@@ -17,27 +16,41 @@ import {
|
|
|
17
16
|
Switch as NativeSwitch,
|
|
18
17
|
Platform
|
|
19
18
|
} from "react-native";
|
|
19
|
+
import { SwitchFrame, SwitchThumb } from "./Switch";
|
|
20
|
+
import { SwitchContext } from "./SwitchContext";
|
|
20
21
|
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
22
|
+
function createSwitch({
|
|
23
|
+
Frame = SwitchFrame,
|
|
24
|
+
Thumb = SwitchThumb,
|
|
25
|
+
acceptsUnstyled
|
|
26
|
+
}) {
|
|
27
|
+
process.env.NODE_ENV === "development" && (Frame !== SwitchFrame && Frame.staticConfig.context && console.warn(
|
|
28
|
+
"Warning: createSwitch() needs to control context to pass checked state from Frame to Thumb, any custom context passed will be overridden."
|
|
29
|
+
), Thumb !== SwitchThumb && Thumb.staticConfig.context && console.warn(
|
|
30
|
+
"Warning: createSwitch() needs to control context to pass checked state from Frame to Thumb, any custom context passed will be overridden."
|
|
31
|
+
)), Frame.staticConfig.context = SwitchContext, Thumb.staticConfig.context = SwitchContext;
|
|
32
|
+
const SwitchThumbComponent = Thumb.styleable(function(props, forwardedRef) {
|
|
33
|
+
const { size: sizeProp, unstyled: unstyledProp, ...thumbProps } = props, context = React.useContext(SwitchContext), {
|
|
34
|
+
disabled,
|
|
35
|
+
checked,
|
|
36
|
+
unstyled: unstyledContext,
|
|
37
|
+
frameWidth,
|
|
38
|
+
size: sizeContext
|
|
39
|
+
} = context, [thumbWidth, setThumbWidth] = React.useState(0), initialChecked = React.useRef(checked).current, distance = frameWidth - thumbWidth, x = initialChecked ? checked ? 0 : -distance : checked ? distance : 0;
|
|
31
40
|
return (
|
|
32
41
|
// @ts-ignore
|
|
33
42
|
/* @__PURE__ */ jsx(
|
|
34
43
|
Thumb,
|
|
35
44
|
{
|
|
36
|
-
|
|
45
|
+
...(unstyledProp ?? unstyledContext ?? !1) === !1 && {
|
|
46
|
+
unstyled: !1,
|
|
47
|
+
size: sizeProp ?? sizeContext ?? "$true",
|
|
48
|
+
theme: checked ? "active" : null
|
|
49
|
+
},
|
|
37
50
|
"data-state": getState(checked),
|
|
38
51
|
"data-disabled": disabled ? "" : void 0,
|
|
39
52
|
alignSelf: initialChecked ? "flex-end" : "flex-start",
|
|
40
|
-
x
|
|
53
|
+
x,
|
|
41
54
|
...thumbProps,
|
|
42
55
|
onLayout: composeEventHandlers(
|
|
43
56
|
props.onLayout,
|
|
@@ -51,7 +64,7 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
51
64
|
)
|
|
52
65
|
);
|
|
53
66
|
}), SwitchComponent = Frame.extractable(
|
|
54
|
-
React.forwardRef(function(propsIn, forwardedRef) {
|
|
67
|
+
React.forwardRef(function SwitchFrame2(propsIn, forwardedRef) {
|
|
55
68
|
const styledContext = React.useContext(SwitchContext), props = useProps(propsIn), {
|
|
56
69
|
labeledBy: ariaLabelledby,
|
|
57
70
|
name,
|
|
@@ -65,12 +78,13 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
65
78
|
unstyled = styledContext.unstyled ?? !1,
|
|
66
79
|
native: nativeProp,
|
|
67
80
|
nativeProps,
|
|
81
|
+
children,
|
|
68
82
|
...switchProps
|
|
69
83
|
} = props, leftBorderWidth = (() => {
|
|
70
84
|
let _;
|
|
71
85
|
for (const key in switchProps)
|
|
72
86
|
(key === "borderWidth" || key === "borderLeftWidth") && (_ = switchProps[key]);
|
|
73
|
-
return acceptsUnstyled && _
|
|
87
|
+
return Frame === SwitchFrame2 && acceptsUnstyled && _ == null && unstyled === !1 && (_ = 2), typeof _ == "string" && (_ = getVariableValue(getSize(_))), typeof _ == "number" ? _ : 0;
|
|
74
88
|
})(), 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({
|
|
75
89
|
prop: checkedProp,
|
|
76
90
|
defaultProp: defaultChecked || !1,
|
|
@@ -116,12 +130,13 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
116
130
|
setChecked((prevChecked) => !prevChecked), isWeb && isFormControl && (hasConsumerStoppedPropagationRef.current = event.isPropagationStopped(), hasConsumerStoppedPropagationRef.current || event.stopPropagation());
|
|
117
131
|
}),
|
|
118
132
|
onLayout: composeEventHandlers(
|
|
133
|
+
// @ts-ignore
|
|
119
134
|
props.onLayout,
|
|
120
|
-
(e) =>
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
)
|
|
135
|
+
(e) => {
|
|
136
|
+
setFrameWidth(e.nativeEvent.layout.width);
|
|
137
|
+
}
|
|
138
|
+
),
|
|
139
|
+
children: typeof children == "function" ? children(checked) : children
|
|
125
140
|
}
|
|
126
141
|
),
|
|
127
142
|
isWeb && isFormControl && /* @__PURE__ */ jsx(
|
|
@@ -175,11 +190,10 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
175
190
|
return checked ? "checked" : "unchecked";
|
|
176
191
|
}
|
|
177
192
|
return withStaticProperties(SwitchComponent, {
|
|
178
|
-
Thumb:
|
|
193
|
+
Thumb: SwitchThumbComponent
|
|
179
194
|
});
|
|
180
195
|
}
|
|
181
196
|
export {
|
|
182
|
-
SwitchContext,
|
|
183
197
|
createSwitch
|
|
184
198
|
};
|
|
185
199
|
//# sourceMappingURL=createSwitch.js.map
|
|
@@ -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,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,
|
|
5
|
-
"names": []
|
|
4
|
+
"mappings": "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",
|
|
5
|
+
"names": ["SwitchFrame"]
|
|
6
6
|
}
|
package/dist/esm/index.js
CHANGED
|
@@ -1,3 +1,13 @@
|
|
|
1
|
+
import { createSwitch } from "./createSwitch";
|
|
2
|
+
import { SwitchFrame, SwitchThumb } from "./Switch";
|
|
1
3
|
export * from "./Switch";
|
|
2
4
|
export * from "./createSwitch";
|
|
5
|
+
const Switch = createSwitch({
|
|
6
|
+
Frame: SwitchFrame,
|
|
7
|
+
Thumb: SwitchThumb,
|
|
8
|
+
acceptsUnstyled: !0
|
|
9
|
+
});
|
|
10
|
+
export {
|
|
11
|
+
Switch
|
|
12
|
+
};
|
|
3
13
|
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/index.ts"],
|
|
4
|
-
"mappings": "AAAA,cAAc;AACd,cAAc;",
|
|
4
|
+
"mappings": "AAAA,SAAS,oBAAoB;AAC7B,SAAS,aAAa,mBAAmB;AAEzC,cAAc;AACd,cAAc;AAEP,MAAM,SAAS,aAAa;AAAA,EACjC,OAAO;AAAA,EACP,OAAO;AAAA,EACP,iBAAiB;AACnB,CAAC;",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
package/dist/jsx/Switch.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { getVariableValue, styled } from "@tamagui/core";
|
|
2
2
|
import { getSize } from "@tamagui/get-token";
|
|
3
3
|
import { ThemeableStack, YStack } from "@tamagui/stacks";
|
|
4
|
-
import { SwitchContext
|
|
4
|
+
import { SwitchContext } from "./SwitchContext";
|
|
5
5
|
const SwitchThumb = styled(ThemeableStack, {
|
|
6
6
|
name: "SwitchThumb",
|
|
7
7
|
context: SwitchContext,
|
|
@@ -66,13 +66,8 @@ const SwitchThumb = styled(ThemeableStack, {
|
|
|
66
66
|
defaultVariants: {
|
|
67
67
|
unstyled: !1
|
|
68
68
|
}
|
|
69
|
-
}), Switch = createSwitch({
|
|
70
|
-
Frame: SwitchFrame,
|
|
71
|
-
Thumb: SwitchThumb,
|
|
72
|
-
acceptsUnstyled: !0
|
|
73
69
|
});
|
|
74
70
|
export {
|
|
75
|
-
Switch,
|
|
76
71
|
SwitchFrame,
|
|
77
72
|
SwitchThumb
|
|
78
73
|
};
|
package/dist/jsx/Switch.js.map
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/Switch.tsx"],
|
|
4
|
-
"mappings": "AAAA,SAAqB,kBAAkB,cAAc;AACrD,SAAS,eAAe;AACxB,SAAS,gBAAgB,cAAc;AAEvC,SAAS,
|
|
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,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,KAAK;AAAA,EACL,SAAS;AAAA,EAET,UAAU;AAAA,IACR,UAAU;AAAA,MACR,OAAO;AAAA,QACL,MAAM;AAAA,QACN,cAAc;AAAA,QACd,aAAa;AAAA,QACb,aAAa;AAAA,QACb,iBAAiB;AAAA,QAEjB,YAAY;AAAA,UACV,aAAa;AAAA,UACb,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
5
|
"names": []
|
|
6
6
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { getVariableValue, styled } from "@tamagui/core";
|
|
2
2
|
import { getSize } from "@tamagui/get-token";
|
|
3
3
|
import { ThemeableStack, YStack } from "@tamagui/stacks";
|
|
4
|
-
import { SwitchContext
|
|
4
|
+
import { SwitchContext } from "./SwitchContext";
|
|
5
5
|
const SwitchThumb = styled(ThemeableStack, {
|
|
6
6
|
name: "SwitchThumb",
|
|
7
7
|
context: SwitchContext,
|
|
@@ -66,13 +66,8 @@ const SwitchThumb = styled(ThemeableStack, {
|
|
|
66
66
|
defaultVariants: {
|
|
67
67
|
unstyled: !1
|
|
68
68
|
}
|
|
69
|
-
}), Switch = createSwitch({
|
|
70
|
-
Frame: SwitchFrame,
|
|
71
|
-
Thumb: SwitchThumb,
|
|
72
|
-
acceptsUnstyled: !0
|
|
73
69
|
});
|
|
74
70
|
export {
|
|
75
|
-
Switch,
|
|
76
71
|
SwitchFrame,
|
|
77
72
|
SwitchThumb
|
|
78
73
|
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/Switch.tsx"],
|
|
4
|
-
"mappings": "AAAA,SAAqB,kBAAkB,cAAc;AACrD,SAAS,eAAe;AACxB,SAAS,gBAAgB,cAAc;AAEvC,SAAS,
|
|
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,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,KAAK;AAAA,EACL,SAAS;AAAA,EAET,UAAU;AAAA,IACR,UAAU;AAAA,MACR,OAAO;AAAA,QACL,MAAM;AAAA,QACN,cAAc;AAAA,QACd,aAAa;AAAA,QACb,aAAa;AAAA,QACb,iBAAiB;AAAA,QAEjB,YAAY;AAAA,UACV,aAAa;AAAA,UACb,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
5
|
"names": []
|
|
6
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,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
|
package/dist/jsx/createSwitch.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { useComposedRefs } from "@tamagui/compose-refs";
|
|
2
2
|
import {
|
|
3
3
|
composeEventHandlers,
|
|
4
|
-
createStyledContext,
|
|
5
4
|
getVariableValue,
|
|
6
5
|
isWeb,
|
|
7
6
|
useProps,
|
|
@@ -17,24 +16,38 @@ import {
|
|
|
17
16
|
Switch as NativeSwitch,
|
|
18
17
|
Platform
|
|
19
18
|
} from "react-native";
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
})
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
19
|
+
import { SwitchFrame, SwitchThumb } from "./Switch";
|
|
20
|
+
import { SwitchContext } from "./SwitchContext";
|
|
21
|
+
function createSwitch({
|
|
22
|
+
Frame = SwitchFrame,
|
|
23
|
+
Thumb = SwitchThumb,
|
|
24
|
+
acceptsUnstyled
|
|
25
|
+
}) {
|
|
26
|
+
process.env.NODE_ENV === "development" && (Frame !== SwitchFrame && 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, unstyled = unstyledProp ?? unstyledContext ?? !1;
|
|
30
39
|
return (
|
|
31
40
|
// @ts-ignore
|
|
32
41
|
<Thumb
|
|
33
|
-
|
|
42
|
+
{...unstyled === !1 && {
|
|
43
|
+
unstyled: !1,
|
|
44
|
+
size: sizeProp ?? sizeContext ?? "$true",
|
|
45
|
+
theme: checked ? "active" : null
|
|
46
|
+
}}
|
|
34
47
|
data-state={getState(checked)}
|
|
35
48
|
data-disabled={disabled ? "" : void 0}
|
|
36
49
|
alignSelf={initialChecked ? "flex-end" : "flex-start"}
|
|
37
|
-
x={
|
|
50
|
+
x={x}
|
|
38
51
|
{...thumbProps}
|
|
39
52
|
onLayout={composeEventHandlers(
|
|
40
53
|
props.onLayout,
|
|
@@ -47,7 +60,7 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
47
60
|
/>
|
|
48
61
|
);
|
|
49
62
|
}), SwitchComponent = Frame.extractable(
|
|
50
|
-
React.forwardRef(function(propsIn, forwardedRef) {
|
|
63
|
+
React.forwardRef(function SwitchFrame2(propsIn, forwardedRef) {
|
|
51
64
|
const styledContext = React.useContext(SwitchContext), props = useProps(propsIn), {
|
|
52
65
|
labeledBy: ariaLabelledby,
|
|
53
66
|
name,
|
|
@@ -61,12 +74,13 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
61
74
|
unstyled = styledContext.unstyled ?? !1,
|
|
62
75
|
native: nativeProp,
|
|
63
76
|
nativeProps,
|
|
77
|
+
children,
|
|
64
78
|
...switchProps
|
|
65
79
|
} = props, leftBorderWidth = (() => {
|
|
66
80
|
let _;
|
|
67
81
|
for (const key in switchProps)
|
|
68
82
|
(key === "borderWidth" || key === "borderLeftWidth") && (_ = switchProps[key]);
|
|
69
|
-
return acceptsUnstyled && _
|
|
83
|
+
return Frame === SwitchFrame2 && acceptsUnstyled && _ == null && unstyled === !1 && (_ = 2), typeof _ == "string" && (_ = getVariableValue(getSize(_))), typeof _ == "number" ? _ : 0;
|
|
70
84
|
})(), 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({
|
|
71
85
|
prop: checkedProp,
|
|
72
86
|
defaultProp: defaultChecked || !1,
|
|
@@ -110,13 +124,13 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
110
124
|
setChecked((prevChecked) => !prevChecked), isWeb && isFormControl && (hasConsumerStoppedPropagationRef.current = event.isPropagationStopped(), hasConsumerStoppedPropagationRef.current || event.stopPropagation());
|
|
111
125
|
})}
|
|
112
126
|
onLayout={composeEventHandlers(
|
|
127
|
+
// @ts-ignore
|
|
113
128
|
props.onLayout,
|
|
114
|
-
(e) =>
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
)
|
|
129
|
+
(e) => {
|
|
130
|
+
setFrameWidth(e.nativeEvent.layout.width);
|
|
131
|
+
}
|
|
118
132
|
)}
|
|
119
|
-
|
|
133
|
+
>{typeof children == "function" ? children(checked) : children}</Frame>
|
|
120
134
|
{isWeb && isFormControl && <BubbleInput
|
|
121
135
|
control={button}
|
|
122
136
|
bubbles={!hasConsumerStoppedPropagationRef.current}
|
|
@@ -162,11 +176,10 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
162
176
|
return checked ? "checked" : "unchecked";
|
|
163
177
|
}
|
|
164
178
|
return withStaticProperties(SwitchComponent, {
|
|
165
|
-
Thumb:
|
|
179
|
+
Thumb: SwitchThumbComponent
|
|
166
180
|
});
|
|
167
181
|
}
|
|
168
182
|
export {
|
|
169
|
-
SwitchContext,
|
|
170
183
|
createSwitch
|
|
171
184
|
};
|
|
172
185
|
//# sourceMappingURL=createSwitch.js.map
|
|
@@ -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,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,
|
|
5
|
-
"names": []
|
|
4
|
+
"mappings": "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",
|
|
5
|
+
"names": ["SwitchFrame"]
|
|
6
6
|
}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { useComposedRefs } from "@tamagui/compose-refs";
|
|
2
2
|
import {
|
|
3
3
|
composeEventHandlers,
|
|
4
|
-
createStyledContext,
|
|
5
4
|
getVariableValue,
|
|
6
5
|
isWeb,
|
|
7
6
|
useProps,
|
|
@@ -17,24 +16,38 @@ import {
|
|
|
17
16
|
Switch as NativeSwitch,
|
|
18
17
|
Platform
|
|
19
18
|
} from "react-native";
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
})
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
19
|
+
import { SwitchFrame, SwitchThumb } from "./Switch";
|
|
20
|
+
import { SwitchContext } from "./SwitchContext";
|
|
21
|
+
function createSwitch({
|
|
22
|
+
Frame = SwitchFrame,
|
|
23
|
+
Thumb = SwitchThumb,
|
|
24
|
+
acceptsUnstyled
|
|
25
|
+
}) {
|
|
26
|
+
process.env.NODE_ENV === "development" && (Frame !== SwitchFrame && 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, unstyled = unstyledProp ?? unstyledContext ?? !1;
|
|
30
39
|
return (
|
|
31
40
|
// @ts-ignore
|
|
32
41
|
<Thumb
|
|
33
|
-
|
|
42
|
+
{...unstyled === !1 && {
|
|
43
|
+
unstyled: !1,
|
|
44
|
+
size: sizeProp ?? sizeContext ?? "$true",
|
|
45
|
+
theme: checked ? "active" : null
|
|
46
|
+
}}
|
|
34
47
|
data-state={getState(checked)}
|
|
35
48
|
data-disabled={disabled ? "" : void 0}
|
|
36
49
|
alignSelf={initialChecked ? "flex-end" : "flex-start"}
|
|
37
|
-
x={
|
|
50
|
+
x={x}
|
|
38
51
|
{...thumbProps}
|
|
39
52
|
onLayout={composeEventHandlers(
|
|
40
53
|
props.onLayout,
|
|
@@ -47,7 +60,7 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
47
60
|
/>
|
|
48
61
|
);
|
|
49
62
|
}), SwitchComponent = Frame.extractable(
|
|
50
|
-
React.forwardRef(function(propsIn, forwardedRef) {
|
|
63
|
+
React.forwardRef(function SwitchFrame2(propsIn, forwardedRef) {
|
|
51
64
|
const styledContext = React.useContext(SwitchContext), props = useProps(propsIn), {
|
|
52
65
|
labeledBy: ariaLabelledby,
|
|
53
66
|
name,
|
|
@@ -61,12 +74,13 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
61
74
|
unstyled = styledContext.unstyled ?? !1,
|
|
62
75
|
native: nativeProp,
|
|
63
76
|
nativeProps,
|
|
77
|
+
children,
|
|
64
78
|
...switchProps
|
|
65
79
|
} = props, leftBorderWidth = (() => {
|
|
66
80
|
let _;
|
|
67
81
|
for (const key in switchProps)
|
|
68
82
|
(key === "borderWidth" || key === "borderLeftWidth") && (_ = switchProps[key]);
|
|
69
|
-
return acceptsUnstyled && _
|
|
83
|
+
return Frame === SwitchFrame2 && acceptsUnstyled && _ == null && unstyled === !1 && (_ = 2), typeof _ == "string" && (_ = getVariableValue(getSize(_))), typeof _ == "number" ? _ : 0;
|
|
70
84
|
})(), 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({
|
|
71
85
|
prop: checkedProp,
|
|
72
86
|
defaultProp: defaultChecked || !1,
|
|
@@ -110,13 +124,13 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
110
124
|
setChecked((prevChecked) => !prevChecked), isWeb && isFormControl && (hasConsumerStoppedPropagationRef.current = event.isPropagationStopped(), hasConsumerStoppedPropagationRef.current || event.stopPropagation());
|
|
111
125
|
})}
|
|
112
126
|
onLayout={composeEventHandlers(
|
|
127
|
+
// @ts-ignore
|
|
113
128
|
props.onLayout,
|
|
114
|
-
(e) =>
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
)
|
|
129
|
+
(e) => {
|
|
130
|
+
setFrameWidth(e.nativeEvent.layout.width);
|
|
131
|
+
}
|
|
118
132
|
)}
|
|
119
|
-
|
|
133
|
+
>{typeof children == "function" ? children(checked) : children}</Frame>
|
|
120
134
|
{isWeb && isFormControl && <BubbleInput
|
|
121
135
|
control={button}
|
|
122
136
|
bubbles={!hasConsumerStoppedPropagationRef.current}
|
|
@@ -162,11 +176,10 @@ function createSwitch({ Frame, Thumb, acceptsUnstyled }) {
|
|
|
162
176
|
return checked ? "checked" : "unchecked";
|
|
163
177
|
}
|
|
164
178
|
return withStaticProperties(SwitchComponent, {
|
|
165
|
-
Thumb:
|
|
179
|
+
Thumb: SwitchThumbComponent
|
|
166
180
|
});
|
|
167
181
|
}
|
|
168
182
|
export {
|
|
169
|
-
SwitchContext,
|
|
170
183
|
createSwitch
|
|
171
184
|
};
|
|
172
185
|
//# sourceMappingURL=createSwitch.js.map
|
|
@@ -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,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,
|
|
5
|
-
"names": []
|
|
4
|
+
"mappings": "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",
|
|
5
|
+
"names": ["SwitchFrame"]
|
|
6
6
|
}
|
package/dist/jsx/index.js
CHANGED
|
@@ -1,3 +1,13 @@
|
|
|
1
|
+
import { createSwitch } from "./createSwitch";
|
|
2
|
+
import { SwitchFrame, SwitchThumb } from "./Switch";
|
|
1
3
|
export * from "./Switch";
|
|
2
4
|
export * from "./createSwitch";
|
|
5
|
+
const Switch = createSwitch({
|
|
6
|
+
Frame: SwitchFrame,
|
|
7
|
+
Thumb: SwitchThumb,
|
|
8
|
+
acceptsUnstyled: !0
|
|
9
|
+
});
|
|
10
|
+
export {
|
|
11
|
+
Switch
|
|
12
|
+
};
|
|
3
13
|
//# sourceMappingURL=index.js.map
|
package/dist/jsx/index.js.map
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/index.ts"],
|
|
4
|
-
"mappings": "AAAA,cAAc;AACd,cAAc;",
|
|
4
|
+
"mappings": "AAAA,SAAS,oBAAoB;AAC7B,SAAS,aAAa,mBAAmB;AAEzC,cAAc;AACd,cAAc;AAEP,MAAM,SAAS,aAAa;AAAA,EACjC,OAAO;AAAA,EACP,OAAO;AAAA,EACP,iBAAiB;AACnB,CAAC;",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
package/dist/jsx/index.native.js
CHANGED
|
@@ -1,3 +1,13 @@
|
|
|
1
|
+
import { createSwitch } from "./createSwitch";
|
|
2
|
+
import { SwitchFrame, SwitchThumb } from "./Switch";
|
|
1
3
|
export * from "./Switch";
|
|
2
4
|
export * from "./createSwitch";
|
|
5
|
+
const Switch = createSwitch({
|
|
6
|
+
Frame: SwitchFrame,
|
|
7
|
+
Thumb: SwitchThumb,
|
|
8
|
+
acceptsUnstyled: !0
|
|
9
|
+
});
|
|
10
|
+
export {
|
|
11
|
+
Switch
|
|
12
|
+
};
|
|
3
13
|
//# sourceMappingURL=index.js.map
|