UNPKG

kepler.gl

Version:

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

312 lines (270 loc) 32.4 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.SaveExportDropdown = exports.PanelAction = undefined; var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral'); var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2); var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n background-color: ', ';\n padding: 12px 16px 0 16px;\n'], ['\n background-color: ', ';\n padding: 12px 16px 0 16px;\n']), _templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n display: flex;\n justify-content: space-between;\n margin-bottom: 16px;\n width: 100%;\n'], ['\n display: flex;\n justify-content: space-between;\n margin-bottom: 16px;\n width: 100%;\n']), _templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n display: flex;\n'], ['\n display: flex;\n']), _templateObject4 = (0, _taggedTemplateLiteral3.default)(['\n align-items: center;\n border-radius: 2px;\n color: ', ';\n display: flex;\n height: 26px;\n justify-content: space-between;\n margin-left: 4px;\n width: 70px;\n padding: 5px;\n font-weight: bold;\n a {\n height: 20px;\n }\n\n :hover {\n cursor: pointer;\n background-color: ', ';\n color: ', ';\n\n a {\n color: ', ';\n }\n }\n'], ['\n align-items: center;\n border-radius: 2px;\n color: ', ';\n display: flex;\n height: 26px;\n justify-content: space-between;\n margin-left: 4px;\n width: 70px;\n padding: 5px;\n font-weight: bold;\n a {\n height: 20px;\n }\n\n :hover {\n cursor: pointer;\n background-color: ', ';\n color: ', ';\n\n a {\n color: ', ';\n }\n }\n']), _templateObject5 = (0, _taggedTemplateLiteral3.default)(['\n background-color: ', ';\n box-shadow: ', ';\n font-size: 11px;\n padding: 16px 0;\n position: absolute;\n transition: ', ';\n display: flex;\n margin-top: ', ';\n opacity: ', ';\n transform: translateX(calc(-50% + 20px));\n pointer-events: ', ';\n z-index: 1000;\n\n .save-export-dropdown__inner {\n box-shadow: none;\n background-color: transparent;\n display: flex;\n }\n\n .save-export-dropdown__item {\n align-items: center;\n border-right: 1px solid ', ';\n color: ', ';\n display: flex;\n flex-direction: column;\n padding: 0 22px;\n\n :hover {\n cursor: pointer;\n color: ', ';\n }\n\n &:last-child {\n border-right: 0;\n }\n }\n\n .save-export-dropdown__title {\n white-space: nowrap;\n margin-top: 4px;\n }\n'], ['\n background-color: ', ';\n box-shadow: ', ';\n font-size: 11px;\n padding: 16px 0;\n position: absolute;\n transition: ', ';\n display: flex;\n margin-top: ', ';\n opacity: ', ';\n transform: translateX(calc(-50% + 20px));\n pointer-events: ', ';\n z-index: 1000;\n\n .save-export-dropdown__inner {\n box-shadow: none;\n background-color: transparent;\n display: flex;\n }\n\n .save-export-dropdown__item {\n align-items: center;\n border-right: 1px solid ', ';\n color: ', ';\n display: flex;\n flex-direction: column;\n padding: 0 22px;\n\n :hover {\n cursor: pointer;\n color: ', ';\n }\n\n &:last-child {\n border-right: 0;\n }\n }\n\n .save-export-dropdown__title {\n white-space: nowrap;\n margin-top: 4px;\n }\n']); // Copyright (c) 2018 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _styledComponents3 = require('../common/styled-components'); var _logo = require('../common/logo'); var _logo2 = _interopRequireDefault(_logo); var _icons = require('../common/icons'); var _panelDropdown = require('./panel-dropdown'); var _panelDropdown2 = _interopRequireDefault(_panelDropdown); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var StyledPanelHeader = _styledComponents2.default.div.attrs({ className: 'side-side-panel__header' })(_templateObject, function (props) { return props.theme.sidePanelHeaderBg; }); var StyledPanelHeaderTop = _styledComponents2.default.div.attrs({ className: 'side-panel__header__top' })(_templateObject2); var StyledPanelTopActions = _styledComponents2.default.div.attrs({ className: 'side-panel__header__actions' })(_templateObject3); var StyledPanelAction = _styledComponents2.default.div.attrs({ className: 'side-panel__header__actions' })(_templateObject4, function (props) { return props.active ? props.theme.textColorHl : props.theme.subtextColor; }, function (props) { return props.theme.secondaryBtnActBgd; }, function (props) { return props.theme.textColorHl; }, function (props) { return props.theme.textColorHl; }); var StyledPanelDropdown = _styledComponents2.default.div(_templateObject5, function (props) { return props.theme.dropdownListBgd; }, function (props) { return props.theme.dropdownListShadow; }, function (props) { return props.theme.transitionSlow; }, function (props) { return props.show ? '6px' : '20px'; }, function (props) { return props.show ? 1 : 0; }, function (props) { return props.show ? 'all' : 'none'; }, function (props) { return props.theme.panelHeaderIcon; }, function (props) { return props.theme.textColor; }, function (props) { return props.theme.textColorHl; }); var PanelAction = exports.PanelAction = function PanelAction(_ref) { var item = _ref.item, onClick = _ref.onClick; return _react2.default.createElement( StyledPanelAction, { className: 'side-panel__panel-header__action', 'data-tip': true, 'data-for': item.id + '-action', onClick: onClick }, item.label ? _react2.default.createElement( 'p', null, item.label ) : null, _react2.default.createElement( 'a', { target: item.blank ? '_blank' : '', href: item.href }, _react2.default.createElement(item.iconComponent, { height: '20px' }) ), item.tooltip ? _react2.default.createElement( _styledComponents3.Tooltip, { id: item.id + '-action', place: 'bottom', delayShow: 500, effect: 'solid' }, _react2.default.createElement( 'span', null, item.tooltip ) ) : null ); }; var PanelItem = function PanelItem(_ref2) { var onClose = _ref2.onClose, onClickHandler = _ref2.onClickHandler, label = _ref2.label, icon = _ref2.icon; return _react2.default.createElement( 'div', { className: 'save-export-dropdown__item', onClick: function onClick(e) { e.stopPropagation(); onClose(); onClickHandler(); } }, icon, _react2.default.createElement( 'div', { className: 'save-export-dropdown__title' }, label ) ); }; var SaveExportDropdown = exports.SaveExportDropdown = function SaveExportDropdown(_ref3) { var onExportImage = _ref3.onExportImage, onExportData = _ref3.onExportData, onExportConfig = _ref3.onExportConfig, onSaveMap = _ref3.onSaveMap, show = _ref3.show, onClose = _ref3.onClose; return _react2.default.createElement( StyledPanelDropdown, { show: show, className: 'save-export-dropdown' }, _react2.default.createElement( _panelDropdown2.default, { className: 'save-export-dropdown__inner', show: show, onClose: onClose }, _react2.default.createElement(PanelItem, { label: 'Export Image', onClickHandler: onExportImage, onClose: onClose, icon: _react2.default.createElement(_icons.Picture, { height: '16px' }) }), _react2.default.createElement(PanelItem, { label: 'Export Data', onClickHandler: onExportData, onClose: onClose, icon: _react2.default.createElement(_icons.Files, { height: '16px' }) }), _react2.default.createElement(PanelItem, { label: 'Export Config', onClickHandler: onExportConfig, onClose: onClose, icon: _react2.default.createElement(_icons.CodeAlt, { height: '16px' }) }), onSaveMap ? _react2.default.createElement(PanelItem, { label: 'Save Map Url', onClickHandler: onSaveMap, onClose: onClose, icon: _react2.default.createElement(_icons.Share, { height: '16px' }) }) : null ) ); }; var defaultActionItems = [{ id: 'save', iconComponent: _icons.Save, onClick: function onClick() {}, label: 'Share', dropdownComponent: SaveExportDropdown }]; function PanelHeaderFactory() { var _class, _temp; return _temp = _class = function (_Component) { (0, _inherits3.default)(PanelHeader, _Component); function PanelHeader() { (0, _classCallCheck3.default)(this, PanelHeader); return (0, _possibleConstructorReturn3.default)(this, (PanelHeader.__proto__ || Object.getPrototypeOf(PanelHeader)).apply(this, arguments)); } (0, _createClass3.default)(PanelHeader, [{ key: 'render', value: function render() { var _props = this.props, appName = _props.appName, version = _props.version, actionItems = _props.actionItems, onSaveMap = _props.onSaveMap, onExportImage = _props.onExportImage, onExportData = _props.onExportData, onExportConfig = _props.onExportConfig, visibleDropdown = _props.visibleDropdown, showExportDropdown = _props.showExportDropdown, hideExportDropdown = _props.hideExportDropdown; return _react2.default.createElement( StyledPanelHeader, { className: 'side-panel__panel-header' }, _react2.default.createElement( StyledPanelHeaderTop, { className: 'side-panel__panel-header__top' }, _react2.default.createElement(this.props.logoComponent, { appName: appName, version: version }), _react2.default.createElement( StyledPanelTopActions, null, actionItems.map(function (item) { return _react2.default.createElement( 'div', { className: 'side-panel__panel-header__right', key: item.id, style: { position: 'relative' } }, _react2.default.createElement(PanelAction, { item: item, onClick: function onClick() { if (item.dropdownComponent) { showExportDropdown(item.id); } item.onClick(); } }), item.dropdownComponent ? _react2.default.createElement(item.dropdownComponent, { onClose: hideExportDropdown, show: visibleDropdown === item.id, onSaveMap: onSaveMap, onExportData: onExportData, onExportImage: onExportImage, onExportConfig: onExportConfig }) : null ); }) ) ) ); } }]); return PanelHeader; }(_react.Component), _class.propTypes = { appName: _propTypes2.default.string, version: _propTypes2.default.string, uiState: _propTypes2.default.object, uiStateActions: _propTypes2.default.object, logoComponent: _propTypes2.default.oneOfType([_propTypes2.default.element, _propTypes2.default.func]), actionItems: _propTypes2.default.arrayOf(_propTypes2.default.any) }, _class.defaultProps = { logoComponent: _logo2.default, actionItems: defaultActionItems }, _temp; } exports.default = PanelHeaderFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/panel-header.js"],"names":["StyledPanelHeader","styled","div","attrs","className","props","theme","sidePanelHeaderBg","StyledPanelHeaderTop","StyledPanelTopActions","StyledPanelAction","active","textColorHl","subtextColor","secondaryBtnActBgd","StyledPanelDropdown","dropdownListBgd","dropdownListShadow","transitionSlow","show","panelHeaderIcon","textColor","PanelAction","item","onClick","id","label","blank","href","tooltip","PanelItem","onClose","onClickHandler","icon","e","stopPropagation","SaveExportDropdown","onExportImage","onExportData","onExportConfig","onSaveMap","defaultActionItems","iconComponent","Save","dropdownComponent","PanelHeaderFactory","appName","version","actionItems","visibleDropdown","showExportDropdown","hideExportDropdown","map","position","Component","propTypes","PropTypes","string","uiState","object","uiStateActions","logoComponent","oneOfType","element","func","arrayOf","any","defaultProps","KeplerGlLogo"],"mappings":"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","file":"panel-header.js","sourcesContent":["// Copyright (c) 2018 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 styled from 'styled-components';\nimport PropTypes from 'prop-types';\nimport {Tooltip} from 'components/common/styled-components';\nimport KeplerGlLogo from 'components/common/logo';\nimport {CodeAlt, Save, Files, Share, Picture} from 'components/common/icons';\nimport ClickOutsideCloseDropdown from 'components/side-panel/panel-dropdown';\n\nconst StyledPanelHeader = styled.div.attrs({\n  className: 'side-side-panel__header'\n})`\n  background-color: ${props => props.theme.sidePanelHeaderBg};\n  padding: 12px 16px 0 16px;\n`;\n\nconst StyledPanelHeaderTop = styled.div.attrs({\n  className: 'side-panel__header__top'\n})`\n  display: flex;\n  justify-content: space-between;\n  margin-bottom: 16px;\n  width: 100%;\n`;\n\nconst StyledPanelTopActions = styled.div.attrs({\n  className: 'side-panel__header__actions'\n})`\n  display: flex;\n`;\n\nconst StyledPanelAction = styled.div.attrs({\n  className: 'side-panel__header__actions'\n})`\n  align-items: center;\n  border-radius: 2px;\n  color: ${props =>\n    props.active ? props.theme.textColorHl : props.theme.subtextColor};\n  display: flex;\n  height: 26px;\n  justify-content: space-between;\n  margin-left: 4px;\n  width: 70px;\n  padding: 5px;\n  font-weight: bold;\n  a {\n    height: 20px;\n  }\n\n  :hover {\n    cursor: pointer;\n    background-color: ${props => props.theme.secondaryBtnActBgd};\n    color: ${props => props.theme.textColorHl};\n\n    a {\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nconst StyledPanelDropdown = styled.div`\n  background-color: ${props => props.theme.dropdownListBgd};\n  box-shadow: ${props => props.theme.dropdownListShadow};\n  font-size: 11px;\n  padding: 16px 0;\n  position: absolute;\n  transition: ${props => props.theme.transitionSlow};\n  display: flex;\n  margin-top: ${props => props.show ? '6px' : '20px'};\n  opacity: ${props => props.show ? 1 : 0};\n  transform: translateX(calc(-50% + 20px));\n  pointer-events:  ${props => props.show ? 'all' : 'none'};\n  z-index: 1000;\n\n  .save-export-dropdown__inner {\n    box-shadow: none;\n    background-color: transparent;\n    display: flex;\n  }\n\n  .save-export-dropdown__item {\n    align-items: center;\n    border-right: 1px solid ${props => props.theme.panelHeaderIcon};\n    color: ${props => props.theme.textColor};\n    display: flex;\n    flex-direction: column;\n    padding: 0 22px;\n\n    :hover {\n      cursor: pointer;\n      color: ${props => props.theme.textColorHl};\n    }\n\n    &:last-child {\n      border-right: 0;\n    }\n  }\n\n  .save-export-dropdown__title {\n    white-space: nowrap;\n    margin-top: 4px;\n  }\n`;\n\nexport const PanelAction = ({item, onClick}) => (\n  <StyledPanelAction className=\"side-panel__panel-header__action\"\n    data-tip data-for={`${item.id}-action`} onClick={onClick}>\n    {item.label ? <p>{item.label}</p> : null}\n    <a target={item.blank ? '_blank' : ''} href={item.href}>\n      <item.iconComponent height=\"20px\" />\n    </a>\n    {item.tooltip ? (<Tooltip\n      id={`${item.id}-action`}\n      place=\"bottom\"\n      delayShow={500}\n      effect=\"solid\"\n    >\n      <span>{item.tooltip}</span>\n    </Tooltip>) : null }\n  </StyledPanelAction>\n);\n\nconst PanelItem = ({onClose, onClickHandler, label, icon}) => (\n  <div className=\"save-export-dropdown__item\" onClick={(e) => {\n    e.stopPropagation();\n    onClose();\n    onClickHandler();\n  }}>\n    {icon}\n    <div className=\"save-export-dropdown__title\">{label}</div>\n  </div>\n);\n\nexport const SaveExportDropdown = ({\n  onExportImage,\n  onExportData,\n  onExportConfig,\n  onSaveMap,\n  show,\n  onClose\n}) => {\n  return (\n    <StyledPanelDropdown show={show} className=\"save-export-dropdown\">\n      <ClickOutsideCloseDropdown className=\"save-export-dropdown__inner\"\n        show={show}\n        onClose={onClose}>\n        <PanelItem\n          label=\"Export Image\"\n          onClickHandler={onExportImage}\n          onClose={onClose}\n          icon={(<Picture height=\"16px\" />)}\n        />\n\n        <PanelItem\n          label=\"Export Data\"\n          onClickHandler={onExportData}\n          onClose={onClose}\n          icon={(<Files height=\"16px\" />)}\n        />\n\n        <PanelItem\n          label=\"Export Config\"\n          onClickHandler={onExportConfig}\n          onClose={onClose}\n          icon={(<CodeAlt height=\"16px\" />)}\n        />\n\n        {onSaveMap ? (\n          <PanelItem\n            label=\"Save Map Url\"\n            onClickHandler={onSaveMap}\n            onClose={onClose}\n            icon={(<Share height=\"16px\" />)}\n          />\n        ) : null}\n      </ClickOutsideCloseDropdown>\n    </StyledPanelDropdown>\n  );\n};\n\nconst defaultActionItems = [\n  {\n    id: 'save',\n    iconComponent: Save,\n    onClick: () => {},\n    label: 'Share',\n    dropdownComponent: SaveExportDropdown\n  }\n];\n\nfunction PanelHeaderFactory() {\n  return class PanelHeader extends Component {\n    static propTypes = {\n      appName: PropTypes.string,\n      version: PropTypes.string,\n      uiState: PropTypes.object,\n      uiStateActions: PropTypes.object,\n      logoComponent: PropTypes.oneOfType([PropTypes.element, PropTypes.func]),\n      actionItems: PropTypes.arrayOf(PropTypes.any)\n    };\n\n    static defaultProps = {\n      logoComponent: KeplerGlLogo,\n      actionItems: defaultActionItems\n    };\n\n    render() {\n      const {\n        appName,\n        version,\n        actionItems,\n        onSaveMap,\n        onExportImage,\n        onExportData,\n        onExportConfig,\n        visibleDropdown,\n        showExportDropdown,\n        hideExportDropdown\n      } = this.props;\n\n      return (\n        <StyledPanelHeader className=\"side-panel__panel-header\">\n          <StyledPanelHeaderTop className=\"side-panel__panel-header__top\">\n            <this.props.logoComponent appName={appName} version={version}/>\n            <StyledPanelTopActions>\n              {actionItems.map(item => (\n                <div className=\"side-panel__panel-header__right\"\n                     key={item.id} style={{position: 'relative'}}>\n                  <PanelAction\n                    item={item}\n                    onClick={() => {\n                      if (item.dropdownComponent) {\n                        showExportDropdown(item.id);\n                      }\n                      item.onClick();\n                    }}\n                  />\n                  {item.dropdownComponent ? (\n                    <item.dropdownComponent\n                      onClose={hideExportDropdown}\n                      show={visibleDropdown === item.id}\n                      onSaveMap={onSaveMap}\n                      onExportData={onExportData}\n                      onExportImage={onExportImage}\n                      onExportConfig={onExportConfig}\n                    />\n                  ) : null}\n                </div>\n              ))}\n            </StyledPanelTopActions>\n          </StyledPanelHeaderTop>\n        </StyledPanelHeader>\n      );\n    }\n  }\n}\n\nexport default PanelHeaderFactory;\n"]}