UNPKG

kepler.gl

Version:

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

134 lines (113 loc) 18.6 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"] = 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")); var _templateObject, _templateObject2, _templateObject3; var StyledItem = _styledComponents["default"].div(_templateObject || (_templateObject = (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 max-width: 200px;\n position: relative;\n\n ", " :hover {\n cursor: pointer;\n color: ", ";\n .nested-group {\n display: block;\n }\n }\n\n .label {\n margin-left: 8px;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n\n .label-icon {\n margin-left: auto;\n }\n\n .nested-group {\n max-width: 200px;\n overflow: hidden;\n display: none;\n color: ", ";\n position: absolute;\n left: 100%;\n top: 0px;\n padding-left: 4px;\n\n label {\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n }\n"])), function (props) { return props.theme.actionPanelHeight; }, function (props) { return props.theme.dropdownListBgd; }, 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 || (_templateObject2 = (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"])), 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 /*#__PURE__*/_react["default"].cloneElement(child, { onClick: function onClick() { if ( /*#__PURE__*/_react["default"].isValidElement(child)) { if (child.props.onClick) { child.props.onClick(index); } } }, className: (0, _classnames["default"])('action-panel-item', child.props.className) }); }; /** @type {typeof import('./action-panel').ActionPanelItem} */ var ActionPanelItem = /*#__PURE__*/_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 === null || onClick === void 0 ? void 0 : onClick(); }, [onClick]); return /*#__PURE__*/_react["default"].createElement(StyledItem, { className: className, onClick: onClickCallback, color: color, style: style }, Icon ? /*#__PURE__*/_react["default"].createElement("div", { className: "icon" }, /*#__PURE__*/_react["default"].createElement(Icon, { height: "16px" })) : null, isSelection ? /*#__PURE__*/_react["default"].createElement(StyledCheckedbox, { type: "checkbox", checked: Boolean(isActive), id: "switch-".concat(label), secondary: true, label: label }) : /*#__PURE__*/_react["default"].createElement("span", { className: "label" }, label), children ? /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("div", { className: "label-icon" }, /*#__PURE__*/_react["default"].createElement(_icons.ArrowRight, { height: "16px" })), /*#__PURE__*/_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 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n box-shadow: ", ";\n transition: ", ";\n color: ", ";\n\n .action-panel-item {\n ", " &:last-of-type {\n border-bottom: 0;\n }\n }\n"])), 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 /** @type {typeof import('./action-panel').ActionPanel} */ 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 /*#__PURE__*/_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","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","Children","map","displayName","StyledActionPanel","direction","dropdownListShadow","transitionSlow","panelHeaderIcon","ActionPanel"],"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, {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  max-width: 200px;\n  position: relative;\n\n  ${props => (props.color ? `border-left: 3px solid rgb(${props.color});` : '')} :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    white-space: nowrap;\n    text-overflow: ellipsis;\n  }\n\n  .label-icon {\n    margin-left: auto;\n  }\n\n  .nested-group {\n    max-width: 200px;\n    overflow: hidden;\n    display: none;\n    color: ${props => props.theme.textColor};\n    position: absolute;\n    left: 100%;\n    top: 0px;\n    padding-left: 4px;\n\n    label {\n      white-space: nowrap;\n      text-overflow: ellipsis;\n    }\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\n/** @type {typeof import('./action-panel').ActionPanelItem} */\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 ? (\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}`} &: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\n/** @type {typeof import('./action-panel').ActionPanel} */\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"]}