@elastic/eui
Version:
Elastic UI Component Library
181 lines (180 loc) • 9.78 kB
JavaScript
"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));
};