UNPKG

@neo4j-ndl/react

Version:

React implementation of Neo4j Design System

98 lines 6.4 kB
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; }; import { jsx as _jsx, jsxs as _jsxs } from "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/>. */ import classNames from 'classnames'; import { useEffect, useLayoutEffect, useRef, useState } from 'react'; import { CleanIconButton } from '../clean-icon-button'; import { ChevronDownIconOutline, ChevronUpIconOutline } from '../icons'; const defaultElement = 'div'; export 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 = useRef(null); const [containerHeight, setContainerHeight] = useState(`${maxHeight}px`); const [isExpanded, setIsExpanded] = useState(maxHeight === undefined); 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); } }, []); 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 (_jsxs(Component, Object.assign({ ref: ref, className: classNames('ndl-code-block-container', className), style: Object.assign({ height: containerHeight }, style) }, restProps, htmlAttributes, { children: [_jsxs("div", { className: "n-flex n-flex-col n-h-full", children: [Boolean(heading) === true && (_jsx("div", { className: classNames('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 })), _jsxs("div", { className: classNames('ndl-code-content-container', { 'ndl-disabled': isDisabled, }), style: { height: Boolean(heading) === true ? 'calc(100% - 24px - 12px)' : '100%', }, children: [_jsx("div", { className: "ndl-code-pseudo-element" }), _jsx("div", { ref: syntaxHighlighterWrapperRef, className: "ndl-highlight-wrapper", role: "textbox", "aria-label": "Code snippet", tabIndex: 0, children: children }), _jsx("div", { className: "ndl-code-pseudo-element" })] })] }), _jsx("div", { className: classNames('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 (_jsx(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 && (_jsx("div", { className: "ndl-code-block-expand-button", children: _jsx(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 ? _jsx(ChevronUpIconOutline, {}) : _jsx(ChevronDownIconOutline, {}) }) }))] }))); }; //# sourceMappingURL=CodeBlockWrapper.js.map