UNPKG

rsuite

Version:

A suite of react components

55 lines (53 loc) 1.68 kB
'use client'; import ToastContainer, { defaultToasterContainer } from "./ToastContainer.js"; import { RSUITE_TOASTER_ID } from "../internals/symbols.js"; const containers = new Map(); /** * Create a container instance. * @param placement * @param props */ async function createContainer(placement, props) { const [container, containerId] = await ToastContainer.getInstance(props); containers.set(`${containerId}_${placement}`, container); return container; } /** * Get the container by ID. Use default ID when ID is not available. * @param containerId * @param placement */ function getContainer(containerId, placement) { return containers.get(`${containerId}_${placement}`); } const toaster = message => toaster.push(message); toaster.push = (message, options = {}) => { const { placement = 'topCenter', container = defaultToasterContainer, ...restOptions } = options; const containerElement = typeof container === 'function' ? container() : container; const containerElementId = containerElement ? containerElement[RSUITE_TOASTER_ID] : null; if (containerElementId) { const existedContainer = getContainer(containerElementId, placement); if (existedContainer) { return existedContainer.current?.push(message, restOptions); } } const newOptions = { ...options, container: containerElement, placement }; return createContainer(placement, newOptions).then(ref => { return ref.current?.push(message, restOptions); }); }; toaster.remove = key => { containers.forEach(c => c.current?.remove(key)); }; toaster.clear = () => { containers.forEach(c => c.current?.clear()); }; export default toaster;