@dnb/eufemia
Version:
DNB Eufemia Design System UI Library
415 lines (414 loc) • 19 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ItemContent = ItemContent;
exports.default = void 0;
require("core-js/modules/web.dom-collections.iterator.js");
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _componentHelper = require("../../shared/component-helper");
var _Theme = require("../../shared/Theme");
var _SpacingHelper = require("../../components/space/SpacingHelper");
var _DrawerListContext = _interopRequireDefault(require("./DrawerListContext"));
var _DrawerListProvider = _interopRequireDefault(require("./DrawerListProvider"));
var _DrawerListPortal = _interopRequireDefault(require("./DrawerListPortal"));
var _DrawerListHelpers = require("./DrawerListHelpers");
const _excluded = ["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", "wrapper_element", "triangle_position", "direction", "max_height", "id", "data", "prepared_data", "raw_data", "opened", "value", "children"],
_excluded2 = ["children", "className", "triangleRef", "cache_hash", "showFocusRing"],
_excluded3 = ["role", "hash", "children", "className", "on_click", "selected", "active", "value", "disabled"],
_excluded4 = ["children", "className"],
_excluded5 = ["className"];
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
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); }
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); }
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
};
class DrawerList extends _react.default.PureComponent {
constructor(props) {
super(props);
this._id = props.id || (0, _componentHelper.makeUniqueId)();
}
render() {
var _this$context;
const hasProvider = (_this$context = this.context) === null || _this$context === void 0 ? void 0 : _this$context.drawerList;
if (hasProvider) {
return _react.default.createElement(DrawerListInstance, this.props);
}
return _react.default.createElement(_DrawerListProvider.default, _extends({
id: this._id
}, this.props, {
data: this.props.data || this.props.children
}), _react.default.createElement(DrawerListInstance, _extends({
id: this._id
}, this.props)));
}
}
exports.default = DrawerList;
_defineProperty(DrawerList, "contextType", _DrawerListContext.default);
_defineProperty(DrawerList, "blurDelay", _DrawerListProvider.default.blurDelay);
_defineProperty(DrawerList, "defaultProps", _objectSpread({}, _DrawerListHelpers.drawerListDefaultProps));
process.env.NODE_ENV !== "production" ? DrawerList.propTypes = _objectSpread({}, _DrawerListHelpers.drawerListPropTypes) : void 0;
class DrawerListInstance extends _react.default.PureComponent {
constructor(props, context) {
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._id = props.id || (0, _componentHelper.makeUniqueId)();
this.state = this.state || {};
context.drawerList.setState(Object.entries(propsToFilterOut).reduce((acc, _ref) => {
let [key] = _ref;
if (props[key]) {
acc[key] = props[key];
}
return acc;
}, {}));
context.drawerList.setState({
triangle_position: props.triangle_position
});
}
render() {
var _this$context2;
const props = (0, _componentHelper.extendPropsWithContextInClassComponent)(this.props, DrawerList.defaultProps, this.context.getTranslation(this.props).DrawerList);
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,
prepared_data: _prepared_data,
raw_data: _raw_data,
opened: _opened,
value: _value,
children
} = props,
attributes = _objectWithoutProperties(props, _excluded);
const id = this._id;
const {
data,
opened,
hidden,
triangle_position,
direction,
max_height,
cache_hash,
selected_item,
active_item,
showFocusRing,
closestToTop,
closestToBottom,
usePortal,
addObservers,
removeObservers,
_refShell,
_refTriangle,
_refUl,
_refRoot
} = this.context.drawerList;
const mainParams = _objectSpread({
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: max_height > 0 ? `${max_height}rem` : null
},
ref: _refUl
};
if (!hidden && (parseFloat(active_item) > -1 || !(parseFloat(active_item) > -1) && !(parseFloat(selected_item) > -1))) {
ulParams['aria-activedescendant'] = `option-${id}-${parseFloat(active_item) > -1 ? active_item : 0}`;
} else if (!(0, _componentHelper.isTrue)(prevent_selection) && !hidden && parseFloat(selected_item) > -1) {
ulParams['aria-activedescendant'] = `option-${id}-${selected_item}`;
}
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 Items = () => data.map((dataItem, i) => {
const _id = dataItem.__id;
const hash = `option-${id}-${_id}-${i}`;
const liParams = {
role: role === 'menu' ? 'menuitem' : 'option',
'data-item': _id,
id: `option-${id}-${_id}`,
hash,
className: (0, _classnames.default)(ignoreEvents || dataItem.ignore_events && 'ignore-events', dataItem.class_name, i === closestToTop && 'closest-to-top', i === closestToBottom && 'closest-to-bottom', i === 0 && 'first-of-type', i === data.length - 1 && 'last-of-type'),
active: _id == active_item,
selected: !dataItem.ignore_events && _id == selected_item,
onClick: this.selectItemHandler,
onKeyDown: this.preventTab,
disabled: dataItem.disabled,
style: dataItem.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 mainList = _react.default.createElement("span", _extends({}, mainParams, {
ref: _refShell
}), _react.default.createElement("span", listParams, hidden === false && data && data.length > 0 ? _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(DrawerList.Options, _extends({
cache_hash: cache_hash + active_item + selected_item + closestToTop + closestToBottom + direction + max_height
}, ulParams, {
showFocusRing: showFocusRing,
triangleRef: _refTriangle
}), typeof options_render === 'function' ? options_render({
data,
Items,
Item: DrawerList.Item
}) : _react.default.createElement(Items, null)), _react.default.createElement(OnMounted, {
addObservers: addObservers,
removeObservers: removeObservers
})) : 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' + (usePortal ? " dnb-drawer-list__root--portal" : ""),
ref: _refRoot
}, usePortal ? _react.default.createElement(_DrawerListPortal.default, {
id: this._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$context2 = this.context) === null || _this$context2 === void 0 ? void 0 : _this$context2.theme, portal_class)
}, mainList) : mainList);
}
}
_defineProperty(DrawerListInstance, "defaultProps", DrawerList.defaultProps);
_defineProperty(DrawerListInstance, "contextType", _DrawerListContext.default);
process.env.NODE_ENV !== "production" ? DrawerListInstance.propTypes = DrawerList.propTypes : void 0;
DrawerList.Options = _react.default.memo(_react.default.forwardRef((props, ref) => {
const {
children,
className = null,
triangleRef = null,
cache_hash = null,
showFocusRing = false
} = props,
rest = _objectWithoutProperties(props, _excluded2);
return _react.default.createElement("ul", _extends({
className: (0, _classnames.default)('dnb-drawer-list__options', className, showFocusRing && 'dnb-drawer-list__options--focusring')
}, rest, {
ref: ref
}), children, _react.default.createElement("li", {
className: "dnb-drawer-list__triangle",
"aria-hidden": true,
ref: triangleRef
}));
}), (prevProps, nextProps) => {
if (!prevProps.cache_hash) {
return null;
}
return prevProps.cache_hash === nextProps.cache_hash;
});
DrawerList.Options.displayName = 'DrawerList.Options';
DrawerList.Options.propTypes = {
children: _propTypes.default.oneOfType([_propTypes.default.node, _propTypes.default.func]).isRequired,
cache_hash: _propTypes.default.string,
showFocusRing: _propTypes.default.bool,
className: _propTypes.default.string,
triangleRef: _propTypes.default.object
};
DrawerList.Item = _react.default.forwardRef((props, ref) => {
const {
role = 'option',
hash = '',
children,
className = null,
on_click = null,
selected,
active = null,
value = null,
disabled
} = props,
rest = _objectWithoutProperties(props, _excluded3);
const params = {
className: (0, _classnames.default)(className, 'dnb-drawer-list__option', selected && 'dnb-drawer-list__option--selected', active && 'dnb-drawer-list__option--focus'),
role,
tabIndex: selected ? '0' : '-1',
'aria-selected': active,
disabled,
'aria-disabled': disabled
};
if (selected) {
params['aria-current'] = true;
}
if (on_click) {
params.onClick = () => (0, _componentHelper.dispatchCustomElementEvent)({
props: _objectSpread(_objectSpread({}, props), {}, {
displayName: DrawerList.Item.displayName
})
}, 'on_click', _objectSpread({
selected,
value
}, rest));
}
return _react.default.createElement("li", _extends({}, params, rest, {
ref: ref,
key: 'li' + hash
}), _react.default.createElement("span", {
className: "dnb-drawer-list__option__inner"
}, _react.default.createElement(ItemContent, {
hash: hash
}, children)));
});
DrawerList.Item.displayName = 'DrawerList.Item';
DrawerList.Item.propTypes = {
role: _propTypes.default.string,
hash: _propTypes.default.string,
children: _propTypes.default.oneOfType([_propTypes.default.node, _propTypes.default.func, _propTypes.default.object]).isRequired,
className: _propTypes.default.string,
on_click: _propTypes.default.func,
selected: _propTypes.default.bool,
active: _propTypes.default.bool,
value: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.number]),
disabled: _propTypes.default.bool
};
function ItemContent(_ref2) {
let {
hash = '',
children = undefined
} = _ref2;
let content = null;
if (Array.isArray(children.content || children)) {
content = (children.content || children).map((item, n) => _react.default.createElement(DrawerListOptionItem, {
key: hash + n,
className: `item-nr-${n + 1}`
}, children.render ? children.render(item, hash + n) : item));
} else if (Object.prototype.hasOwnProperty.call(children, 'content')) {
content = children.render ? children.render(children.content, hash, children) : children.content;
if (content) {
content = _react.default.createElement(DrawerListOptionItem, null, content);
}
} else {
content = children && _react.default.createElement(DrawerListOptionItem, null, children);
}
return Object.prototype.hasOwnProperty.call(children, 'suffix_value') ? _react.default.createElement(_react.default.Fragment, null, content, _react.default.createElement(DrawerListOptionItem, {
className: "dnb-drawer-list__option__suffix"
}, children.suffix_value)) : content;
}
process.env.NODE_ENV !== "production" ? ItemContent.propTypes = {
hash: _propTypes.default.string,
children: _propTypes.default.oneOfType([_propTypes.default.node, _propTypes.default.object])
} : void 0;
function DrawerListOptionItem(_ref3) {
let {
children = undefined,
className = null
} = _ref3,
props = _objectWithoutProperties(_ref3, _excluded4);
return _react.default.createElement("span", _extends({
className: (0, _classnames.default)('dnb-drawer-list__option__item', className)
}, props), children);
}
DrawerList.HorizontalItem = _ref4 => {
let {
className = null
} = _ref4,
props = _objectWithoutProperties(_ref4, _excluded5);
return _react.default.createElement(DrawerListOptionItem, _extends({
className: (0, _classnames.default)('dnb-drawer-list__option__item--horizontal', className)
}, props));
};
DrawerList.HorizontalItem.propTypes = {
children: _propTypes.default.oneOfType([_propTypes.default.node, _propTypes.default.func]).isRequired,
className: _propTypes.default.string
};
class OnMounted extends _react.default.PureComponent {
componentDidMount() {
this.props.addObservers();
}
componentWillUnmount() {
this.props.removeObservers();
}
render() {
return null;
}
}
process.env.NODE_ENV !== "production" ? OnMounted.propTypes = {
addObservers: _propTypes.default.func.isRequired,
removeObservers: _propTypes.default.func.isRequired
} : void 0;
//# sourceMappingURL=DrawerList.js.map