@coinbase/cds-web 9.1.0 → 9.1.2
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/CHANGELOG.md
CHANGED
|
@@ -8,6 +8,18 @@ All notable changes to this project will be documented in this file.
|
|
|
8
8
|
|
|
9
9
|
<!-- template-start -->
|
|
10
10
|
|
|
11
|
+
## 9.1.2 (5/28/2026 PST)
|
|
12
|
+
|
|
13
|
+
#### 🐞 Fixes
|
|
14
|
+
|
|
15
|
+
- Add data attribute to popover container. [[#717](https://github.com/coinbase/cds/pull/717)]
|
|
16
|
+
|
|
17
|
+
## 9.1.1 (5/27/2026 PST)
|
|
18
|
+
|
|
19
|
+
#### 🐞 Fixes
|
|
20
|
+
|
|
21
|
+
- Fix: support inside label variant on select. [[#726](https://github.com/coinbase/cds/pull/726)]
|
|
22
|
+
|
|
11
23
|
## 9.1.0 (5/26/2026 PST)
|
|
12
24
|
|
|
13
25
|
#### 🚀 Updates
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DefaultSelectControl.d.ts","sourceRoot":"","sources":["../../../src/alpha/select/DefaultSelectControl.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAyD,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"DefaultSelectControl.d.ts","sourceRoot":"","sources":["../../../src/alpha/select/DefaultSelectControl.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAyD,MAAM,OAAO,CAAC;AAgB9E,OAAO,EAEL,KAAK,kBAAkB,EAEvB,KAAK,UAAU,EAChB,MAAM,UAAU,CAAC;AA4BlB,KAAK,wBAAwB,GAAG,CAC9B,IAAI,SAAS,UAAU,EACvB,iBAAiB,SAAS,MAAM,GAAG,MAAM,EAEzC,KAAK,EAAE,kBAAkB,CAAC,IAAI,EAAE,iBAAiB,CAAC,GAAG;IACnD,GAAG,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;CAC9B,KACE,KAAK,CAAC,YAAY,CAAC;AA+exB,eAAO,MAAM,oBAAoB,EAAoC,wBAAwB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Popover.d.ts","sourceRoot":"","sources":["../../../src/overlays/popover/Popover.tsx"],"names":[],"mappings":"AACA,OAAO,KAAiD,MAAM,OAAO,CAAC;AAyBtE,OAAO,KAAK,EAAE,4BAA4B,EAAgB,MAAM,gBAAgB,CAAC;AAoBjF;;;;;;;;GAQG;AACH,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;mBAqDc,CAAC;;;;
|
|
1
|
+
{"version":3,"file":"Popover.d.ts","sourceRoot":"","sources":["../../../src/overlays/popover/Popover.tsx"],"names":[],"mappings":"AACA,OAAO,KAAiD,MAAM,OAAO,CAAC;AAyBtE,OAAO,KAAK,EAAE,4BAA4B,EAAgB,MAAM,gBAAgB,CAAC;AAoBjF;;;;;;;;GAQG;AACH,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;mBAqDc,CAAC;;;;wCAkJlC,CAAC"}
|
|
@@ -12,7 +12,6 @@ import { HelperText } from '../../controls/HelperText';
|
|
|
12
12
|
import { InputLabel } from '../../controls/InputLabel';
|
|
13
13
|
import { InputStack } from '../../controls/InputStack';
|
|
14
14
|
import { cx } from '../../cx';
|
|
15
|
-
import { useTheme } from '../../hooks/useTheme';
|
|
16
15
|
import { HStack } from '../../layout/HStack';
|
|
17
16
|
import { VStack } from '../../layout/VStack';
|
|
18
17
|
import { AnimatedCaret } from '../../motion/AnimatedCaret';
|
|
@@ -45,7 +44,7 @@ const DefaultSelectControlComponent = /*#__PURE__*/memo(/*#__PURE__*/forwardRef(
|
|
|
45
44
|
variant,
|
|
46
45
|
helperText,
|
|
47
46
|
label,
|
|
48
|
-
labelVariant,
|
|
47
|
+
labelVariant: labelVariantProp,
|
|
49
48
|
contentNode,
|
|
50
49
|
startNode,
|
|
51
50
|
endNode: customEndNode,
|
|
@@ -67,11 +66,13 @@ const DefaultSelectControlComponent = /*#__PURE__*/memo(/*#__PURE__*/forwardRef(
|
|
|
67
66
|
classNames
|
|
68
67
|
} = _ref,
|
|
69
68
|
props = _objectWithoutProperties(_ref, _excluded);
|
|
70
|
-
const theme = useTheme();
|
|
71
69
|
const isMultiSelect = type === 'multi';
|
|
70
|
+
// When compact, labelVariant is ignored
|
|
71
|
+
const labelVariant = compact ? undefined : labelVariantProp;
|
|
72
72
|
// horizontal/inline label is used for compact selesct exepct for multi-selects
|
|
73
73
|
// multi-selects render their label outside of the control unless labelVariant is set to 'inside'
|
|
74
74
|
const shouldShowCompactLabel = compact && label && !isMultiSelect;
|
|
75
|
+
const shouldShowInsideLabel = labelVariant === 'inside' && !compact && label;
|
|
75
76
|
const hasValue = value !== null && !(Array.isArray(value) && value.length === 0);
|
|
76
77
|
// Map of options to their values
|
|
77
78
|
// If multiple options share the same value, the first occurrence wins (matches native HTML select behavior)
|
|
@@ -158,27 +159,32 @@ const DefaultSelectControlComponent = /*#__PURE__*/memo(/*#__PURE__*/forwardRef(
|
|
|
158
159
|
style: styles === null || styles === void 0 ? void 0 : styles.controlHelperTextNode,
|
|
159
160
|
children: helperText
|
|
160
161
|
}) : helperText, [helperText, variant, classNames === null || classNames === void 0 ? void 0 : classNames.controlHelperTextNode, styles === null || styles === void 0 ? void 0 : styles.controlHelperTextNode]);
|
|
161
|
-
const labelNode = useMemo(() =>
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
162
|
+
const labelNode = useMemo(() => {
|
|
163
|
+
if (shouldShowInsideLabel || shouldShowCompactLabel) return null;
|
|
164
|
+
if (typeof label === 'string') {
|
|
165
|
+
return /*#__PURE__*/_jsx(InputLabel, {
|
|
166
|
+
className: classNames === null || classNames === void 0 ? void 0 : classNames.controlLabelNode,
|
|
167
|
+
color: "fg",
|
|
168
|
+
paddingY: 0.5,
|
|
169
|
+
style: styles === null || styles === void 0 ? void 0 : styles.controlLabelNode,
|
|
170
|
+
children: label
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
return label;
|
|
174
|
+
}, [shouldShowInsideLabel, shouldShowCompactLabel, classNames === null || classNames === void 0 ? void 0 : classNames.controlLabelNode, styles === null || styles === void 0 ? void 0 : styles.controlLabelNode, label]);
|
|
175
|
+
const inlineLabelNode = useMemo(() => {
|
|
176
|
+
if (!shouldShowInsideLabel && !shouldShowCompactLabel) return null;
|
|
177
|
+
if (typeof label === 'string') {
|
|
178
|
+
return /*#__PURE__*/_jsx(InputLabel, {
|
|
179
|
+
className: classNames === null || classNames === void 0 ? void 0 : classNames.controlLabelNode,
|
|
180
|
+
color: "fg",
|
|
181
|
+
paddingY: 0,
|
|
182
|
+
style: styles === null || styles === void 0 ? void 0 : styles.controlLabelNode,
|
|
183
|
+
children: label
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
return label;
|
|
187
|
+
}, [shouldShowInsideLabel, shouldShowCompactLabel, classNames === null || classNames === void 0 ? void 0 : classNames.controlLabelNode, styles === null || styles === void 0 ? void 0 : styles.controlLabelNode, label]);
|
|
182
188
|
const valueNode = useMemo(() => {
|
|
183
189
|
if (hasValue && isMultiSelect) {
|
|
184
190
|
const valuesToShow = value.length <= maxSelectedOptionsToShow ? value : value.slice(0, maxSelectedOptionsToShow);
|
|
@@ -262,8 +268,32 @@ const DefaultSelectControlComponent = /*#__PURE__*/memo(/*#__PURE__*/forwardRef(
|
|
|
262
268
|
}), shouldShowCompactLabel ? /*#__PURE__*/_jsx(HStack, {
|
|
263
269
|
alignItems: "center",
|
|
264
270
|
paddingEnd: 1,
|
|
265
|
-
children:
|
|
266
|
-
}) : null, /*#__PURE__*/
|
|
271
|
+
children: inlineLabelNode
|
|
272
|
+
}) : null, shouldShowInsideLabel ? /*#__PURE__*/_jsxs(VStack, {
|
|
273
|
+
flexGrow: 1,
|
|
274
|
+
minWidth: 0,
|
|
275
|
+
width: "100%",
|
|
276
|
+
children: [inlineLabelNode, /*#__PURE__*/_jsx(HStack, {
|
|
277
|
+
alignItems: "center",
|
|
278
|
+
flexGrow: 1,
|
|
279
|
+
minWidth: 0,
|
|
280
|
+
width: "100%",
|
|
281
|
+
children: /*#__PURE__*/_jsxs(VStack, {
|
|
282
|
+
ref: valueNodeContainerRef,
|
|
283
|
+
alignItems: align,
|
|
284
|
+
className: classNames === null || classNames === void 0 ? void 0 : classNames.controlValueNode,
|
|
285
|
+
flexGrow: 1,
|
|
286
|
+
flexShrink: 1,
|
|
287
|
+
flexWrap: "wrap",
|
|
288
|
+
gap: 1,
|
|
289
|
+
justifyContent: "flex-start",
|
|
290
|
+
minWidth: 0,
|
|
291
|
+
overflow: "hidden",
|
|
292
|
+
style: styles === null || styles === void 0 ? void 0 : styles.controlValueNode,
|
|
293
|
+
children: [valueNode, contentNode]
|
|
294
|
+
})
|
|
295
|
+
})]
|
|
296
|
+
}) : /*#__PURE__*/_jsx(HStack, {
|
|
267
297
|
alignItems: "center",
|
|
268
298
|
flexGrow: 1,
|
|
269
299
|
flexShrink: 1,
|
|
@@ -286,7 +316,7 @@ const DefaultSelectControlComponent = /*#__PURE__*/memo(/*#__PURE__*/forwardRef(
|
|
|
286
316
|
children: [valueNode, contentNode]
|
|
287
317
|
})
|
|
288
318
|
})]
|
|
289
|
-
}), [computedControlAccessibilityLabel, ariaHaspopup, open, role, interactableBlendStyles, classNames === null || classNames === void 0 ? void 0 : classNames.controlInputNode, classNames === null || classNames === void 0 ? void 0 : classNames.controlStartNode, classNames === null || classNames === void 0 ? void 0 : classNames.controlValueNode, disabled, styles === null || styles === void 0 ? void 0 : styles.controlInputNode, styles === null || styles === void 0 ? void 0 : styles.controlStartNode, styles === null || styles === void 0 ? void 0 : styles.controlValueNode, tabIndex, onKeyDown, startNode, shouldShowCompactLabel,
|
|
319
|
+
}), [computedControlAccessibilityLabel, ariaHaspopup, open, role, interactableBlendStyles, classNames === null || classNames === void 0 ? void 0 : classNames.controlInputNode, classNames === null || classNames === void 0 ? void 0 : classNames.controlStartNode, classNames === null || classNames === void 0 ? void 0 : classNames.controlValueNode, disabled, styles === null || styles === void 0 ? void 0 : styles.controlInputNode, styles === null || styles === void 0 ? void 0 : styles.controlStartNode, styles === null || styles === void 0 ? void 0 : styles.controlValueNode, tabIndex, onKeyDown, startNode, shouldShowCompactLabel, shouldShowInsideLabel, inlineLabelNode, align, valueNode, contentNode, setOpen]);
|
|
290
320
|
const endNode = useMemo(() => /*#__PURE__*/_jsx(Pressable, {
|
|
291
321
|
"aria-hidden": true,
|
|
292
322
|
flexShrink: 0,
|
|
@@ -307,13 +337,11 @@ const DefaultSelectControlComponent = /*#__PURE__*/memo(/*#__PURE__*/forwardRef(
|
|
|
307
337
|
})
|
|
308
338
|
}), [classNames === null || classNames === void 0 ? void 0 : classNames.controlEndNode, labelVariant, styles === null || styles === void 0 ? void 0 : styles.controlEndNode, customEndNode, open, variant, setOpen]);
|
|
309
339
|
const inputStackStyles = useMemo(() => ({
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
}
|
|
316
|
-
}), [compact, theme.space, labelVariant]);
|
|
340
|
+
paddingTop: compact || labelVariant === 'inside' ? 'var(--space-1)' : 'var(--space-2)',
|
|
341
|
+
paddingBottom: compact || labelVariant === 'inside' ? 'var(--space-1)' : 'var(--space-2)',
|
|
342
|
+
paddingLeft: 'var(--space-2)',
|
|
343
|
+
paddingRight: 'var(--space-2)'
|
|
344
|
+
}), [compact, labelVariant]);
|
|
317
345
|
return /*#__PURE__*/_jsx(InputStack, _objectSpread({
|
|
318
346
|
ref: ref,
|
|
319
347
|
blendStyles: interactableBlendStyles,
|
|
@@ -323,9 +351,11 @@ const DefaultSelectControlComponent = /*#__PURE__*/memo(/*#__PURE__*/forwardRef(
|
|
|
323
351
|
focusedBorderWidth: focusedBorderWidth,
|
|
324
352
|
helperTextNode: helperTextNode,
|
|
325
353
|
inputNode: inputNode,
|
|
326
|
-
labelNode:
|
|
354
|
+
labelNode: labelNode,
|
|
327
355
|
labelVariant: labelVariant,
|
|
328
|
-
styles:
|
|
356
|
+
styles: {
|
|
357
|
+
input: inputStackStyles
|
|
358
|
+
},
|
|
329
359
|
variant: variant
|
|
330
360
|
}, props));
|
|
331
361
|
}));
|
|
@@ -101,7 +101,8 @@ export const Popover = /*#__PURE__*/memo(/*#__PURE__*/forwardRef((_ref, ref) =>
|
|
|
101
101
|
}, [computedSkid, getOffsetGap, computedGap, isAutoPlacement, rawPlacement]);
|
|
102
102
|
const {
|
|
103
103
|
refs,
|
|
104
|
-
floatingStyles
|
|
104
|
+
floatingStyles,
|
|
105
|
+
placement
|
|
105
106
|
} = useFloating({
|
|
106
107
|
placement: isAutoPlacement ? undefined : rawPlacement,
|
|
107
108
|
strategy,
|
|
@@ -124,6 +125,7 @@ export const Popover = /*#__PURE__*/memo(/*#__PURE__*/forwardRef((_ref, ref) =>
|
|
|
124
125
|
}, []);
|
|
125
126
|
const memoizedContent = useMemo(() => /*#__PURE__*/_jsx("div", {
|
|
126
127
|
ref: refs.setFloating,
|
|
128
|
+
"data-placement": placement,
|
|
127
129
|
onClick: handleCaptureEvents,
|
|
128
130
|
onMouseDown: handleCaptureEvents,
|
|
129
131
|
style: _objectSpread(_objectSpread({}, floatingStyles), {}, {
|
|
@@ -145,7 +147,7 @@ export const Popover = /*#__PURE__*/memo(/*#__PURE__*/forwardRef((_ref, ref) =>
|
|
|
145
147
|
children: content
|
|
146
148
|
}))
|
|
147
149
|
})
|
|
148
|
-
}), [refs.setFloating,
|
|
150
|
+
}), [refs.setFloating, handleCaptureEvents, placement, floatingStyles, autoFocusDelay, disableAutoFocus, disableFocusTrap, disableTypeFocus, focusTabIndexElements, handleClose, respectNegativeTabIndex, restoreFocusOnUnmount, testID, controlledElementAccessibilityProps, content]);
|
|
149
151
|
const renderContent = hasHoverInteractions ? memoizedContent : /*#__PURE__*/_jsx(Box, {
|
|
150
152
|
"aria-label": accessibilityLabel,
|
|
151
153
|
"aria-modal": "true",
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@coinbase/cds-web",
|
|
3
|
-
"version": "9.1.
|
|
3
|
+
"version": "9.1.2",
|
|
4
4
|
"description": "Coinbase Design System - Web",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -215,7 +215,7 @@
|
|
|
215
215
|
"react-dom": "^18.0.0 || ~19.1.2"
|
|
216
216
|
},
|
|
217
217
|
"dependencies": {
|
|
218
|
-
"@coinbase/cds-common": "^9.1.
|
|
218
|
+
"@coinbase/cds-common": "^9.1.2",
|
|
219
219
|
"@coinbase/cds-icons": "^5.17.0",
|
|
220
220
|
"@coinbase/cds-illustrations": "^4.40.1",
|
|
221
221
|
"@coinbase/cds-lottie-files": "^3.3.4",
|