@neo4j-ndl/react
Version:
React implementation of Neo4j Design System
105 lines • 7.05 kB
JavaScript
;
var __rest = (this && this.__rest) || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.CodeBlockWrapper = void 0;
const jsx_runtime_1 = require("react/jsx-runtime");
/**
*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [http://neo4j.com]
*
* This file is part of Neo4j.
*
* Neo4j is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
const classnames_1 = __importDefault(require("classnames"));
const react_1 = require("react");
const clean_icon_button_1 = require("../clean-icon-button");
const icons_1 = require("../icons");
const defaultElement = 'div';
const CodeBlockWrapper = (_a) => {
var _b;
var { as, maxHeight, code, heading, children, isDisabled, actions, shouldShowExpandButton, setShouldShowExpandButton, className, style, ref, htmlAttributes } = _a, restProps = __rest(_a, ["as", "maxHeight", "code", "heading", "children", "isDisabled", "actions", "shouldShowExpandButton", "setShouldShowExpandButton", "className", "style", "ref", "htmlAttributes"]);
const Component = as !== null && as !== void 0 ? as : defaultElement;
const syntaxHighlighterWrapperRef = (0, react_1.useRef)(null);
const [containerHeight, setContainerHeight] = (0, react_1.useState)(`${maxHeight}px`);
const [isExpanded, setIsExpanded] = (0, react_1.useState)(maxHeight === undefined);
(0, react_1.useEffect)(() => {
var _a, _b, _c, _d;
if (((_b = (_a = syntaxHighlighterWrapperRef.current) === null || _a === void 0 ? void 0 : _a.scrollHeight) !== null && _b !== void 0 ? _b : 0) <=
((_d = (_c = syntaxHighlighterWrapperRef.current) === null || _c === void 0 ? void 0 : _c.clientHeight) !== null && _d !== void 0 ? _d : 0)) {
setIsExpanded(true);
}
else {
setIsExpanded(false);
}
}, []);
(0, react_1.useLayoutEffect)(() => {
var _a, _b, _c, _d;
if (maxHeight === undefined) {
return;
}
if (((_b = (_a = syntaxHighlighterWrapperRef.current) === null || _a === void 0 ? void 0 : _a.clientHeight) !== null && _b !== void 0 ? _b : 0) >=
((_d = (_c = syntaxHighlighterWrapperRef.current) === null || _c === void 0 ? void 0 : _c.scrollHeight) !== null && _d !== void 0 ? _d : 0)) {
setContainerHeight(`fit-content`);
setShouldShowExpandButton(false);
}
else {
setContainerHeight(`${maxHeight}px`);
setShouldShowExpandButton(true);
}
}, [maxHeight, code, setShouldShowExpandButton]);
return ((0, jsx_runtime_1.jsxs)(Component, Object.assign({ ref: ref, className: (0, classnames_1.default)('ndl-code-block-container', className), style: Object.assign({ height: containerHeight }, style) }, restProps, htmlAttributes, { children: [(0, jsx_runtime_1.jsxs)("div", { className: "n-flex n-flex-col n-h-full", children: [Boolean(heading) === true && ((0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)('ndl-code-block-title', {
'ndl-disabled': isDisabled,
}), style: {
maxWidth: `calc(100% - ${((_b = actions === null || actions === void 0 ? void 0 : actions.length) !== null && _b !== void 0 ? _b : 0) * 36 + 20}px)`,
}, "data-testid": "ndl-code-block-title", children: heading })), (0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)('ndl-code-content-container', {
'ndl-disabled': isDisabled,
}), style: {
height: Boolean(heading) === true ? 'calc(100% - 24px - 12px)' : '100%',
}, children: [(0, jsx_runtime_1.jsx)("div", { className: "ndl-code-pseudo-element" }), (0, jsx_runtime_1.jsx)("div", { ref: syntaxHighlighterWrapperRef, className: "ndl-highlight-wrapper", role: "textbox", "aria-label": "Code snippet", tabIndex: 0, children: children }), (0, jsx_runtime_1.jsx)("div", { className: "ndl-code-pseudo-element" })] })] }), (0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)('ndl-code-block-actions', {
'ndl-disabled': isDisabled,
}), children: actions === null || actions === void 0 ? void 0 : actions.map((iconButtonProps, i) => {
const { htmlAttributes, description } = iconButtonProps, restCleanIconButtonProps = __rest(iconButtonProps, ["htmlAttributes", "description"]);
return ((0, jsx_runtime_1.jsx)(clean_icon_button_1.CleanIconButton, Object.assign({ description: `${description !== null && description !== void 0 ? description : 'CodeBlock Action'}`, isDisabled: isDisabled, htmlAttributes: Object.assign({ 'data-testid': `ndl-action-button-${i}` }, htmlAttributes) }, restCleanIconButtonProps), i));
}) }), shouldShowExpandButton && ((0, jsx_runtime_1.jsx)("div", { className: "ndl-code-block-expand-button", children: (0, jsx_runtime_1.jsx)(clean_icon_button_1.CleanIconButton, { description: isExpanded ? 'Collapse' : 'Expand', tooltipProps: {
root: {
shouldCloseOnReferenceClick: true,
},
}, onClick: () => {
if (isExpanded) {
setContainerHeight(`${maxHeight}px`);
setIsExpanded(false);
}
else {
setContainerHeight(`fit-content`);
setIsExpanded(true);
}
}, children: isExpanded ? (0, jsx_runtime_1.jsx)(icons_1.ChevronUpIconOutline, {}) : (0, jsx_runtime_1.jsx)(icons_1.ChevronDownIconOutline, {}) }) }))] })));
};
exports.CodeBlockWrapper = CodeBlockWrapper;
//# sourceMappingURL=CodeBlockWrapper.js.map