@deque/cauldron-react 6.27.0-canary.7fd2f1e5 → 6.27.0-canary.a988b4ae

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.
@@ -6,6 +6,7 @@ interface DialogContextValue {
6
6
  onClose: () => void;
7
7
  forceAction: boolean;
8
8
  closeButtonText: string;
9
+ scrollable: boolean;
9
10
  }
10
11
  declare const DialogContext: React.Context<DialogContextValue | null>;
11
12
  declare function useDialogContext(): DialogContextValue;
@@ -12,6 +12,7 @@ export interface DialogProps extends React.HTMLAttributes<HTMLDivElement> {
12
12
  };
13
13
  closeButtonText?: string;
14
14
  portal?: React.RefObject<HTMLElement> | HTMLElement;
15
+ scrollable?: boolean;
15
16
  }
16
17
  declare const Dialog: React.ForwardRefExoticComponent<DialogProps & React.RefAttributes<HTMLDivElement>>;
17
18
  export default Dialog;
@@ -2,8 +2,9 @@ import React from 'react';
2
2
  import { DialogProps } from '../Dialog';
3
3
  interface ModalProps extends Omit<DialogProps, 'forceAction'> {
4
4
  variant?: 'info';
5
+ scrollable?: boolean;
5
6
  }
6
- declare const Modal: ({ children, className, variant, ...other }: ModalProps) => React.JSX.Element;
7
+ declare const Modal: ({ children, className, variant, scrollable, ...other }: ModalProps) => React.JSX.Element;
7
8
  declare const ModalHeader: {
8
9
  ({ children, className, ...other }: import("../Dialog").DialogHeaderProps): React.JSX.Element;
9
10
  displayName: string;
package/lib/index.js CHANGED
@@ -1532,9 +1532,9 @@ var isEscape = function (event) {
1532
1532
  return event.key === 'Escape' || event.key === 'Esc' || event.keyCode === 27;
1533
1533
  };
1534
1534
  var Dialog = React.forwardRef(function (_a, ref) {
1535
- var dialogRefProp = _a.dialogRef, _b = _a.forceAction, forceAction = _b === void 0 ? false : _b, className = _a.className, children = _a.children, _c = _a.closeButtonText, closeButtonText = _c === void 0 ? 'Close' : _c, heading = _a.heading, _d = _a.show, show = _d === void 0 ? false : _d, portal = _a.portal, _e = _a.onClose, onClose = _e === void 0 ? function () { return null; } : _e, other = tslib.__rest(_a, ["dialogRef", "forceAction", "className", "children", "closeButtonText", "heading", "show", "portal", "onClose"]);
1535
+ var dialogRefProp = _a.dialogRef, _b = _a.forceAction, forceAction = _b === void 0 ? false : _b, className = _a.className, children = _a.children, _c = _a.closeButtonText, closeButtonText = _c === void 0 ? 'Close' : _c, heading = _a.heading, _d = _a.show, show = _d === void 0 ? false : _d, portal = _a.portal, _e = _a.scrollable, scrollable = _e === void 0 ? false : _e, _f = _a.onClose, onClose = _f === void 0 ? function () { return null; } : _f, other = tslib.__rest(_a, ["dialogRef", "forceAction", "className", "children", "closeButtonText", "heading", "show", "portal", "scrollable", "onClose"]);
1536
1536
  var dialogRef = useSharedRef(dialogRefProp || ref);
1537
- var _f = tslib.__read(nextId.useId(1, 'dialog-title-'), 1), headingId = _f[0];
1537
+ var _g = tslib.__read(nextId.useId(1, 'dialog-title-'), 1), headingId = _g[0];
1538
1538
  var headingRef = React.useRef(null);
1539
1539
  var isolatorRef = React.useRef();
1540
1540
  var headingLevel = typeof heading === 'object' && 'level' in heading && heading.level
@@ -1605,14 +1605,16 @@ var Dialog = React.forwardRef(function (_a, ref) {
1605
1605
  headingLevel: headingLevel,
1606
1606
  onClose: handleClose,
1607
1607
  forceAction: forceAction,
1608
- closeButtonText: closeButtonText
1608
+ closeButtonText: closeButtonText,
1609
+ scrollable: scrollable
1609
1610
  }); }, [
1610
1611
  headingId,
1611
1612
  headingRef,
1612
1613
  headingLevel,
1613
1614
  handleClose,
1614
1615
  forceAction,
1615
- closeButtonText
1616
+ closeButtonText,
1617
+ scrollable
1616
1618
  ]);
1617
1619
  if (!show || !isBrowser()) {
1618
1620
  return null;
@@ -1642,11 +1644,12 @@ var Dialog = React.forwardRef(function (_a, ref) {
1642
1644
  Dialog.displayName = 'Dialog';
1643
1645
  var DialogContent = function (_a) {
1644
1646
  var children = _a.children, className = _a.className, align = _a.align, other = tslib.__rest(_a, ["children", "className", "align"]);
1647
+ var context = React.useContext(DialogContext);
1645
1648
  return (React__default["default"].createElement("div", tslib.__assign({ className: classNames__default["default"]('Dialog__content', className, {
1646
1649
  'text--align-left': align === 'left',
1647
1650
  'text--align-center': align === 'center',
1648
1651
  'text--align-right': align === 'right'
1649
- }) }, other), children));
1652
+ }), tabIndex: (context === null || context === void 0 ? void 0 : context.scrollable) ? -1 : undefined }, other), children));
1650
1653
  };
