UNPKG

3.55 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 closeClassName: PropTypes.string,
18 closeAriaLabel: PropTypes.string,
19 cssModule: PropTypes.object,
20 color: PropTypes.string,
21 fade: PropTypes.bool,
22 isOpen: PropTypes.bool,
23 toggle: PropTypes.func,
24 tag: tagPropType,
25 transition: PropTypes.shape(Fade.propTypes),
26 innerRef: PropTypes.oneOfType([PropTypes.object, PropTypes.string, PropTypes.func])
27};
28var defaultProps = {
29 color: 'success',
30 isOpen: true,
31 tag: 'div',
32 closeAriaLabel: 'Close',
33 fade: true,
34 transition: _objectSpread(_objectSpread({}, Fade.defaultProps), {}, {
35 unmountOnExit: true
36 })
37};
38
39function Alert(props) {
40 var className = props.className,
41 closeClassName = props.closeClassName,
42 closeAriaLabel = props.closeAriaLabel,
43 cssModule = props.cssModule,
44 Tag = props.tag,
45 color = props.color,
46 isOpen = props.isOpen,
47 toggle = props.toggle,
48 children = props.children,
49 transition = props.transition,
50 fade = props.fade,
51 innerRef = props.innerRef,
52 attributes = _objectWithoutPropertiesLoose(props, ["className", "closeClassName", "closeAriaLabel", "cssModule", "tag", "color", "isOpen", "toggle", "children", "transition", "fade", "innerRef"]);
53
54 var classes = mapToCssModules(classNames(className, 'alert', "alert-" + color, {
55 'alert-dismissible': toggle
56 }), cssModule);
57 var closeClasses = mapToCssModules(classNames('close', closeClassName), cssModule);
58
59 var alertTransition = _objectSpread(_objectSpread(_objectSpread({}, Fade.defaultProps), transition), {}, {
60 baseClass: fade ? transition.baseClass : '',
61 timeout: fade ? transition.timeout : 0
62 });
63
64 return /*#__PURE__*/React.createElement(Fade, _extends({}, attributes, alertTransition, {
65 tag: Tag,
66 className: classes,
67 in: isOpen,
68 role: "alert",
69 innerRef: innerRef
70 }), toggle ? /*#__PURE__*/React.createElement("button", {
71 type: "button",
72 className: closeClasses,
73 "aria-label": closeAriaLabel,
74 onClick: toggle
75 }, /*#__PURE__*/React.createElement("span", {
76 "aria-hidden": "true"
77 }, "\xD7")) : null, children);
78}
79
80Alert.propTypes = propTypes;
81Alert.defaultProps = defaultProps;
82export default Alert;
\No newline at end of file