kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
172 lines (138 loc) • 16.9 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = 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 _class, _temp2;
var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n z-index: 99;\n height: 100%;\n width: ', 'px;\n display: flex;\n transition: width 250ms;\n position: absolute;\n padding-top: ', 'px;\n padding-right: ', 'px;\n padding-bottom: ', 'px;\n padding-left: ', 'px;\n'], ['\n z-index: 99;\n height: 100%;\n width: ', 'px;\n display: flex;\n transition: width 250ms;\n position: absolute;\n padding-top: ', 'px;\n padding-right: ', 'px;\n padding-bottom: ', 'px;\n padding-left: ', 'px;\n']),
_templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n transition: left 250ms, right 250ms;\n left: ', 'px;\n align-items: stretch;\n flex-grow: 1;\n'], ['\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n transition: left 250ms, right 250ms;\n left: ', 'px;\n align-items: stretch;\n flex-grow: 1;\n']),
_templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n background-color: ', ';\n border-radius: 1px;\n display: flex;\n flex-direction: column;\n height: 100%;\n'], ['\n background-color: ', ';\n border-radius: 1px;\n display: flex;\n flex-direction: column;\n height: 100%;\n']),
_templateObject4 = (0, _taggedTemplateLiteral3.default)(['\n align-items: center;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n justify-content: center;\n background-color: ', ';\n border-radius: 1px;\n color: ', ';\n display: flex;\n height: 20px;\n position: absolute;\n right: -8px;\n top: ', 'px;\n width: 20px;\n\n :hover {\n cursor: pointer;\n box-shadow: none;\n background-color: ', ';\n }\n'], ['\n align-items: center;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n justify-content: center;\n background-color: ', ';\n border-radius: 1px;\n color: ', ';\n display: flex;\n height: 20px;\n position: absolute;\n right: -8px;\n top: ', 'px;\n width: 20px;\n\n :hover {\n cursor: pointer;\n box-shadow: none;\n background-color: ', ';\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 _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _styledComponents = require('styled-components');
var _styledComponents2 = _interopRequireDefault(_styledComponents);
var _icons = require('../common/icons');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var StyledSidePanelContainer = _styledComponents2.default.div(_templateObject, function (props) {
return props.width + 2 * props.theme.sidePanel.margin.left;
}, function (props) {
return props.theme.sidePanel.margin.top;
}, function (props) {
return props.theme.sidePanel.margin.right;
}, function (props) {
return props.theme.sidePanel.margin.bottom;
}, function (props) {
return props.theme.sidePanel.margin.left;
});
var SideBarContainer = _styledComponents2.default.div(_templateObject2, function (props) {
return props.left;
});
var SideBarInner = _styledComponents2.default.div(_templateObject3, function (props) {
return props.theme.sidePanelBg;
});
var CollapseButton = _styledComponents2.default.div(_templateObject4, function (props) {
return props.theme.sideBarCloseBtnBgd;
}, function (props) {
return props.theme.sideBarCloseBtnColor;
}, function (props) {
return props.theme.sidePanel.margin.top;
}, function (props) {
return props.theme.sideBarCloseBtnBgdHover;
});
var SideBar = (_temp2 = _class = function (_Component) {
(0, _inherits3.default)(SideBar, _Component);
function SideBar() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, SideBar);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = SideBar.__proto__ || Object.getPrototypeOf(SideBar)).call.apply(_ref, [this].concat(args))), _this), _this._onOpenOrClose = function () {
_this.props.onOpenOrClose({ isOpen: !_this.props.isOpen });
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
(0, _createClass3.default)(SideBar, [{
key: 'render',
value: function render() {
var _props = this.props,
isOpen = _props.isOpen,
minifiedWidth = _props.minifiedWidth,
width = _props.width;
var horizontalOffset = isOpen ? 0 : minifiedWidth - width;
return _react2.default.createElement(
StyledSidePanelContainer,
{
width: isOpen ? width : 0,
className: 'side-panel--container'
},
_react2.default.createElement(
SideBarContainer,
{ className: 'side-bar', style: { width: width + 'px' },
left: horizontalOffset },
isOpen ? _react2.default.createElement(
SideBarInner,
{ className: 'side-bar__inner' },
this.props.children
) : null,
_react2.default.createElement(
CollapseButton,
{
className: 'side-bar__close',
onClick: this._onOpenOrClose
},
_react2.default.createElement(_icons.ArrowRight, {
height: '12px',
style: { transform: 'rotate(' + (isOpen ? 180 : 0) + 'deg)' }
})
)
)
);
}
}]);
return SideBar;
}(_react.Component), _class.defaultProps = {
width: 300,
minifiedWidth: 0,
isOpen: true,
onOpenOrClose: function noop() {}
}, _class.propTypes = {
width: _propTypes2.default.number,
isOpen: _propTypes2.default.bool,
minifiedWidth: _propTypes2.default.number,
onOpenOrClose: _propTypes2.default.func
}, _temp2);
exports.default = SideBar;
;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/side-bar.js"],"names":["StyledSidePanelContainer","styled","div","props","width","theme","sidePanel","margin","left","top","right","bottom","SideBarContainer","SideBarInner","sidePanelBg","CollapseButton","sideBarCloseBtnBgd","sideBarCloseBtnColor","sideBarCloseBtnBgdHover","SideBar","_onOpenOrClose","onOpenOrClose","isOpen","minifiedWidth","horizontalOffset","children","transform","Component","defaultProps","noop","propTypes","PropTypes","number","bool","func"],"mappings":"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","file":"side-bar.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 PropTypes from 'prop-types';\nimport styled from 'styled-components';\nimport {ArrowRight} from 'components/common/icons';\n\nconst StyledSidePanelContainer = styled.div`\n  z-index: 99;\n  height: 100%;\n  width: ${props => props.width + 2 * props.theme.sidePanel.margin.left}px;\n  display: flex;\n  transition: width 250ms;\n  position: absolute;\n  padding-top: ${props => props.theme.sidePanel.margin.top}px;\n  padding-right: ${props => props.theme.sidePanel.margin.right}px;\n  padding-bottom: ${props => props.theme.sidePanel.margin.bottom}px;\n  padding-left: ${props => props.theme.sidePanel.margin.left}px;\n`;\n\nconst SideBarContainer = styled.div`\n  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n  transition: left 250ms, right 250ms;\n  left: ${props => props.left}px;\n  align-items: stretch;\n  flex-grow: 1;\n`;\n\nconst SideBarInner = styled.div`\n  background-color: ${props => props.theme.sidePanelBg};\n  border-radius: 1px;\n  display: flex;\n  flex-direction: column;\n  height: 100%;\n`;\n\nconst CollapseButton = styled.div`\n  align-items: center;\n  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n  justify-content: center;\n  background-color: ${props => props.theme.sideBarCloseBtnBgd};\n  border-radius: 1px;\n  color: ${props => props.theme.sideBarCloseBtnColor};\n  display: flex;\n  height: 20px;\n  position: absolute;\n  right: -8px;\n  top: ${props => props.theme.sidePanel.margin.top}px;\n  width: 20px;\n\n  :hover {\n    cursor: pointer;\n    box-shadow: none;\n    background-color: ${props => props.theme.sideBarCloseBtnBgdHover};\n  }\n`;\n\nexport default class SideBar extends Component {\n  static defaultProps = {\n    width: 300,\n    minifiedWidth: 0,\n    isOpen: true,\n    onOpenOrClose: function noop() {}\n  };\n\n  static propTypes = {\n    width: PropTypes.number,\n    isOpen: PropTypes.bool,\n    minifiedWidth: PropTypes.number,\n    onOpenOrClose: PropTypes.func\n  };\n\n  _onOpenOrClose = () => {\n    this.props.onOpenOrClose({isOpen: !this.props.isOpen});\n  };\n\n  render() {\n    const {isOpen, minifiedWidth, width} = this.props;\n    const horizontalOffset = isOpen ? 0 : minifiedWidth - width;\n\n    return (\n      <StyledSidePanelContainer\n        width={isOpen ? width : 0}\n        className=\"side-panel--container\"\n      >\n        <SideBarContainer className=\"side-bar\" style={{width: `${width}px`}}\n                          left={horizontalOffset}>\n          {isOpen ? (\n            <SideBarInner className=\"side-bar__inner\">\n              {this.props.children}\n            </SideBarInner>\n          ) : null}\n          <CollapseButton\n            className=\"side-bar__close\"\n            onClick={this._onOpenOrClose}\n          >\n            <ArrowRight\n              height=\"12px\"\n              style={{transform: `rotate(${isOpen ? 180 : 0}deg)`}}\n            />\n          </CollapseButton>\n        </SideBarContainer>\n      </StyledSidePanelContainer>\n    );\n  }\n};\n"]}
;