@tamagui/input 1.143.0 → 2.0.0-1
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/Input.cjs +57 -122
- package/dist/cjs/Input.js +46 -115
- package/dist/cjs/Input.js.map +1 -1
- package/dist/cjs/Input.native.js +133 -71
- package/dist/cjs/Input.native.js.map +1 -1
- package/dist/cjs/TextArea.cjs +1 -1
- package/dist/cjs/TextArea.js +1 -1
- package/dist/cjs/TextArea.js.map +1 -1
- package/dist/cjs/TextArea.native.js +1 -1
- package/dist/cjs/TextArea.native.js.map +1 -1
- package/dist/esm/Input.js +47 -116
- package/dist/esm/Input.js.map +1 -1
- package/dist/esm/Input.mjs +58 -123
- package/dist/esm/Input.mjs.map +1 -1
- package/dist/esm/Input.native.js +134 -72
- package/dist/esm/Input.native.js.map +1 -1
- package/dist/esm/TextArea.js +1 -1
- package/dist/esm/TextArea.js.map +1 -1
- package/dist/esm/TextArea.mjs +1 -1
- package/dist/esm/TextArea.mjs.map +1 -1
- package/dist/esm/TextArea.native.js +1 -1
- package/dist/esm/TextArea.native.js.map +1 -1
- package/dist/jsx/Input.js +47 -116
- package/dist/jsx/Input.js.map +1 -1
- package/dist/jsx/Input.mjs +58 -123
- package/dist/jsx/Input.mjs.map +1 -1
- package/dist/jsx/Input.native.js +133 -71
- package/dist/jsx/Input.native.js.map +1 -1
- package/dist/jsx/TextArea.js +1 -1
- package/dist/jsx/TextArea.js.map +1 -1
- package/dist/jsx/TextArea.mjs +1 -1
- package/dist/jsx/TextArea.mjs.map +1 -1
- package/dist/jsx/TextArea.native.js +1 -1
- package/dist/jsx/TextArea.native.js.map +1 -1
- package/package.json +13 -13
- package/src/Input.native.tsx +145 -110
- package/src/Input.tsx +67 -137
- package/src/TextArea.tsx +4 -2
- package/src/types.ts +52 -41
- package/src/v1/Input.native.tsx +154 -0
- package/src/v1/Input.tsx +191 -0
- package/src/v1/TextArea.tsx +35 -0
- package/src/v1/index.ts +3 -0
- package/src/v1/types.ts +65 -0
- package/types/Input.d.ts +47 -21
- package/types/Input.d.ts.map +1 -1
- package/types/Input.native.d.ts +52 -22
- package/types/Input.native.d.ts.map +1 -1
- package/types/TextArea.d.ts +25 -11
- package/types/TextArea.d.ts.map +1 -1
- package/types/types.d.ts +47 -21
- package/types/types.d.ts.map +1 -1
- package/types/v1/Input.d.ts +115 -0
- package/types/v1/Input.native.d.ts +114 -0
- package/types/v1/TextArea.d.ts +98 -0
- package/types/v1/index.d.ts +4 -0
- package/types/v1/types.d.ts +39 -0
- package/types/v1/types.d.ts.map +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["Input_native_exports","__export","Input","module","exports","__toCommonJS","import_jsx_runtime","require","import_react","__toESM","
|
|
1
|
+
{"version":3,"names":["Input_native_exports","__export","Input","module","exports","__toCommonJS","import_jsx_runtime","require","import_react","__toESM","import_react_native","import_core","import_focusable","import_shared","StyledInput","styled","TextInput","styledBody","styleable","props","forwardedRef","_theme_placeholderTextColor","_theme_selectionColor","type","disabled","readOnly","id","rows","autoComplete","enterKeyHint","placeholderTextColor","selectionColor","onChange","onInput","onKeyDown","onChangeText","onSubmitEditing","onSelectionChange","selection","dirname","min","max","minLength","multiple","name","pattern","required","step","tag","rest","ref","default","useRef","theme","useTheme","composedRefs","useComposedRefs","secureTextEntry","keyboardType","inputMode","returnKeyType","_theme_placeholderTextColor_val","resolvedPlaceholderColor","getTokenValue","val","_theme_selectionColor_val","resolvedSelectionColor","useEffect","registerFocusable","focusAndSelect","_ref_current","current","focus","handleChangeText","text","target","value","handleKeyPress","e","key","nativeEvent","length","handleSubmitEditing","handleSelectionChange","finalProps","editable","multiline","numberOfLines","onKeyPress","jsx"],"sources":["../../src/Input.native.tsx"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
package/dist/cjs/TextArea.cjs
CHANGED
package/dist/cjs/TextArea.js
CHANGED
package/dist/cjs/TextArea.js.map
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/TextArea.tsx"],
|
|
4
|
-
"mappings": ";;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAAuB,yBACvB,eAAsB,oBACtB,gBAAmD;
|
|
4
|
+
"mappings": ";;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAAuB,yBACvB,eAAsB,oBACtB,gBAAmD;AAQ5C,MAAM,eAAW,mBAAO,oBAAO;AAAA,EACpC,MAAM;AAAA,EACN,KAAK;AAAA;AAAA;AAAA,EAIL,YAAY;AAAA,EAEZ,UAAU;AAAA,IACR,UAAU;AAAA,MACR,OAAO;AAAA,QACL,QAAQ;AAAA,QACR,GAAG;AAAA,QACH,MAAM;AAAA,MACR;AAAA,IACF;AAAA,IAEA,MAAM;AAAA,MACJ,WAAW;AAAA,IACb;AAAA,EACF;AAAA,EAEA,iBAAiB;AAAA,IACf,UAAU,QAAQ,IAAI,qBAAqB;AAAA,EAC7C;AACF,CAAC;",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["__toCommonJS","mod","__copyProps","__defProp","value","TextArea_exports","__export","TextArea","module","exports","import_web","require","import_Input","import_shared","styled","Input","name","tag","whiteSpace","variants","unstyled","false","height","defaultStyles","
|
|
1
|
+
{"version":3,"names":["__toCommonJS","mod","__copyProps","__defProp","value","TextArea_exports","__export","TextArea","module","exports","import_web","require","import_Input","import_shared","styled","Input","name","tag","whiteSpace","variants","unstyled","false","height","defaultStyles","rows","size","textAreaSizeVariant","defaultVariants","process","env","TAMAGUI_HEADLESS"],"sources":["../../src/TextArea.tsx"],"sourcesContent":[null],"mappings":";;;;;;;;;;;;;;;;;;;AAAA,IAAAA,YAAA,GAAAC,GAAA,IAAAC,WAAA,CAAAC,SAAA;EAAAC,KAAA;AAAA,IAAAH,GAAA;AAAA,IAAAI,gBAAA;AAAAC,QAAA,CAAAD,gBAAA;EAAAE,QAAA,EAAAA,CAAA,KAAAA;AAAA;AAAAC,MAAA,CAAAC,OAAA,GAAuBT,YAAA,CAAAK,gBACvB;AASO,IAAAK,UAAM,GAAAC,OAAW,gBAAO;EAAAC,YAAA,GAAAD,OAAO;EAAAE,aAAA,GAAAF,OAAA;EAAAJ,QAAA,OAAAG,UAAA,CAAAI,MAAA,EAAAF,YAAA,CAAAG,KAAA;IACpCC,IAAA,EAAM;IACNC,GAAA,EAAK;IAAA;IAAA;IAILC,UAAA,EAAY;IAEZC,QAAA,EAAU;MACRC,QAAA,EAAU;QACRC,KAAA,EAAO;UACLC,MAAA,EAAQ;UACR,GAAGT,aAAA,CAAAU,aAAA;UACHC,IAAA,EAAM;QACR;MACF;MAEAC,IAAA,EAAM;QACJ,WAAWZ,aAAA,CAAAa;MACb;IACF;IAEAC,eAAA,EAAiB;MACfP,QAAA,EAAUQ,OAAA,CAAQC,GAAA,CAAIC,gBAAA,KAAqB;IAC7C;EACF,CAAC","ignoreList":[]}
|
package/dist/esm/Input.js
CHANGED
|
@@ -1,117 +1,58 @@
|
|
|
1
|
-
import { View, styled, useComposedRefs,
|
|
1
|
+
import { View, styled, useComposedRefs, useTheme } from "@tamagui/core";
|
|
2
2
|
import { registerFocusable } from "@tamagui/focusable";
|
|
3
3
|
import React from "react";
|
|
4
4
|
import { styledBody } from "./shared";
|
|
5
5
|
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
6
|
-
const StyledInput = styled(View, styledBody[0], styledBody[1]), Input = StyledInput.styleable((
|
|
6
|
+
const StyledInput = styled(View, styledBody[0], styledBody[1]), Input = StyledInput.styleable((props, forwardedRef) => {
|
|
7
7
|
const {
|
|
8
|
-
// some of destructed props are just to avoid passing them to ...rest because they are not in web.
|
|
9
|
-
allowFontScaling,
|
|
10
|
-
selectTextOnFocus,
|
|
11
|
-
showSoftInputOnFocus,
|
|
12
|
-
textContentType,
|
|
13
|
-
passwordRules,
|
|
14
|
-
textBreakStrategy,
|
|
15
|
-
underlineColorAndroid,
|
|
16
|
-
selection,
|
|
17
|
-
lineBreakStrategyIOS,
|
|
18
|
-
returnKeyLabel,
|
|
19
8
|
disabled,
|
|
20
|
-
onSubmitEditing,
|
|
21
|
-
caretHidden,
|
|
22
|
-
clearButtonMode,
|
|
23
|
-
clearTextOnFocus,
|
|
24
|
-
contextMenuHidden,
|
|
25
|
-
dataDetectorTypes,
|
|
26
9
|
id,
|
|
27
|
-
enablesReturnKeyAutomatically,
|
|
28
|
-
importantForAutofill,
|
|
29
|
-
inlineImageLeft,
|
|
30
|
-
inlineImagePadding,
|
|
31
|
-
inputAccessoryViewID,
|
|
32
|
-
keyboardAppearance,
|
|
33
|
-
keyboardType,
|
|
34
|
-
cursorColor,
|
|
35
|
-
disableFullscreenUI,
|
|
36
|
-
editable,
|
|
37
|
-
maxFontSizeMultiplier,
|
|
38
|
-
multiline,
|
|
39
|
-
numberOfLines,
|
|
40
10
|
onChangeText,
|
|
41
|
-
|
|
42
|
-
onEndEditing,
|
|
43
|
-
onScroll,
|
|
11
|
+
onSubmitEditing,
|
|
44
12
|
onSelectionChange,
|
|
45
|
-
|
|
13
|
+
selection,
|
|
46
14
|
placeholderTextColor,
|
|
47
|
-
blurOnSubmit,
|
|
48
|
-
enterKeyHint,
|
|
49
|
-
returnKeyType,
|
|
50
|
-
rejectResponderTermination,
|
|
51
|
-
scrollEnabled,
|
|
52
|
-
secureTextEntry,
|
|
53
15
|
selectionColor,
|
|
54
|
-
|
|
16
|
+
rows,
|
|
55
17
|
...rest
|
|
56
|
-
} =
|
|
57
|
-
const start = ref.current?.selectionStart ?? 0, end = ref.current?.selectionEnd ?? 0;
|
|
58
|
-
onSelectionChange?.({
|
|
59
|
-
nativeEvent: {
|
|
60
|
-
selection: {
|
|
61
|
-
end,
|
|
62
|
-
start
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
});
|
|
66
|
-
});
|
|
18
|
+
} = props, ref = React.useRef(null), theme = useTheme(), composedRefs = useComposedRefs(forwardedRef, ref);
|
|
67
19
|
React.useEffect(() => {
|
|
68
|
-
if (onSelectionChange)
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
20
|
+
if (!onSelectionChange) return;
|
|
21
|
+
const node = ref.current;
|
|
22
|
+
if (!node) return;
|
|
23
|
+
const handleSelectionChange = () => {
|
|
24
|
+
onSelectionChange({
|
|
25
|
+
nativeEvent: {
|
|
26
|
+
selection: {
|
|
27
|
+
start: node.selectionStart ?? 0,
|
|
28
|
+
end: node.selectionEnd ?? 0
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
};
|
|
33
|
+
return node.addEventListener("select", handleSelectionChange), () => node.removeEventListener("select", handleSelectionChange);
|
|
34
|
+
}, [onSelectionChange]), React.useEffect(() => {
|
|
35
|
+
selection && ref.current && ref.current.setSelectionRange(selection.start, selection.end ?? selection.start);
|
|
36
|
+
}, [selection?.start, selection?.end]), React.useEffect(() => {
|
|
37
|
+
if (!(!id || disabled))
|
|
38
|
+
return registerFocusable(id, {
|
|
39
|
+
focusAndSelect: () => ref.current?.focus(),
|
|
40
|
+
focus: () => ref.current?.focus()
|
|
41
|
+
});
|
|
42
|
+
}, [id, disabled]);
|
|
43
|
+
const handleKeyDown = (e) => {
|
|
44
|
+
e.key === "Enter" && onSubmitEditing && onSubmitEditing({
|
|
45
|
+
nativeEvent: { text: e.target.value }
|
|
46
|
+
}), rest.onKeyDown?.(e);
|
|
47
|
+
}, handleChange = (e) => {
|
|
48
|
+
onChangeText?.(e.target.value), rest.onChange?.(e);
|
|
49
|
+
}, finalProps = {
|
|
76
50
|
...rest,
|
|
77
51
|
disabled,
|
|
78
|
-
caretColor,
|
|
79
52
|
id,
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
if (secureTextEntry) return "password";
|
|
84
|
-
switch (keyboardType) {
|
|
85
|
-
case "number-pad":
|
|
86
|
-
case "numeric":
|
|
87
|
-
return "number";
|
|
88
|
-
case "email-address":
|
|
89
|
-
return "email";
|
|
90
|
-
case "phone-pad":
|
|
91
|
-
return "tel";
|
|
92
|
-
case "url":
|
|
93
|
-
return "url";
|
|
94
|
-
default:
|
|
95
|
-
return "text";
|
|
96
|
-
}
|
|
97
|
-
})(),
|
|
98
|
-
inputMode: (() => {
|
|
99
|
-
switch (keyboardType) {
|
|
100
|
-
case "number-pad":
|
|
101
|
-
case "numeric":
|
|
102
|
-
return "numeric";
|
|
103
|
-
case "decimal-pad":
|
|
104
|
-
return "decimal";
|
|
105
|
-
case "email-address":
|
|
106
|
-
return "email";
|
|
107
|
-
case "phone-pad":
|
|
108
|
-
return "tel";
|
|
109
|
-
case "url":
|
|
110
|
-
return "url";
|
|
111
|
-
default:
|
|
112
|
-
return;
|
|
113
|
-
}
|
|
114
|
-
})(),
|
|
53
|
+
rows,
|
|
54
|
+
onKeyDown: onSubmitEditing ? handleKeyDown : rest.onKeyDown,
|
|
55
|
+
onChange: onChangeText ? handleChange : rest.onChange,
|
|
115
56
|
style: {
|
|
116
57
|
...rest.style,
|
|
117
58
|
...placeholderTextColor && {
|
|
@@ -122,25 +63,15 @@ const StyledInput = styled(View, styledBody[0], styledBody[1]), Input = StyledIn
|
|
|
122
63
|
}
|
|
123
64
|
}
|
|
124
65
|
};
|
|
125
|
-
return
|
|
126
|
-
if (id && !disabled)
|
|
127
|
-
return registerFocusable(id, {
|
|
128
|
-
focusAndSelect: () => {
|
|
129
|
-
ref.current?.focus();
|
|
130
|
-
},
|
|
131
|
-
focus: () => {
|
|
132
|
-
}
|
|
133
|
-
});
|
|
134
|
-
}, [id, disabled]), /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
66
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
135
67
|
/* @__PURE__ */ jsx("style", { children: `
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
` }),
|
|
68
|
+
input::selection, textarea::selection {
|
|
69
|
+
background-color: var(--selectionColor) !important;
|
|
70
|
+
}
|
|
71
|
+
input::placeholder, textarea::placeholder {
|
|
72
|
+
color: var(--placeholderColor) !important;
|
|
73
|
+
}
|
|
74
|
+
` }),
|
|
144
75
|
/* @__PURE__ */ jsx(StyledInput, { ref: composedRefs, ...finalProps })
|
|
145
76
|
] });
|
|
146
77
|
});
|
package/dist/esm/Input.js.map
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/Input.tsx"],
|
|
4
|
-
"mappings": "AAAA,SAAS,MAAM,QAAQ,iBAAiB,
|
|
4
|
+
"mappings": "AAAA,SAAS,MAAM,QAAQ,iBAAiB,gBAAgB;AACxD,SAAS,yBAAyB;AAClC,OAAO,WAAW;AAClB,SAAS,kBAAkB;AAqGvB,mBACE,KADF;AAlGJ,MAAM,cAAc,OAAO,MAAM,WAAW,CAAC,GAAG,WAAW,CAAC,CAAC,GAMhD,QAAQ,YAAY,UAAsB,CAAC,OAAO,iBAAiB;AAC9E,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EACL,IAAI,OAEE,MAAM,MAAM,OAAyB,IAAI,GACzC,QAAQ,SAAS,GACjB,eAAe,gBAAgB,cAAc,GAAG;AAGtD,QAAM,UAAU,MAAM;AACpB,QAAI,CAAC,kBAAmB;AAExB,UAAM,OAAO,IAAI;AACjB,QAAI,CAAC,KAAM;AAEX,UAAM,wBAAwB,MAAM;AAClC,wBAAkB;AAAA,QAChB,aAAa;AAAA,UACX,WAAW;AAAA,YACT,OAAO,KAAK,kBAAkB;AAAA,YAC9B,KAAK,KAAK,gBAAgB;AAAA,UAC5B;AAAA,QACF;AAAA,MACF,CAAC;AAAA,IACH;AAEA,gBAAK,iBAAiB,UAAU,qBAAqB,GAC9C,MAAM,KAAK,oBAAoB,UAAU,qBAAqB;AAAA,EACvE,GAAG,CAAC,iBAAiB,CAAC,GAGtB,MAAM,UAAU,MAAM;AACpB,IAAI,aAAa,IAAI,WACnB,IAAI,QAAQ,kBAAkB,UAAU,OAAO,UAAU,OAAO,UAAU,KAAK;AAAA,EAEnF,GAAG,CAAC,WAAW,OAAO,WAAW,GAAG,CAAC,GAGrC,MAAM,UAAU,MAAM;AACpB,QAAI,GAAC,MAAM;AACX,aAAO,kBAAkB,IAAI;AAAA,QAC3B,gBAAgB,MAAM,IAAI,SAAS,MAAM;AAAA,QACzC,OAAO,MAAM,IAAI,SAAS,MAAM;AAAA,MAClC,CAAC;AAAA,EACH,GAAG,CAAC,IAAI,QAAQ,CAAC;AAGjB,QAAM,gBAAgB,CAAC,MAA6C;AAClE,IAAI,EAAE,QAAQ,WAAW,mBACvB,gBAAgB;AAAA,MACd,aAAa,EAAE,MAAO,EAAE,OAA4B,MAAM;AAAA,IAC5D,CAAC,GAEH,KAAK,YAAY,CAAC;AAAA,EACpB,GAGM,eAAe,CAAC,MAA2C;AAC/D,mBAAe,EAAE,OAAO,KAAK,GAC7B,KAAK,WAAW,CAAC;AAAA,EACnB,GAEM,aAAa;AAAA,IACjB,GAAG;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA,WAAW,kBAAkB,gBAAgB,KAAK;AAAA,IAClD,UAAU,eAAe,eAAe,KAAK;AAAA,IAC7C,OAAO;AAAA,MACL,GAAI,KAAK;AAAA,MACT,GAAI,wBAAwB;AAAA,QAC1B,sBACE,MAAM,oBAAoB,GAAG,YAAY;AAAA,MAC7C;AAAA,MACA,GAAI,kBAAkB;AAAA,QACpB,oBAAoB,MAAM,cAAc,GAAG,YAAY;AAAA,MACzD;AAAA,IACF;AAAA,EACF;AAEA,SACE,iCACE;AAAA,wBAAC,WACE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,WAQH;AAAA,IACA,oBAAC,eAAY,KAAK,cAAe,GAAG,YAAY;AAAA,KAClD;AAEJ,CAAC;",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
package/dist/esm/Input.mjs
CHANGED
|
@@ -1,150 +1,85 @@
|
|
|
1
|
-
import { View, styled, useComposedRefs,
|
|
1
|
+
import { View, styled, useComposedRefs, useTheme } from "@tamagui/core";
|
|
2
2
|
import { registerFocusable } from "@tamagui/focusable";
|
|
3
3
|
import React from "react";
|
|
4
4
|
import { styledBody } from "./shared.mjs";
|
|
5
5
|
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
6
6
|
const StyledInput = styled(View, styledBody[0], styledBody[1]),
|
|
7
|
-
Input = StyledInput.styleable((
|
|
7
|
+
Input = StyledInput.styleable((props, forwardedRef) => {
|
|
8
8
|
const {
|
|
9
|
-
// some of destructed props are just to avoid passing them to ...rest because they are not in web.
|
|
10
|
-
allowFontScaling,
|
|
11
|
-
selectTextOnFocus,
|
|
12
|
-
showSoftInputOnFocus,
|
|
13
|
-
textContentType,
|
|
14
|
-
passwordRules,
|
|
15
|
-
textBreakStrategy,
|
|
16
|
-
underlineColorAndroid,
|
|
17
|
-
selection,
|
|
18
|
-
lineBreakStrategyIOS,
|
|
19
|
-
returnKeyLabel,
|
|
20
9
|
disabled,
|
|
21
|
-
onSubmitEditing,
|
|
22
|
-
caretHidden,
|
|
23
|
-
clearButtonMode,
|
|
24
|
-
clearTextOnFocus,
|
|
25
|
-
contextMenuHidden,
|
|
26
|
-
dataDetectorTypes,
|
|
27
10
|
id,
|
|
28
|
-
enablesReturnKeyAutomatically,
|
|
29
|
-
importantForAutofill,
|
|
30
|
-
inlineImageLeft,
|
|
31
|
-
inlineImagePadding,
|
|
32
|
-
inputAccessoryViewID,
|
|
33
|
-
keyboardAppearance,
|
|
34
|
-
keyboardType,
|
|
35
|
-
cursorColor,
|
|
36
|
-
disableFullscreenUI,
|
|
37
|
-
editable,
|
|
38
|
-
maxFontSizeMultiplier,
|
|
39
|
-
multiline,
|
|
40
|
-
numberOfLines,
|
|
41
11
|
onChangeText,
|
|
42
|
-
|
|
43
|
-
onEndEditing,
|
|
44
|
-
onScroll,
|
|
12
|
+
onSubmitEditing,
|
|
45
13
|
onSelectionChange,
|
|
46
|
-
|
|
14
|
+
selection,
|
|
47
15
|
placeholderTextColor,
|
|
48
|
-
blurOnSubmit,
|
|
49
|
-
enterKeyHint,
|
|
50
|
-
returnKeyType,
|
|
51
|
-
rejectResponderTermination,
|
|
52
|
-
scrollEnabled,
|
|
53
|
-
secureTextEntry,
|
|
54
16
|
selectionColor,
|
|
55
|
-
|
|
17
|
+
rows,
|
|
56
18
|
...rest
|
|
57
|
-
} =
|
|
19
|
+
} = props,
|
|
58
20
|
ref = React.useRef(null),
|
|
59
21
|
theme = useTheme(),
|
|
60
|
-
composedRefs = useComposedRefs(forwardedRef, ref)
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
22
|
+
composedRefs = useComposedRefs(forwardedRef, ref);
|
|
23
|
+
React.useEffect(() => {
|
|
24
|
+
if (!onSelectionChange) return;
|
|
25
|
+
const node = ref.current;
|
|
26
|
+
if (!node) return;
|
|
27
|
+
const handleSelectionChange = () => {
|
|
28
|
+
onSelectionChange({
|
|
65
29
|
nativeEvent: {
|
|
66
30
|
selection: {
|
|
67
|
-
|
|
68
|
-
|
|
31
|
+
start: node.selectionStart ?? 0,
|
|
32
|
+
end: node.selectionEnd ?? 0
|
|
69
33
|
}
|
|
70
34
|
}
|
|
71
35
|
});
|
|
72
|
-
});
|
|
73
|
-
React.useEffect(() => {
|
|
74
|
-
if (onSelectionChange) return ref.current?.addEventListener("selectionchange", _onSelectionChange), () => {
|
|
75
|
-
ref.current?.removeEventListener("selectionchange", _onSelectionChange);
|
|
76
36
|
};
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
id,
|
|
85
|
-
enterKeyHint,
|
|
86
|
-
type: (() => {
|
|
87
|
-
if (rest?.type) return rest.type;
|
|
88
|
-
if (secureTextEntry) return "password";
|
|
89
|
-
switch (keyboardType) {
|
|
90
|
-
case "number-pad":
|
|
91
|
-
case "numeric":
|
|
92
|
-
return "number";
|
|
93
|
-
case "email-address":
|
|
94
|
-
return "email";
|
|
95
|
-
case "phone-pad":
|
|
96
|
-
return "tel";
|
|
97
|
-
case "url":
|
|
98
|
-
return "url";
|
|
99
|
-
default:
|
|
100
|
-
return "text";
|
|
101
|
-
}
|
|
102
|
-
})(),
|
|
103
|
-
inputMode: (() => {
|
|
104
|
-
switch (keyboardType) {
|
|
105
|
-
case "number-pad":
|
|
106
|
-
case "numeric":
|
|
107
|
-
return "numeric";
|
|
108
|
-
case "decimal-pad":
|
|
109
|
-
return "decimal";
|
|
110
|
-
case "email-address":
|
|
111
|
-
return "email";
|
|
112
|
-
case "phone-pad":
|
|
113
|
-
return "tel";
|
|
114
|
-
case "url":
|
|
115
|
-
return "url";
|
|
116
|
-
default:
|
|
117
|
-
return;
|
|
118
|
-
}
|
|
119
|
-
})(),
|
|
120
|
-
style: {
|
|
121
|
-
...rest.style,
|
|
122
|
-
...(placeholderTextColor && {
|
|
123
|
-
"--placeholderColor": theme[placeholderTextColor]?.variable || placeholderTextColor
|
|
124
|
-
}),
|
|
125
|
-
...(selectionColor && {
|
|
126
|
-
"--selectionColor": theme[selectionColor]?.variable || selectionColor
|
|
127
|
-
})
|
|
128
|
-
}
|
|
129
|
-
};
|
|
130
|
-
return React.useEffect(() => {
|
|
131
|
-
if (id && !disabled) return registerFocusable(id, {
|
|
132
|
-
focusAndSelect: () => {
|
|
133
|
-
ref.current?.focus();
|
|
134
|
-
},
|
|
135
|
-
focus: () => {}
|
|
37
|
+
return node.addEventListener("select", handleSelectionChange), () => node.removeEventListener("select", handleSelectionChange);
|
|
38
|
+
}, [onSelectionChange]), React.useEffect(() => {
|
|
39
|
+
selection && ref.current && ref.current.setSelectionRange(selection.start, selection.end ?? selection.start);
|
|
40
|
+
}, [selection?.start, selection?.end]), React.useEffect(() => {
|
|
41
|
+
if (!(!id || disabled)) return registerFocusable(id, {
|
|
42
|
+
focusAndSelect: () => ref.current?.focus(),
|
|
43
|
+
focus: () => ref.current?.focus()
|
|
136
44
|
});
|
|
137
|
-
}, [id, disabled])
|
|
45
|
+
}, [id, disabled]);
|
|
46
|
+
const handleKeyDown = e => {
|
|
47
|
+
e.key === "Enter" && onSubmitEditing && onSubmitEditing({
|
|
48
|
+
nativeEvent: {
|
|
49
|
+
text: e.target.value
|
|
50
|
+
}
|
|
51
|
+
}), rest.onKeyDown?.(e);
|
|
52
|
+
},
|
|
53
|
+
handleChange = e => {
|
|
54
|
+
onChangeText?.(e.target.value), rest.onChange?.(e);
|
|
55
|
+
},
|
|
56
|
+
finalProps = {
|
|
57
|
+
...rest,
|
|
58
|
+
disabled,
|
|
59
|
+
id,
|
|
60
|
+
rows,
|
|
61
|
+
onKeyDown: onSubmitEditing ? handleKeyDown : rest.onKeyDown,
|
|
62
|
+
onChange: onChangeText ? handleChange : rest.onChange,
|
|
63
|
+
style: {
|
|
64
|
+
...rest.style,
|
|
65
|
+
...(placeholderTextColor && {
|
|
66
|
+
"--placeholderColor": theme[placeholderTextColor]?.variable || placeholderTextColor
|
|
67
|
+
}),
|
|
68
|
+
...(selectionColor && {
|
|
69
|
+
"--selectionColor": theme[selectionColor]?.variable || selectionColor
|
|
70
|
+
})
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
return /* @__PURE__ */jsxs(Fragment, {
|
|
138
74
|
children: [/* @__PURE__ */jsx("style", {
|
|
139
75
|
children: `
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
`
|
|
76
|
+
input::selection, textarea::selection {
|
|
77
|
+
background-color: var(--selectionColor) !important;
|
|
78
|
+
}
|
|
79
|
+
input::placeholder, textarea::placeholder {
|
|
80
|
+
color: var(--placeholderColor) !important;
|
|
81
|
+
}
|
|
82
|
+
`
|
|
148
83
|
}), /* @__PURE__ */jsx(StyledInput, {
|
|
149
84
|
ref: composedRefs,
|
|
150
85
|
...finalProps
|
package/dist/esm/Input.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["View","styled","useComposedRefs","
|
|
1
|
+
{"version":3,"names":["View","styled","useComposedRefs","useTheme","registerFocusable","React","styledBody","Fragment","jsx","jsxs","StyledInput","Input","styleable","props","forwardedRef","disabled","id","onChangeText","onSubmitEditing","onSelectionChange","selection","placeholderTextColor","selectionColor","rows","rest","ref","useRef","theme","composedRefs","useEffect","node","current","handleSelectionChange","nativeEvent","start","selectionStart","end","selectionEnd","addEventListener","removeEventListener","setSelectionRange","focusAndSelect","focus","handleKeyDown","e","key","text","target","value","onKeyDown","handleChange","onChange","finalProps","style","variable","children"],"sources":["../../src/Input.tsx"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|