UNPKG

@intuitionrobotics/thunderstorm

Version:
52 lines 2 kB
/* * Thunderstorm is a full web app framework! * * Typescript & Express backend infrastructure that natively runs on firebase function * Typescript & React frontend infrastructure * * Copyright (C) 2020 Intuition Robotics * * 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"; // noinspection TypeScriptPreferShortImport import { ToastModule } from "./ToasterModule.js"; // noinspection TypeScriptPreferShortImport import { BaseComponent } from "../../core/BaseComponent.js"; export class BaseToaster extends BaseComponent { constructor(props) { super(props); this.state = {}; } __showToast = (model) => { this.setState({ model }); if (!model) return; const duration = model.duration; if (duration <= 0) return; this.debounce(() => ToastModule.hideToast(model), 'closing_action', duration); }; render() { const toast = this.state.model; if (!toast?.content) return null; return this.renderToaster(toast); } renderActions = (toast) => { if (!toast.actions || toast.actions.length === 0) return React.createElement("button", { onClick: () => ToastModule.hideToast(toast) }, "X"); return React.createElement("div", { className: 'll_v_l' }, React.Children.map(toast.actions, (action, idx) => React.cloneElement(action, { key: idx }))); }; } //# sourceMappingURL=BaseToaster.js.map