UNPKG

@navikt/ds-react

Version:

React components from the Norwegian Labour and Welfare Administration.

58 lines 3.91 kB
var __rest = (this && this.__rest) || function (s, e) { var t = {}; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; import React, { forwardRef } from "react"; import { ChevronDownIcon } from "@navikt/aksel-icons"; import { useId } from "../utils-external/index.js"; import { cl, composeEventHandlers } from "../utils/helpers/index.js"; import { useControllableState } from "../utils/hooks/index.js"; import { useI18n } from "../utils/i18n/i18n.hooks.js"; import AnimateHeight from "./AnimateHeight.js"; import DataCell from "./DataCell.js"; import Row from "./Row.js"; import { isElementInteractiveTarget } from "./Table.utils.js"; export const ExpandableRow = forwardRef((_a, ref) => { var { className, children, content, togglePlacement = "left", defaultOpen = false, open, onOpenChange, expansionDisabled = false, expandOnRowClick = false, colSpan = 999, contentGutter, onClick } = _a, rest = __rest(_a, ["className", "children", "content", "togglePlacement", "defaultOpen", "open", "onOpenChange", "expansionDisabled", "expandOnRowClick", "colSpan", "contentGutter", "onClick"]); const [_open, _setOpen] = useControllableState({ defaultValue: defaultOpen, value: open, onChange: onOpenChange, }); const translate = useI18n("global"); const id = useId(); const expansionHandler = (event) => { _setOpen((oldOpen) => !oldOpen); event.stopPropagation(); }; const handleRowClick = (event) => { expandOnRowClick && !expansionDisabled && !isElementInteractiveTarget(event.target) && expansionHandler(event); }; return (React.createElement(React.Fragment, null, React.createElement(Row, Object.assign({}, rest, { ref: ref, className: cl("aksel-table__expandable-row", className, { "aksel-table__expandable-row--open": _open, "aksel-table__expandable-row--expansion-disabled": expansionDisabled, "aksel-table__expandable-row--clickable": expandOnRowClick, }), onClick: composeEventHandlers(onClick, handleRowClick) }), togglePlacement === "right" && children, React.createElement(DataCell, { className: cl("aksel-table__toggle-expand-cell", { "aksel-table__toggle-expand-cell--open": _open, }), onClick: !expansionDisabled ? expansionHandler : () => null }, !expansionDisabled && (React.createElement("button", { className: "aksel-table__toggle-expand-button", type: "button", "aria-controls": id, "aria-expanded": _open, onClick: expansionHandler }, React.createElement(ChevronDownIcon, { className: "aksel-table__expandable-icon", title: _open ? translate("showLess") : translate("showMore") })))), togglePlacement === "left" && children), React.createElement("tr", { "data-state": _open ? "open" : "closed", className: "aksel-table__expanded-row", "aria-hidden": !_open, id: id }, React.createElement("td", { colSpan: colSpan, className: "aksel-table__expanded-row-cell" }, React.createElement(AnimateHeight, { className: "aksel-table__expanded-row-collapse", innerClassName: `aksel-table__expanded-row-content aksel-table__expanded-row-content--gutter-${contentGutter !== null && contentGutter !== void 0 ? contentGutter : togglePlacement}`, height: _open ? "auto" : 0, duration: 150, easing: "cubic-bezier(0.39,0.57,0.56,1)" }, content))))); }); export default ExpandableRow; //# sourceMappingURL=ExpandableRow.js.map