UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

254 lines (253 loc) • 8.01 kB
/** * DevExtreme (esm/__internal/ui/toast/m_toast.js) * Version: 24.2.6 * Build date: Mon Mar 17 2025 * * Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ import _extends from "@babel/runtime/helpers/esm/extends"; import eventsEngine from "../../../common/core/events/core/events_engine"; import pointerEvents from "../../../common/core/events/pointer"; import registerComponent from "../../../core/component_registrator"; import domAdapter from "../../../core/dom_adapter"; import $ from "../../../core/renderer"; import { extend } from "../../../core/utils/extend"; import readyCallbacks from "../../../core/utils/ready_callbacks"; import { isString } from "../../../core/utils/type"; import Overlay from "../../../ui/overlay/ui.overlay"; import { isMaterialBased } from "../../../ui/themes"; const ready = readyCallbacks.add; const TOAST_CLASS = "dx-toast"; const TOAST_CLASS_PREFIX = "dx-toast-"; const TOAST_WRAPPER_CLASS = "dx-toast-wrapper"; const TOAST_CONTENT_CLASS = "dx-toast-content"; const TOAST_MESSAGE_CLASS = "dx-toast-message"; const TOAST_ICON_CLASS = "dx-toast-icon"; const WIDGET_NAME = "dxToast"; const toastTypes = ["info", "warning", "error", "success"]; const TOAST_STACK = []; const FIRST_Z_INDEX_OFFSET = 8e3; const POSITION_ALIASES = { top: { my: "top", at: "top", of: null, offset: "0 0" }, bottom: { my: "bottom", at: "bottom", of: null, offset: "0 -20" }, center: { my: "center", at: "center", of: null, offset: "0 0" }, right: { my: "center right", at: "center right", of: null, offset: "0 0" }, left: { my: "center left", at: "center left", of: null, offset: "0 0" } }; const DEFAULT_BOUNDARY_OFFSET = { h: 0, v: 0 }; const DEFAULT_MARGIN = 20; ready((() => { eventsEngine.subscribeGlobal(domAdapter.getDocument(), pointerEvents.down, (e => { for (let i = TOAST_STACK.length - 1; i >= 0; i--) { if (!TOAST_STACK[i]._proxiedDocumentDownHandler(e)) { return } } })) })); class Toast extends Overlay { _getDefaultOptions() { return _extends({}, super._getDefaultOptions(), { message: "", type: "info", displayTime: 2e3, position: "bottom center", animation: { show: { type: "fade", duration: 400, from: 0, to: 1 }, hide: { type: "fade", duration: 400, from: 1, to: 0 } }, shading: false, height: "auto", hideTopOverlayHandler: null, preventScrollEvents: false, closeOnSwipe: true, closeOnClick: false }) } _defaultOptionsRules() { const tabletAndMobileCommonOptions = { displayTime: isMaterialBased() ? 4e3 : 2e3, hideOnOutsideClick: true, animation: { show: { type: "fade", duration: 200, from: 0, to: 1 }, hide: { type: "fade", duration: 200, from: 1, to: 0 } } }; return super._defaultOptionsRules().concat([{ device: device => "phone" === device.deviceType, options: _extends({ width: "calc(100vw - 40px)" }, tabletAndMobileCommonOptions) }, { device: device => "tablet" === device.deviceType, options: _extends({ width: "auto", maxWidth: "80vw" }, tabletAndMobileCommonOptions) }, { device: device => isMaterialBased() && "desktop" === device.deviceType, options: { minWidth: 344, maxWidth: 568, displayTime: 4e3 } }]) } _init() { super._init(); this._posStringToObject() } _renderContentImpl() { const { message: message, type: type } = this.option(); this._message = $("<div>").addClass("dx-toast-message").text(message).appendTo(this.$content()); this.setAria("role", "alert", this._message); if (toastTypes.includes(type.toLowerCase())) { this.$content().prepend($("<div>").addClass("dx-toast-icon")) } super._renderContentImpl() } _render() { super._render(); this.$element().addClass("dx-toast"); this.$wrapper().addClass("dx-toast-wrapper"); const { type: type } = this.option(); this.$content().addClass("dx-toast-" + String(type).toLowerCase()); this.$content().addClass("dx-toast-content"); this._toggleCloseEvents("Swipe"); this._toggleCloseEvents("Click") } _toggleCloseEvents(event) { const dxEvent = `dx${event.toLowerCase()}`; eventsEngine.off(this.$content(), dxEvent); this.option(`closeOn${event}`) && eventsEngine.on(this.$content(), dxEvent, this.hide.bind(this)) } _posStringToObject() { const { position: position } = this.option(); if (!isString(position)) { return } const verticalPosition = position.split(" ")[0]; const horizontalPosition = position.split(" ")[1]; this.option("position", extend({ boundaryOffset: DEFAULT_BOUNDARY_OFFSET }, POSITION_ALIASES[verticalPosition])); switch (horizontalPosition) { case "center": case "left": case "right": this.option("position").at += ` ${horizontalPosition}`; this.option("position").my += ` ${horizontalPosition}` } } _show() { return super._show.apply(this, arguments).always((() => { clearTimeout(this._hideTimeout); const { displayTime: displayTime } = this.option(); this._hideTimeout = setTimeout(this.hide.bind(this), displayTime) })) } _overlayStack() { return TOAST_STACK } _zIndexInitValue() { return super._zIndexInitValue() + 8e3 } _dispose() { clearTimeout(this._hideTimeout); super._dispose() } _optionChanged(args) { const { name: name, value: value, previousValue: previousValue } = args; switch (name) { case "type": this.$content().removeClass("dx-toast-" + previousValue); this.$content().addClass("dx-toast-" + String(value).toLowerCase()); break; case "message": if (this._message) { this._message.text(value) } break; case "closeOnSwipe": this._toggleCloseEvents("Swipe"); break; case "closeOnClick": this._toggleCloseEvents("Click"); break; case "displayTime": break; default: super._optionChanged(args) } } } registerComponent("dxToast", Toast); export default Toast;