1651
1654
  DialogContent.displayName = 'DialogContent';
1652
1655
  var DialogFooter = function (_a) {
@@ -1700,10 +1703,11 @@ var AlertContent = DialogContent;
1700
1703
  var AlertActions = DialogFooter;
1701
1704
 
1702
1705
  var Modal = function (_a) {
1703
- var children = _a.children, className = _a.className, variant = _a.variant, other = tslib.__rest(_a, ["children", "className", "variant"]);
1706
+ var children = _a.children, className = _a.className, variant = _a.variant, scrollable = _a.scrollable, other = tslib.__rest(_a, ["children", "className", "variant", "scrollable"]);
1704
1707
  return (React__default["default"].createElement(Dialog, tslib.__assign({ className: classNames__default["default"]('Modal', className, {
1705
- 'Modal--info': variant === 'info'
1706
- }) }, other, { forceAction: false }), children));
1708
+ 'Modal--info': variant === 'info',
1709
+ 'Modal--scrollable': scrollable
1710
+ }) }, other, { scrollable: scrollable, forceAction: false }), children));
1707
1711
  };
1708
1712
  var ModalHeader = DialogHeader;
1709
1713
  var ModalHeading = DialogHeading;
@@ -4602,16 +4606,6 @@ var Combobox = React.forwardRef(function (_a, ref) {
4602
4606
  : ComboboxNoResults;
4603
4607
  }, [renderNoResults]);
4604
4608
  var noMatchingOptions = !!inputValue && !matchingOptions.size && (React__default["default"].createElement(NoMatchingOptions, null));
4605
- var comboboxListbox = (
4606
- // eslint-disable-next-line
4607
- // @ts-expect-error
4608
- // multiselect & value props are passed to Listbox, but TS is unable to infer that
4609
- // it's a correct mapping from Combobox's multiselect & value props
4610
- React__default["default"].createElement(Listbox, { className: classNames__default["default"]('Combobox__listbox', {
4611
- 'Combobox__listbox--open': open
4612
- }), role: noMatchingOptions ? 'presentation' : 'listbox', "aria-labelledby": noMatchingOptions ? undefined : "".concat(id, "-label"), id: "".concat(id, "-listbox"), value: multiselect ? selectedValues : selectedValues[0], onMouseDown: handleComboboxOptionMouseDown, onClick: handleComboboxOptionClick, onSelectionChange: handleSelectionChange, onActiveChange: handleActiveChange, ref: listboxRef, tabIndex: noMatchingOptions ? undefined : -1, "aria-activedescendant": undefined, multiselect: multiselect, disabled: disabled },
4613
- comboboxOptions,
4614
- noMatchingOptions));
4615
4609
  var errorId = "".concat(id, "-error");
4616
4610
  var descriptionId = "".concat(id, "-description");
4617
4611
  var describedby = ariaDescribedby;
