@carbon/react 1.93.0 → 1.94.0-rc.0

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 (37) hide show
  1. package/.playwright/INTERNAL_AVT_REPORT_DO_NOT_USE.json +923 -923
  2. package/es/components/CodeSnippet/CodeSnippet.d.ts +1 -1
  3. package/es/components/Copy/Copy.d.ts +1 -1
  4. package/es/components/CopyButton/CopyButton.d.ts +1 -1
  5. package/es/components/DataTable/DataTable.d.ts +1 -1
  6. package/es/components/DataTable/Table.d.ts +1 -1
  7. package/es/components/DataTable/Table.js +2 -21
  8. package/es/components/DataTable/TableToolbar.js +1 -0
  9. package/es/components/DataTable/state/sorting.d.ts +4 -2
  10. package/es/components/DatePicker/DatePicker.d.ts +8 -0
  11. package/es/components/DatePicker/DatePicker.js +22 -8
  12. package/es/components/FluidComboBox/FluidComboBox.d.ts +0 -5
  13. package/es/components/FluidComboBox/FluidComboBox.js +0 -5
  14. package/es/components/Slider/Slider.js +1 -1
  15. package/es/components/Tabs/Tabs.js +3 -45
  16. package/es/components/TreeView/TreeNode.js +5 -0
  17. package/es/components/UIShell/Content.d.ts +1 -1
  18. package/es/tools/events.d.ts +1 -1
  19. package/lib/components/CodeSnippet/CodeSnippet.d.ts +1 -1
  20. package/lib/components/Copy/Copy.d.ts +1 -1
  21. package/lib/components/CopyButton/CopyButton.d.ts +1 -1
  22. package/lib/components/DataTable/DataTable.d.ts +1 -1
  23. package/lib/components/DataTable/Table.d.ts +1 -1
  24. package/lib/components/DataTable/Table.js +1 -20
  25. package/lib/components/DataTable/TableToolbar.js +1 -0
  26. package/lib/components/DataTable/state/sorting.d.ts +4 -2
  27. package/lib/components/DatePicker/DatePicker.d.ts +8 -0
  28. package/lib/components/DatePicker/DatePicker.js +22 -8
  29. package/lib/components/FluidComboBox/FluidComboBox.d.ts +0 -5
  30. package/lib/components/FluidComboBox/FluidComboBox.js +0 -5
  31. package/lib/components/Slider/Slider.js +1 -1
  32. package/lib/components/Tabs/Tabs.js +2 -44
  33. package/lib/components/TreeView/TreeNode.js +5 -0
  34. package/lib/components/UIShell/Content.d.ts +1 -1
  35. package/lib/tools/events.d.ts +1 -1
  36. package/package.json +4 -4
  37. package/telemetry.yml +2 -0
@@ -26,7 +26,6 @@ var useControllableState = require('../../internal/useControllableState.js');
26
26
  var useId = require('../../internal/useId.js');
27
27
  var useIsomorphicEffect = require('../../internal/useIsomorphicEffect.js');
28
28
  var useMergedRefs = require('../../internal/useMergedRefs.js');
29
- var useNoInteractiveChildren = require('../../internal/useNoInteractiveChildren.js');
30
29
  var usePrefix = require('../../internal/usePrefix.js');
31
30
  var keys = require('../../internal/keyboard/keys.js');
32
31
  var match = require('../../internal/keyboard/match.js');
