UNPKG

@elastic/eui

Version:

Elastic UI Component Library

181 lines (180 loc) 9.78 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.EuiToast = exports.COLOR_TO_NOTIFICATION_ICON_MAP = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _euiThemeCommon = require("@elastic/eui-theme-common"); var _services = require("../../services"); var _accessibility = require("../accessibility"); var _button = require("../button"); var _i18n = require("../i18n"); var _icon = require("../icon"); var _text = require("../text"); var _toast = require("./toast.styles"); var _notification_icon = require("../notification_icon/notification_icon"); var _notification_icon2 = require("../notification_icon/notification_icon.styles"); var _toast_action = require("./toast_action"); var _title = require("../title"); var _react2 = require("@emotion/react"); var _excluded = ["title", "text", "color", "iconType", "children", "className", "actionProps", "style", "onClose", "animationMs"]; /* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one * or more contributor license agreements. Licensed under the Elastic License * 2.0 and the Server Side Public License, v 1; you may not use this file except * in compliance with, at your election, the Elastic License 2.0 or the Server * Side Public License, v 1. */ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } var COLOR_TO_NOTIFICATION_ICON_MAP = exports.COLOR_TO_NOTIFICATION_ICON_MAP = { primary: 'info', success: 'success', warning: 'warning', danger: 'error' }; var EuiToast = exports.EuiToast = function EuiToast(_ref) { var title = _ref.title, text = _ref.text, _ref$color = _ref.color, color = _ref$color === void 0 ? 'primary' : _ref$color, iconType = _ref.iconType, children = _ref.children, className = _ref.className, actionProps = _ref.actionProps, style = _ref.style, onClose = _ref.onClose, animationMs = _ref.animationMs, rest = (0, _objectWithoutProperties2.default)(_ref, _excluded); var _useEuiTheme = (0, _services.useEuiTheme)(), euiTheme = _useEuiTheme.euiTheme; var styles = (0, _services.useEuiMemoizedStyles)(_toast.euiToastStyles); var iconStyles = (0, _services.useEuiMemoizedStyles)(_notification_icon2.euiNotificationIconStyles); var headerStyles = (0, _services.useEuiMemoizedStyles)(_toast.euiToastHeaderStyles); var cssStyles = [styles.euiToast]; var decorCssStyles = [styles.decor, animationMs && styles.hasAnimation]; var classes = (0, _classnames.default)('euiToast', className, (0, _defineProperty2.default)({}, "euiToast--".concat(color), color)); var highlightColorToken = (0, _euiThemeCommon.getTokenName)('borderStrong', color); var typeColor = euiTheme.colors[highlightColorToken]; var backgroundLightToken = (0, _euiThemeCommon.getTokenName)('backgroundLight', color); var backgroundLightColor = euiTheme.colors[backgroundLightToken]; var cssVariables = (0, _react.useMemo)(function () { return _objectSpread({ '--euiToastTypeColor': typeColor, '--euiToastTypeBackgroundColor': backgroundLightColor }, animationMs && { '--euiToastAnimationMs': "".concat(animationMs, "ms") }); }, [typeColor, backgroundLightColor, animationMs]); var dismissButton = (0, _react.useMemo)(function () { if (!onClose) return; return (0, _react2.jsx)(_i18n.EuiI18n, { token: "euiToast.dismissToast", default: "Dismiss toast" }, function (dismissToast) { return (0, _react2.jsx)(_button.EuiButtonIcon, { css: styles.dismissButton, iconType: "cross", color: "text", size: "xs", "aria-label": dismissToast, onClick: onClose, "data-test-subj": "toastCloseButton" }); }); }, [onClose, styles]); var header = (0, _react.useMemo)(function () { if (!title) return; var headerCssStyles = [headerStyles.euiToastHeader, onClose && headerStyles.hasDismissButton]; return (0, _react2.jsx)(_title.EuiTitle, { size: "xs", css: headerCssStyles, "data-test-subj": "euiToastHeader__title" }, (0, _react2.jsx)("p", null, title)); }, [title, headerStyles, onClose]); var icon = (0, _react.useMemo)(function () { if (!iconType) { var _COLOR_TO_NOTIFICATIO; var defaultIconType = (_COLOR_TO_NOTIFICATIO = COLOR_TO_NOTIFICATION_ICON_MAP[color]) !== null && _COLOR_TO_NOTIFICATIO !== void 0 ? _COLOR_TO_NOTIFICATIO : 'info'; return (0, _react2.jsx)(_notification_icon.EuiNotificationIcon, { css: styles.icon, type: defaultIconType, size: "l" }); } return (0, _react2.jsx)(_icon.EuiIcon, { css: [styles.icon, iconStyles.size.l, ";label:icon;"], type: iconType, size: "l", "aria-hidden": "true", color: typeColor }); }, [iconType, color, typeColor, styles, iconStyles]); var optionalChildren = (0, _react.useMemo)(function () { if (!text && !children) return null; return (0, _react2.jsx)("div", { css: styles.text, "data-test-subj": "euiToastBody" }, text && (0, _react2.jsx)(_text.EuiText, { size: "s", color: "default", className: "euiToast__text", "data-test-subj": "euiToastText" }, text), children && (0, _react2.jsx)(_text.EuiText, { className: "euiToast__additionalContent", size: "s", color: "default", "data-test-subj": "euiToastAdditionalContent" }, children)); }, [text, children, styles]); var actionControls = (0, _react.useMemo)(function () { var actionPrimaryProps = _objectSpread(_objectSpread({}, actionProps === null || actionProps === void 0 ? void 0 : actionProps.primary), {}, { color: color }); var actionSecondaryProps = _objectSpread(_objectSpread({}, actionProps === null || actionProps === void 0 ? void 0 : actionProps.secondary), {}, { color: color }); var hasActionPrimary = Boolean(actionProps === null || actionProps === void 0 ? void 0 : actionProps.primary); var hasActionSecondary = Boolean(actionProps === null || actionProps === void 0 ? void 0 : actionProps.secondary); if (!hasActionPrimary && !hasActionSecondary) return null; var actionPrimary = hasActionPrimary && (0, _react2.jsx)(_toast_action.EuiToastAction, (0, _extends2.default)({ actionType: "primary" }, actionPrimaryProps)); var actionSecondary = hasActionSecondary && (0, _react2.jsx)(_toast_action.EuiToastAction, (0, _extends2.default)({ actionType: "secondary" }, actionSecondaryProps)); return (0, _react2.jsx)("div", { css: styles.actions }, actionPrimary, actionSecondary); }, [actionProps, color, styles]); return (0, _react2.jsx)("div", (0, _extends2.default)({ css: cssStyles, className: classes, style: _objectSpread(_objectSpread({}, cssVariables), style) }, rest), (0, _react2.jsx)("div", { className: "euiToastDecor", css: decorCssStyles, role: "presentation" }), (0, _react2.jsx)(_accessibility.EuiScreenReaderOnly, null, (0, _react2.jsx)("p", null, (0, _react2.jsx)(_i18n.EuiI18n, { token: "euiToast.newNotification", default: "A new notification appears" }))), (0, _react2.jsx)("div", { css: styles.wrapper }, (0, _react2.jsx)("div", { css: styles.body }, icon, (0, _react2.jsx)("div", { css: styles.content }, // Note: the DOM position of the dismiss button matters to screen reader users. // We generally want them to have some context of _what_ they're dismissing, // instead of navigating to the dismiss button first before the content header && optionalChildren ? (0, _react2.jsx)(_react.default.Fragment, null, header, dismissButton, optionalChildren) : (0, _react2.jsx)(_react.default.Fragment, null, header || optionalChildren, dismissButton))), actionControls)); };