@dnb/eufemia
Version:
DNB Eufemia Design System UI Library
55 lines (54 loc) • 1.93 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = 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 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