@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.
Files changed (105) hide show
  1. package/lib/commonjs/components/Button/index.js +3 -0
  2. package/lib/commonjs/components/Button/index.js.map +1 -1
  3. package/lib/commonjs/components/Form/FormLabelRoot.js +33 -0
  4. package/lib/commonjs/components/Form/FormLabelRoot.js.map +1 -0
  5. package/lib/commonjs/components/Form/FormLabelRoot.web.js +18 -0
  6. package/lib/commonjs/components/Form/FormLabelRoot.web.js.map +1 -0
  7. package/lib/commonjs/components/Form/FormRoot.js +25 -0
  8. package/lib/commonjs/components/Form/FormRoot.js.map +1 -0
  9. package/lib/commonjs/components/Form/FormRoot.web.js +17 -0
  10. package/lib/commonjs/components/Form/FormRoot.web.js.map +1 -0
  11. package/lib/commonjs/components/Form/index.js +255 -0
  12. package/lib/commonjs/components/Form/index.js.map +1 -0
  13. package/lib/commonjs/components/Form/styles.js +57 -0
  14. package/lib/commonjs/components/Form/styles.js.map +1 -0
  15. package/lib/commonjs/components/Select/SelectTriggerHost.js +10 -0
  16. package/lib/commonjs/components/Select/SelectTriggerHost.js.map +1 -0
  17. package/lib/commonjs/components/Select/SelectTriggerHost.web.js +98 -0
  18. package/lib/commonjs/components/Select/SelectTriggerHost.web.js.map +1 -0
  19. package/lib/commonjs/components/Select/index.js +2 -1
  20. package/lib/commonjs/components/Select/index.js.map +1 -1
  21. package/lib/commonjs/components/Select/styles.js +3 -3
  22. package/lib/commonjs/components/Select/styles.js.map +1 -1
  23. package/lib/commonjs/components/index.js +12 -0
  24. package/lib/commonjs/components/index.js.map +1 -1
  25. package/lib/commonjs/index.js +40 -0
  26. package/lib/commonjs/index.js.map +1 -1
  27. package/lib/module/components/Button/index.js +3 -0
  28. package/lib/module/components/Button/index.js.map +1 -1
  29. package/lib/module/components/Form/FormLabelRoot.js +29 -0
  30. package/lib/module/components/Form/FormLabelRoot.js.map +1 -0
  31. package/lib/module/components/Form/FormLabelRoot.web.js +13 -0
  32. package/lib/module/components/Form/FormLabelRoot.web.js.map +1 -0
  33. package/lib/module/components/Form/FormRoot.js +21 -0
  34. package/lib/module/components/Form/FormRoot.js.map +1 -0
  35. package/lib/module/components/Form/FormRoot.web.js +12 -0
  36. package/lib/module/components/Form/FormRoot.web.js.map +1 -0
  37. package/lib/module/components/Form/index.js +252 -0
  38. package/lib/module/components/Form/index.js.map +1 -0
  39. package/lib/module/components/Form/styles.js +53 -0
  40. package/lib/module/components/Form/styles.js.map +1 -0
  41. package/lib/module/components/Select/SelectTriggerHost.js +7 -0
  42. package/lib/module/components/Select/SelectTriggerHost.js.map +1 -0
  43. package/lib/module/components/Select/SelectTriggerHost.web.js +93 -0
  44. package/lib/module/components/Select/SelectTriggerHost.web.js.map +1 -0
  45. package/lib/module/components/Select/index.js +2 -1
  46. package/lib/module/components/Select/index.js.map +1 -1
  47. package/lib/module/components/Select/styles.js +3 -3
  48. package/lib/module/components/Select/styles.js.map +1 -1
  49. package/lib/module/components/index.js +1 -0
  50. package/lib/module/components/index.js.map +1 -1
  51. package/lib/module/index.js +3 -0
  52. package/lib/module/index.js.map +1 -1
  53. package/lib/typescript/components/Avatar/index.d.ts +1 -1
  54. package/lib/typescript/components/Avatar/index.d.ts.map +1 -1
  55. package/lib/typescript/components/Button/index.d.ts.map +1 -1
  56. package/lib/typescript/components/Checkbox/index.d.ts +1 -1
  57. package/lib/typescript/components/Checkbox/index.d.ts.map +1 -1
  58. package/lib/typescript/components/Dialog/index.d.ts +0 -1
  59. package/lib/typescript/components/Dialog/index.d.ts.map +1 -1
  60. package/lib/typescript/components/Form/FormLabelRoot.d.ts +18 -0
  61. package/lib/typescript/components/Form/FormLabelRoot.d.ts.map +1 -0
  62. package/lib/typescript/components/Form/FormLabelRoot.web.d.ts +20 -0
  63. package/lib/typescript/components/Form/FormLabelRoot.web.d.ts.map +1 -0
  64. package/lib/typescript/components/Form/FormRoot.d.ts +12 -0
  65. package/lib/typescript/components/Form/FormRoot.d.ts.map +1 -0
  66. package/lib/typescript/components/Form/FormRoot.web.d.ts +10 -0
  67. package/lib/typescript/components/Form/FormRoot.web.d.ts.map +1 -0
  68. package/lib/typescript/components/Form/index.d.ts +64 -0
  69. package/lib/typescript/components/Form/index.d.ts.map +1 -0
  70. package/lib/typescript/components/Form/styles.d.ts +22 -0
  71. package/lib/typescript/components/Form/styles.d.ts.map +1 -0
  72. package/lib/typescript/components/Input/index.d.ts +1 -1
  73. package/lib/typescript/components/Input/index.d.ts.map +1 -1
  74. package/lib/typescript/components/Select/SelectTriggerHost.d.ts +3 -0
  75. package/lib/typescript/components/Select/SelectTriggerHost.d.ts.map +1 -0
  76. package/lib/typescript/components/Select/SelectTriggerHost.web.d.ts +13 -0
  77. package/lib/typescript/components/Select/SelectTriggerHost.web.d.ts.map +1 -0
  78. package/lib/typescript/components/Select/index.d.ts +1 -1
  79. package/lib/typescript/components/Select/index.d.ts.map +1 -1
  80. package/lib/typescript/components/Select/styles.d.ts.map +1 -1
  81. package/lib/typescript/components/Switch/index.d.ts +0 -1
  82. package/lib/typescript/components/Switch/index.d.ts.map +1 -1
  83. package/lib/typescript/components/index.d.ts +1 -0
  84. package/lib/typescript/components/index.d.ts.map +1 -1
  85. package/lib/typescript/index.d.ts +3 -0
  86. package/lib/typescript/index.d.ts.map +1 -1
  87. package/package.json +5 -4
  88. package/src/components/Avatar/index.tsx +0 -2
  89. package/src/components/Button/index.tsx +1 -0
  90. package/src/components/Checkbox/index.tsx +0 -2
  91. package/src/components/Dialog/index.tsx +0 -2
  92. package/src/components/Form/FormLabelRoot.tsx +33 -0
  93. package/src/components/Form/FormLabelRoot.web.tsx +18 -0
  94. package/src/components/Form/FormRoot.tsx +19 -0
  95. package/src/components/Form/FormRoot.web.tsx +12 -0
  96. package/src/components/Form/index.tsx +272 -0
  97. package/src/components/Form/styles.ts +75 -0
  98. package/src/components/Input/index.tsx +0 -2
  99. package/src/components/Select/SelectTriggerHost.tsx +4 -0
  100. package/src/components/Select/SelectTriggerHost.web.tsx +136 -0
  101. package/src/components/Select/index.tsx +2 -3
  102. package/src/components/Select/styles.ts +7 -3
  103. package/src/components/Switch/index.tsx +0 -2
  104. package/src/components/index.ts +1 -0
  105. 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: Pressable,
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
- ['items-center justify-center', COLOR_TEXT_MUTED, 'data-[invalid=true]:text-red-500'],
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: {
@@ -9,5 +9,3 @@ export interface SwitchProps extends ISwitchProps, SwitchVariantProps {
9
9
  }
10
10
 
11
11
  export const Switch = SwitchPrimitive;
12
-
13
- export type { SwitchVariantProps };
@@ -7,6 +7,7 @@ export * from './Card';
7
7
  export * from './Checkbox';
8
8
  export * from './Chip';
9
9
  export * from './Dialog';
10
+ export * from './Form';
10
11
  export * from './Image';
11
12
  export * from './Input';
12
13
  export * from './Link';
package/src/index.ts CHANGED
@@ -1 +1,4 @@
1
+ /// <reference types="uniwind/types" preserve="true" />
1
2
  export * from './components';
3
+ export { View, ScrollView, KeyboardAvoidingView } from 'react-native';
4
+ export { SafeAreaView, useSafeAreaInsets } from 'react-native-safe-area-context';