@dnb/eufemia
Version:
DNB Eufemia Design System UI Library
379 lines (378 loc) • 16 kB
JavaScript
;
"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