@@ -4622,6 +4616,16 @@ var Combobox = React.forwardRef(function (_a, ref) {
4622
4616
  describedby = addIdRef(describedby, errorId);
4623
4617
  }
4624
4618
  var inputProps = tslib.__assign(tslib.__assign({}, props), { 'aria-describedby': describedby });
4619
+ var comboboxListbox = (
4620
+ // eslint-disable-next-line
4621
+ // @ts-expect-error
4622
+ // multiselect & value props are passed to Listbox, but TS is unable to infer that
4623
+ // it's a correct mapping from Combobox's multiselect & value props
4624
+ React__default["default"].createElement(Listbox, { className: classNames__default["default"]('Combobox__listbox', {
4625
+ 'Combobox__listbox--open': open
4626
+ }), role: noMatchingOptions ? 'presentation' : 'listbox', "aria-labelledby": noMatchingOptions ? undefined : "".concat(id, "-label"), "aria-describedby": describedby, id: "".concat(id, "-listbox"), value: multiselect ? selectedValues : selectedValues[0], onMouseDown: handleComboboxOptionMouseDown, onClick: handleComboboxOptionClick, onSelectionChange: handleSelectionChange, onActiveChange: handleActiveChange, ref: listboxRef, tabIndex: noMatchingOptions ? undefined : -1, "aria-activedescendant": undefined, multiselect: multiselect, disabled: disabled },
4627
+ comboboxOptions,
4628
+ noMatchingOptions));
4625
4629
  return (React__default["default"].createElement("div", { id: id, className: classNames__default["default"]('Combobox', { 'Combobox--multiselect': multiselect }, className), ref: comboboxRef },
4626
4630
  name &&
4627
4631
  formValues.map(function (formValue, index) { return (React__default["default"].createElement("input", { type: "hidden", key: index, name: name, value: formValue })); }),
@@ -4654,7 +4658,7 @@ var Combobox = React.forwardRef(function (_a, ref) {
4654
4658
  };
4655
4659
  return (React__default["default"].createElement(ComboboxPill, { ref: refCallback, key: value, value: value, removeOptionLabel: removeOptionLabels[index], disabled: disabled, onClick: handleClick, onKeyDown: handlePillKeyDown }));
4656
4660
  }),
4657
- React__default["default"].createElement("input", tslib.__assign({ type: "text", id: "".concat(id, "-input"), ref: inputRef, value: inputValue, role: "combobox", disabled: disabled, "aria-autocomplete": !isAutoComplete ? 'none' : 'list', "aria-controls": "".concat(id, "-listbox"), "aria-expanded": open, "aria-haspopup": "listbox", "aria-activedescendant": open && activeDescendant ? activeDescendant.element.id : undefined }, inputProps, { onChange: handleChange, onKeyDown: handleKeyDown, onFocus: handleFocus, onBlur: handleBlur })),
4661
+ React__default["default"].createElement("input", tslib.__assign({ type: "text", id: "".concat(id, "-input"), ref: inputRef, value: inputValue, role: "combobox", disabled: disabled, "aria-invalid": error ? true : undefined, "aria-autocomplete": !isAutoComplete ? 'none' : 'list', "aria-controls": "".concat(id, "-listbox"), "aria-expanded": open, "aria-haspopup": "listbox", "aria-activedescendant": open && activeDescendant ? activeDescendant.element.id : undefined }, inputProps, { onChange: handleChange, onKeyDown: handleKeyDown, onFocus: handleFocus, onBlur: handleBlur })),
4658
4662
  React__default["default"].createElement("span", { className: "Combobox__arrow" })),
4659
4663
  React__default["default"].createElement(ComboboxProvider, { autocomplete: autocomplete, inputValue: inputValue, formValues: formValues, selectedValues: selectedValues, removeOptionLabels: removeOptionLabels, setRemoveOptionLabels: setRemoveOptionLabels, matches: !isAutoComplete || defaultAutoCompleteMatches, matchingOptions: matchingOptions, setMatchingOptions: setMatchingOptions, setFormValues: setFormValues }, portal && typeof document !== 'undefined'
4660
4664
  ? reactDom.createPortal(comboboxListbox,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@deque/cauldron-react",
3
- "version": "6.27.0-canary.7fd2f1e5",
3
+ "version": "6.27.0-canary.a988b4ae",
4
4
  "license": "MPL-2.0",
5
5
  "description": "Fully accessible react components library for Deque Cauldron",
6
6
  "homepage": "https://cauldron.dequelabs.com/",