@@ -1112,10 +1111,6 @@ const TabPanel = /*#__PURE__*/React.forwardRef(({
1112
1111
  ...rest
1113
1112
  }, forwardRef) => {
1114
1113
  const prefix = usePrefix.usePrefix();
1115
- const panel = React.useRef(null);
1116
- const ref = useMergedRefs.useMergedRefs([forwardRef, panel]);
1117
- const [tabIndex, setTabIndex] = React.useState(0);
1118
- const [interactiveContent, setInteractiveContent] = React.useState(false);
1119
1114
  const {
1120
1115
  selectedIndex,
1121
1116
  baseId
@@ -1123,50 +1118,13 @@ const TabPanel = /*#__PURE__*/React.forwardRef(({
1123
1118
  const index = React.useContext(TabPanelContext);
1124
1119
  const id = `${baseId}-tabpanel-${index}`;
1125
1120
  const tabId = `${baseId}-tab-${index}`;
1126
- const className = cx(`${prefix}--tab-content`, customClassName, {
1127
- [`${prefix}--tab-content--interactive`]: interactiveContent
1128
- });
1129
- React.useEffect(() => {
1130
- if (!panel.current) {
1131
- return;
1132
- }
1133
- const content = useNoInteractiveChildren.getInteractiveContent(panel.current);
1134
- if (content) {
1135
- setInteractiveContent(true);
1136
- setTabIndex(-1);
1137
- }
1138
- }, []);
1139
-
1140
- // tabindex should only be 0 if no interactive content in children
1141
- React.useEffect(() => {
1142
- const node = panel.current;
1143
- if (!node) {
1144
- return;
1145
- }
1146
- function callback() {
1147
- const content = useNoInteractiveChildren.getInteractiveContent(node);
1148
- if (content) {
1149
- setInteractiveContent(true);
1150
- setTabIndex(-1);
1151
- } else {
1152
- setInteractiveContent(false);
1153
- setTabIndex(0);
1154
- }
1155
- }
1156
- const observer = new MutationObserver(callback);
1157
- observer.observe(node, {
1158
- childList: true,
1159
- subtree: true
1160
- });
1161
- return () => observer.disconnect();
1162
- }, []);
1121
+ const className = cx(`${prefix}--tab-content`, customClassName);
1163
1122
  return /*#__PURE__*/React.createElement("div", _rollupPluginBabelHelpers.extends({}, rest, {
1164
1123
  "aria-labelledby": tabId,
1165
1124
  id: id,
1166
1125
  className: className,
1167
- ref: ref,
1126
+ ref: forwardRef,
1168
1127
  role: "tabpanel",
1169
- tabIndex: tabIndex,
1170
1128
  hidden: selectedIndex !== index
1171
1129
  }), children);
1172
1130
  });
@@ -146,6 +146,7 @@ const TreeNode = /*#__PURE__*/React.forwardRef(({
146
146
  const currentNode = React.useRef(null);
147
147
  const currentNodeLabel = React.useRef(null);
148
148
  const prefix = usePrefix.usePrefix();
149
+ const nodeLabelId = `${id}__label`;
149
150
  const renderLabelText = () => {
150
151
  if (isEllipsisApplied && tooltipText) {
151
152
  return /*#__PURE__*/React.createElement(index$1.IconButton, {
@@ -156,11 +157,13 @@ const TreeNode = /*#__PURE__*/React.forwardRef(({
156
157
  className: `${prefix}--tree-node__label__text-button`,
157
158
  wrapperClasses: `${prefix}--popover-container`
158
159
  }, /*#__PURE__*/React.createElement("span", {
160
+ id: nodeLabelId,
159
161
  ref: labelTextRef,
160
162
  className: `${prefix}--tree-node__label__text`
161
163
  }, label));
162
164
  }
163
165
  return /*#__PURE__*/React.createElement("span", {
166
+ id: nodeLabelId,
164
167
  ref: labelTextRef,
165
168
  className: `${prefix}--tree-node__label__text`
166
169
  }, label);
@@ -399,6 +402,7 @@ const TreeNode = /*#__PURE__*/React.forwardRef(({
399
402
  }), nodeContent), children && /*#__PURE__*/React.createElement("ul", {
400
403
  id: `${id}-subtree`,
401
404
  role: "group",
405
+ "aria-labelledby": nodeLabelId,
402
406
  className: cx(`${prefix}--tree-node__children`, {
403
407
  [`${prefix}--tree-node--hidden`]: !expanded
404
408
  })
@@ -412,6 +416,7 @@ const TreeNode = /*#__PURE__*/React.forwardRef(({
412
416
  }), nodeContent, children && /*#__PURE__*/React.createElement("ul", {
413
417
  id: `${id}-subtree`,
414
418
  role: "group",
419
+ "aria-labelledby": nodeLabelId,
415
420
  className: cx(`${prefix}--tree-node__children`, {
416
421
  [`${prefix}--tree-node--hidden`]: !expanded
417
422
  })
@@ -69,7 +69,7 @@ declare const Content: {
69
69
  results?: number | undefined;
70
70
  security?: string | undefined;
71
71
  unselectable?: "on" | "off" | undefined;
72
- popover?: "" | "auto" | "manual" | undefined;
72
+ popover?: "" | "auto" | "manual" | "hint" | undefined;
73
73
  popoverTargetAction?: "toggle" | "show" | "hide" | undefined;
74
74
  popoverTarget?: string | undefined;
75
75
  inert?: boolean | undefined;
@@ -14,4 +14,4 @@ import type { SyntheticEvent } from 'react';
14
14
  * @param handlers - An array of event handler functions.
15
15
  * @returns A composite event handler.
16
16
  */
17
- export declare const composeEventHandlers: <E extends SyntheticEvent = SyntheticEvent<Element, Event>>(handlers: (((event: E, ...args: any[]) => void) | undefined)[]) => (event: E, ...args: any[]) => void;
17
+ export declare const composeEventHandlers: <E extends SyntheticEvent = SyntheticEvent>(handlers: (((event: E, ...args: any[]) => void) | undefined)[]) => (event: E, ...args: any[]) => void;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@carbon/react",
3
3
  "description": "React components for the Carbon Design System",
4
- "version": "1.93.0",
4
+ "version": "1.94.0-rc.0",
5
5
  "license": "Apache-2.0",
6
6
  "main": "lib/index.js",
7
7
  "types": "lib/index.d.ts",
@@ -53,9 +53,9 @@
53
53
  "dependencies": {
54
54
  "@babel/runtime": "^7.27.3",
55
55
  "@carbon/feature-flags": "^0.31.0",
56
- "@carbon/icons-react": "^11.69.0",
56
+ "@carbon/icons-react": "^11.70.0-rc.0",
57
57
  "@carbon/layout": "^11.43.0",
58
- "@carbon/styles": "^1.92.0",
58
+ "@carbon/styles": "^1.93.0-rc.0",
59
59
  "@carbon/utilities": "^0.11.0",
60
60
  "@floating-ui/react": "^0.27.4",
61
61
  "@ibm/telemetry-js": "^1.5.0",
@@ -139,5 +139,5 @@
139
139
  "**/*.scss",
140
140
  "**/*.css"
141
141
  ],
142
- "gitHead": "c17cce753e36124e6e8e02daba97ae9d4decbcc3"
142
+ "gitHead": "dff507858b43de91b300a98fa1bec24d38aaeb48"
143
143
  }
package/telemetry.yml CHANGED
@@ -314,7 +314,9 @@ collect:
314
314
  - enable
315
315
  - maxDate
316
316
  - minDate
317
+ - nextMonthAriaLabel
317
318
  - parseDate
319
+ - prevMonthAriaLabel
318
320
  - short
319
321
  # DatePickerSkeleton
320
322
  - range