kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
200 lines (157 loc) • 17.5 kB
JavaScript
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = NotificationItemFactory;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _icons = require("../common/icons");
var _reactMarkdown = _interopRequireDefault(require("react-markdown"));
function _templateObject4() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n svg {\n vertical-align: text-top;\n }\n"]);
_templateObject4 = function _templateObject4() {
return data;
};
return data;
}
function _templateObject3() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n flex-grow: 2;\n width: ", "px;\n margin: 0 1em;\n overflow: ", ";\n padding-right: ", ";\n\n p {\n margin-top: 0;\n a {\n color: #fff;\n text-decoration: underline;\n }\n }\n"]);
_templateObject3 = function _templateObject3() {
return data;
};
return data;
}
function _templateObject2() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n cursor: pointer;\n"]);
_templateObject2 = function _templateObject2() {
return data;
};
return data;
}
function _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n color: #fff;\n display: flex;\n flex-direction: row;\n width: ", "px;\n height: ", "px;\n font-size: 11px;\n margin-bottom: 1rem;\n padding: 1em;\n border-radius: 4px;\n box-shadow: ", ";\n cursor: pointer;\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
var NotificationItemContent = _styledComponents["default"].div(_templateObject(), function (props) {
return props.theme.notificationColors[props.type] || '#000';
}, function (props) {
return props.theme.notificationPanelItemWidth * (1 + Number(props.isExpanded));
}, function (props) {
return props.theme.notificationPanelItemHeight * (1 + Number(props.isExpanded));
}, function (props) {
return props.theme.boxShadow;
});
var DeleteIcon = (0, _styledComponents["default"])(_icons.Delete)(_templateObject2());
var NotificationMessage = _styledComponents["default"].div.attrs({
className: 'notification-item--message'
})(_templateObject3(), function (props) {
return props.theme.notificationPanelItemWidth;
}, function (props) {
return props.isExpanded ? 'auto' : 'hidden';
}, function (props) {
return props.isExpanded ? '1em' : 0;
});
var NotificationIcon = _styledComponents["default"].div(_templateObject4());
var icons = {
info: _react["default"].createElement(_icons.Info, null),
warning: _react["default"].createElement(_icons.Warning, null),
error: _react["default"].createElement(_icons.Warning, null),
success: _react["default"].createElement(_icons.Checkmark, null)
};
var LinkRenderer = function LinkRenderer(props) {
return _react["default"].createElement("a", {
href: props.href,
target: "_blank",
rel: "noopener noreferrer"
}, props.children);
};
function NotificationItemFactory() {
var _class, _temp;
return _temp = _class =
/*#__PURE__*/
function (_Component) {
(0, _inherits2["default"])(NotificationItem, _Component);
function NotificationItem() {
var _getPrototypeOf2;
var _this;
(0, _classCallCheck2["default"])(this, NotificationItem);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(NotificationItem)).call.apply(_getPrototypeOf2, [this].concat(args)));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", {
isExpanded: false
});
return _this;
}
(0, _createClass2["default"])(NotificationItem, [{
key: "componentDidMount",
value: function componentDidMount() {
if (this.props.isExpanded) {
this.setState({
isExpanded: true
});
}
}
}, {
key: "render",
value: function render() {
var _this2 = this;
var _this$props = this.props,
notification = _this$props.notification,
removeNotification = _this$props.removeNotification;
var isExpanded = this.state.isExpanded;
return _react["default"].createElement(NotificationItemContent, {
className: "notification-item",
type: notification.type,
isExpanded: isExpanded,
onClick: function onClick() {
return _this2.setState({
isExpanded: !isExpanded
});
}
}, _react["default"].createElement(NotificationIcon, {
className: "notification-item--icon"
}, icons[notification.type]), _react["default"].createElement(NotificationMessage, {
isExpanded: isExpanded,
theme: this.props.theme
}, _react["default"].createElement(_reactMarkdown["default"], {
source: notification.message,
renderers: {
link: LinkRenderer
}
})), typeof removeNotification === 'function' ? _react["default"].createElement("div", {
className: "notification-item--action"
}, _react["default"].createElement(DeleteIcon, {
height: "10px",
onClick: function onClick() {
return removeNotification(notification.id);
}
})) : null);
}
}]);
return NotificationItem;
}(_react.Component), (0, _defineProperty2["default"])(_class, "propTypes", {
notification: _propTypes["default"].shape({
id: _propTypes["default"].string.isRequired,
type: _propTypes["default"].string.isRequired,
message: _propTypes["default"].string.isRequired
}).isRequired,
isExpanded: _propTypes["default"].bool
}), _temp;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/notification-panel/notification-item.js"],"names":["NotificationItemContent","styled","div","props","theme","notificationColors","type","notificationPanelItemWidth","Number","isExpanded","notificationPanelItemHeight","boxShadow","DeleteIcon","Delete","NotificationMessage","attrs","className","NotificationIcon","icons","info","warning","error","success","LinkRenderer","href","children","NotificationItemFactory","setState","notification","removeNotification","state","message","link","id","Component","PropTypes","shape","string","isRequired","bool"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport styled from 'styled-components';\nimport {Delete, Info, Warning, Checkmark} from 'components/common/icons';\nimport ReactMarkdown from 'react-markdown';\n\nconst NotificationItemContent = styled.div`\n  background-color: ${props => props.theme.notificationColors[props.type] || '#000'};\n  color: #fff;\n  display: flex;\n  flex-direction: row;\n  width: ${props => props.theme.notificationPanelItemWidth * (1 + Number(props.isExpanded))}px;\n  height: ${props => props.theme.notificationPanelItemHeight * (1 + Number(props.isExpanded))}px;\n  font-size: 11px;\n  margin-bottom: 1rem;\n  padding: 1em;\n  border-radius: 4px;\n  box-shadow: ${props => props.theme.boxShadow};\n  cursor: pointer;\n`;\n\nconst DeleteIcon = styled(Delete)`\n  cursor: pointer;\n`;\n\nconst NotificationMessage = styled.div.attrs({\n  className: 'notification-item--message'\n})`\n  flex-grow: 2;\n  width: ${props => props.theme.notificationPanelItemWidth}px;\n  margin: 0 1em;\n  overflow: ${props => (props.isExpanded ? 'auto' : 'hidden')};\n  padding-right: ${props => (props.isExpanded ? '1em' : 0)};\n\n  p {\n    margin-top: 0;\n    a {\n      color: #fff;\n      text-decoration: underline;\n    }\n  }\n`;\n\nconst NotificationIcon = styled.div`\n  svg {\n    vertical-align: text-top;\n  }\n`;\n\nconst icons = {\n  info: <Info />,\n  warning: <Warning />,\n  error: <Warning />,\n  success: <Checkmark />\n};\n\nconst LinkRenderer = props => {\n  return (\n    <a href={props.href} target=\"_blank\" rel=\"noopener noreferrer\">\n      {props.children}\n    </a>\n  );\n};\n\nexport default function NotificationItemFactory() {\n  return class NotificationItem extends Component {\n    static propTypes = {\n      notification: PropTypes.shape({\n        id: PropTypes.string.isRequired,\n        type: PropTypes.string.isRequired,\n        message: PropTypes.string.isRequired\n      }).isRequired,\n      isExpanded: PropTypes.bool\n    };\n\n    state = {\n      isExpanded: false\n    };\n\n    componentDidMount() {\n      if (this.props.isExpanded) {\n        this.setState({isExpanded: true});\n      }\n    }\n\n    render() {\n      const {notification, removeNotification} = this.props;\n      const {isExpanded} = this.state;\n\n      return (\n        <NotificationItemContent\n          className=\"notification-item\"\n          type={notification.type}\n          isExpanded={isExpanded}\n          onClick={() => this.setState({isExpanded: !isExpanded})}\n        >\n          <NotificationIcon className=\"notification-item--icon\">\n            {icons[notification.type]}\n          </NotificationIcon>\n          <NotificationMessage isExpanded={isExpanded} theme={this.props.theme}>\n            <ReactMarkdown source={notification.message} renderers={{link: LinkRenderer}} />\n          </NotificationMessage>\n          {typeof removeNotification === 'function' ? (\n            <div className=\"notification-item--action\">\n              <DeleteIcon height=\"10px\" onClick={() => removeNotification(notification.id)} />\n            </div>\n          ) : null}\n        </NotificationItemContent>\n      );\n    }\n  };\n}\n"]}
;