@dnb/eufemia
Version:
DNB Eufemia Design System UI Library
56 lines (55 loc) • 2.57 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _Button = _interopRequireDefault(require("../button/Button.js"));
var _index = require("../../icons/index.js");
var _useSharedState = require("../../shared/helpers/useSharedState.js");
var _useTranslation = _interopRequireDefault(require("../../shared/useTranslation.js"));
var _jsxRuntime = require("react/jsx-runtime");
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
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 ListShowMoreButton(props) {
var _data$expanded;
const {
id,
showMore,
showLess,
...rest
} = props;
const {
List: {
showMore: showMoreTranslation,
showLess: showLessTranslation
} = {}
} = (0, _useTranslation.default)();
const resolvedShowMore = showMore !== null && showMore !== void 0 ? showMore : showMoreTranslation;
const resolvedShowLess = showLess !== null && showLess !== void 0 ? showLess : showLessTranslation;
const {
data,
update
} = (0, _useSharedState.useSharedState)(id, {
expanded: false
});
const expanded = (_data$expanded = data === null || data === void 0 ? void 0 : data.expanded) !== null && _data$expanded !== void 0 ? _data$expanded : false;
const handleClick = (0, _react.useCallback)(() => {
update({
expanded: !expanded
});
}, [expanded, update]);
return (0, _jsxRuntime.jsx)(_Button.default, {
variant: "tertiary",
text: expanded ? resolvedShowLess : resolvedShowMore,
icon: expanded ? _index.chevron_up : _index.chevron_down,
iconPosition: "right",
onClick: handleClick,
"aria-expanded": expanded,
"aria-controls": typeof id === 'string' ? id : undefined,
...rest
});
}
ListShowMoreButton._supportsSpacingProps = true;
var _default = exports.default = ListShowMoreButton;
//# sourceMappingURL=ListShowMoreButton.js.map