@deque/cauldron-react 4.3.0 → 4.4.0-canary.77fc2183

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.
@@ -2,7 +2,7 @@ import React, { InputHTMLAttributes, Ref } from 'react';
2
2
  export interface CheckboxProps extends InputHTMLAttributes<HTMLInputElement> {
3
3
  id: string;
4
4
  label: React.ReactNode;
5
- labelDescription?: string;
5
+ labelDescription?: React.ReactNode;
6
6
  error?: React.ReactNode;
7
7
  customIcon?: React.ReactNode;
8
8
  checkboxRef?: Ref<HTMLInputElement>;
@@ -4,6 +4,7 @@ interface Props extends SyntaxHighlighterProps {
4
4
  children: React.ReactNode;
5
5
  language?: 'javascript' | 'css' | 'html' | 'yaml';
6
6
  className?: string;
7
+ tabIndex?: number;
7
8
  }
8
9
  declare const Code: React.ComponentType<Props>;
9
10
  export default Code;
@@ -1,5 +1,6 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
+ import { IconType } from '../Icon';
3
4
  export interface PanelTriggerProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {
4
5
  children?: ((props: {
5
6
  open: boolean;
@@ -7,14 +8,18 @@ export interface PanelTriggerProps extends React.ButtonHTMLAttributes<HTMLButton
7
8
  open?: boolean;
8
9
  fullWidth?: string;
9
10
  onClick?: (e: React.MouseEvent<HTMLButtonElement>) => void;
11
+ iconExpanded?: IconType;
12
+ iconCollapsed?: IconType;
10
13
  }
11
- declare function PanelTrigger({ children, className, open, fullWidth, onClick, ...other }: PanelTriggerProps): JSX.Element;
14
+ declare function PanelTrigger({ children, className, open, fullWidth, onClick, iconExpanded, iconCollapsed, ...other }: PanelTriggerProps): JSX.Element;
12
15
  declare namespace PanelTrigger {
13
16
  var propTypes: {
14
17
  children: PropTypes.Requireable<string | number | boolean | {} | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
15
18
  open: PropTypes.Requireable<boolean>;
16
19
  onClick: PropTypes.Requireable<(...args: any[]) => any>;
17
20
  className: PropTypes.Requireable<string>;
21
+ iconExpanded: PropTypes.Requireable<string>;
22
+ iconCollapsed: PropTypes.Requireable<string>;
18
23
  };
19
24
  }
20
25
  declare const _default: React.MemoExoticComponent<typeof PanelTrigger>;
@@ -2,6 +2,6 @@
2
2
  * GENERATED CODE. DO NOT EDIT DIRECTLY!
3
3
  */
4
4
  /** IconType represents each valid icon type. */
5
- export declare type IconType = 'add-user' | 'arrow-circle-up' | 'arrow-circle-down' | 'arrow-circle-left' | 'arrow-circle-right' | 'arrow-up' | 'arrow-down' | 'arrow-left' | 'arrow-right' | 'arrows-alt' | 'bolt' | 'caution' | 'check-circle' | 'check-shield' | 'check-solid' | 'check' | 'checkbox-checked' | 'checkbox-unchecked' | 'chevron-double-up' | 'chevron-double-down' | 'chevron-double-left' | 'chevron-double-right' | 'chevron-up' | 'chevron-down' | 'chevron-left' | 'chevron-right' | 'close' | 'code' | 'copy' | 'download' | 'exchange' | 'external-link' | 'eye' | 'filter' | 'flag' | 'gears' | 'grid' | 'hamburger-menu' | 'highlight' | 'info-circle-alt' | 'info-circle' | 'info-square' | 'kabob' | 'list' | 'lock' | 'magnifying-glass' | 'menu' | 'minus' | 'new-releases' | 'new' | 'no' | 'pencil' | 'plus' | 'question-circle' | 'radio-checked' | 'radio-unchecked' | 'recycle' | 'resend' | 'robot' | 'run-again' | 'save' | 'share' | 'sort-triangle' | 'sort' | 'star' | 'sun' | 'tag' | 'target' | 'trash' | 'triangle-up' | 'triangle-down' | 'triangle-left' | 'triangle-right' | 'upload';
5
+ export declare type IconType = 'add-user' | 'arrow-circle-up' | 'arrow-circle-down' | 'arrow-circle-left' | 'arrow-circle-right' | 'arrow-up' | 'arrow-down' | 'arrow-left' | 'arrow-right' | 'arrows-alt' | 'bolt' | 'caution' | 'check-circle' | 'check-shield' | 'check-solid' | 'check' | 'checkbox-checked' | 'checkbox-unchecked' | 'chevron-double-up' | 'chevron-double-down' | 'chevron-double-left' | 'chevron-double-right' | 'chevron-up' | 'chevron-down' | 'chevron-left' | 'chevron-right' | 'close' | 'code' | 'copy' | 'download' | 'dropper' | 'exchange' | 'external-link' | 'eye' | 'filter' | 'flag' | 'gears' | 'grid' | 'hamburger-menu' | 'highlight' | 'info-circle-alt' | 'info-circle' | 'info-square' | 'kabob' | 'list' | 'lock' | 'magnifying-glass' | 'menu' | 'minus' | 'new-releases' | 'new' | 'no' | 'pencil' | 'plus' | 'question-circle' | 'radio-checked' | 'radio-unchecked' | 'recycle' | 'resend' | 'robot' | 'run-again' | 'save' | 'share' | 'sort-triangle' | 'sort' | 'star' | 'sun' | 'tag' | 'target' | 'trash' | 'triangle-up' | 'triangle-down' | 'triangle-left' | 'triangle-right' | 'upload';
6
6
  /** iconTypes holds each valid icon type. */
7
7
  export declare const iconTypes: string[];
@@ -1,9 +1,16 @@
1
+ /**
2
+ * Unfortunately, eslint does not recognize the Polymorphic component has propTypes set
3
+ *
4
+ * We might be able to remove this if we upgrade eslint and associated plugins
5
+ * See: https://github.com/dequelabs/cauldron/issues/451
6
+ */
7
+ import React from 'react';
1
8
  import * as Polymorphic from '../../utils/polymorphic-type';
2
9
  import { IconType } from '../Icon';
3
10
  import { TooltipProps } from '../Tooltip';
4
11
  export interface IconButtonOwnProps {
5
12
  icon: IconType;
6
- label: string;
13
+ label: React.ReactNode;
7
14
  tooltipPlacement?: TooltipProps['placement'];
8
15
  tooltipVariant?: TooltipProps['variant'];
9
16
  tooltipPortal?: TooltipProps['portal'];
@@ -4,6 +4,7 @@ interface LoaderOverlayProps extends React.HTMLAttributes<HTMLDivElement> {
4
4
  label?: string;
5
5
  focusOnInitialRender?: boolean;
6
6
  children?: React.ReactNode;
7
+ focusTrap?: boolean;
7
8
  }
8
9
  declare const LoaderOverlay: React.ForwardRefExoticComponent<LoaderOverlayProps & React.RefAttributes<HTMLDivElement>>;
9
10
  export default LoaderOverlay;
@@ -1,22 +1,13 @@
1
- import { HTMLAttributes, ReactElement, ReactNode } from 'react';
2
- import PropTypes from 'prop-types';
1
+ import React, { HTMLAttributes, ReactNode } from 'react';
3
2
  interface PanelProps extends HTMLAttributes<HTMLElement> {
4
3
  children: ReactNode;
5
- heading?: ReactElement<any> | {
4
+ heading?: ReactNode | {
6
5
  id?: string;
7
- text: ReactElement<any>;
6
+ text: ReactNode;
8
7
  level: number | undefined;
9
8
  };
10
9
  collapsed?: boolean;
11
10
  className?: string;
12
11
  }
13
- declare const Panel: {
14
- ({ children, collapsed, className, heading, ...other }: PanelProps): JSX.Element;
15
- displayName: string;
16
- propTypes: {
17
- children: PropTypes.Validator<string | number | boolean | {} | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
18
- heading: PropTypes.Requireable<string | number | boolean | {} | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
19
- className: PropTypes.Requireable<string>;
20
- };
21
- };
12
+ declare const Panel: React.ForwardRefExoticComponent<PanelProps & React.RefAttributes<HTMLElement>>;
22
13
  export default Panel;
@@ -1,9 +1,9 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  export interface RadioItem extends React.InputHTMLAttributes<HTMLInputElement> {
4
- label: string;
4
+ label: React.ReactNode;
5
5
  value?: string;
6
- labelDescription?: string;
6
+ labelDescription?: React.ReactNode;
7
7
  }
8
8
  export interface RadioGroupProps {
9
9
  name?: string;
@@ -1,11 +1,7 @@
1
- import React from 'react';
1
+ import { TableHTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
- interface TableProps {
4
- children: React.ReactNode;
5
- className?: string;
6
- }
7
3
  declare const Table: {
8
- ({ children, className, ...other }: TableProps): JSX.Element;
4
+ ({ children, className, ...other }: TableHTMLAttributes<HTMLTableElement>): JSX.Element;
9
5
  displayName: string;
10
6
  propTypes: {
11
7
  children: PropTypes.Validator<string | number | boolean | {} | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
@@ -1,11 +1,7 @@
1
- import React from 'react';
1
+ import { HTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
- interface TableBodyProps {
4
- children: React.ReactNode;
5
- className?: string;
6
- }
7
3
  declare const TableBody: {
8
- ({ children, className, ...other }: TableBodyProps): JSX.Element;
4
+ ({ children, className, ...other }: HTMLAttributes<HTMLTableSectionElement>): JSX.Element;
9
5
  displayName: string;
10
6
  propTypes: {
11
7
  children: PropTypes.Validator<string | number | boolean | {} | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
@@ -1,11 +1,7 @@
1
- import React, { TdHTMLAttributes } from 'react';
1
+ import { TdHTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
- interface TableCellProps extends TdHTMLAttributes<HTMLTableCellElement> {
4
- children: React.ReactNode;
5
- className?: string;
6
- }
7
3
  declare const TableCell: {
8
- ({ children, className, ...other }: TableCellProps): JSX.Element;
4
+ ({ children, className, ...other }: TdHTMLAttributes<HTMLTableCellElement>): JSX.Element;
9
5
  displayName: string;
10
6
  propTypes: {
11
7
  children: PropTypes.Validator<string | number | boolean | {} | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
@@ -1,11 +1,7 @@
1
- import React from 'react';
1
+ import { HTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
- interface TableHeadProps {
4
- children: React.ReactNode;
5
- className?: string;
6
- }
7
3
  declare const TableHead: {
8
- ({ children, className, ...other }: TableHeadProps): JSX.Element;
4
+ ({ children, className, ...other }: HTMLAttributes<HTMLTableSectionElement>): JSX.Element;
9
5
  displayName: string;
10
6
  propTypes: {
11
7
  children: PropTypes.Validator<string | number | boolean | {} | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
@@ -1,22 +1,22 @@
1
- import React, { ThHTMLAttributes } from 'react';
1
+ import { ThHTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  declare type SortDirection = 'ascending' | 'descending' | 'none';
4
4
  interface TableHeaderProps extends ThHTMLAttributes<HTMLTableCellElement> {
5
- children: React.ReactNode;
6
5
  sortDirection?: SortDirection;
7
6
  onSort?: () => void;
8
- className?: string;
9
7
  sortAscendingAnnouncement?: string;
10
- sortDescendingAnnouncemen?: string;
8
+ sortDescendingAnnouncement?: string;
11
9
  }
12
10
  declare const TableHeader: {
13
- ({ children, sortDirection, onSort, className, sortAscendingAnnouncement, sortDescendingAnnouncemen, ...other }: TableHeaderProps): JSX.Element;
11
+ ({ children, sortDirection, onSort, className, sortAscendingAnnouncement, sortDescendingAnnouncement, ...other }: TableHeaderProps): JSX.Element;
14
12
  displayName: string;
15
13
  propTypes: {
16
14
  children: PropTypes.Validator<string | number | boolean | {} | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
17
15
  sortDirection: PropTypes.Requireable<string>;
18
16
  onSort: PropTypes.Requireable<(...args: any[]) => any>;
19
17
  className: PropTypes.Requireable<string>;
18
+ sortAscendingAnnouncement: PropTypes.Requireable<string>;
19
+ sortDescendingAnnouncement: PropTypes.Requireable<string>;
20
20
  };
21
21
  };
22
22
  export default TableHeader;
@@ -1,11 +1,7 @@
1
- import React from 'react';
1
+ import { HTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
- interface TableRowProps {
4
- children: React.ReactNode;
5
- className?: string;
6
- }
7
3
  declare const TableRow: {
8
- ({ children, className, ...other }: TableRowProps): JSX.Element;
4
+ ({ children, className, ...other }: HTMLAttributes<HTMLTableRowElement>): JSX.Element;
9
5
  displayName: string;
10
6
  propTypes: {
11
7
  children: PropTypes.Validator<string | number | boolean | {} | PropTypes.ReactElementLike | PropTypes.ReactNodeArray>;
@@ -1,8 +1,10 @@
1
1
  import React from 'react';
2
+ import SkipLink from '../SkipLink';
2
3
  interface TwoColumnPanelProps extends React.HTMLAttributes<HTMLDivElement> {
3
4
  initialCollapsed?: boolean;
4
5
  showCollapsedPanelLabel?: string;
5
6
  hideCollapsedPanelLabel?: string;
7
+ skipLink?: SkipLink;
6
8
  }
7
9
  declare const TwoColumnPanel: React.ForwardRefExoticComponent<TwoColumnPanelProps & React.RefAttributes<HTMLDivElement>>;
8
10
  export default TwoColumnPanel;
package/lib/dropper.js ADDED
@@ -0,0 +1,24 @@
1
+ 'use strict';
2
+
3
+ function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
4
+
5
+ var React = require('react');
6
+ var React__default = _interopDefault(React);
7
+
8
+ var _path;
9
+
10
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
11
+
12
+ const SvgDropper = props => /*#__PURE__*/React.createElement("svg", _extends({
13
+ overflow: "visible",
14
+ preserveAspectRatio: "none",
15
+ viewBox: "0 0 24 24",
16
+ height: 24,
17
+ width: 24
18
+ }, props), _path || (_path = /*#__PURE__*/React.createElement("path", {
19
+ d: "m20.71 5.63-2.34-2.34a.996.996 0 0 0-1.41 0l-3.12 3.12-1.93-1.91-1.41 1.41 1.42 1.42L3 16.25V21h4.75l8.92-8.92 1.42 1.42 1.41-1.41-1.92-1.92 3.12-3.12c.4-.4.4-1.03.01-1.42zM6.92 19 5 17.08l8.06-8.06 1.92 1.92L6.92 19z",
20
+ fill: "currentColor",
21
+ vectorEffect: "non-scaling-stroke"
22
+ })));
23
+
24
+ exports.default = SvgDropper;
package/lib/index.js CHANGED
@@ -147,6 +147,7 @@ var iconTypes = [
147
147
  'code',
148
148
  'copy',
149
149
  'download',
150
+ 'dropper',
150
151
  'exchange',
151
152
  'external-link',
152
153
  'eye',
@@ -213,6 +214,7 @@ function __variableDynamicImportRuntime0__(path) {
213
214
  case './icons/code.svg': return Promise.resolve().then(function () { return require('./code.js'); });
214
215
  case './icons/copy.svg': return Promise.resolve().then(function () { return require('./copy.js'); });
215
216
  case './icons/download.svg': return Promise.resolve().then(function () { return require('./download.js'); });
217
+ case './icons/dropper.svg': return Promise.resolve().then(function () { return require('./dropper.js'); });
216
218
  case './icons/exchange.svg': return Promise.resolve().then(function () { return require('./exchange.js'); });
217
219
  case './icons/external-link.svg': return Promise.resolve().then(function () { return require('./external-link.js'); });
218
220
  case './icons/eye.svg': return Promise.resolve().then(function () { return require('./eye.js'); });
@@ -1663,13 +1665,6 @@ var IconButton = React.forwardRef(function (_a, ref) {
1663
1665
  accessibilityProps['aria-disabled'] = disabled;
1664
1666
  }
1665
1667
  }
1666
- React.useEffect(function () {
1667
- var _a;
1668
- if (!disabled) {
1669
- return;
1670
- }
1671
- (_a = internalRef.current) === null || _a === void 0 ? void 0 : _a.setAttribute('aria-label', label);
1672
- }, [disabled]);
1673
1668
  return (React__default.createElement(React__default.Fragment, null,
1674
1669
  React__default.createElement(Component, tslib.__assign({ className: classNames(className, {
1675
1670
  IconButton: true,
@@ -1677,7 +1672,8 @@ var IconButton = React.forwardRef(function (_a, ref) {
1677
1672
  'IconButton--secondary': variant === 'secondary',
1678
1673
  'IconButton--error': variant === 'error'
1679
1674
  }), ref: internalRef, disabled: disabled, tabIndex: disabled ? -1 : tabIndex }, accessibilityProps, other),
1680
- React__default.createElement(Icon, { type: icon })),
1675
+ React__default.createElement(Icon, { type: icon }),
1676
+ React__default.createElement(Offscreen, null, label)),
1681
1677
  !disabled && (React__default.createElement(Tooltip, { target: internalRef, placement: tooltipPlacement, variant: tooltipVariant, portal: tooltipPortal, association: "aria-labelledby", hideElementOnHidden: true }, label))));
1682
1678
  });
1683
1679
  IconButton.propTypes = {
@@ -1685,7 +1681,7 @@ IconButton.propTypes = {
1685
1681
  as: PropTypes.elementType,
1686
1682
  // @ts-expect-error
1687
1683
  icon: PropTypes.string.isRequired,
1688
- label: PropTypes.string.isRequired,
1684
+ label: PropTypes.node.isRequired,
1689
1685
  // @ts-expect-error
1690
1686
  tooltipPlacement: PropTypes.string,
1691
1687
  // @ts-expect-error
@@ -2360,7 +2356,7 @@ var RadioGroup = function (_a) {
2360
2356
  var _a;
2361
2357
  handleChange(radioValue);
2362
2358
  onChange(radio, (_a = inputs.current) === null || _a === void 0 ? void 0 : _a[index]);
2363
- }, disabled: disabled, checked: isChecked, "aria-describedby": labelDescription && id + "Desc" }, other)),
2359
+ }, disabled: disabled, checked: isChecked, "aria-describedby": labelDescription ? id + "Desc" : undefined }, other)),
2364
2360
  React__default.createElement("label", { htmlFor: id, className: classNames('Field__label', {
2365
2361
  'Field__label--disabled': disabled
2366
2362
  }) }, label),
@@ -2600,16 +2596,18 @@ var TextField = /** @class */ (function (_super) {
2600
2596
  }(React__default.Component));
2601
2597
 
2602
2598
  function PanelTrigger(_a) {
2603
- var children = _a.children, className = _a.className, open = _a.open, fullWidth = _a.fullWidth, onClick = _a.onClick, other = tslib.__rest(_a, ["children", "className", "open", "fullWidth", "onClick"]);
2599
+ var children = _a.children, className = _a.className, open = _a.open, fullWidth = _a.fullWidth, onClick = _a.onClick, _b = _a.iconExpanded, iconExpanded = _b === void 0 ? 'chevron-down' : _b, _c = _a.iconCollapsed, iconCollapsed = _c === void 0 ? 'chevron-right' : _c, other = tslib.__rest(_a, ["children", "className", "open", "fullWidth", "onClick", "iconExpanded", "iconCollapsed"]);
2604
2600
  return (React__default.createElement("button", tslib.__assign({}, other, { className: classNames('ExpandCollapse__trigger', fullWidth ? 'fullWidth' : '', className), type: "button", "aria-expanded": open, onClick: onClick }),
2605
2601
  React__default.createElement("div", { className: "ExpandCollapse__trigger-title" }, typeof children === 'function' ? children({ open: !!open }) : children),
2606
- React__default.createElement(Icon, { type: open ? 'chevron-down' : 'chevron-right' })));
2602
+ React__default.createElement(Icon, { type: open ? iconExpanded : iconCollapsed })));
2607
2603
  }
2608
2604
  PanelTrigger.propTypes = {
2609
2605
  children: PropTypes.oneOfType([PropTypes.func, PropTypes.node]),
2610
2606
  open: PropTypes.bool,
2611
2607
  onClick: PropTypes.func,
2612
- className: PropTypes.string
2608
+ className: PropTypes.string,
2609
+ iconExpanded: PropTypes.string,
2610
+ iconCollapsed: PropTypes.string
2613
2611
  };
2614
2612
  var PanelTrigger$1 = React__default.memo(PanelTrigger);
2615
2613
 
@@ -7984,8 +7982,8 @@ SyntaxHighlighter.registerLanguage('css', css_1);
7984
7982
  SyntaxHighlighter.registerLanguage('html', xml_1);
7985
7983
  SyntaxHighlighter.registerLanguage('yaml', yaml_1);
7986
7984
  var Code = function (_a) {
7987
- var children = _a.children, className = _a.className, props = tslib.__rest(_a, ["children", "className"]);
7988
- return (React__default.createElement(SyntaxHighlighter, tslib.__assign({}, props, { useInlineStyles: false, className: classNames('Code', className) }), children));
7985
+ var children = _a.children, className = _a.className, tabIndex = _a.tabIndex, props = tslib.__rest(_a, ["children", "className", "tabIndex"]);
7986
+ return (React__default.createElement(SyntaxHighlighter, tslib.__assign({}, props, { useInlineStyles: false, className: classNames('Code', className), tabIndex: tabIndex }), children));
7989
7987
  };
7990
7988
  Code.displayName = 'Code';
7991
7989
  Code.propTypes = {
@@ -8023,7 +8021,7 @@ function useSharedRef(ref) {
8023
8021
  }
8024
8022
 
8025
8023
  var LoaderOverlay = React.forwardRef(function (_a, ref) {
8026
- var className = _a.className, variant = _a.variant, label = _a.label, children = _a.children, focusOnInitialRender = _a.focusOnInitialRender, other = tslib.__rest(_a, ["className", "variant", "label", "children", "focusOnInitialRender"]);
8024
+ var className = _a.className, variant = _a.variant, label = _a.label, children = _a.children, focusOnInitialRender = _a.focusOnInitialRender, _b = _a.focusTrap, focusTrap = _b === void 0 ? false : _b, other = tslib.__rest(_a, ["className", "variant", "label", "children", "focusOnInitialRender", "focusTrap"]);
8027
8025
  var overlayRef = useSharedRef(ref);
8028
8026
  React.useEffect(function () {
8029
8027
  if (!!focusOnInitialRender && overlayRef.current) {
@@ -8034,16 +8032,25 @@ var LoaderOverlay = React.forwardRef(function (_a, ref) {
8034
8032
  }
8035
8033
  return;
8036
8034
  }, [overlayRef.current]);
8037
- return (React__default.createElement("div", tslib.__assign({ className: classNames('Loader__overlay', className, variant === 'large'
8038
- ? 'Loader__overlay--large'
8039
- : variant === 'small'
8040
- ? 'Loader__overlay--small'
8041
- : ''), ref: overlayRef, tabIndex: -1 }, other),
8042
- React__default.createElement("div", { className: "Loader__overlay__loader" },
8043
- React__default.createElement(Loader, { variant: variant }),
8044
- React__default.createElement(AxeLoader, null)),
8045
- label ? React__default.createElement("span", { className: "Loader__overlay__label" }, label) : null,
8046
- children));
8035
+ var Wrapper = focusTrap ? FocusTrap : React__default.Fragment;
8036
+ var wrapperProps = focusTrap
8037
+ ? {
8038
+ focusTrapOptions: {
8039
+ fallbackFocus: '.Loader__overlay'
8040
+ }
8041
+ }
8042
+ : {};
8043
+ return (React__default.createElement(Wrapper, tslib.__assign({}, wrapperProps),
8044
+ React__default.createElement("div", tslib.__assign({ className: classNames('Loader__overlay', className, variant === 'large'
8045
+ ? 'Loader__overlay--large'
8046
+ : variant === 'small'
8047
+ ? 'Loader__overlay--small'
8048
+ : ''), ref: overlayRef, tabIndex: -1 }, other),
8049
+ React__default.createElement("div", { className: "Loader__overlay__loader" },
8050
+ React__default.createElement(Loader, { variant: variant }),
8051
+ React__default.createElement(AxeLoader, null)),
8052
+ label ? (React__default.createElement("span", { className: "Loader__overlay__label" }, label)) : null,
8053
+ children)));
8047
8054
  });
8048
8055
  LoaderOverlay.propTypes = {
8049
8056
  className: PropTypes.string,
@@ -8123,18 +8130,15 @@ TableHead.propTypes = {
8123
8130
  };
8124
8131
 
8125
8132
  var TableHeader = function (_a) {
8126
- var children = _a.children, sortDirection = _a.sortDirection, onSort = _a.onSort, className = _a.className, _b = _a.sortAscendingAnnouncement, sortAscendingAnnouncement = _b === void 0 ? 'sorted ascending' : _b, _c = _a.sortDescendingAnnouncemen, sortDescendingAnnouncemen = _c === void 0 ? 'sorted descending' : _c, other = tslib.__rest(_a, ["children", "sortDirection", "onSort", "className", "sortAscendingAnnouncement", "sortDescendingAnnouncemen"]);
8133
+ var children = _a.children, sortDirection = _a.sortDirection, onSort = _a.onSort, className = _a.className, _b = _a.sortAscendingAnnouncement, sortAscendingAnnouncement = _b === void 0 ? 'sorted ascending' : _b, _c = _a.sortDescendingAnnouncement, sortDescendingAnnouncement = _c === void 0 ? 'sorted descending' : _c, other = tslib.__rest(_a, ["children", "sortDirection", "onSort", "className", "sortAscendingAnnouncement", "sortDescendingAnnouncement"]);
8127
8134
  // When the sort direction changes, we want to announce the change in a live region
8128
8135
  // because changes to the sort value is not widely supported yet
8129
8136
  // see: https://a11ysupport.io/tech/aria/aria-sort_attribute
8130
- var _d = tslib.__read(React.useState(''), 2), announcement = _d[0], setAnnouncement = _d[1];
8131
- React.useEffect(function () {
8132
- if (sortDirection !== 'none') {
8133
- setAnnouncement(sortDirection === 'ascending'
8134
- ? sortAscendingAnnouncement
8135
- : sortDescendingAnnouncemen);
8136
- }
8137
- }, [sortDirection]);
8137
+ var announcement = sortDirection === 'ascending'
8138
+ ? sortAscendingAnnouncement
8139
+ : sortDirection === 'descending'
8140
+ ? sortDescendingAnnouncement
8141
+ : '';
8138
8142
  return (React__default.createElement("th", tslib.__assign({ "aria-sort": sortDirection, className: classNames('TableHeader', className, {
8139
8143
  'TableHeader--sort-ascending': sortDirection === 'ascending',
8140
8144
  'TableHeader--sort-descending': sortDirection === 'descending'
@@ -8149,7 +8153,9 @@ TableHeader.propTypes = {
8149
8153
  children: PropTypes.node.isRequired,
8150
8154
  sortDirection: PropTypes.string,
8151
8155
  onSort: PropTypes.func,
8152
- className: PropTypes.string
8156
+ className: PropTypes.string,
8157
+ sortAscendingAnnouncement: PropTypes.string,
8158
+ sortDescendingAnnouncement: PropTypes.string
8153
8159
  };
8154
8160
 
8155
8161
  var TableRow = function (_a) {
@@ -8385,7 +8391,7 @@ Stepper.propTypes = {
8385
8391
  className: PropTypes.string
8386
8392
  };
8387
8393
 
8388
- var Panel = function (_a) {
8394
+ var Panel = React.forwardRef(function (_a, ref) {
8389
8395
  var _b;
8390
8396
  var children = _a.children, collapsed = _a.collapsed, className = _a.className, heading = _a.heading, other = tslib.__rest(_a, ["children", "collapsed", "className", "heading"]);
8391
8397
  var headingId = !heading
@@ -8397,19 +8403,22 @@ var Panel = function (_a) {
8397
8403
  if (!headingId) {
8398
8404
  return null;
8399
8405
  }
8400
- var HeadingComponent = "h" + (typeof heading === 'object' && 'level' in heading && !!heading.level
8406
+ var HeadingComponent = "h" + (heading &&
8407
+ typeof heading === 'object' &&
8408
+ 'level' in heading &&
8409
+ !!heading.level
8401
8410
  ? heading.level
8402
8411
  : 2);
8403
- return (React__default.createElement(HeadingComponent, { id: headingId, className: "Panel__Heading" }, typeof heading === 'object' && 'text' in heading
8412
+ return (React__default.createElement(HeadingComponent, { id: headingId, className: "Panel__Heading" }, heading && typeof heading === 'object' && 'text' in heading
8404
8413
  ? heading.text
8405
8414
  : heading));
8406
8415
  };
8407
8416
  return (React__default.createElement("section", tslib.__assign({ "aria-labelledby": headingId, className: classNames('Panel', className, (_b = {},
8408
8417
  _b['Panel--collapsed'] = collapsed,
8409
- _b)) }, other),
8418
+ _b)), ref: ref }, other),
8410
8419
  React__default.createElement(Heading, null),
8411
8420
  children));
8412
- };
8421
+ });
8413
8422
  Panel.displayName = 'Panel';
8414
8423
  Panel.propTypes = {
8415
8424
  children: PropTypes.node.isRequired,
@@ -8556,11 +8565,23 @@ var BreadcrumbLink = React.forwardRef(function (_a, ref) {
8556
8565
  return (React__default.createElement(ElementType, tslib.__assign({ className: classNames('Link', 'Breadcrumb__Link', className), ref: ref }, props), children));
8557
8566
  });
8558
8567
 
8568
+ var ColumnLeft = React.forwardRef(function (_a, ref) {
8569
+ var className = _a.className, children = _a.children, props = tslib.__rest(_a, ["className", "children"]);
8570
+ return (React__default.createElement("section", tslib.__assign({ className: classNames('TwoColumnPanel__Left', className) }, props, { ref: ref }), children));
8571
+ });
8572
+ ColumnLeft.displayName = 'ColumnLeft';
8573
+
8574
+ var ColumnRight = React.forwardRef(function (_a, ref) {
8575
+ var className = _a.className, children = _a.children, props = tslib.__rest(_a, ["className", "children"]);
8576
+ return (React__default.createElement("section", tslib.__assign({ className: classNames('TwoColumnPanel__Right', className) }, props, { ref: ref }), children));
8577
+ });
8578
+ ColumnRight.displayName = 'ColumnRight';
8579
+
8559
8580
  var TwoColumnPanel = React.forwardRef(function (_a, ref) {
8560
- var className = _a.className, children = _a.children, _b = _a.initialCollapsed, initialCollapsed = _b === void 0 ? false : _b, _c = _a.showCollapsedPanelLabel, showCollapsedPanelLabel = _c === void 0 ? 'Show Panel' : _c, _d = _a.hideCollapsedPanelLabel, hideCollapsedPanelLabel = _d === void 0 ? 'Hide Panel' : _d, props = tslib.__rest(_a, ["className", "children", "initialCollapsed", "showCollapsedPanelLabel", "hideCollapsedPanelLabel"]);
8561
- var _e = tslib.__read(React.useState(initialCollapsed), 2), isCollapsed = _e[0], setCollapsed = _e[1];
8562
- var _f = tslib.__read(React.useState(false), 2), isFocusTrap = _f[0], setIsFocusTrap = _f[1];
8563
- var _g = tslib.__read(React.useState(!initialCollapsed), 2), showPanel = _g[0], setShowPanel = _g[1];
8581
+ var className = _a.className, children = _a.children, _b = _a.initialCollapsed, initialCollapsed = _b === void 0 ? false : _b, _c = _a.showCollapsedPanelLabel, showCollapsedPanelLabel = _c === void 0 ? 'Show Panel' : _c, _d = _a.hideCollapsedPanelLabel, hideCollapsedPanelLabel = _d === void 0 ? 'Hide Panel' : _d, _e = _a.skipLink, skipLink = _e === void 0 ? null : _e, props = tslib.__rest(_a, ["className", "children", "initialCollapsed", "showCollapsedPanelLabel", "hideCollapsedPanelLabel", "skipLink"]);
8582
+ var _f = tslib.__read(React.useState(initialCollapsed), 2), isCollapsed = _f[0], setCollapsed = _f[1];
8583
+ var _g = tslib.__read(React.useState(false), 2), isFocusTrap = _g[0], setIsFocusTrap = _g[1];
8584
+ var _h = tslib.__read(React.useState(!initialCollapsed), 2), showPanel = _h[0], setShowPanel = _h[1];
8564
8585
  var togglePanel = function () {
8565
8586
  if (isCollapsed) {
8566
8587
  setShowPanel(true);
@@ -8687,6 +8708,7 @@ var TwoColumnPanel = React.forwardRef(function (_a, ref) {
8687
8708
  fallbackFocus: columnLeftRef.current
8688
8709
  }, containerElements: [columnLeftRef.current] }),
8689
8710
  React__default.createElement(ClickOutsideListener, { onClickOutside: handleClickOutside, target: columnLeftRef.current }),
8711
+ isCollapsed ? null : skipLink,
8690
8712
  showPanel ? ColumnLeftComponent : null,
8691
8713
  ColumnRightComponent));
8692
8714
  });
@@ -8704,18 +8726,6 @@ var ColumnGroupHeader = React.forwardRef(function (_a, ref) {
8704
8726
  });
8705
8727
  ColumnGroupHeader.displayName = 'ColumnGroupHeader';
8706
8728
 
8707
- var ColumnLeft = React.forwardRef(function (_a, ref) {
8708
- var className = _a.className, children = _a.children, props = tslib.__rest(_a, ["className", "children"]);
8709
- return (React__default.createElement("section", tslib.__assign({ className: classNames('TwoColumnPanel__Left', className) }, props, { ref: ref }), children));
8710
- });
8711
- ColumnLeft.displayName = 'ColumnLeft';
8712
-
8713
- var ColumnRight = React.forwardRef(function (_a, ref) {
8714
- var className = _a.className, children = _a.children, props = tslib.__rest(_a, ["className", "children"]);
8715
- return (React__default.createElement("section", tslib.__assign({ className: classNames('TwoColumnPanel__Right', className) }, props, { ref: ref }), children));
8716
- });
8717
- ColumnRight.displayName = 'ColumnRight';
8718
-
8719
8729
  var ColumnList = React.forwardRef(function (_a, ref) {
8720
8730
  var className = _a.className, children = _a.children, props = tslib.__rest(_a, ["className", "children"]);
8721
8731
  return (React__default.createElement("div", tslib.__assign({ className: classNames('TwoColumnPanel__List', className) }, props, { ref: ref }), children));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@deque/cauldron-react",
3
- "version": "4.3.0",
3
+ "version": "4.4.0-canary.77fc2183",
4
4
  "description": "Fully accessible react components library for Deque Cauldron",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -124,4 +124,4 @@
124
124
  "\\.svg$": "<rootDir>/__tests__/svgMock.js"
125
125
  }
126
126
  }
127
- }
127
+ }