UNPKG

@dnb/eufemia

Version:

DNB Eufemia Design System UI Library

379 lines (378 loc) 16 kB
"use strict"; "use client"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _push = _interopRequireDefault(require("core-js-pure/stable/instance/push.js")); var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _componentHelper = require("../../shared/component-helper.js"); var _Theme = require("../../shared/Theme.js"); var _SpacingHelper = require("../../components/space/SpacingHelper.js"); var _Element = _interopRequireDefault(require("../../elements/Element.js")); var _DrawerListContext = _interopRequireDefault(require("./DrawerListContext.js")); var _DrawerListProvider = _interopRequireDefault(require("./DrawerListProvider.js")); var _DrawerListPortal = _interopRequireDefault(require("./DrawerListPortal.js")); var _DrawerListHelpers = require("./DrawerListHelpers.js"); var _DrawerListItem = require("./DrawerListItem.js"); function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); } function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } const propsToFilterOut = { on_show: null, on_hide: null, handle_dismiss_focus: null, on_change: null, on_pre_change: null, on_resize: null, on_select: null, on_state_update: null, on_key_down: null, options_render: null, wrapper_element: null }; function DrawerList(props) { const drawerListContext = (0, _react.useContext)(_DrawerListContext.default); if (drawerListContext !== null && drawerListContext !== void 0 && drawerListContext.drawerList) { return _react.default.createElement(DrawerListInstance, props); } const { data, children, ...rest } = props; return _react.default.createElement(_DrawerListProvider.default, _extends({}, rest, { data: data || (!_react.default.isValidElement(children) ? children : undefined) }), _react.default.createElement(DrawerListInstance, props)); } DrawerList.blurDelay = _DrawerListProvider.default.blurDelay; class DrawerListInstance extends _react.default.Component { constructor(props) { super(props); _defineProperty(this, "preventTab", e => { switch ((0, _componentHelper.keycode)(e)) { case 'tab': if (!this.context.drawerList.hasFocusOnElement) { e.preventDefault(); this.context.drawerList.setHidden(); } break; case 'page down': case 'page up': e.preventDefault(); break; } }); _defineProperty(this, "selectItemHandler", event => { const selected_item = parseFloat(event.currentTarget.getAttribute('data-item')); if (selected_item > -1) { this.context.drawerList.selectItemAndClose(selected_item, { fireSelectEvent: true, event }); } }); this.state = this.state || {}; } componentDidMount() { this.context.drawerList.setState(Object.entries(propsToFilterOut).reduce((acc, [key]) => { if (this.props[key]) { acc[key] = this.props[key]; } return acc; }, {})); this.context.drawerList.setState({ triangle_position: this.props.triangle_position }); } render() { var _renderData$, _this$context; const props = (0, _componentHelper.extendPropsWithContextInClassComponent)(this.props, DrawerListInstance.defaultProps); const { role, align_drawer, fixed_position, independent_width, scrollable, focusable, size, no_animation, no_scroll_animation, prevent_selection, action_menu, is_popup, portal_class, list_class, ignore_events, options_render, className, cache_hash: _cache_hash, wrapper_element: _wrapper_element, triangle_position: _triangle_position, direction: _direction, max_height: _max_height, id: _id, data: _data, opened: _opened, value: _value, children, ...attributes } = props; function noNullNumbers({ selected_item, active_item, max_height, ...rest }) { return { selected_item: selected_item !== null && selected_item !== void 0 ? selected_item : undefined, active_item: active_item !== null && active_item !== void 0 ? active_item : undefined, max_height: max_height !== null && max_height !== void 0 ? max_height : undefined, ...rest }; } const { id, data, groups, opened, hidden, triangle_position, direction, max_height, cache_hash, selected_item, active_item, showFocusRing, closestToTop, closestToBottom, skipPortal, addObservers, removeObservers, _refShell, _refTriangle, _refUl, _refRoot } = noNullNumbers(this.context.drawerList); const renderData = makeRenderData(data, groups, this.context.getTranslation(this.props).DrawerList); const hasGroups = renderData.length > 1 || ((_renderData$ = renderData[0]) === null || _renderData$ === void 0 ? void 0 : _renderData$.groupTitle) !== undefined; const mainParams = { id: `${id}-drawer-list`, className: (0, _classnames.default)(`dnb-drawer-list dnb-drawer-list--${direction}`, ((0, _componentHelper.isTrue)(independent_width) || (0, _componentHelper.isTrue)(action_menu)) && 'dnb-drawer-list--independent-width', (0, _SpacingHelper.createSpacingClasses)(props), className, opened && 'dnb-drawer-list--opened', hidden && 'dnb-drawer-list--hidden', triangle_position && `dnb-drawer-list--triangle-position-${triangle_position}`, align_drawer && `dnb-drawer-list--${align_drawer}`, size && `dnb-drawer-list--${size}`, (0, _componentHelper.isTrue)(action_menu) && `dnb-drawer-list--action-menu`, (0, _componentHelper.isTrue)(is_popup) && 'dnb-drawer-list--is-popup', (0, _componentHelper.isTrue)(scrollable) && 'dnb-drawer-list--scroll', (0, _componentHelper.isTrue)(no_scroll_animation) && 'dnb-drawer-list--no-scroll-animation'), ...attributes }; const listParams = { id: `${id}-listbox`, className: (0, _classnames.default)('dnb-drawer-list__list', list_class, (0, _componentHelper.isTrue)(no_animation) && 'dnb-drawer-list__list--no-animation') }; const ulParams = { role, id: `${id}-ul`, 'aria-expanded': opened, 'aria-labelledby': `${id}-label`, tabIndex: -1, style: { maxHeight: parseFloat(max_height) > 0 ? `${max_height}rem` : null }, ref: _refUl }; if (!hidden) { ulParams['aria-activedescendant'] = this.context.drawerList.ariaActiveDescendant; } if ((0, _componentHelper.isTrue)(focusable)) { ulParams.tabIndex = 0; } (0, _componentHelper.validateDOMAttributes)(this.props, mainParams); (0, _componentHelper.validateDOMAttributes)(null, listParams); (0, _componentHelper.validateDOMAttributes)(null, ulParams); Object.assign(this.context.drawerList.attributes, (0, _componentHelper.validateDOMAttributes)(null, attributes)); const ignoreEvents = (0, _componentHelper.isTrue)(ignore_events); const GroupItems = () => renderData.filter(Boolean).map(({ groupTitle, groupData: data, hideTitle }, j) => { var _Items; const Items = () => data.map((dataItem, i) => { const { __id, ignore_events, class_name, disabled, style } = dataItem; const hash = `option-${id}-${__id}-${i}`; const tagId = `option-${id}-${__id}`; const liParams = { role: role === 'menu' ? 'menuitem' : 'option', 'data-item': __id, id: tagId, hash, className: (0, _classnames.default)(ignoreEvents || ignore_events && 'ignore-events', class_name, i === 0 && 'first-of-type' + (j === 0 ? " first-item" : ""), i === data.length - 1 && 'last-of-type' + (j === renderData.length - 1 ? " last-item" : ""), tagId === closestToTop && 'closest-to-top', tagId === closestToBottom && 'closest-to-bottom'), active: __id === active_item, selected: !ignore_events && __id === selected_item, onClick: this.selectItemHandler, onKeyDown: this.preventTab, disabled: disabled, style: style }; if (ignoreEvents) { liParams.active = null; liParams.selected = null; liParams.onClick = null; liParams.onKeyDown = null; liParams.className = (0, _classnames.default)(liParams.className, 'dnb-drawer-list__option--ignore'); } return _react.default.createElement(DrawerList.Item, _extends({ key: hash }, liParams), dataItem); }); const ItemsRendered = () => typeof options_render === 'function' ? options_render({ data, Items, Item: DrawerList.Item }) : _Items || (_Items = _react.default.createElement(Items, null)); if (hasGroups) { const groupdId = `${id}-group-title-${j}`; return _react.default.createElement("ul", { key: j, role: "group", "aria-labelledby": groupdId, className: (0, _classnames.default)('dnb-drawer-list__group', j === 0 && 'first-of-type', j === renderData.length - 1 && 'last-of-type') }, _react.default.createElement("li", { id: groupdId, role: "presentation", className: (0, _classnames.default)('dnb-drawer-list__group-title', hideTitle && 'dnb-sr-only', groupdId === closestToBottom && 'closest-to-bottom', groupdId === closestToTop && 'closest-to-top') }, groupTitle), _react.default.createElement(ItemsRendered, null)); } else { return _react.default.createElement(ItemsRendered, { key: j }); } }); const mainList = _react.default.createElement("span", _extends({}, mainParams, { ref: _refShell }), _react.default.createElement("span", listParams, hidden === false && renderData.length > 0 ? _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(DrawerList.Options, _extends({ hasGroups: hasGroups, cache_hash: cache_hash + active_item + selected_item + closestToTop + closestToBottom + direction + max_height }, ulParams, { showFocusRing: showFocusRing, triangleRef: _refTriangle }), _react.default.createElement(GroupItems, null)), _react.default.createElement(OnMounted, { addObservers: addObservers, removeObservers: removeObservers })) : _react.default.isValidElement(children) && _react.default.createElement("span", { className: "dnb-drawer-list__content" }, children, _react.default.createElement("span", { className: "dnb-drawer-list__triangle", ref: _refTriangle })))); return _react.default.createElement("span", { className: 'dnb-drawer-list__root' + (!skipPortal ? " dnb-drawer-list__root--portal" : ""), ref: _refRoot }, _react.default.createElement(_DrawerListPortal.default, { id: id, rootRef: _refRoot, opened: hidden === false, include_owner_width: align_drawer === 'right', independent_width: (0, _componentHelper.isTrue)(independent_width), fixed_position: (0, _componentHelper.isTrue)(fixed_position), className: (0, _Theme.getThemeClasses)((_this$context = this.context) === null || _this$context === void 0 ? void 0 : _this$context.theme, portal_class), skipPortal: skipPortal }, mainList)); } } _defineProperty(DrawerListInstance, "defaultProps", { ..._DrawerListHelpers.drawerListDefaultProps }); _defineProperty(DrawerListInstance, "contextType", _DrawerListContext.default); function makeRenderData(data, groups, translation) { const renderData = []; const noIndex = []; if (Array.isArray(data) && data.length > 0) { data.forEach(dataItem => { var _dataItem$groupIndex; const index = (_dataItem$groupIndex = dataItem.groupIndex) !== null && _dataItem$groupIndex !== void 0 ? _dataItem$groupIndex : undefined; if (index >= 0) { var _context; if (!renderData[index]) { let groupTitle = groups === null || groups === void 0 ? void 0 : groups[index]; let hideTitle = false; if (!groupTitle) { if (index === 0) { groupTitle = translation.defaultGroupSR; hideTitle = true; } else { (0, _componentHelper.warn)(`Missing group title for groupIndex: ${index}`); groupTitle = `${translation.missingGroup} ${index + 1}`; } } renderData[index] = { groupTitle, hideTitle, groupData: [] }; } (0, _push.default)(_context = renderData[index].groupData).call(_context, dataItem); } else { (0, _push.default)(noIndex).call(noIndex, dataItem); } }); } if (noIndex.length > 0) { (0, _push.default)(renderData).call(renderData, { groupTitle: renderData.length > 0 ? translation.noGroupSR : undefined, hideTitle: true, groupData: noIndex }); } return renderData; } DrawerList.Options = _react.default.memo(_react.default.forwardRef((props, ref) => { const { children, className, triangleRef, cache_hash, showFocusRing = false, hasGroups = false, ...rest } = props; return _react.default.createElement(_Element.default, _extends({ internalClass: false, as: hasGroups ? 'span' : 'ul', className: (0, _classnames.default)('dnb-drawer-list__options', className, showFocusRing && 'dnb-drawer-list__options--focusring') }, rest, { ref: ref }), children, _react.default.createElement(_Element.default, { internalClass: false, as: hasGroups ? 'span' : 'li', className: "dnb-drawer-list__triangle", "aria-hidden": true, ref: triangleRef })); }), (prevProps, nextProps) => { if (!prevProps.cache_hash) { return false; } return prevProps.cache_hash === nextProps.cache_hash; }); DrawerList.Item = _DrawerListItem.DrawerListItem; DrawerList.HorizontalItem = _DrawerListItem.DrawerListHorizontalItem; class OnMounted extends _react.default.PureComponent { componentDidMount() { this.props.addObservers(); } componentWillUnmount() { this.props.removeObservers(); } render() { return null; } } var _default = exports.default = DrawerList; //# sourceMappingURL=DrawerList.js.map