kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
131 lines (112 loc) • 17.4 kB
JavaScript
;
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 = _interopRequireDefault(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
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 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"])), 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 || (_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: #6a7485;\n }\n }\n"])), function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.dropdownListBgd;
});
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: 'action-panel-item'
});
};
var ActionPanelItem = exports.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;
return (/*#__PURE__*/_react["default"].createElement(StyledItem, {
className: className,
onClick: function onClick(event) {
event.preventDefault();
event.stopPropagation();
_onClick();
},
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 && children.length ? /*#__PURE__*/_react["default"].createElement("div", {
className: "label-icon"
}, /*#__PURE__*/_react["default"].createElement(_icons.ArrowRight, {
style: {
fill: '#6a7485'
},
height: "16px"
})) : null, children && children.length ? /*#__PURE__*/_react["default"].createElement("div", {
className: "nested-group"
}, _react["default"].Children.map(children, renderChildren)) : null)
);
});
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 ", "\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
var ActionPanel = function ActionPanel(_ref2) {
var children = _ref2.children,
className = _ref2.className,
_ref2$direction = _ref2.direction,
direction = _ref2$direction === void 0 ? 'column' : _ref2$direction,
onClick = _ref2.onClick;
return (/*#__PURE__*/_react["default"].createElement(StyledActionPanel, {
className: className,
direction: direction
}, _react["default"].Children.map(children, renderChildren))
);
};
ActionPanel.displayName = 'ActionPanel';
var _default = exports["default"] = ActionPanel;
//# 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","event","preventDefault","stopPropagation","Boolean","length","fill","Children","map","displayName","StyledActionPanel","direction","dropdownListShadow","transitionSlow","panelHeaderIcon","ActionPanel"],"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 from 'react';\nimport styled from 'styled-components';\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: #6a7485;\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: 'action-panel-item'\n  });\n\nexport const ActionPanelItem = React.memo(\n  ({\n    children,\n    color,\n    className,\n    Icon,\n    label,\n    onClick,\n    isSelection,\n    isActive,\n    style\n  }) => (\n    <StyledItem\n      className={className}\n      onClick={event => {\n        event.preventDefault();\n        event.stopPropagation();\n        onClick();\n      }}\n      color={color}\n      style={style}\n    >\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 className=\"label-icon\">\n          <ArrowRight style={{fill: '#6a7485'}} height=\"16px\" />\n        </div>\n      ) : null}\n      {children && children.length ? (\n        <div className=\"nested-group\">\n          {React.Children.map(children, renderChildren)}\n        </div>\n      ) : null}\n    </StyledItem>\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`;\n\n// React compound element https://medium.com/@Dane_s/react-js-compound-components-a6e54b5c9992\nconst ActionPanel = ({children, className, direction = 'column', onClick}) => (\n  <StyledActionPanel className={className} direction={direction}>\n    {React.Children.map(children, renderChildren)}\n  </StyledActionPanel>\n);\n\nActionPanel.displayName = 'ActionPanel';\n\nexport default ActionPanel;\n"]}