kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
165 lines (129 loc) • 19.3 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.CollapseButtonFactory = void 0;
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 _templateObject, _templateObject2, _templateObject3, _templateObject4;
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
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 StyledSidePanelContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["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"])), 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 = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n transition: left 250ms, right 250ms;\n left: ", "px;\n align-items: stretch;\n flex-grow: 1;\n"])), function (props) {
return props.left;
});
var SideBarInner = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n border-radius: 1px;\n display: flex;\n flex-direction: column;\n box-shadow: 8px 10px 10px -5px #00000033;\n height: 100%;\n"])), function (props) {
return props.theme.sidePanelBg;
});
var StyledCollapseButton = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["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"])), 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 CollapseButtonFactory = exports.CollapseButtonFactory = function CollapseButtonFactory() {
var CollapseButton = function CollapseButton(_ref) {
var onClick = _ref.onClick,
isOpen = _ref.isOpen;
return (/*#__PURE__*/_react["default"].createElement(StyledCollapseButton, {
className: "side-bar__close",
onClick: onClick
}, /*#__PURE__*/_react["default"].createElement(_icons.ArrowRight, {
height: "12px",
style: {
transform: "rotate(".concat(isOpen ? 180 : 0, "deg)"),
fill: 'currentColor'
}
}))
);
};
return CollapseButton;
};
SidebarFactory.deps = [CollapseButtonFactory];
function SidebarFactory(CollapseButton) {
var _class, _temp;
return _temp = _class = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(SideBar, _Component);
var _super = _createSuper(SideBar);
function SideBar() {
var _this;
(0, _classCallCheck2["default"])(this, SideBar);
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), "_onOpenOrClose", function () {
_this.props.onOpenOrClose({
isOpen: !_this.props.isOpen
});
});
return _this;
}
(0, _createClass2["default"])(SideBar, [{
key: "render",
value: function render() {
var _this$props = this.props,
isOpen = _this$props.isOpen,
minifiedWidth = _this$props.minifiedWidth,
width = _this$props.width;
var horizontalOffset = isOpen ? 0 : minifiedWidth - width;
return (/*#__PURE__*/_react["default"].createElement(StyledSidePanelContainer, {
width: isOpen ? width : 0,
className: "side-panel--container"
}, /*#__PURE__*/_react["default"].createElement(SideBarContainer, {
className: "side-bar",
style: {
width: "".concat(width, "px")
},
left: horizontalOffset
}, isOpen ? /*#__PURE__*/_react["default"].createElement(SideBarInner, {
className: "side-bar__inner"
}, this.props.children) : null, /*#__PURE__*/_react["default"].createElement(CollapseButton, {
isOpen: isOpen,
onClick: this._onOpenOrClose
})))
);
}
}]);
return SideBar;
}(_react.Component), (0, _defineProperty2["default"])(_class, "defaultProps", {
width: 300,
minifiedWidth: 0,
isOpen: true,
onOpenOrClose: function noop() {}
}), (0, _defineProperty2["default"])(_class, "propTypes", {
width: _propTypes["default"].number,
isOpen: _propTypes["default"].bool,
minifiedWidth: _propTypes["default"].number,
onOpenOrClose: _propTypes["default"].func
}), _temp;
}
var _default = exports["default"] = SidebarFactory;
//# 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","StyledCollapseButton","sideBarCloseBtnBgd","sideBarCloseBtnColor","sideBarCloseBtnBgdHover","CollapseButtonFactory","CollapseButton","onClick","isOpen","transform","fill","SidebarFactory","deps","onOpenOrClose","minifiedWidth","horizontalOffset","children","_onOpenOrClose","Component","noop","PropTypes","number","bool","func"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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  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  box-shadow: 8px 10px 10px -5px #00000033;\n  height: 100%;\n`;\n\nconst StyledCollapseButton = 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 const CollapseButtonFactory = () => {\n  const CollapseButton = ({onClick, isOpen}) => (\n    <StyledCollapseButton className=\"side-bar__close\" onClick={onClick}>\n      <ArrowRight\n        height=\"12px\"\n        style={{\n          transform: `rotate(${isOpen ? 180 : 0}deg)`,\n          fill: 'currentColor'\n        }}\n      />\n    </StyledCollapseButton>\n  );\n  return CollapseButton;\n};\n\nSidebarFactory.deps = [CollapseButtonFactory];\n\nfunction SidebarFactory(CollapseButton) {\n  return 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\n            className=\"side-bar\"\n            style={{width: `${width}px`}}\n            left={horizontalOffset}\n          >\n            {isOpen ? (\n              <SideBarInner className=\"side-bar__inner\">\n                {this.props.children}\n              </SideBarInner>\n            ) : null}\n            <CollapseButton isOpen={isOpen} onClick={this._onOpenOrClose} />\n          </SideBarContainer>\n        </StyledSidePanelContainer>\n      );\n    }\n  };\n}\n\nexport default SidebarFactory;\n"]}