UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

164 lines (130 loc) 17.9 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); 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 _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); 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")); var _templateObject, _templateObject2, _templateObject3, _templateObject4; function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } var NotificationItemContent = _styledComponents["default"].div(_templateObject || (_templateObject = (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"])), 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 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n cursor: pointer;\n"]))); var NotificationMessage = _styledComponents["default"].div.attrs({ className: 'notification-item--message' })(_templateObject3 || (_templateObject3 = (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"])), 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 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n svg {\n vertical-align: text-top;\n }\n"]))); var icons = { info: /*#__PURE__*/_react["default"].createElement(_icons.Info, null), warning: /*#__PURE__*/_react["default"].createElement(_icons.Warning, null), error: /*#__PURE__*/_react["default"].createElement(_icons.Warning, null), success: /*#__PURE__*/_react["default"].createElement(_icons.Checkmark, null) }; var LinkRenderer = function LinkRenderer(props) { return /*#__PURE__*/_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); var _super = _createSuper(NotificationItem); function NotificationItem() { 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 = _super.call.apply(_super, [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 /*#__PURE__*/_react["default"].createElement(NotificationItemContent, { className: "notification-item", type: notification.type, isExpanded: isExpanded, onClick: function onClick() { return _this2.setState({ isExpanded: !isExpanded }); } }, /*#__PURE__*/_react["default"].createElement(NotificationIcon, { className: "notification-item--icon" }, icons[notification.type]), /*#__PURE__*/_react["default"].createElement(NotificationMessage, { isExpanded: isExpanded, theme: this.props.theme }, /*#__PURE__*/_react["default"].createElement(_reactMarkdown["default"], { source: notification.message, renderers: { link: LinkRenderer } })), typeof removeNotification === 'function' ? /*#__PURE__*/_react["default"].createElement("div", { className: "notification-item--action" }, /*#__PURE__*/_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) 2021 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"]}