UNPKG

2.78 kBJavaScriptView Raw
1import _extends from "@babel/runtime/helpers/esm/extends";
2import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
3import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
4
5function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
6
7function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
8
9import React from 'react';
10import PropTypes from 'prop-types';
11import classNames from 'classnames';
12import { mapToCssModules, tagPropType } from './utils';
13import Fade from './Fade';
14var propTypes = {
15 children: PropTypes.node,
16 className: PropTypes.string,
17 cssModule: PropTypes.object,
18 fade: PropTypes.bool,
19 isOpen: PropTypes.bool,
20 tag: tagPropType,
21 transition: PropTypes.shape(Fade.propTypes),
22 innerRef: PropTypes.oneOfType([PropTypes.object, PropTypes.string, PropTypes.func])
23};
24var defaultProps = {
25 isOpen: true,
26 tag: 'div',
27 fade: true,
28 transition: _objectSpread(_objectSpread({}, Fade.defaultProps), {}, {
29 unmountOnExit: true
30 })
31};
32
33function Toast(props) {
34 var className = props.className,
35 cssModule = props.cssModule,
36 Tag = props.tag,
37 isOpen = props.isOpen,
38 children = props.children,
39 transition = props.transition,
40 fade = props.fade,
41 innerRef = props.innerRef,
42 attributes = _objectWithoutPropertiesLoose(props, ["className", "cssModule", "tag", "isOpen", "children", "transition", "fade", "innerRef"]);
43
44 var classes = mapToCssModules(classNames(className, 'toast'), cssModule);
45
46 var toastTransition = _objectSpread(_objectSpread(_objectSpread({}, Fade.defaultProps), transition), {}, {
47 baseClass: fade ? transition.baseClass : '',
48 timeout: fade ? transition.timeout : 0
49 });
50
51 return /*#__PURE__*/React.createElement(Fade, _extends({}, attributes, toastTransition, {
52 tag: Tag,
53 className: classes,
54 in: isOpen,
55 role: "alert",
56 innerRef: innerRef
57 }), children);
58}
59
60Toast.propTypes = propTypes;
61Toast.defaultProps = defaultProps;
62export default Toast;
\No newline at end of file