@korsolutions/ui 0.0.94 → 0.0.95
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/module/components/combobox/components/combobox-content.js +2 -0
- package/dist/module/components/combobox/components/combobox-content.js.map +1 -1
- package/dist/module/components/combobox/components/combobox-option.js +6 -5
- package/dist/module/components/combobox/components/combobox-option.js.map +1 -1
- package/dist/module/components/combobox/components/combobox-overlay.js +9 -3
- package/dist/module/components/combobox/components/combobox-overlay.js.map +1 -1
- package/dist/module/components/combobox/components/combobox-trigger.js +1 -3
- package/dist/module/components/combobox/components/combobox-trigger.js.map +1 -1
- package/dist/module/components/focus/focus-prevent.js +10 -0
- package/dist/module/components/focus/focus-prevent.js.map +1 -0
- package/dist/typescript/src/components/combobox/components/combobox-content.d.ts.map +1 -1
- package/dist/typescript/src/components/combobox/components/combobox-option.d.ts.map +1 -1
- package/dist/typescript/src/components/combobox/components/combobox-overlay.d.ts.map +1 -1
- package/dist/typescript/src/components/combobox/components/combobox-trigger.d.ts.map +1 -1
- package/dist/typescript/src/components/focus/focus-prevent.d.ts +6 -0
- package/dist/typescript/src/components/focus/focus-prevent.d.ts.map +1 -0
- package/package.json +1 -1
- package/src/components/combobox/components/combobox-content.tsx +2 -0
- package/src/components/combobox/components/combobox-option.tsx +6 -5
- package/src/components/combobox/components/combobox-overlay.tsx +10 -3
- package/src/components/combobox/components/combobox-trigger.tsx +1 -3
- package/src/components/focus/focus-prevent.ts +8 -0
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
import React from "react";
|
|
4
4
|
import { ScrollView, StyleSheet } from "react-native";
|
|
5
5
|
import { useRelativePosition } from "../../../hooks/use-relative-position.js";
|
|
6
|
+
import { focusPreventProps } from "../../focus/focus-prevent.js";
|
|
6
7
|
import { useCombobox } from "../context.js";
|
|
7
8
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
8
9
|
export function ComboboxContent(props) {
|
|
@@ -26,6 +27,7 @@ export function ComboboxContent(props) {
|
|
|
26
27
|
},
|
|
27
28
|
keyboardShouldPersistTaps: "handled",
|
|
28
29
|
nestedScrollEnabled: true,
|
|
30
|
+
...focusPreventProps,
|
|
29
31
|
children: props.children
|
|
30
32
|
});
|
|
31
33
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","ScrollView","StyleSheet","useRelativePosition","useCombobox","jsx","_jsx","ComboboxContent","props","combobox","composedStyles","flatten","styles","content","default","state","style","flatStyles","positionStyle","align","triggerPosition","contentLayout","alignOffset","preferredSide","sideOffset","width","onLayout","e","setContentLayout","nativeEvent","layout","keyboardShouldPersistTaps","nestedScrollEnabled","children"],"sourceRoot":"../../../../../src","sources":["components/combobox/components/combobox-content.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,UAAU,EAAEC,UAAU,QAAwC,cAAc;AACrF,SAASC,mBAAmB,QAAQ,yCAAsC;AAC1E,SAASC,WAAW,QAAQ,eAAY;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAOzC,OAAO,SAASC,eAAeA,CAACC,KAA2B,EAAE;EAC3D,MAAMC,QAAQ,GAAGL,WAAW,CAAC,CAAC;EAC9B,MAAMM,cAAc,
|
|
1
|
+
{"version":3,"names":["React","ScrollView","StyleSheet","useRelativePosition","focusPreventProps","useCombobox","jsx","_jsx","ComboboxContent","props","combobox","composedStyles","flatten","styles","content","default","state","style","flatStyles","positionStyle","align","triggerPosition","contentLayout","alignOffset","preferredSide","sideOffset","width","onLayout","e","setContentLayout","nativeEvent","layout","keyboardShouldPersistTaps","nestedScrollEnabled","children"],"sourceRoot":"../../../../../src","sources":["components/combobox/components/combobox-content.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,UAAU,EAAEC,UAAU,QAAwC,cAAc;AACrF,SAASC,mBAAmB,QAAQ,yCAAsC;AAC1E,SAASC,iBAAiB,QAAQ,8BAA2B;AAC7D,SAASC,WAAW,QAAQ,eAAY;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAOzC,OAAO,SAASC,eAAeA,CAACC,KAA2B,EAAE;EAC3D,MAAMC,QAAQ,GAAGL,WAAW,CAAC,CAAC;EAC9B,MAAMM,cAAc,GAAGT,UAAU,CAACU,OAAO,CAAC,CACxCF,QAAQ,CAACG,MAAM,EAAEC,OAAO,EAAEC,OAAO,EACjCL,QAAQ,CAACG,MAAM,EAAEC,OAAO,GAAGJ,QAAQ,CAACM,KAAK,CAAC,EAC1CP,KAAK,CAACQ,KAAK,CACZ,CAAC;EAEF,MAAMC,UAAU,GAAGhB,UAAU,CAACU,OAAO,CAACD,cAAc,CAAC;EAErD,MAAMQ,aAAa,GAAGhB,mBAAmB,CAAC;IACxCiB,KAAK,EAAE,OAAO;IACdC,eAAe,EAAEX,QAAQ,CAACW,eAAe;IACzCC,aAAa,EAAEZ,QAAQ,CAACY,aAAa;IACrCC,WAAW,EAAE,CAAC;IACdC,aAAa,EAAE,QAAQ;IACvBC,UAAU,EAAE;EACd,CAAC,CAAC;EAEF,oBACElB,IAAA,CAACN,UAAU;IACTgB,KAAK,EAAE,CAACE,aAAa,EAAED,UAAU,EAAE;MAAEQ,KAAK,EAAEhB,QAAQ,CAACW,eAAe,CAACK;IAAM,CAAC,CAAE;IAC9EC,QAAQ,EAAGC,CAAC,IAAK;MACflB,QAAQ,CAACmB,gBAAgB,CAACD,CAAC,CAACE,WAAW,CAACC,MAAM,CAAC;IACjD,CAAE;IACFC,yBAAyB,EAAC,SAAS;IACnCC,mBAAmB;IAAA,GACf7B,iBAAiB;IAAA8B,QAAA,EAEpBzB,KAAK,CAACyB;EAAQ,CACL,CAAC;AAEjB","ignoreList":[]}
|
|
@@ -2,7 +2,6 @@
|
|
|
2
2
|
|
|
3
3
|
import React, { useState } from "react";
|
|
4
4
|
import { Pressable, StyleSheet } from "react-native";
|
|
5
|
-
import { setInnerInputValue } from "../../../utils/input-utils.js";
|
|
6
5
|
import { useCombobox } from "../context.js";
|
|
7
6
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
8
7
|
const calculateState = (comboboxState, hovered, selected) => {
|
|
@@ -21,11 +20,13 @@ export function ComboboxOption(props) {
|
|
|
21
20
|
const optionStyles = combobox.styles?.option;
|
|
22
21
|
const composedStyles = StyleSheet.flatten([optionStyles?.default, optionStyles?.[optionState]]);
|
|
23
22
|
const handlePress = () => {
|
|
24
|
-
combobox.onChange(props.item);
|
|
25
|
-
combobox.setIsOpen(false);
|
|
26
|
-
if (!combobox.inputRef.current) return;
|
|
27
23
|
const itemLabel = combobox.getItemLabel(props.item);
|
|
28
|
-
|
|
24
|
+
combobox.onChange(props.item);
|
|
25
|
+
combobox.onInputChange?.(itemLabel);
|
|
26
|
+
combobox.inputRef.current?.blur();
|
|
27
|
+
requestAnimationFrame(() => {
|
|
28
|
+
combobox.setIsOpen(false);
|
|
29
|
+
});
|
|
29
30
|
};
|
|
30
31
|
return /*#__PURE__*/_jsx(Pressable, {
|
|
31
32
|
onPress: handlePress,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","useState","Pressable","StyleSheet","
|
|
1
|
+
{"version":3,"names":["React","useState","Pressable","StyleSheet","useCombobox","jsx","_jsx","calculateState","comboboxState","hovered","selected","ComboboxOption","props","isHovered","setIsHovered","combobox","itemValue","getItemValue","item","selectedValue","value","undefined","isSelected","optionState","state","optionStyles","styles","option","composedStyles","flatten","default","handlePress","itemLabel","getItemLabel","onChange","onInputChange","inputRef","current","blur","requestAnimationFrame","setIsOpen","onPress","onPointerEnter","onPointerLeave","style","children"],"sourceRoot":"../../../../../src","sources":["components/combobox/components/combobox-option.tsx"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,QAAQ,QAAQ,OAAO;AACvC,SAASC,SAAS,EAAEC,UAAU,QAAwC,cAAc;AAEpF,SAASC,WAAW,QAAQ,eAAY;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAQzC,MAAMC,cAAc,GAAGA,CACrBC,aAA4B,EAC5BC,OAAgB,EAChBC,QAAiB,KACO;EACxB,IAAIF,aAAa,KAAK,UAAU,EAAE,OAAO,UAAU;EACnD,IAAIE,QAAQ,EAAE,OAAO,UAAU;EAC/B,IAAID,OAAO,EAAE,OAAO,SAAS;EAC7B,OAAO,SAAS;AAClB,CAAC;AAED,OAAO,SAASE,cAAcA,CAAIC,KAA6B,EAAE;EAC/D,MAAM,CAACC,SAAS,EAAEC,YAAY,CAAC,GAAGb,QAAQ,CAAC,KAAK,CAAC;EACjD,MAAMc,QAAQ,GAAGX,WAAW,CAAC,CAAC;EAE9B,MAAMY,SAAS,GAAGD,QAAQ,CAACE,YAAY,CAACL,KAAK,CAACM,IAAI,CAAC;EACnD,MAAMC,aAAa,GAAGJ,QAAQ,CAACK,KAAK,IAAI,IAAI,GAAGL,QAAQ,CAACE,YAAY,CAACF,QAAQ,CAACK,KAAK,CAAC,GAAGC,SAAS;EAChG,MAAMC,UAAU,GAAGN,SAAS,KAAKG,aAAa;EAE9C,MAAMI,WAAW,GAAGhB,cAAc,CAACQ,QAAQ,CAACS,KAAK,EAAEX,SAAS,EAAES,UAAU,CAAC;EACzE,MAAMG,YAAY,GAAGV,QAAQ,CAACW,MAAM,EAAEC,MAAM;EAC5C,MAAMC,cAAc,GAAGzB,UAAU,CAAC0B,OAAO,CAAC,CAACJ,YAAY,EAAEK,OAAO,EAAEL,YAAY,GAAGF,WAAW,CAAC,CAAC,CAAC;EAE/F,MAAMQ,WAAW,GAAGA,CAAA,KAAM;IACxB,MAAMC,SAAS,GAAGjB,QAAQ,CAACkB,YAAY,CAACrB,KAAK,CAACM,IAAI,CAAC;IACnDH,QAAQ,CAACmB,QAAQ,CAACtB,KAAK,CAACM,IAAI,CAAC;IAC7BH,QAAQ,CAACoB,aAAa,GAAGH,SAAS,CAAC;IACnCjB,QAAQ,CAACqB,QAAQ,CAACC,OAAO,EAAEC,IAAI,CAAC,CAAC;IACjCC,qBAAqB,CAAC,MAAM;MAC1BxB,QAAQ,CAACyB,SAAS,CAAC,KAAK,CAAC;IAC3B,CAAC,CAAC;EACJ,CAAC;EAED,oBACElC,IAAA,CAACJ,SAAS;IACRuC,OAAO,EAAEV,WAAY;IACrBW,cAAc,EAAEA,CAAA,KAAM5B,YAAY,CAAC,IAAI,CAAE;IACzC6B,cAAc,EAAEA,CAAA,KAAM7B,YAAY,CAAC,KAAK,CAAE;IAC1C8B,KAAK,EAAEhB,cAAuC;IAAAiB,QAAA,EAE7CjC,KAAK,CAACiC;EAAQ,CACN,CAAC;AAEhB","ignoreList":[]}
|
|
@@ -2,17 +2,23 @@
|
|
|
2
2
|
|
|
3
3
|
import React from "react";
|
|
4
4
|
import { Pressable, StyleSheet } from "react-native";
|
|
5
|
+
import { focusPreventProps } from "../../focus/focus-prevent.js";
|
|
5
6
|
import { useCombobox } from "../context.js";
|
|
6
7
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
7
8
|
export function ComboboxOverlay(props) {
|
|
8
9
|
const combobox = useCombobox();
|
|
10
|
+
const onPress = () => {
|
|
11
|
+
combobox.inputRef.current?.blur();
|
|
12
|
+
requestAnimationFrame(() => {
|
|
13
|
+
combobox.setIsOpen(false);
|
|
14
|
+
});
|
|
15
|
+
};
|
|
9
16
|
const composedStyles = StyleSheet.flatten([combobox.styles?.overlay?.default, combobox.styles?.overlay?.[combobox.state], props.style]);
|
|
10
17
|
return /*#__PURE__*/_jsx(Pressable, {
|
|
11
|
-
onPress:
|
|
12
|
-
combobox.setIsOpen(false);
|
|
13
|
-
},
|
|
18
|
+
onPress: onPress,
|
|
14
19
|
pointerEvents: "auto",
|
|
15
20
|
style: [StyleSheet.absoluteFill, composedStyles],
|
|
21
|
+
...focusPreventProps,
|
|
16
22
|
children: props.children
|
|
17
23
|
});
|
|
18
24
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","Pressable","StyleSheet","useCombobox","jsx","_jsx","ComboboxOverlay","props","combobox","composedStyles","flatten","styles","overlay","default","state","style","
|
|
1
|
+
{"version":3,"names":["React","Pressable","StyleSheet","focusPreventProps","useCombobox","jsx","_jsx","ComboboxOverlay","props","combobox","onPress","inputRef","current","blur","requestAnimationFrame","setIsOpen","composedStyles","flatten","styles","overlay","default","state","style","pointerEvents","absoluteFill","children"],"sourceRoot":"../../../../../src","sources":["components/combobox/components/combobox-overlay.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,SAAS,EAAkBC,UAAU,QAAwB,cAAc;AACpF,SAASC,iBAAiB,QAAQ,8BAA2B;AAC7D,SAASC,WAAW,QAAQ,eAAY;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAOzC,OAAO,SAASC,eAAeA,CAACC,KAA2B,EAAE;EAC3D,MAAMC,QAAQ,GAAGL,WAAW,CAAC,CAAC;EAE9B,MAAMM,OAAO,GAAGA,CAAA,KAAM;IACpBD,QAAQ,CAACE,QAAQ,CAACC,OAAO,EAAEC,IAAI,CAAC,CAAC;IACjCC,qBAAqB,CAAC,MAAM;MAC1BL,QAAQ,CAACM,SAAS,CAAC,KAAK,CAAC;IAC3B,CAAC,CAAC;EACJ,CAAC;EAED,MAAMC,cAAc,GAAGd,UAAU,CAACe,OAAO,CAAC,CACxCR,QAAQ,CAACS,MAAM,EAAEC,OAAO,EAAEC,OAAO,EACjCX,QAAQ,CAACS,MAAM,EAAEC,OAAO,GAAGV,QAAQ,CAACY,KAAK,CAAC,EAC1Cb,KAAK,CAACc,KAAK,CACZ,CAAC;EAEF,oBACEhB,IAAA,CAACL,SAAS;IACRS,OAAO,EAAEA,OAAQ;IACjBa,aAAa,EAAC,MAAM;IACpBD,KAAK,EAAE,CAACpB,UAAU,CAACsB,YAAY,EAAER,cAAc,CAAE;IAAA,GAC7Cb,iBAAiB;IAAAsB,QAAA,EAEpBjB,KAAK,CAACiB;EAAQ,CACN,CAAC;AAEhB","ignoreList":[]}
|
|
@@ -16,10 +16,8 @@ export function ComboboxTrigger({
|
|
|
16
16
|
}) {
|
|
17
17
|
const combobox = useCombobox();
|
|
18
18
|
const triggerState = calculateState(combobox.isDisabled, combobox.isOpen);
|
|
19
|
-
const selectedLabel = combobox.value != null ? combobox.getItemLabel(combobox.value) : "";
|
|
20
19
|
const open = () => {
|
|
21
20
|
if (combobox.isDisabled) return;
|
|
22
|
-
combobox.onInputChange(selectedLabel);
|
|
23
21
|
requestAnimationFrame(() => {
|
|
24
22
|
measureLayoutPosition(combobox.inputRef.current, layout => {
|
|
25
23
|
combobox.setTriggerPosition(layout);
|
|
@@ -50,7 +48,7 @@ export function ComboboxTrigger({
|
|
|
50
48
|
return /*#__PURE__*/_jsx(TextInput, {
|
|
51
49
|
...composedProps,
|
|
52
50
|
ref: combobox.inputRef,
|
|
53
|
-
value:
|
|
51
|
+
value: combobox.inputValue,
|
|
54
52
|
onChange: undefined,
|
|
55
53
|
onChangeText: combobox.onInputChange,
|
|
56
54
|
onFocus: onFocus,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","StyleSheet","TextInput","measureLayoutPosition","useCombobox","jsx","_jsx","calculateState","isDisabled","isOpen","ComboboxTrigger","render","props","combobox","triggerState","
|
|
1
|
+
{"version":3,"names":["React","StyleSheet","TextInput","measureLayoutPosition","useCombobox","jsx","_jsx","calculateState","isDisabled","isOpen","ComboboxTrigger","render","props","combobox","triggerState","open","requestAnimationFrame","inputRef","current","layout","setTriggerPosition","setIsOpen","onFocus","e","triggerStyles","styles","trigger","composedProps","default","style","flatten","composedStyle","value","inputValue","onChange","onInputChange","ref","undefined","onChangeText"],"sourceRoot":"../../../../../src","sources":["components/combobox/components/combobox-trigger.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,UAAU,EAAEC,SAAS,QAA6B,cAAc;AAEzE,SAASC,qBAAqB,QAAQ,oCAAiC;AACvE,SAASC,WAAW,QAAQ,eAAY;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAgBzC,MAAMC,cAAc,GAAGA,CAACC,UAAmB,EAAEC,MAAe,KAA2B;EACrF,IAAID,UAAU,EAAE,OAAO,UAAU;EACjC,IAAIC,MAAM,EAAE,OAAO,SAAS;EAC5B,OAAO,SAAS;AAClB,CAAC;AAED,OAAO,SAASC,eAAeA,CAAC;EAAEC,MAAM;EAAE,GAAGC;AAA4B,CAAC,EAAE;EAC1E,MAAMC,QAAQ,GAAGT,WAAW,CAAC,CAAC;EAE9B,MAAMU,YAAY,GAAGP,cAAc,CAACM,QAAQ,CAACL,UAAU,EAAEK,QAAQ,CAACJ,MAAM,CAAC;EAEzE,MAAMM,IAAI,GAAGA,CAAA,KAAM;IACjB,IAAIF,QAAQ,CAACL,UAAU,EAAE;IACzBQ,qBAAqB,CAAC,MAAM;MAC1Bb,qBAAqB,CAACU,QAAQ,CAACI,QAAQ,CAACC,OAAO,EAAGC,MAAM,IAAK;QAC3DN,QAAQ,CAACO,kBAAkB,CAACD,MAAM,CAAC;QACnCN,QAAQ,CAACQ,SAAS,CAAC,IAAI,CAAC;MAC1B,CAAC,CAAC;IACJ,CAAC,CAAC;EACJ,CAAC;EAED,MAAMC,OAAkC,GAAIC,CAAC,IAAK;IAChDX,KAAK,CAACU,OAAO,GAAGC,CAAC,CAAC;IAClBR,IAAI,CAAC,CAAC;EACR,CAAC;EAED,MAAMS,aAAa,GAAGX,QAAQ,CAACY,MAAM,EAAEC,OAAO;EAC9C,MAAMC,aAA6B,GAAG;IACpC,GAAGH,aAAa,EAAEI,OAAO;IACzB,GAAGJ,aAAa,GAAGV,YAAY,CAAC;IAChC,GAAGF,KAAK;IACRiB,KAAK,EAAE5B,UAAU,CAAC6B,OAAO,CAAC,CACxBN,aAAa,EAAEI,OAAO,EAAEC,KAAK,EAC7BL,aAAa,GAAGV,YAAY,CAAC,EAAEe,KAAK,CACrC;EACH,CAAC;EAED,MAAME,aAAa,GAAG9B,UAAU,CAAC6B,OAAO,CAAC,CACvCN,aAAa,EAAEI,OAAO,EAAEC,KAAK,EAC7BL,aAAa,GAAGV,YAAY,CAAC,EAAEe,KAAK,EACpCjB,KAAK,CAACiB,KAAK,CACZ,CAAC;EAEF,IAAIlB,MAAM,EAAE;IACV,OAAOA,MAAM,CAAC;MACZM,QAAQ,EAAEJ,QAAQ,CAACI,QAAQ;MAC3BF,IAAI;MACJiB,KAAK,EAAEnB,QAAQ,CAACoB,UAAU;MAC1BC,QAAQ,EAAErB,QAAQ,CAACsB;IACrB,CAAC,CAAC;EACJ;EAEA,oBACE7B,IAAA,CAACJ,SAAS;IAAA,GACJyB,aAAa;IACjBS,GAAG,EAAEvB,QAAQ,CAACI,QAAS;IACvBe,KAAK,EAAEnB,QAAQ,CAACoB,UAAW;IAC3BC,QAAQ,EAAEG,SAAU;IACpBC,YAAY,EAAEzB,QAAQ,CAACsB,aAAc;IACrCb,OAAO,EAAEA,OAAQ;IACjBO,KAAK,EAAEE;EAAc,CACtB,CAAC;AAEN","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["Platform","focusPreventProps","select","web","onMouseDown","e","preventDefault","default"],"sourceRoot":"../../../../src","sources":["components/focus/focus-prevent.ts"],"mappings":";;AAAA,SAASA,QAAQ,QAAQ,cAAc;AAEvC,OAAO,MAAMC,iBAAiB,GAAGD,QAAQ,CAACE,MAAM,CAAC;EAC/CC,GAAG,EAAE;IACHC,WAAW,EAAGC,CAAmB,IAAKA,CAAC,CAACC,cAAc,CAAC;EACzD,CAAC;EACDC,OAAO,EAAE,CAAC;AACZ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"combobox-content.d.ts","sourceRoot":"","sources":["../../../../../../src/components/combobox/components/combobox-content.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAA0B,KAAK,SAAS,EAAE,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"combobox-content.d.ts","sourceRoot":"","sources":["../../../../../../src/components/combobox/components/combobox-content.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAA0B,KAAK,SAAS,EAAE,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAKtF,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,KAAK,CAAC,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC;CAC9B;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,oBAAoB,qBAgC1D"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"combobox-option.d.ts","sourceRoot":"","sources":["../../../../../../src/components/combobox/components/combobox-option.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAExC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"combobox-option.d.ts","sourceRoot":"","sources":["../../../../../../src/components/combobox/components/combobox-option.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAExC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAIpE,MAAM,MAAM,mBAAmB,CAAC,CAAC,IAAI;IACnC,IAAI,EAAE,CAAC,CAAC;IACR,QAAQ,CAAC,EAAE,eAAe,CAAC;CAC5B,CAAC;AAaF,wBAAgB,cAAc,CAAC,CAAC,EAAE,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC,qBAgC9D"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"combobox-overlay.d.ts","sourceRoot":"","sources":["../../../../../../src/components/combobox/components/combobox-overlay.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAa,KAAK,SAAS,EAAc,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"combobox-overlay.d.ts","sourceRoot":"","sources":["../../../../../../src/components/combobox/components/combobox-overlay.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAa,KAAK,SAAS,EAAc,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAIrF,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,KAAK,CAAC,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC;CAC9B;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,oBAAoB,qBA0B1D"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"combobox-trigger.d.ts","sourceRoot":"","sources":["../../../../../../src/components/combobox/components/combobox-trigger.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAyB,KAAK,cAAc,EAAE,MAAM,cAAc,CAAC;AAC1E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAKjE,KAAK,eAAe,GAAG,IAAI,CAAC,cAAc,EAAE,OAAO,GAAG,UAAU,GAAG,cAAc,CAAC,CAAC;AAEnF,KAAK,WAAW,GAAG;IACjB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,YAAY,GAAG,IAAI,CAAC,CAAC;IAC/C,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACnC,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG,eAAe,GAAG;IACnD,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,KAAK,KAAK,CAAC,SAAS,CAAC;CAClD,CAAC;AAQF,wBAAgB,eAAe,CAAC,EAAE,MAAM,EAAE,GAAG,KAAK,EAAE,EAAE,oBAAoB,
|
|
1
|
+
{"version":3,"file":"combobox-trigger.d.ts","sourceRoot":"","sources":["../../../../../../src/components/combobox/components/combobox-trigger.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAyB,KAAK,cAAc,EAAE,MAAM,cAAc,CAAC;AAC1E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAKjE,KAAK,eAAe,GAAG,IAAI,CAAC,cAAc,EAAE,OAAO,GAAG,UAAU,GAAG,cAAc,CAAC,CAAC;AAEnF,KAAK,WAAW,GAAG;IACjB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,YAAY,GAAG,IAAI,CAAC,CAAC;IAC/C,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACnC,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG,eAAe,GAAG;IACnD,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,KAAK,KAAK,CAAC,SAAS,CAAC;CAClD,CAAC;AAQF,wBAAgB,eAAe,CAAC,EAAE,MAAM,EAAE,GAAG,KAAK,EAAE,EAAE,oBAAoB,mSAyDzE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"focus-prevent.d.ts","sourceRoot":"","sources":["../../../../../src/components/focus/focus-prevent.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,iBAAiB;qBAET,KAAK,CAAC,UAAU;;;CAGnC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import React from "react";
|
|
2
2
|
import { ScrollView, StyleSheet, type StyleProp, type ViewStyle } from "react-native";
|
|
3
3
|
import { useRelativePosition } from "../../../hooks/use-relative-position";
|
|
4
|
+
import { focusPreventProps } from "../../focus/focus-prevent";
|
|
4
5
|
import { useCombobox } from "../context";
|
|
5
6
|
|
|
6
7
|
export interface ComboboxContentProps {
|
|
@@ -35,6 +36,7 @@ export function ComboboxContent(props: ComboboxContentProps) {
|
|
|
35
36
|
}}
|
|
36
37
|
keyboardShouldPersistTaps="handled"
|
|
37
38
|
nestedScrollEnabled
|
|
39
|
+
{...focusPreventProps}
|
|
38
40
|
>
|
|
39
41
|
{props.children}
|
|
40
42
|
</ScrollView>
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import React, { useState } from "react";
|
|
2
2
|
import { Pressable, StyleSheet, type StyleProp, type ViewStyle } from "react-native";
|
|
3
3
|
import type { ElementChildren } from "../../../types/element.types";
|
|
4
|
-
import { setInnerInputValue } from "../../../utils/input-utils";
|
|
5
4
|
import { useCombobox } from "../context";
|
|
6
5
|
import type { ComboboxOptionState, ComboboxState } from "../types";
|
|
7
6
|
|
|
@@ -34,11 +33,13 @@ export function ComboboxOption<T>(props: ComboboxOptionProps<T>) {
|
|
|
34
33
|
const composedStyles = StyleSheet.flatten([optionStyles?.default, optionStyles?.[optionState]]);
|
|
35
34
|
|
|
36
35
|
const handlePress = () => {
|
|
37
|
-
combobox.onChange(props.item);
|
|
38
|
-
combobox.setIsOpen(false);
|
|
39
|
-
if (!combobox.inputRef.current) return;
|
|
40
36
|
const itemLabel = combobox.getItemLabel(props.item);
|
|
41
|
-
|
|
37
|
+
combobox.onChange(props.item);
|
|
38
|
+
combobox.onInputChange?.(itemLabel);
|
|
39
|
+
combobox.inputRef.current?.blur();
|
|
40
|
+
requestAnimationFrame(() => {
|
|
41
|
+
combobox.setIsOpen(false);
|
|
42
|
+
});
|
|
42
43
|
};
|
|
43
44
|
|
|
44
45
|
return (
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import React from "react";
|
|
2
2
|
import { Pressable, type StyleProp, StyleSheet, type ViewStyle } from "react-native";
|
|
3
|
+
import { focusPreventProps } from "../../focus/focus-prevent";
|
|
3
4
|
import { useCombobox } from "../context";
|
|
4
5
|
|
|
5
6
|
export interface ComboboxOverlayProps {
|
|
@@ -10,6 +11,13 @@ export interface ComboboxOverlayProps {
|
|
|
10
11
|
export function ComboboxOverlay(props: ComboboxOverlayProps) {
|
|
11
12
|
const combobox = useCombobox();
|
|
12
13
|
|
|
14
|
+
const onPress = () => {
|
|
15
|
+
combobox.inputRef.current?.blur();
|
|
16
|
+
requestAnimationFrame(() => {
|
|
17
|
+
combobox.setIsOpen(false);
|
|
18
|
+
});
|
|
19
|
+
};
|
|
20
|
+
|
|
13
21
|
const composedStyles = StyleSheet.flatten([
|
|
14
22
|
combobox.styles?.overlay?.default,
|
|
15
23
|
combobox.styles?.overlay?.[combobox.state],
|
|
@@ -18,11 +26,10 @@ export function ComboboxOverlay(props: ComboboxOverlayProps) {
|
|
|
18
26
|
|
|
19
27
|
return (
|
|
20
28
|
<Pressable
|
|
21
|
-
onPress={
|
|
22
|
-
combobox.setIsOpen(false);
|
|
23
|
-
}}
|
|
29
|
+
onPress={onPress}
|
|
24
30
|
pointerEvents="auto"
|
|
25
31
|
style={[StyleSheet.absoluteFill, composedStyles]}
|
|
32
|
+
{...focusPreventProps}
|
|
26
33
|
>
|
|
27
34
|
{props.children}
|
|
28
35
|
</Pressable>
|
|
@@ -28,11 +28,9 @@ export function ComboboxTrigger({ render, ...props }: ComboboxTriggerProps) {
|
|
|
28
28
|
const combobox = useCombobox();
|
|
29
29
|
|
|
30
30
|
const triggerState = calculateState(combobox.isDisabled, combobox.isOpen);
|
|
31
|
-
const selectedLabel = combobox.value != null ? combobox.getItemLabel(combobox.value) : "";
|
|
32
31
|
|
|
33
32
|
const open = () => {
|
|
34
33
|
if (combobox.isDisabled) return;
|
|
35
|
-
combobox.onInputChange(selectedLabel);
|
|
36
34
|
requestAnimationFrame(() => {
|
|
37
35
|
measureLayoutPosition(combobox.inputRef.current, (layout) => {
|
|
38
36
|
combobox.setTriggerPosition(layout);
|
|
@@ -76,7 +74,7 @@ export function ComboboxTrigger({ render, ...props }: ComboboxTriggerProps) {
|
|
|
76
74
|
<TextInput
|
|
77
75
|
{...composedProps}
|
|
78
76
|
ref={combobox.inputRef}
|
|
79
|
-
value={
|
|
77
|
+
value={combobox.inputValue}
|
|
80
78
|
onChange={undefined}
|
|
81
79
|
onChangeText={combobox.onInputChange}
|
|
82
80
|
onFocus={onFocus}
|