@blueprintjs/core
Version:
Core styles & components
36 lines • 1.99 kB
JavaScript
/*
* Copyright 2021 Palantir Technologies, Inc. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import * as React from "react";
import { Classes, DISPLAYNAME_PREFIX } from "../../common";
import { Button } from "../button/buttons";
import { Text } from "../text/text";
// eslint-disable-next-line @typescript-eslint/ban-types
export const PanelView2 = (props) => {
const handleClose = React.useCallback(() => props.onClose(props.panel), [props.onClose, props.panel]);
const maybeBackButton = props.previousPanel === undefined ? null : (React.createElement(Button, { className: Classes.PANEL_STACK_HEADER_BACK, icon: "chevron-left", minimal: true, onClick: handleClose, small: true, text: props.previousPanel.title, title: props.previousPanel.htmlTitle }));
return (React.createElement("div", { className: Classes.PANEL_STACK2_VIEW },
props.showHeader && (React.createElement("div", { className: Classes.PANEL_STACK2_HEADER },
React.createElement("span", null, maybeBackButton),
React.createElement(Text, { className: Classes.HEADING, ellipsize: true, title: props.panel.htmlTitle }, props.panel.title),
React.createElement("span", null))),
props.panel.renderPanel({
closePanel: handleClose,
openPanel: props.onOpen,
...props.panel.props,
})));
};
PanelView2.displayName = `${DISPLAYNAME_PREFIX}.PanelView2`;
//# sourceMappingURL=panelView2.js.map