@thewhileloop/whileui 0.1.2 → 0.2.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.
Files changed (82) hide show
  1. package/README.md +283 -38
  2. package/dist/blocks/layout/action-bar.d.ts +8 -0
  3. package/dist/blocks/layout/action-bar.d.ts.map +1 -0
  4. package/dist/blocks/layout/action-bar.js +10 -0
  5. package/dist/blocks/layout/action-bar.js.map +1 -0
  6. package/dist/blocks/layout/confirm-action-sheet.d.ts +24 -0
  7. package/dist/blocks/layout/confirm-action-sheet.d.ts.map +1 -0
  8. package/dist/blocks/layout/confirm-action-sheet.js +41 -0
  9. package/dist/blocks/layout/confirm-action-sheet.js.map +1 -0
  10. package/dist/blocks/layout/index.d.ts +2 -0
  11. package/dist/blocks/layout/index.d.ts.map +1 -1
  12. package/dist/blocks/layout/index.js +2 -0
  13. package/dist/blocks/layout/index.js.map +1 -1
  14. package/dist/blocks/navigation/index.d.ts +1 -0
  15. package/dist/blocks/navigation/index.d.ts.map +1 -1
  16. package/dist/blocks/navigation/index.js +1 -0
  17. package/dist/blocks/navigation/index.js.map +1 -1
  18. package/dist/blocks/navigation/navigation-sidebar.d.ts +23 -0
  19. package/dist/blocks/navigation/navigation-sidebar.d.ts.map +1 -0
  20. package/dist/blocks/navigation/navigation-sidebar.js +11 -0
  21. package/dist/blocks/navigation/navigation-sidebar.js.map +1 -0
  22. package/dist/components/card/card.d.ts +81 -2
  23. package/dist/components/card/card.d.ts.map +1 -1
  24. package/dist/components/card/card.js +27 -6
  25. package/dist/components/card/card.js.map +1 -1
  26. package/dist/components/card/index.d.ts +1 -1
  27. package/dist/components/card/index.d.ts.map +1 -1
  28. package/dist/components/card/index.js +1 -1
  29. package/dist/components/card/index.js.map +1 -1
  30. package/dist/components/data-row/data-row.d.ts +69 -0
  31. package/dist/components/data-row/data-row.d.ts.map +1 -0
  32. package/dist/components/data-row/data-row.js +89 -0
  33. package/dist/components/data-row/data-row.js.map +1 -0
  34. package/dist/components/data-row/index.d.ts +2 -0
  35. package/dist/components/data-row/index.d.ts.map +1 -0
  36. package/dist/components/data-row/index.js +2 -0
  37. package/dist/components/data-row/index.js.map +1 -0
  38. package/dist/components/form-field/form-field.d.ts +124 -0
  39. package/dist/components/form-field/form-field.d.ts.map +1 -0
  40. package/dist/components/form-field/form-field.js +68 -0
  41. package/dist/components/form-field/form-field.js.map +1 -0
  42. package/dist/components/form-field/index.d.ts +2 -0
  43. package/dist/components/form-field/index.d.ts.map +1 -0
  44. package/dist/components/form-field/index.js +2 -0
  45. package/dist/components/form-field/index.js.map +1 -0
  46. package/dist/components/labeled-field/index.d.ts +2 -0
  47. package/dist/components/labeled-field/index.d.ts.map +1 -0
  48. package/dist/components/labeled-field/index.js +2 -0
  49. package/dist/components/labeled-field/index.js.map +1 -0
  50. package/dist/components/labeled-field/labeled-field.d.ts +19 -0
  51. package/dist/components/labeled-field/labeled-field.d.ts.map +1 -0
  52. package/dist/components/labeled-field/labeled-field.js +15 -0
  53. package/dist/components/labeled-field/labeled-field.js.map +1 -0
  54. package/dist/components/numeric-input/index.d.ts +2 -0
  55. package/dist/components/numeric-input/index.d.ts.map +1 -0
  56. package/dist/components/numeric-input/index.js +2 -0
  57. package/dist/components/numeric-input/index.js.map +1 -0
  58. package/dist/components/numeric-input/numeric-input.d.ts +119 -0
  59. package/dist/components/numeric-input/numeric-input.d.ts.map +1 -0
  60. package/dist/components/numeric-input/numeric-input.js +129 -0
  61. package/dist/components/numeric-input/numeric-input.js.map +1 -0
  62. package/dist/components/segmented-control/index.d.ts +2 -0
  63. package/dist/components/segmented-control/index.d.ts.map +1 -0
  64. package/dist/components/segmented-control/index.js +2 -0
  65. package/dist/components/segmented-control/index.js.map +1 -0
  66. package/dist/components/segmented-control/segmented-control.d.ts +281 -0
  67. package/dist/components/segmented-control/segmented-control.d.ts.map +1 -0
  68. package/dist/components/segmented-control/segmented-control.js +112 -0
  69. package/dist/components/segmented-control/segmented-control.js.map +1 -0
  70. package/dist/index.d.ts +7 -1
  71. package/dist/index.d.ts.map +1 -1
  72. package/dist/index.js +7 -1
  73. package/dist/index.js.map +1 -1
  74. package/dist/lib/index.d.ts +1 -0
  75. package/dist/lib/index.d.ts.map +1 -1
  76. package/dist/lib/index.js +1 -0
  77. package/dist/lib/index.js.map +1 -1
  78. package/dist/lib/theme-bridge.d.ts +29 -0
  79. package/dist/lib/theme-bridge.d.ts.map +1 -0
  80. package/dist/lib/theme-bridge.js +79 -0
  81. package/dist/lib/theme-bridge.js.map +1 -0
  82. package/package.json +1 -1
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { View } from 'react-native';
4
+ import { FormControl, FormField, FormHint, FormLabel, FormMessage, } from '../form-field';
5
+ import { cn } from '../../lib/cn';
6
+ function LabeledField({ label, hint, error, leftSlot, rightSlot, children, controlWrapperClassName, required, disabled, invalid, ...props }) {
7
+ const isInvalid = invalid ?? Boolean(error);
8
+ return (_jsxs(FormField, { required: required, disabled: disabled, invalid: isInvalid, ...props, children: [label ? _jsx(FormLabel, { children: label }) : null, _jsx(FormControl, { children: _jsxs(View, { className: cn('flex-row items-center gap-2 rounded-md border border-input bg-background px-3', isInvalid && 'border-destructive', disabled && 'opacity-60', controlWrapperClassName), children: [leftSlot ? _jsx(View, { className: "shrink-0", children: leftSlot }) : null, _jsx(View, { className: "min-h-10 min-w-0 flex-1 justify-center", children: children }), rightSlot ? _jsx(View, { className: "shrink-0", children: rightSlot }) : null] }) }), error ? _jsx(FormMessage, { children: error }) : hint ? _jsx(FormHint, { children: hint }) : null] }));
9
+ }
10
+ const LabeledFieldControl = React.forwardRef(({ className, ...props }, ref) => {
11
+ return _jsx(View, { ref: ref, className: cn('min-w-0 flex-1', className), ...props });
12
+ });
13
+ LabeledFieldControl.displayName = 'LabeledFieldControl';
14
+ export { LabeledField, LabeledFieldControl };
15
+ //# sourceMappingURL=labeled-field.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"labeled-field.js","sourceRoot":"","sources":["../../../src/components/labeled-field/labeled-field.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAkB,MAAM,cAAc,CAAC;AACpD,OAAO,EACL,WAAW,EACX,SAAS,EACT,QAAQ,EACR,SAAS,EACT,WAAW,GAEZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAgBlC,SAAS,YAAY,CAAC,EACpB,KAAK,EACL,IAAI,EACJ,KAAK,EACL,QAAQ,EACR,SAAS,EACT,QAAQ,EACR,uBAAuB,EACvB,QAAQ,EACR,QAAQ,EACR,OAAO,EACP,GAAG,KAAK,EACU;IAClB,MAAM,SAAS,GAAG,OAAO,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC;IAE5C,OAAO,CACL,MAAC,SAAS,IAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,KAAM,KAAK,aAC7E,KAAK,CAAC,CAAC,CAAC,KAAC,SAAS,cAAE,KAAK,GAAa,CAAC,CAAC,CAAC,IAAI,EAC9C,KAAC,WAAW,cACV,MAAC,IAAI,IACH,SAAS,EAAE,EAAE,CACX,+EAA+E,EAC/E,SAAS,IAAI,oBAAoB,EACjC,QAAQ,IAAI,YAAY,EACxB,uBAAuB,CACxB,aAEA,QAAQ,CAAC,CAAC,CAAC,KAAC,IAAI,IAAC,SAAS,EAAC,UAAU,YAAE,QAAQ,GAAQ,CAAC,CAAC,CAAC,IAAI,EAC/D,KAAC,IAAI,IAAC,SAAS,EAAC,wCAAwC,YAAE,QAAQ,GAAQ,EACzE,SAAS,CAAC,CAAC,CAAC,KAAC,IAAI,IAAC,SAAS,EAAC,UAAU,YAAE,SAAS,GAAQ,CAAC,CAAC,CAAC,IAAI,IAC5D,GACK,EACb,KAAK,CAAC,CAAC,CAAC,KAAC,WAAW,cAAE,KAAK,GAAe,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAC,QAAQ,cAAE,IAAI,GAAY,CAAC,CAAC,CAAC,IAAI,IAC7E,CACb,CAAC;AACJ,CAAC;AAED,MAAM,mBAAmB,GAAG,KAAK,CAAC,UAAU,CAC1C,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,GAAG,EAAE,EAAE;IAC/B,OAAO,KAAC,IAAI,IAAC,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,EAAE,CAAC,gBAAgB,EAAE,SAAS,CAAC,KAAM,KAAK,GAAI,CAAC;AACnF,CAAC,CACF,CAAC;AAEF,mBAAmB,CAAC,WAAW,GAAG,qBAAqB,CAAC;AAExD,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { NumericInput, numericInputVariants, numericInputTextVariants, type NumericInputProps, } from './numeric-input';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/numeric-input/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,oBAAoB,EACpB,wBAAwB,EACxB,KAAK,iBAAiB,GACvB,MAAM,iBAAiB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { NumericInput, numericInputVariants, numericInputTextVariants, } from './numeric-input';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/numeric-input/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,oBAAoB,EACpB,wBAAwB,GAEzB,MAAM,iBAAiB,CAAC"}
@@ -0,0 +1,119 @@
1
+ import React from 'react';
2
+ import { TextInput, type TextInputProps } from 'react-native';
3
+ import { type VariantProps } from '../../lib/tv';
4
+ declare const numericInputVariants: import("tailwind-variants").TVReturnType<{
5
+ variant: {
6
+ default: string;
7
+ error: string;
8
+ };
9
+ size: {
10
+ default: string;
11
+ compact: string;
12
+ };
13
+ }, undefined, "w-full flex-row items-center rounded-md border bg-background", import("tailwind-variants/dist/config.js").TVConfig<{
14
+ variant: {
15
+ default: string;
16
+ error: string;
17
+ };
18
+ size: {
19
+ default: string;
20
+ compact: string;
21
+ };
22
+ }, {
23
+ variant: {
24
+ default: string;
25
+ error: string;
26
+ };
27
+ size: {
28
+ default: string;
29
+ compact: string;
30
+ };
31
+ }>, {
32
+ variant: {
33
+ default: string;
34
+ error: string;
35
+ };
36
+ size: {
37
+ default: string;
38
+ compact: string;
39
+ };
40
+ }, undefined, import("tailwind-variants").TVReturnType<{
41
+ variant: {
42
+ default: string;
43
+ error: string;
44
+ };
45
+ size: {
46
+ default: string;
47
+ compact: string;
48
+ };
49
+ }, undefined, "w-full flex-row items-center rounded-md border bg-background", import("tailwind-variants/dist/config.js").TVConfig<{
50
+ variant: {
51
+ default: string;
52
+ error: string;
53
+ };
54
+ size: {
55
+ default: string;
56
+ compact: string;
57
+ };
58
+ }, {
59
+ variant: {
60
+ default: string;
61
+ error: string;
62
+ };
63
+ size: {
64
+ default: string;
65
+ compact: string;
66
+ };
67
+ }>, unknown, unknown, undefined>>;
68
+ declare const numericInputTextVariants: import("tailwind-variants").TVReturnType<{
69
+ size: {
70
+ default: string;
71
+ compact: string;
72
+ };
73
+ }, undefined, "flex-1 px-3 py-2 text-foreground", import("tailwind-variants/dist/config.js").TVConfig<{
74
+ size: {
75
+ default: string;
76
+ compact: string;
77
+ };
78
+ }, {
79
+ size: {
80
+ default: string;
81
+ compact: string;
82
+ };
83
+ }>, {
84
+ size: {
85
+ default: string;
86
+ compact: string;
87
+ };
88
+ }, undefined, import("tailwind-variants").TVReturnType<{
89
+ size: {
90
+ default: string;
91
+ compact: string;
92
+ };
93
+ }, undefined, "flex-1 px-3 py-2 text-foreground", import("tailwind-variants/dist/config.js").TVConfig<{
94
+ size: {
95
+ default: string;
96
+ compact: string;
97
+ };
98
+ }, {
99
+ size: {
100
+ default: string;
101
+ compact: string;
102
+ };
103
+ }>, unknown, unknown, undefined>>;
104
+ export interface NumericInputProps extends Omit<TextInputProps, 'value' | 'defaultValue' | 'onChangeText' | 'keyboardType'>, VariantProps<typeof numericInputVariants> {
105
+ className?: string;
106
+ inputClassName?: string;
107
+ prefix?: React.ReactNode;
108
+ suffix?: React.ReactNode;
109
+ value?: number | null;
110
+ defaultValue?: number;
111
+ onValueChange?: (value: number | null) => void;
112
+ min?: number;
113
+ max?: number;
114
+ step?: number;
115
+ showSteppers?: boolean;
116
+ }
117
+ declare const NumericInput: React.ForwardRefExoticComponent<NumericInputProps & React.RefAttributes<TextInput>>;
118
+ export { NumericInput, numericInputVariants, numericInputTextVariants };
119
+ //# sourceMappingURL=numeric-input.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"numeric-input.d.ts","sourceRoot":"","sources":["../../../src/components/numeric-input/numeric-input.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAyC,MAAM,OAAO,CAAC;AAC9D,OAAO,EAAmB,SAAS,EAAQ,KAAK,cAAc,EAAE,MAAM,cAAc,CAAC;AAErF,OAAO,EAAM,KAAK,YAAY,EAAE,MAAM,cAAc,CAAC;AAErD,QAAA,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAgBxB,CAAC;AAEH,QAAA,MAAM,wBAAwB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAW5B,CAAC;AAgDH,MAAM,WAAW,iBACf,SACE,IAAI,CAAC,cAAc,EAAE,OAAO,GAAG,cAAc,GAAG,cAAc,GAAG,cAAc,CAAC,EAChF,YAAY,CAAC,OAAO,oBAAoB,CAAC;IAC3C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC;IAC/C,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAED,QAAA,MAAM,YAAY,qFA0IjB,CAAC;AAIF,OAAO,EAAE,YAAY,EAAE,oBAAoB,EAAE,wBAAwB,EAAE,CAAC"}
@@ -0,0 +1,129 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React, { useCallback, useMemo, useState } from 'react';
3
+ import { Pressable, Text, TextInput, View } from 'react-native';
4
+ import { cn } from '../../lib/cn';
5
+ import { tv } from '../../lib/tv';
6
+ const numericInputVariants = tv({
7
+ base: 'w-full flex-row items-center rounded-md border bg-background',
8
+ variants: {
9
+ variant: {
10
+ default: 'border-input',
11
+ error: 'border-destructive',
12
+ },
13
+ size: {
14
+ default: 'h-10',
15
+ compact: 'h-9',
16
+ },
17
+ },
18
+ defaultVariants: {
19
+ variant: 'default',
20
+ size: 'default',
21
+ },
22
+ });
23
+ const numericInputTextVariants = tv({
24
+ base: 'flex-1 px-3 py-2 text-foreground',
25
+ variants: {
26
+ size: {
27
+ default: 'text-sm',
28
+ compact: 'text-xs',
29
+ },
30
+ },
31
+ defaultVariants: {
32
+ size: 'default',
33
+ },
34
+ });
35
+ const stepperButtonVariants = tv({
36
+ base: 'h-full w-11 items-center justify-center active:opacity-70',
37
+ variants: {
38
+ size: {
39
+ default: 'px-3',
40
+ compact: 'px-2',
41
+ },
42
+ disabled: {
43
+ true: 'opacity-40',
44
+ false: '',
45
+ },
46
+ },
47
+ defaultVariants: {
48
+ size: 'default',
49
+ disabled: false,
50
+ },
51
+ });
52
+ function toInputText(value) {
53
+ if (value === null || value === undefined) {
54
+ return '';
55
+ }
56
+ return Number.isFinite(value) ? String(value) : '';
57
+ }
58
+ function parseNumericText(text) {
59
+ const normalized = text.replace(',', '.').trim();
60
+ if (!normalized || normalized === '-' || normalized === '.' || normalized === '-.') {
61
+ return null;
62
+ }
63
+ const parsed = Number.parseFloat(normalized);
64
+ return Number.isFinite(parsed) ? parsed : null;
65
+ }
66
+ function clampValue(value, min, max) {
67
+ let next = value;
68
+ if (min !== undefined && next < min) {
69
+ next = min;
70
+ }
71
+ if (max !== undefined && next > max) {
72
+ next = max;
73
+ }
74
+ return next;
75
+ }
76
+ const NumericInput = React.forwardRef(({ className, inputClassName, prefix, suffix, value, defaultValue, onValueChange, min, max, step = 1, showSteppers = false, variant = 'default', size = 'default', editable = true, placeholderTextColor = '#737373', onBlur, ...props }, ref) => {
77
+ const [internalText, setInternalText] = useState(() => toInputText(defaultValue));
78
+ const isControlled = value !== undefined;
79
+ const textValue = isControlled ? toInputText(value) : internalText;
80
+ const currentValue = useMemo(() => parseNumericText(textValue), [textValue]);
81
+ const setTextAndValue = useCallback((nextText) => {
82
+ if (!isControlled) {
83
+ setInternalText(nextText);
84
+ }
85
+ onValueChange?.(parseNumericText(nextText));
86
+ }, [isControlled, onValueChange]);
87
+ const applyNumericValue = useCallback((nextValue) => {
88
+ if (nextValue === null) {
89
+ if (!isControlled) {
90
+ setInternalText('');
91
+ }
92
+ onValueChange?.(null);
93
+ return;
94
+ }
95
+ const clamped = clampValue(nextValue, min, max);
96
+ if (!isControlled) {
97
+ setInternalText(toInputText(clamped));
98
+ }
99
+ onValueChange?.(clamped);
100
+ }, [isControlled, max, min, onValueChange]);
101
+ const handleTextChange = (nextText) => {
102
+ const isNumericLike = /^-?\d*(?:[.,]\d*)?$/.test(nextText);
103
+ if (!isNumericLike) {
104
+ return;
105
+ }
106
+ setTextAndValue(nextText);
107
+ };
108
+ const handleBlur = (event) => {
109
+ const parsed = parseNumericText(textValue);
110
+ if (parsed !== null) {
111
+ const clamped = clampValue(parsed, min, max);
112
+ if (!isControlled) {
113
+ setInternalText(toInputText(clamped));
114
+ }
115
+ onValueChange?.(clamped);
116
+ }
117
+ onBlur?.(event);
118
+ };
119
+ const canDecrease = editable && (min === undefined || currentValue === null || currentValue > min);
120
+ const canIncrease = editable && (max === undefined || currentValue === null || currentValue < max);
121
+ const nudge = (delta) => {
122
+ const baseline = currentValue ?? min ?? 0;
123
+ applyNumericValue(baseline + delta * step);
124
+ };
125
+ return (_jsxs(View, { className: cn(numericInputVariants({ variant, size }), !editable && 'opacity-50', className), children: [prefix ? _jsx(View, { className: "shrink-0 pl-3", children: prefix }) : null, _jsx(TextInput, { ref: ref, className: cn(numericInputTextVariants({ size }), inputClassName), value: textValue, onChangeText: handleTextChange, onBlur: handleBlur, keyboardType: "decimal-pad", editable: editable, placeholderTextColor: placeholderTextColor, ...props }), suffix ? _jsx(View, { className: "shrink-0 pr-3", children: suffix }) : null, showSteppers ? (_jsxs(View, { className: "ml-1 h-full flex-row border-l border-input", children: [_jsx(Pressable, { className: cn(stepperButtonVariants({ size, disabled: !canDecrease })), onPress: () => nudge(-1), disabled: !canDecrease, hitSlop: 4, accessibilityRole: "button", accessibilityLabel: "Decrease value", children: _jsx(Text, { className: "text-base font-medium text-foreground", children: "-" }) }), _jsx(Pressable, { className: cn(stepperButtonVariants({ size, disabled: !canIncrease })), onPress: () => nudge(1), disabled: !canIncrease, hitSlop: 4, accessibilityRole: "button", accessibilityLabel: "Increase value", children: _jsx(Text, { className: "text-base font-medium text-foreground", children: "+" }) })] })) : null] }));
126
+ });
127
+ NumericInput.displayName = 'NumericInput';
128
+ export { NumericInput, numericInputVariants, numericInputTextVariants };
129
+ //# sourceMappingURL=numeric-input.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"numeric-input.js","sourceRoot":"","sources":["../../../src/components/numeric-input/numeric-input.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export { SegmentedControl, SegmentedControlItem, SegmentedControlItemText, segmentedControlVariants, segmentedControlItemVariants, segmentedControlItemTextVariants, type SegmentedControlProps, type SegmentedControlItemProps, type SegmentedControlItemTextProps, } from './segmented-control';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/segmented-control/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gBAAgB,EAChB,oBAAoB,EACpB,wBAAwB,EACxB,wBAAwB,EACxB,4BAA4B,EAC5B,gCAAgC,EAChC,KAAK,qBAAqB,EAC1B,KAAK,yBAAyB,EAC9B,KAAK,6BAA6B,GACnC,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { SegmentedControl, SegmentedControlItem, SegmentedControlItemText, segmentedControlVariants, segmentedControlItemVariants, segmentedControlItemTextVariants, } from './segmented-control';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/segmented-control/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gBAAgB,EAChB,oBAAoB,EACpB,wBAAwB,EACxB,wBAAwB,EACxB,4BAA4B,EAC5B,gCAAgC,GAIjC,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,281 @@
1
+ import React from 'react';
2
+ import { type PressableProps, type TextProps, type ViewProps } from 'react-native';
3
+ declare const segmentedControlVariants: import("tailwind-variants").TVReturnType<{
4
+ wrap: {
5
+ true: string;
6
+ false: string;
7
+ };
8
+ size: {
9
+ default: string;
10
+ compact: string;
11
+ };
12
+ }, undefined, "w-full flex-row items-center rounded-lg bg-muted p-1", import("tailwind-variants/dist/config.js").TVConfig<{
13
+ wrap: {
14
+ true: string;
15
+ false: string;
16
+ };
17
+ size: {
18
+ default: string;
19
+ compact: string;
20
+ };
21
+ }, {
22
+ wrap: {
23
+ true: string;
24
+ false: string;
25
+ };
26
+ size: {
27
+ default: string;
28
+ compact: string;
29
+ };
30
+ }>, {
31
+ wrap: {
32
+ true: string;
33
+ false: string;
34
+ };
35
+ size: {
36
+ default: string;
37
+ compact: string;
38
+ };
39
+ }, undefined, import("tailwind-variants").TVReturnType<{
40
+ wrap: {
41
+ true: string;
42
+ false: string;
43
+ };
44
+ size: {
45
+ default: string;
46
+ compact: string;
47
+ };
48
+ }, undefined, "w-full flex-row items-center rounded-lg bg-muted p-1", import("tailwind-variants/dist/config.js").TVConfig<{
49
+ wrap: {
50
+ true: string;
51
+ false: string;
52
+ };
53
+ size: {
54
+ default: string;
55
+ compact: string;
56
+ };
57
+ }, {
58
+ wrap: {
59
+ true: string;
60
+ false: string;
61
+ };
62
+ size: {
63
+ default: string;
64
+ compact: string;
65
+ };
66
+ }>, unknown, unknown, undefined>>;
67
+ declare const segmentedControlItemVariants: import("tailwind-variants").TVReturnType<{
68
+ selected: {
69
+ true: string;
70
+ false: string;
71
+ };
72
+ size: {
73
+ default: string;
74
+ compact: string;
75
+ };
76
+ disabled: {
77
+ true: string;
78
+ false: string;
79
+ };
80
+ wrap: {
81
+ true: string;
82
+ false: string;
83
+ };
84
+ }, undefined, "min-h-10 min-w-0 flex-row items-center justify-center rounded-md px-3 active:opacity-70", import("tailwind-variants/dist/config.js").TVConfig<{
85
+ selected: {
86
+ true: string;
87
+ false: string;
88
+ };
89
+ size: {
90
+ default: string;
91
+ compact: string;
92
+ };
93
+ disabled: {
94
+ true: string;
95
+ false: string;
96
+ };
97
+ wrap: {
98
+ true: string;
99
+ false: string;
100
+ };
101
+ }, {
102
+ selected: {
103
+ true: string;
104
+ false: string;
105
+ };
106
+ size: {
107
+ default: string;
108
+ compact: string;
109
+ };
110
+ disabled: {
111
+ true: string;
112
+ false: string;
113
+ };
114
+ wrap: {
115
+ true: string;
116
+ false: string;
117
+ };
118
+ }>, {
119
+ selected: {
120
+ true: string;
121
+ false: string;
122
+ };
123
+ size: {
124
+ default: string;
125
+ compact: string;
126
+ };
127
+ disabled: {
128
+ true: string;
129
+ false: string;
130
+ };
131
+ wrap: {
132
+ true: string;
133
+ false: string;
134
+ };
135
+ }, undefined, import("tailwind-variants").TVReturnType<{
136
+ selected: {
137
+ true: string;
138
+ false: string;
139
+ };
140
+ size: {
141
+ default: string;
142
+ compact: string;
143
+ };
144
+ disabled: {
145
+ true: string;
146
+ false: string;
147
+ };
148
+ wrap: {
149
+ true: string;
150
+ false: string;
151
+ };
152
+ }, undefined, "min-h-10 min-w-0 flex-row items-center justify-center rounded-md px-3 active:opacity-70", import("tailwind-variants/dist/config.js").TVConfig<{
153
+ selected: {
154
+ true: string;
155
+ false: string;
156
+ };
157
+ size: {
158
+ default: string;
159
+ compact: string;
160
+ };
161
+ disabled: {
162
+ true: string;
163
+ false: string;
164
+ };
165
+ wrap: {
166
+ true: string;
167
+ false: string;
168
+ };
169
+ }, {
170
+ selected: {
171
+ true: string;
172
+ false: string;
173
+ };
174
+ size: {
175
+ default: string;
176
+ compact: string;
177
+ };
178
+ disabled: {
179
+ true: string;
180
+ false: string;
181
+ };
182
+ wrap: {
183
+ true: string;
184
+ false: string;
185
+ };
186
+ }>, unknown, unknown, undefined>>;
187
+ declare const segmentedControlItemTextVariants: import("tailwind-variants").TVReturnType<{
188
+ selected: {
189
+ true: string;
190
+ false: string;
191
+ };
192
+ size: {
193
+ default: string;
194
+ compact: string;
195
+ };
196
+ }, undefined, "font-medium", import("tailwind-variants/dist/config.js").TVConfig<{
197
+ selected: {
198
+ true: string;
199
+ false: string;
200
+ };
201
+ size: {
202
+ default: string;
203
+ compact: string;
204
+ };
205
+ }, {
206
+ selected: {
207
+ true: string;
208
+ false: string;
209
+ };
210
+ size: {
211
+ default: string;
212
+ compact: string;
213
+ };
214
+ }>, {
215
+ selected: {
216
+ true: string;
217
+ false: string;
218
+ };
219
+ size: {
220
+ default: string;
221
+ compact: string;
222
+ };
223
+ }, undefined, import("tailwind-variants").TVReturnType<{
224
+ selected: {
225
+ true: string;
226
+ false: string;
227
+ };
228
+ size: {
229
+ default: string;
230
+ compact: string;
231
+ };
232
+ }, undefined, "font-medium", import("tailwind-variants/dist/config.js").TVConfig<{
233
+ selected: {
234
+ true: string;
235
+ false: string;
236
+ };
237
+ size: {
238
+ default: string;
239
+ compact: string;
240
+ };
241
+ }, {
242
+ selected: {
243
+ true: string;
244
+ false: string;
245
+ };
246
+ size: {
247
+ default: string;
248
+ compact: string;
249
+ };
250
+ }>, unknown, unknown, undefined>>;
251
+ export interface SegmentedControlProps extends ViewProps {
252
+ value?: string;
253
+ defaultValue?: string;
254
+ onValueChange?: (value: string) => void;
255
+ wrap?: boolean | 'auto';
256
+ size?: 'default' | 'compact';
257
+ disabled?: boolean;
258
+ className?: string;
259
+ }
260
+ export interface SegmentedControlItemProps extends Omit<PressableProps, 'children'> {
261
+ value: string;
262
+ children?: React.ReactNode;
263
+ className?: string;
264
+ }
265
+ export interface SegmentedControlItemTextProps extends TextProps {
266
+ className?: string;
267
+ }
268
+ declare function SegmentedControl({ value: controlledValue, defaultValue, onValueChange, wrap, size, disabled, className, children, ...props }: SegmentedControlProps): import("react/jsx-runtime").JSX.Element;
269
+ declare namespace SegmentedControl {
270
+ var displayName: string;
271
+ }
272
+ declare function SegmentedControlItem({ value: itemValue, className, children, disabled: itemDisabled, ...props }: SegmentedControlItemProps): import("react/jsx-runtime").JSX.Element;
273
+ declare namespace SegmentedControlItem {
274
+ var displayName: string;
275
+ }
276
+ declare function SegmentedControlItemText({ className, ...props }: SegmentedControlItemTextProps): import("react/jsx-runtime").JSX.Element;
277
+ declare namespace SegmentedControlItemText {
278
+ var displayName: string;
279
+ }
280
+ export { SegmentedControl, SegmentedControlItem, SegmentedControlItemText, segmentedControlVariants, segmentedControlItemVariants, segmentedControlItemTextVariants, };
281
+ //# sourceMappingURL=segmented-control.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"segmented-control.d.ts","sourceRoot":"","sources":["../../../src/components/segmented-control/segmented-control.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAuD,MAAM,OAAO,CAAC;AAC5E,OAAO,EAIL,KAAK,cAAc,EACnB,KAAK,SAAS,EACd,KAAK,SAAS,EACf,MAAM,cAAc,CAAC;AAItB,QAAA,MAAM,wBAAwB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAgB5B,CAAC;AAEH,QAAA,MAAM,4BAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCA0BhC,CAAC;AAEH,QAAA,MAAM,gCAAgC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAgBpC,CAAC;AA4BH,MAAM,WAAW,qBAAsB,SAAQ,SAAS;IACtD,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,IAAI,CAAC,EAAE,OAAO,GAAG,MAAM,CAAC;IACxB,IAAI,CAAC,EAAE,SAAS,GAAG,SAAS,CAAC;IAC7B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,yBAA0B,SAAQ,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC;IACjF,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,6BAA8B,SAAQ,SAAS;IAC9D,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,iBAAS,gBAAgB,CAAC,EACxB,KAAK,EAAE,eAAe,EACtB,YAAiB,EACjB,aAAa,EACb,IAAa,EACb,IAAgB,EAChB,QAAgB,EAChB,SAAS,EACT,QAAQ,EACR,GAAG,KAAK,EACT,EAAE,qBAAqB,2CAiCvB;kBA3CQ,gBAAgB;;;AA6CzB,iBAAS,oBAAoB,CAAC,EAC5B,KAAK,EAAE,SAAS,EAChB,SAAS,EACT,QAAQ,EACR,QAAQ,EAAE,YAAY,EACtB,GAAG,KAAK,EACT,EAAE,yBAAyB,2CAgC3B;kBAtCQ,oBAAoB;;;AAwC7B,iBAAS,wBAAwB,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,6BAA6B,2CAUvF;kBAVQ,wBAAwB;;;AAgBjC,OAAO,EACL,gBAAgB,EAChB,oBAAoB,EACpB,wBAAwB,EACxB,wBAAwB,EACxB,4BAA4B,EAC5B,gCAAgC,GACjC,CAAC"}