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
JavaScript
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"]}
;