@intuitionrobotics/thunderstorm
Version:
52 lines • 2 kB
JavaScript
/*
* 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