@cdx-ui/components 0.0.1-alpha.29 → 0.0.1-alpha.30
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/lib/commonjs/components/Button/index.js +3 -0
- package/lib/commonjs/components/Button/index.js.map +1 -1
- package/lib/commonjs/components/Form/FormLabelRoot.js +33 -0
- package/lib/commonjs/components/Form/FormLabelRoot.js.map +1 -0
- package/lib/commonjs/components/Form/FormLabelRoot.web.js +18 -0
- package/lib/commonjs/components/Form/FormLabelRoot.web.js.map +1 -0
- package/lib/commonjs/components/Form/FormRoot.js +25 -0
- package/lib/commonjs/components/Form/FormRoot.js.map +1 -0
- package/lib/commonjs/components/Form/FormRoot.web.js +17 -0
- package/lib/commonjs/components/Form/FormRoot.web.js.map +1 -0
- package/lib/commonjs/components/Form/index.js +255 -0
- package/lib/commonjs/components/Form/index.js.map +1 -0
- package/lib/commonjs/components/Form/styles.js +57 -0
- package/lib/commonjs/components/Form/styles.js.map +1 -0
- package/lib/commonjs/components/Select/SelectTriggerHost.js +10 -0
- package/lib/commonjs/components/Select/SelectTriggerHost.js.map +1 -0
- package/lib/commonjs/components/Select/SelectTriggerHost.web.js +98 -0
- package/lib/commonjs/components/Select/SelectTriggerHost.web.js.map +1 -0
- package/lib/commonjs/components/Select/index.js +2 -1
- package/lib/commonjs/components/Select/index.js.map +1 -1
- package/lib/commonjs/components/Select/styles.js +3 -3
- package/lib/commonjs/components/Select/styles.js.map +1 -1
- package/lib/commonjs/components/index.js +12 -0
- package/lib/commonjs/components/index.js.map +1 -1
- package/lib/commonjs/index.js +40 -0
- package/lib/commonjs/index.js.map +1 -1
- package/lib/module/components/Button/index.js +3 -0
- package/lib/module/components/Button/index.js.map +1 -1
- package/lib/module/components/Form/FormLabelRoot.js +29 -0
- package/lib/module/components/Form/FormLabelRoot.js.map +1 -0
- package/lib/module/components/Form/FormLabelRoot.web.js +13 -0
- package/lib/module/components/Form/FormLabelRoot.web.js.map +1 -0
- package/lib/module/components/Form/FormRoot.js +21 -0
- package/lib/module/components/Form/FormRoot.js.map +1 -0
- package/lib/module/components/Form/FormRoot.web.js +12 -0
- package/lib/module/components/Form/FormRoot.web.js.map +1 -0
- package/lib/module/components/Form/index.js +252 -0
- package/lib/module/components/Form/index.js.map +1 -0
- package/lib/module/components/Form/styles.js +53 -0
- package/lib/module/components/Form/styles.js.map +1 -0
- package/lib/module/components/Select/SelectTriggerHost.js +7 -0
- package/lib/module/components/Select/SelectTriggerHost.js.map +1 -0
- package/lib/module/components/Select/SelectTriggerHost.web.js +93 -0
- package/lib/module/components/Select/SelectTriggerHost.web.js.map +1 -0
- package/lib/module/components/Select/index.js +2 -1
- package/lib/module/components/Select/index.js.map +1 -1
- package/lib/module/components/Select/styles.js +3 -3
- package/lib/module/components/Select/styles.js.map +1 -1
- package/lib/module/components/index.js +1 -0
- package/lib/module/components/index.js.map +1 -1
- package/lib/module/index.js +3 -0
- package/lib/module/index.js.map +1 -1
- package/lib/typescript/components/Avatar/index.d.ts +1 -1
- package/lib/typescript/components/Avatar/index.d.ts.map +1 -1
- package/lib/typescript/components/Button/index.d.ts.map +1 -1
- package/lib/typescript/components/Checkbox/index.d.ts +1 -1
- package/lib/typescript/components/Checkbox/index.d.ts.map +1 -1
- package/lib/typescript/components/Dialog/index.d.ts +0 -1
- package/lib/typescript/components/Dialog/index.d.ts.map +1 -1
- package/lib/typescript/components/Form/FormLabelRoot.d.ts +18 -0
- package/lib/typescript/components/Form/FormLabelRoot.d.ts.map +1 -0
- package/lib/typescript/components/Form/FormLabelRoot.web.d.ts +20 -0
- package/lib/typescript/components/Form/FormLabelRoot.web.d.ts.map +1 -0
- package/lib/typescript/components/Form/FormRoot.d.ts +12 -0
- package/lib/typescript/components/Form/FormRoot.d.ts.map +1 -0
- package/lib/typescript/components/Form/FormRoot.web.d.ts +10 -0
- package/lib/typescript/components/Form/FormRoot.web.d.ts.map +1 -0
- package/lib/typescript/components/Form/index.d.ts +64 -0
- package/lib/typescript/components/Form/index.d.ts.map +1 -0
- package/lib/typescript/components/Form/styles.d.ts +22 -0
- package/lib/typescript/components/Form/styles.d.ts.map +1 -0
- package/lib/typescript/components/Input/index.d.ts +1 -1
- package/lib/typescript/components/Input/index.d.ts.map +1 -1
- package/lib/typescript/components/Select/SelectTriggerHost.d.ts +3 -0
- package/lib/typescript/components/Select/SelectTriggerHost.d.ts.map +1 -0
- package/lib/typescript/components/Select/SelectTriggerHost.web.d.ts +13 -0
- package/lib/typescript/components/Select/SelectTriggerHost.web.d.ts.map +1 -0
- package/lib/typescript/components/Select/index.d.ts +1 -1
- package/lib/typescript/components/Select/index.d.ts.map +1 -1
- package/lib/typescript/components/Select/styles.d.ts.map +1 -1
- package/lib/typescript/components/Switch/index.d.ts +0 -1
- package/lib/typescript/components/Switch/index.d.ts.map +1 -1
- package/lib/typescript/components/index.d.ts +1 -0
- package/lib/typescript/components/index.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +3 -0
- package/lib/typescript/index.d.ts.map +1 -1
- package/package.json +5 -4
- package/src/components/Avatar/index.tsx +0 -2
- package/src/components/Button/index.tsx +1 -0
- package/src/components/Checkbox/index.tsx +0 -2
- package/src/components/Dialog/index.tsx +0 -2
- package/src/components/Form/FormLabelRoot.tsx +33 -0
- package/src/components/Form/FormLabelRoot.web.tsx +18 -0
- package/src/components/Form/FormRoot.tsx +19 -0
- package/src/components/Form/FormRoot.web.tsx +12 -0
- package/src/components/Form/index.tsx +272 -0
- package/src/components/Form/styles.ts +75 -0
- package/src/components/Input/index.tsx +0 -2
- package/src/components/Select/SelectTriggerHost.tsx +4 -0
- package/src/components/Select/SelectTriggerHost.web.tsx +136 -0
- package/src/components/Select/index.tsx +2 -3
- package/src/components/Select/styles.ts +7 -3
- package/src/components/Switch/index.tsx +0 -2
- package/src/components/index.ts +1 -0
- package/src/index.ts +3 -0
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import React, { forwardRef } from 'react';
|
|
2
|
+
import { StyleSheet } from 'react-native';
|
|
3
|
+
import type { PressableProps } from 'react-native';
|
|
4
|
+
|
|
5
|
+
export type SelectTriggerHostProps = PressableProps & { className?: string };
|
|
6
|
+
|
|
7
|
+
/** Props that must not be forwarded to a DOM `<button>`. */
|
|
8
|
+
const OMIT = new Set<string>([
|
|
9
|
+
'hitSlop',
|
|
10
|
+
'pressRetentionOffset',
|
|
11
|
+
'android_ripple',
|
|
12
|
+
'android_disableSound',
|
|
13
|
+
'unstable_pressDelay',
|
|
14
|
+
'onLongPress',
|
|
15
|
+
'delayLongPress',
|
|
16
|
+
'onPress',
|
|
17
|
+
'onPressIn',
|
|
18
|
+
'onPressOut',
|
|
19
|
+
'onHoverIn',
|
|
20
|
+
'onHoverOut',
|
|
21
|
+
'disabled',
|
|
22
|
+
'style',
|
|
23
|
+
'className',
|
|
24
|
+
'testID',
|
|
25
|
+
'children',
|
|
26
|
+
'accessible',
|
|
27
|
+
'accessibilityActions',
|
|
28
|
+
'accessibilityElementsHidden',
|
|
29
|
+
'accessibilityHint',
|
|
30
|
+
'accessibilityIgnoresInvertColors',
|
|
31
|
+
'accessibilityLabel',
|
|
32
|
+
'accessibilityLabelledBy',
|
|
33
|
+
'accessibilityLiveRegion',
|
|
34
|
+
'accessibilityRole',
|
|
35
|
+
'accessibilityState',
|
|
36
|
+
'accessibilityValue',
|
|
37
|
+
'accessibilityViewIsModal',
|
|
38
|
+
'importantForAccessibility',
|
|
39
|
+
'needsOffscreenAlphaCompositing',
|
|
40
|
+
'collapsable',
|
|
41
|
+
'shouldRasterizeIOS',
|
|
42
|
+
'removeClippedSubviews',
|
|
43
|
+
'onAccessibilityAction',
|
|
44
|
+
'onAccessibilityEscape',
|
|
45
|
+
'onAccessibilityTap',
|
|
46
|
+
]);
|
|
47
|
+
|
|
48
|
+
function resolveChildren(children: PressableProps['children']): React.ReactNode {
|
|
49
|
+
if (typeof children === 'function') {
|
|
50
|
+
return children({ pressed: false });
|
|
51
|
+
}
|
|
52
|
+
return children;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function filterDomProps(rest: object): React.ButtonHTMLAttributes<HTMLButtonElement> {
|
|
56
|
+
const entries = Object.entries(rest).filter(([key]) => !OMIT.has(key));
|
|
57
|
+
return Object.fromEntries(entries) as React.ButtonHTMLAttributes<HTMLButtonElement>;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
/** UA `<button>` defaults (centered text, inline sizing) fight our flex + `justify-between` layout. */
|
|
61
|
+
const webButtonLayoutStyle: React.CSSProperties = {
|
|
62
|
+
display: 'flex',
|
|
63
|
+
flexDirection: 'row',
|
|
64
|
+
alignItems: 'center',
|
|
65
|
+
justifyContent: 'space-between',
|
|
66
|
+
width: '100%',
|
|
67
|
+
minWidth: 0,
|
|
68
|
+
textAlign: 'start',
|
|
69
|
+
boxSizing: 'border-box',
|
|
70
|
+
margin: 0,
|
|
71
|
+
font: 'inherit',
|
|
72
|
+
lineHeight: 'normal',
|
|
73
|
+
WebkitAppearance: 'none',
|
|
74
|
+
appearance: 'none',
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
/**
|
|
78
|
+
* Native `<button type="button">` so the trigger is HTML-labelable (`<label htmlFor>` focuses it).
|
|
79
|
+
* `Pressable` on web is a non-labelable div; no extra refs are needed for label association.
|
|
80
|
+
*/
|
|
81
|
+
export const SelectTriggerHost = forwardRef<HTMLButtonElement, SelectTriggerHostProps>(
|
|
82
|
+
function SelectTriggerHost(props, ref) {
|
|
83
|
+
const {
|
|
84
|
+
children,
|
|
85
|
+
onPress,
|
|
86
|
+
onPressIn,
|
|
87
|
+
onPressOut,
|
|
88
|
+
onHoverIn,
|
|
89
|
+
onHoverOut,
|
|
90
|
+
disabled,
|
|
91
|
+
style,
|
|
92
|
+
className,
|
|
93
|
+
testID,
|
|
94
|
+
...rest
|
|
95
|
+
} = props;
|
|
96
|
+
|
|
97
|
+
const domProps = filterDomProps(rest);
|
|
98
|
+
const flattened = StyleSheet.flatten(style) as React.CSSProperties | undefined;
|
|
99
|
+
|
|
100
|
+
return (
|
|
101
|
+
<button
|
|
102
|
+
ref={ref}
|
|
103
|
+
{...domProps}
|
|
104
|
+
type="button"
|
|
105
|
+
disabled={!!disabled}
|
|
106
|
+
className={typeof className === 'string' ? className : undefined}
|
|
107
|
+
style={{ ...webButtonLayoutStyle, ...(flattened ?? {}) }}
|
|
108
|
+
data-testid={testID}
|
|
109
|
+
onClick={(e) => {
|
|
110
|
+
if (!disabled) {
|
|
111
|
+
onPress?.(e as unknown as Parameters<NonNullable<PressableProps['onPress']>>[0]);
|
|
112
|
+
}
|
|
113
|
+
}}
|
|
114
|
+
onPointerDown={(e) => {
|
|
115
|
+
onPressIn?.(e as unknown as Parameters<NonNullable<PressableProps['onPressIn']>>[0]);
|
|
116
|
+
}}
|
|
117
|
+
onPointerUp={(e) => {
|
|
118
|
+
onPressOut?.(e as unknown as Parameters<NonNullable<PressableProps['onPressOut']>>[0]);
|
|
119
|
+
}}
|
|
120
|
+
onPointerCancel={(e) => {
|
|
121
|
+
onPressOut?.(e as unknown as Parameters<NonNullable<PressableProps['onPressOut']>>[0]);
|
|
122
|
+
}}
|
|
123
|
+
onMouseEnter={(e) => {
|
|
124
|
+
onHoverIn?.(e as unknown as Parameters<NonNullable<PressableProps['onHoverIn']>>[0]);
|
|
125
|
+
}}
|
|
126
|
+
onMouseLeave={(e) => {
|
|
127
|
+
onHoverOut?.(e as unknown as Parameters<NonNullable<PressableProps['onHoverOut']>>[0]);
|
|
128
|
+
}}
|
|
129
|
+
>
|
|
130
|
+
{resolveChildren(children)}
|
|
131
|
+
</button>
|
|
132
|
+
);
|
|
133
|
+
},
|
|
134
|
+
);
|
|
135
|
+
|
|
136
|
+
SelectTriggerHost.displayName = 'SelectTriggerHost';
|
|
@@ -12,6 +12,7 @@ import {
|
|
|
12
12
|
} from '@cdx-ui/primitives';
|
|
13
13
|
import { cn, useStyleContext, withStyleContext } from '@cdx-ui/utils';
|
|
14
14
|
import { Icon, IconProps } from '../Icon';
|
|
15
|
+
import { SelectTriggerHost } from './SelectTriggerHost';
|
|
15
16
|
import {
|
|
16
17
|
type SelectVariantProps,
|
|
17
18
|
selectContentVariants,
|
|
@@ -30,7 +31,7 @@ const useSelectStyleContext = () => useStyleContext(SCOPE) as SelectVariantProps
|
|
|
30
31
|
|
|
31
32
|
const SelectPrimitive = createSelect({
|
|
32
33
|
Root,
|
|
33
|
-
Trigger:
|
|
34
|
+
Trigger: SelectTriggerHost,
|
|
34
35
|
Value: Text,
|
|
35
36
|
Icon: View,
|
|
36
37
|
Content: View,
|
|
@@ -212,5 +213,3 @@ export const Select = Object.assign(SelectRoot, {
|
|
|
212
213
|
Item: SelectItem,
|
|
213
214
|
ItemLabel: SelectItemLabel,
|
|
214
215
|
}) as SelectCompoundComponent;
|
|
215
|
-
|
|
216
|
-
export type { SelectVariantProps } from './styles';
|
|
@@ -19,7 +19,7 @@ import {
|
|
|
19
19
|
|
|
20
20
|
export const selectTriggerVariants = cva(
|
|
21
21
|
[
|
|
22
|
-
'flex-row items-center justify-between',
|
|
22
|
+
'flex w-full min-w-0 flex-row items-center justify-between text-start',
|
|
23
23
|
RADIUS_SM,
|
|
24
24
|
SHADOW_SM,
|
|
25
25
|
TRANSITION_COLORS,
|
|
@@ -61,7 +61,7 @@ export const selectTriggerVariants = cva(
|
|
|
61
61
|
|
|
62
62
|
export const selectValueVariants = cva(
|
|
63
63
|
[
|
|
64
|
-
'flex-1',
|
|
64
|
+
'min-w-0 flex-1 text-start',
|
|
65
65
|
'data-[placeholder=true]:text-slate-400',
|
|
66
66
|
'data-[invalid=true]:text-red-600',
|
|
67
67
|
COLOR_TEXT_PRIMARY,
|
|
@@ -82,7 +82,11 @@ export const selectValueVariants = cva(
|
|
|
82
82
|
// ── Icon ────────────────────────────────────────────────────
|
|
83
83
|
|
|
84
84
|
export const selectIconVariants = cva(
|
|
85
|
-
[
|
|
85
|
+
[
|
|
86
|
+
'shrink-0 items-center justify-center self-center',
|
|
87
|
+
COLOR_TEXT_MUTED,
|
|
88
|
+
'data-[invalid=true]:text-red-500',
|
|
89
|
+
],
|
|
86
90
|
{
|
|
87
91
|
variants: {
|
|
88
92
|
size: {
|
package/src/components/index.ts
CHANGED
package/src/index.ts
CHANGED