UNPKG

@etsoo/materialui

Version:

TypeScript Material-UI Implementation

39 lines (38 loc) 1.59 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.BridgeCloseButton = BridgeCloseButton; const jsx_runtime_1 = require("react/jsx-runtime"); const appscript_1 = require("@etsoo/appscript"); const Close_1 = __importDefault(require("@mui/icons-material/Close")); const react_1 = __importDefault(require("react")); const ReactApp_1 = require("./app/ReactApp"); const IconButton_1 = __importDefault(require("@mui/material/IconButton")); const Box_1 = __importDefault(require("@mui/material/Box")); /** * Bridge close button * @param props Props * @returns Component */ function BridgeCloseButton(props) { // Global app const app = (0, ReactApp_1.useAppContext)(); // Destruct const { boxProps, onClick, title = app?.get("close") ?? "Close", validate, ...rest } = props; // Host const host = appscript_1.BridgeUtils.host; if (host == null || !host.closable() || (validate && validate(host) === false)) { return (0, jsx_runtime_1.jsx)(react_1.default.Fragment, {}); } // Click handler const onClickLocal = (event) => { if (onClick) onClick(event); host.exit(); }; return ((0, jsx_runtime_1.jsx)(Box_1.default, { ...boxProps, children: (0, jsx_runtime_1.jsx)(IconButton_1.default, { "aria-label": "close", onClick: onClickLocal, title: title, ...rest, children: (0, jsx_runtime_1.jsx)(Close_1.default, {}) }) })); }