@thewhileloop/whileui 0.2.0 → 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.
- package/README.md +1 -1
- package/dist/components/card/card.js +3 -3
- package/dist/components/segmented-control/segmented-control.d.ts +1 -1
- package/dist/components/segmented-control/segmented-control.d.ts.map +1 -1
- package/dist/components/segmented-control/segmented-control.js +8 -6
- package/dist/components/segmented-control/segmented-control.js.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -28,7 +28,7 @@ const Card = React.forwardRef(({ className, padding, unstyled, ...props }, ref)
|
|
|
28
28
|
});
|
|
29
29
|
Card.displayName = 'Card';
|
|
30
30
|
const CardHeader = React.forwardRef(({ className, ...props }, ref) => {
|
|
31
|
-
return _jsx(View, { ref: ref, className: cn('pb-
|
|
31
|
+
return _jsx(View, { ref: ref, className: cn('pb-3', className), ...props });
|
|
32
32
|
});
|
|
33
33
|
CardHeader.displayName = 'CardHeader';
|
|
34
34
|
const CardTitle = React.forwardRef(({ className, ...props }, ref) => {
|
|
@@ -40,11 +40,11 @@ const CardDescription = React.forwardRef(({ className, ...props }, ref) => {
|
|
|
40
40
|
});
|
|
41
41
|
CardDescription.displayName = 'CardDescription';
|
|
42
42
|
const CardContent = React.forwardRef(({ className, ...props }, ref) => {
|
|
43
|
-
return _jsx(View, { ref: ref, className: cn('
|
|
43
|
+
return _jsx(View, { ref: ref, className: cn('pb-3', className), ...props });
|
|
44
44
|
});
|
|
45
45
|
CardContent.displayName = 'CardContent';
|
|
46
46
|
const CardFooter = React.forwardRef(({ className, ...props }, ref) => {
|
|
47
|
-
return _jsx(View, { ref: ref, className: cn('flex-row items-center pt-
|
|
47
|
+
return _jsx(View, { ref: ref, className: cn('flex-row items-center pt-1', className), ...props });
|
|
48
48
|
});
|
|
49
49
|
CardFooter.displayName = 'CardFooter';
|
|
50
50
|
// ─── Exports ─────────────────────────────────────────────────
|
|
@@ -252,7 +252,7 @@ export interface SegmentedControlProps extends ViewProps {
|
|
|
252
252
|
value?: string;
|
|
253
253
|
defaultValue?: string;
|
|
254
254
|
onValueChange?: (value: string) => void;
|
|
255
|
-
wrap?: boolean;
|
|
255
|
+
wrap?: boolean | 'auto';
|
|
256
256
|
size?: 'default' | 'compact';
|
|
257
257
|
disabled?: boolean;
|
|
258
258
|
className?: string;
|
|
@@ -1 +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,CAAC;
|
|
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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import { createContext, useContext, useMemo, useState } from 'react';
|
|
2
|
+
import React, { createContext, useContext, useMemo, useState } from 'react';
|
|
3
3
|
import { Pressable, Text, View, } from 'react-native';
|
|
4
4
|
import { cn } from '../../lib/cn';
|
|
5
5
|
import { tv } from '../../lib/tv';
|
|
@@ -7,7 +7,7 @@ const segmentedControlVariants = tv({
|
|
|
7
7
|
base: 'w-full flex-row items-center rounded-lg bg-muted p-1',
|
|
8
8
|
variants: {
|
|
9
9
|
wrap: {
|
|
10
|
-
true: 'flex-wrap gap-1',
|
|
10
|
+
true: 'flex-wrap justify-center gap-1',
|
|
11
11
|
false: 'flex-nowrap gap-1',
|
|
12
12
|
},
|
|
13
13
|
size: {
|
|
@@ -36,7 +36,7 @@ const segmentedControlItemVariants = tv({
|
|
|
36
36
|
false: '',
|
|
37
37
|
},
|
|
38
38
|
wrap: {
|
|
39
|
-
true: '
|
|
39
|
+
true: 'basis-[48%] grow-0',
|
|
40
40
|
false: 'flex-1',
|
|
41
41
|
},
|
|
42
42
|
},
|
|
@@ -75,9 +75,11 @@ const SegmentedControlItemContext = createContext({
|
|
|
75
75
|
selected: false,
|
|
76
76
|
size: 'default',
|
|
77
77
|
});
|
|
78
|
-
function SegmentedControl({ value: controlledValue, defaultValue = '', onValueChange, wrap =
|
|
78
|
+
function SegmentedControl({ value: controlledValue, defaultValue = '', onValueChange, wrap = 'auto', size = 'default', disabled = false, className, children, ...props }) {
|
|
79
79
|
const [internalValue, setInternalValue] = useState(defaultValue);
|
|
80
80
|
const value = controlledValue ?? internalValue;
|
|
81
|
+
const itemCount = useMemo(() => React.Children.toArray(children).filter((child) => React.isValidElement(child)).length, [children]);
|
|
82
|
+
const shouldWrap = wrap === 'auto' ? itemCount > 3 : wrap;
|
|
81
83
|
const handleValueChange = (nextValue) => {
|
|
82
84
|
if (disabled || value === nextValue) {
|
|
83
85
|
return;
|
|
@@ -85,8 +87,8 @@ function SegmentedControl({ value: controlledValue, defaultValue = '', onValueCh
|
|
|
85
87
|
setInternalValue(nextValue);
|
|
86
88
|
onValueChange?.(nextValue);
|
|
87
89
|
};
|
|
88
|
-
const contextValue = useMemo(() => ({ value, onValueChange: handleValueChange, size, wrap, disabled }), [value, size,
|
|
89
|
-
return (_jsx(SegmentedControlContext.Provider, { value: contextValue, children: _jsx(View, { className: cn(segmentedControlVariants({ wrap, size }), className), accessibilityRole: "radiogroup", ...props, children: children }) }));
|
|
90
|
+
const contextValue = useMemo(() => ({ value, onValueChange: handleValueChange, size, wrap: shouldWrap, disabled }), [value, size, shouldWrap, disabled]);
|
|
91
|
+
return (_jsx(SegmentedControlContext.Provider, { value: contextValue, children: _jsx(View, { className: cn(segmentedControlVariants({ wrap: shouldWrap, size }), className), accessibilityRole: "radiogroup", ...props, children: children }) }));
|
|
90
92
|
}
|
|
91
93
|
function SegmentedControlItem({ value: itemValue, className, children, disabled: itemDisabled, ...props }) {
|
|
92
94
|
const { value, onValueChange, size, wrap, disabled } = useContext(SegmentedControlContext);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"segmented-control.js","sourceRoot":"","sources":["../../../src/components/segmented-control/segmented-control.tsx"],"names":[],"mappings":";AAAA,
|
|
1
|
+
{"version":3,"file":"segmented-control.js","sourceRoot":"","sources":["../../../src/components/segmented-control/segmented-control.tsx"],"names":[],"mappings":"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"}
|