@roo-ui/components
Version:
124 lines (100 loc) • 3.47 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var _templateObject = _taggedTemplateLiteral([''], ['']);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _cleanElement = require('clean-element');
var _cleanElement2 = _interopRequireDefault(_cleanElement);
var _ = require('..');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _taggedTemplateLiteral(strings, raw) { return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
var CleanDiv = (0, _cleanElement2.default)('div');
var Base = function Base(_ref) {
var children = _ref.children,
icon = _ref.icon,
onClose = _ref.onClose,
contained = _ref.contained,
props = _objectWithoutProperties(_ref, ['children', 'icon', 'onClose', 'contained']);
var Wrapper = contained ? _.Container : _.Box;
return _react2.default.createElement(
CleanDiv,
props,
_react2.default.createElement(
Wrapper,
{ px: contained ? undefined : 4 },
_react2.default.createElement(
_.Flex,
{ py: 4 },
icon && _react2.default.createElement(
_.Box,
{ pr: 3 },
_react2.default.createElement(_.Icon, icon)
),
_react2.default.createElement(
_.Text,
{ mb: 0, textAlign: 'left' },
children
),
onClose && _react2.default.createElement(
_.Box,
{ ml: 'auto', pl: 3 },
_react2.default.createElement(
_.NakedButton,
{ onClick: onClose },
_react2.default.createElement(_.Icon, { name: 'close' })
)
)
)
)
);
};
Base.propTypes = {
children: _propTypes2.default.node.isRequired,
icon: _propTypes2.default.shape(_.Icon.propTypes),
contained: _propTypes2.default.bool,
onClose: _propTypes2.default.func
};
Base.defaultProps = {
contained: false,
icon: null,
onClose: null
};
var Alert = _.Box.withComponent(Base);
Alert.defaultProps = _extends({}, _.Box.defaultProps, {
bg: 'grey.3',
mb: 3
});
Alert.info = Alert.extend(_templateObject);
Alert.info.displayName = 'Alert';
Alert.info.defaultProps = _extends({}, Alert.defaultProps, {
bg: 'ui.infoBackground',
icon: {
name: 'info',
color: 'grey.0'
}
});
Alert.success = Alert.extend(_templateObject);
Alert.success.displayName = 'Alert';
Alert.success.defaultProps = _extends({}, Alert.defaultProps, {
bg: 'ui.successBackground',
icon: {
name: 'checkCircle',
color: 'ui.success'
}
});
Alert.error = Alert.extend(_templateObject);
Alert.error.displayName = 'Alert';
Alert.error.defaultProps = _extends({}, Alert.defaultProps, {
bg: 'ui.errorBackground',
icon: {
name: 'warning',
color: 'ui.error'
}
});
exports.default = Alert;