UNPKG

kepler.gl

Version:

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

160 lines (133 loc) 18.3 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.ActionPanelItem = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _classnames = _interopRequireDefault(require("classnames")); var _icons = require("./icons"); var _switch = _interopRequireDefault(require("./switch")); function _templateObject3() { var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n box-shadow: ", ";\n transition: ", ";\n color: ", ";\n\n .action-panel-item {\n ", "\n\n &:last-of-type {\n border-bottom: 0;\n }\n }\n"]); _templateObject3 = function _templateObject3() { return data; }; return data; } function _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n label {\n margin-bottom: 0;\n color: ", ";\n padding-left: 20px;\n line-height: 12px;\n\n &:before {\n width: 12px;\n height: 12px;\n background-color: ", ";\n }\n &:hover {\n color: ", ";\n }\n }\n"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n align-items: center;\n font-size: 12px;\n line-height: 14px;\n padding: 8px;\n min-height: ", "px;\n text-transform: capitalize;\n background-color: ", ";\n width: ", "px;\n position: relative;\n ", "\n\n :hover {\n cursor: pointer;\n color: ", ";\n .nested-group {\n display: block;\n }\n }\n\n .label {\n margin-left: 8px;\n }\n\n .label-icon {\n margin-left: auto;\n }\n\n .nested-group {\n width: 110px;\n display: none;\n color: ", ";\n position: absolute;\n left: 110px;\n top: 0px;\n padding-left: 4px;\n }\n"]); _templateObject = function _templateObject() { return data; }; return data; } var StyledItem = _styledComponents["default"].div(_templateObject(), function (props) { return props.theme.actionPanelHeight; }, function (props) { return props.theme.dropdownListBgd; }, function (props) { return props.theme.actionPanelWidth; }, function (props) { return props.color ? "border-left: 3px solid rgb(".concat(props.color, ");") : ''; }, function (props) { return props.theme.textColorHl; }, function (props) { return props.theme.textColor; }); var StyledCheckedbox = (0, _styledComponents["default"])(_switch["default"])(_templateObject2(), function (props) { return props.theme.textColor; }, function (props) { return props.theme.dropdownListBgd; }, function (props) { return props.theme.textColorHl; }); var renderChildren = function renderChildren(child, index) { return _react["default"].cloneElement(child, { onClick: function onClick() { if (_react["default"].isValidElement(child)) { if (child.props.onClick) { child.props.onClick(index); } } }, className: (0, _classnames["default"])('action-panel-item', child.props.className) }); }; var ActionPanelItem = _react["default"].memo(function (_ref) { var children = _ref.children, color = _ref.color, className = _ref.className, Icon = _ref.Icon, label = _ref.label, onClick = _ref.onClick, isSelection = _ref.isSelection, isActive = _ref.isActive, style = _ref.style; var onClickCallback = (0, _react.useCallback)(function (event) { event.preventDefault(); event.stopPropagation(); onClick(); }, [onClick]); return _react["default"].createElement(StyledItem, { className: className, onClick: onClickCallback, color: color, style: style }, Icon ? _react["default"].createElement("div", { className: "icon" }, _react["default"].createElement(Icon, { height: "16px" })) : null, isSelection ? _react["default"].createElement(StyledCheckedbox, { type: "checkbox", checked: Boolean(isActive), id: "switch-".concat(label), secondary: true, label: label }) : _react["default"].createElement("span", { className: "label" }, label), children && children.length ? _react["default"].createElement("div", null, _react["default"].createElement("div", { className: "label-icon" }, _react["default"].createElement(_icons.ArrowRight, { height: "16px" })), _react["default"].createElement("div", { className: "nested-group" }, _react["default"].Children.map(children, renderChildren))) : null); }); exports.ActionPanelItem = ActionPanelItem; ActionPanelItem.displayName = 'ActionPanelItem'; var StyledActionPanel = _styledComponents["default"].div(_templateObject3(), function (props) { return props.direction; }, function (props) { return props.theme.dropdownListShadow; }, function (props) { return props.theme.transitionSlow; }, function (props) { return props.theme.textColor; }, function (props) { return props.direction === 'column' ? "border-bottom: 1px solid ".concat(props.theme.panelHeaderIcon) : "border-right: 1px solid ".concat(props.theme.panelHeaderIcon); }); // React compound element https://medium.com/@Dane_s/react-js-compound-components-a6e54b5c9992 var ActionPanel = function ActionPanel(_ref2) { var children = _ref2.children, className = _ref2.className, _ref2$direction = _ref2.direction, direction = _ref2$direction === void 0 ? 'column' : _ref2$direction; return _react["default"].createElement(StyledActionPanel, { className: className, direction: direction }, _react["default"].Children.map(children, renderChildren)); }; ActionPanel.displayName = 'ActionPanel'; var _default = ActionPanel; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/action-panel.js"],"names":["StyledItem","styled","div","props","theme","actionPanelHeight","dropdownListBgd","actionPanelWidth","color","textColorHl","textColor","StyledCheckedbox","Checkbox","renderChildren","child","index","React","cloneElement","onClick","isValidElement","className","ActionPanelItem","memo","children","Icon","label","isSelection","isActive","style","onClickCallback","event","preventDefault","stopPropagation","Boolean","length","Children","map","displayName","StyledActionPanel","direction","dropdownListShadow","transitionSlow","panelHeaderIcon","ActionPanel"],"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, {useCallback} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\nimport {ArrowRight} from 'components/common/icons';\nimport Checkbox from 'components/common/switch';\n\nconst StyledItem = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  font-size: 12px;\n  line-height: 14px;\n  padding: 8px;\n  min-height: ${props => props.theme.actionPanelHeight}px;\n  text-transform: capitalize;\n  background-color: ${props => props.theme.dropdownListBgd};\n  width: ${props => props.theme.actionPanelWidth}px;\n  position: relative;\n  ${props => (props.color ? `border-left: 3px solid rgb(${props.color});` : '')}\n\n  :hover {\n    cursor: pointer;\n    color: ${props => props.theme.textColorHl};\n    .nested-group {\n      display: block;\n    }\n  }\n\n  .label {\n    margin-left: 8px;\n  }\n\n  .label-icon {\n    margin-left: auto;\n  }\n\n  .nested-group {\n    width: 110px;\n    display: none;\n    color: ${props => props.theme.textColor};\n    position: absolute;\n    left: 110px;\n    top: 0px;\n    padding-left: 4px;\n  }\n`;\n\nconst StyledCheckedbox = styled(Checkbox)`\n  label {\n    margin-bottom: 0;\n    color: ${props => props.theme.textColor};\n    padding-left: 20px;\n    line-height: 12px;\n\n    &:before {\n      width: 12px;\n      height: 12px;\n      background-color: ${props => props.theme.dropdownListBgd};\n    }\n    &:hover {\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nconst renderChildren = (child, index) =>\n  React.cloneElement(child, {\n    onClick: () => {\n      if (React.isValidElement(child)) {\n        if (child.props.onClick) {\n          child.props.onClick(index);\n        }\n      }\n    },\n    className: classnames('action-panel-item', child.props.className)\n  });\n\nexport const ActionPanelItem = React.memo(\n  ({children, color, className, Icon, label, onClick, isSelection, isActive, style}) => {\n    const onClickCallback = useCallback(\n      event => {\n        event.preventDefault();\n        event.stopPropagation();\n        onClick();\n      },\n      [onClick]\n    );\n\n    return (\n      <StyledItem className={className} onClick={onClickCallback} color={color} style={style}>\n        {Icon ? (\n          <div className=\"icon\">\n            <Icon height=\"16px\" />\n          </div>\n        ) : null}\n        {isSelection ? (\n          <StyledCheckedbox\n            type=\"checkbox\"\n            checked={Boolean(isActive)}\n            id={`switch-${label}`}\n            secondary\n            label={label}\n          />\n        ) : (\n          <span className=\"label\">{label}</span>\n        )}\n        {children && children.length ? (\n          <div>\n            <div className=\"label-icon\">\n              <ArrowRight height=\"16px\" />\n            </div>\n            <div className=\"nested-group\">{React.Children.map(children, renderChildren)}</div>\n          </div>\n        ) : null}\n      </StyledItem>\n    );\n  }\n);\n\nActionPanelItem.displayName = 'ActionPanelItem';\n\nconst StyledActionPanel = styled.div`\n  display: flex;\n  flex-direction: ${props => props.direction};\n  box-shadow: ${props => props.theme.dropdownListShadow};\n  transition: ${props => props.theme.transitionSlow};\n  color: ${props => props.theme.textColor};\n\n  .action-panel-item {\n    ${props =>\n      props.direction === 'column'\n        ? `border-bottom: 1px solid ${props.theme.panelHeaderIcon}`\n        : `border-right: 1px solid ${props.theme.panelHeaderIcon}`}\n\n    &:last-of-type {\n      border-bottom: 0;\n    }\n  }\n`;\n\n// React compound element https://medium.com/@Dane_s/react-js-compound-components-a6e54b5c9992\nconst ActionPanel = ({children, className, direction = 'column'}) => (\n  <StyledActionPanel className={className} direction={direction}>\n    {React.Children.map(children, renderChildren)}\n  </StyledActionPanel>\n);\n\nActionPanel.displayName = 'ActionPanel';\n\nexport default ActionPanel;\n"]}