kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
179 lines (145 loc) • 19.4 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _dropdownList = require("../../common/item-selector/dropdown-list");
var _itemSelector = _interopRequireDefault(require("../../common/item-selector/item-selector"));
var _defaultSettings = require("../../../constants/default-settings");
var _styledComponents2 = require("../../common/styled-components");
var _reactIntl = require("react-intl");
function _templateObject4() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n // override item-selector dropdown padding\n .item-selector .item-selector__dropdown {\n padding: 4px 10px 4px 2px;\n }\n"]);
_templateObject4 = function _templateObject4() {
return data;
};
return data;
}
function _templateObject3() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n background-color: ", ";\n border-top: 1px solid ", ";\n display: flex;\n flex-wrap: wrap;\n align-items: flex-start;\n padding: 12px 0 0 12px;\n"]);
_templateObject3 = function _templateObject3() {
return data;
};
return data;
}
function _templateObject2() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n &.list {\n display: flex;\n align-items: center;\n\n .layer-type-selector__item__icon {\n color: ", ";\n background-size: ", "px ", "px;\n margin-right: 12px;\n }\n }\n\n .layer-type-selector__item__icon {\n color: ", ";\n display: flex;\n background-image: url(", ");\n background-size: ", "px ", "px;\n }\n\n .layer-type-selector__item__label {\n text-transform: capitalize;\n font-size: 12px;\n text-align: center;\n color: ", ";\n }\n"]);
_templateObject2 = function _templateObject2() {
return data;
};
return data;
}
function _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n padding-bottom: 12px;\n padding-right: 12px;\n\n &.selected {\n .layer-type-selector__item__icon {\n border: 1px solid #caf2f4;\n }\n }\n\n :hover,\n &.selected {\n cursor: pointer;\n .layer-type-selector__item__icon {\n color: ", ";\n }\n\n .layer-type-selector__item__label {\n color: ", ";\n }\n }\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
var ITEM_SIZE = {
large: 60,
small: 28
};
var StyledDropdownListItem = _styledComponents["default"].div(_templateObject(), function (props) {
return props.theme.activeColor;
}, function (props) {
return props.theme.textColor;
});
var StyledListItem = _styledComponents["default"].div(_templateObject2(), function (props) {
return props.theme.activeColor;
}, ITEM_SIZE.small, ITEM_SIZE.small, function (props) {
return props.theme.labelColor;
}, "".concat(_defaultSettings.CLOUDFRONT, "/kepler.gl-layer-icon-bg.png"), ITEM_SIZE.large, ITEM_SIZE.large, function (props) {
return props.theme.labelColor;
});
var DropdownListWrapper = _styledComponents["default"].div(_templateObject3(), function (props) {
return props.theme.dropdownList;
}, function (props) {
return props.theme.dropdownListBgd;
}, function (props) {
return props.theme.dropdownListBorderTop;
});
var LayerTypeListItem = function LayerTypeListItem(_ref) {
var value = _ref.value,
isTile = _ref.isTile;
return _react["default"].createElement(StyledListItem, {
className: (0, _classnames["default"])('layer-type-selector__item__inner', {
list: !isTile
})
}, _react["default"].createElement("div", {
className: "layer-type-selector__item__icon"
}, _react["default"].createElement(value.icon, {
height: "".concat(isTile ? ITEM_SIZE.large : ITEM_SIZE.small, "px")
})), _react["default"].createElement("div", {
className: "layer-type-selector__item__label"
}, _react["default"].createElement(_reactIntl.FormattedMessage, {
id: "layer.type.".concat(value.label.toLowerCase()),
defaultMessage: value.label
})));
};
var LayerTypeDropdownList = function LayerTypeDropdownList(props) {
return _react["default"].createElement(DropdownListWrapper, {
className: _dropdownList.classList.list
}, props.options.map(function (value, i) {
return _react["default"].createElement(StyledDropdownListItem, {
className: (0, _classnames["default"])('layer-type-selector__item', {
selected: props.selectedItems.find(function (it) {
return it.id === value.id;
}),
hover: props.selectionIndex === i
}),
key: "".concat(value.id, "_").concat(i),
onMouseDown: function onMouseDown(e) {
e.preventDefault();
props.onOptionSelected(value, e);
},
onClick: function onClick(e) {
e.preventDefault();
props.onOptionSelected(value, e);
}
}, _react["default"].createElement(props.customListItemComponent, {
value: value,
isTile: true
}));
}));
};
var propTypes = {
layer: _propTypes["default"].object.isRequired,
onSelect: _propTypes["default"].func.isRequired
};
var StyledLayerTypeSelector = _styledComponents["default"].div(_templateObject4());
var LayerTypeSelector = function LayerTypeSelector(_ref2) {
var layer = _ref2.layer,
layerTypeOptions = _ref2.layerTypeOptions,
onSelect = _ref2.onSelect;
return _react["default"].createElement(_styledComponents2.SidePanelSection, null, _react["default"].createElement(StyledLayerTypeSelector, {
className: "layer-config__type"
}, _react["default"].createElement(_itemSelector["default"], {
selectedItems: layerTypeOptions.find(function (op) {
return op.id === layer.type;
}),
options: layerTypeOptions,
multiSelect: false,
placeholder: "placeholder.selectType",
onChange: onSelect,
getOptionValue: function getOptionValue(op) {
return op.id;
},
filterOption: "label",
displayOption: function displayOption(op) {
return op.label;
},
DropDownLineItemRenderComponent: LayerTypeListItem,
DropDownRenderComponent: LayerTypeDropdownList
})));
};
LayerTypeSelector.propTypes = propTypes;
var _default = LayerTypeSelector;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/layer-type-selector.js"],"names":["ITEM_SIZE","large","small","StyledDropdownListItem","styled","div","props","theme","activeColor","textColor","StyledListItem","labelColor","CLOUDFRONT","DropdownListWrapper","dropdownList","dropdownListBgd","dropdownListBorderTop","LayerTypeListItem","value","isTile","list","label","toLowerCase","LayerTypeDropdownList","classList","options","map","i","selected","selectedItems","find","it","id","hover","selectionIndex","e","preventDefault","onOptionSelected","propTypes","layer","PropTypes","object","isRequired","onSelect","func","StyledLayerTypeSelector","LayerTypeSelector","layerTypeOptions","op","type"],"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 from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport styled from 'styled-components';\n\nimport {classList} from 'components/common/item-selector/dropdown-list';\nimport ItemSelector from 'components/common/item-selector/item-selector';\nimport {CLOUDFRONT} from 'constants/default-settings';\n\nimport {SidePanelSection} from 'components/common/styled-components';\nimport {FormattedMessage} from 'react-intl';\n\nconst ITEM_SIZE = {\n  large: 60,\n  small: 28\n};\n\nconst StyledDropdownListItem = styled.div`\n  padding-bottom: 12px;\n  padding-right: 12px;\n\n  &.selected {\n    .layer-type-selector__item__icon {\n      border: 1px solid #caf2f4;\n    }\n  }\n\n  :hover,\n  &.selected {\n    cursor: pointer;\n    .layer-type-selector__item__icon {\n      color: ${props => props.theme.activeColor};\n    }\n\n    .layer-type-selector__item__label {\n      color: ${props => props.theme.textColor};\n    }\n  }\n`;\n\nconst StyledListItem = styled.div`\n  &.list {\n    display: flex;\n    align-items: center;\n\n    .layer-type-selector__item__icon {\n      color: ${props => props.theme.activeColor};\n      background-size: ${ITEM_SIZE.small}px ${ITEM_SIZE.small}px;\n      margin-right: 12px;\n    }\n  }\n\n  .layer-type-selector__item__icon {\n    color: ${props => props.theme.labelColor};\n    display: flex;\n    background-image: url(${`${CLOUDFRONT}/kepler.gl-layer-icon-bg.png`});\n    background-size: ${ITEM_SIZE.large}px ${ITEM_SIZE.large}px;\n  }\n\n  .layer-type-selector__item__label {\n    text-transform: capitalize;\n    font-size: 12px;\n    text-align: center;\n    color: ${props => props.theme.labelColor};\n  }\n`;\n\nconst DropdownListWrapper = styled.div`\n  ${props => props.theme.dropdownList};\n  background-color: ${props => props.theme.dropdownListBgd};\n  border-top: 1px solid ${props => props.theme.dropdownListBorderTop};\n  display: flex;\n  flex-wrap: wrap;\n  align-items: flex-start;\n  padding: 12px 0 0 12px;\n`;\n\nconst LayerTypeListItem = ({value, isTile}) => (\n  <StyledListItem className={classNames('layer-type-selector__item__inner', {list: !isTile})}>\n    <div className=\"layer-type-selector__item__icon\">\n      <value.icon height={`${isTile ? ITEM_SIZE.large : ITEM_SIZE.small}px`} />\n    </div>\n    <div className=\"layer-type-selector__item__label\">\n      <FormattedMessage\n        id={`layer.type.${value.label.toLowerCase()}`}\n        defaultMessage={value.label}\n      />\n    </div>\n  </StyledListItem>\n);\n\nconst LayerTypeDropdownList = props => (\n  <DropdownListWrapper className={classList.list}>\n    {props.options.map((value, i) => (\n      <StyledDropdownListItem\n        className={classNames('layer-type-selector__item', {\n          selected: props.selectedItems.find(it => it.id === value.id),\n          hover: props.selectionIndex === i\n        })}\n        key={`${value.id}_${i}`}\n        onMouseDown={e => {\n          e.preventDefault();\n          props.onOptionSelected(value, e);\n        }}\n        onClick={e => {\n          e.preventDefault();\n          props.onOptionSelected(value, e);\n        }}\n      >\n        <props.customListItemComponent value={value} isTile />\n      </StyledDropdownListItem>\n    ))}\n  </DropdownListWrapper>\n);\n\nconst propTypes = {\n  layer: PropTypes.object.isRequired,\n  onSelect: PropTypes.func.isRequired\n};\n\nconst StyledLayerTypeSelector = styled.div`\n  // override item-selector dropdown padding\n  .item-selector .item-selector__dropdown {\n    padding: 4px 10px 4px 2px;\n  }\n`;\nconst LayerTypeSelector = ({layer, layerTypeOptions, onSelect}) => (\n  <SidePanelSection>\n    <StyledLayerTypeSelector className=\"layer-config__type\">\n      <ItemSelector\n        selectedItems={layerTypeOptions.find(op => op.id === layer.type)}\n        options={layerTypeOptions}\n        multiSelect={false}\n        placeholder=\"placeholder.selectType\"\n        onChange={onSelect}\n        getOptionValue={op => op.id}\n        filterOption=\"label\"\n        displayOption={op => op.label}\n        DropDownLineItemRenderComponent={LayerTypeListItem}\n        DropDownRenderComponent={LayerTypeDropdownList}\n      />\n    </StyledLayerTypeSelector>\n  </SidePanelSection>\n);\n\nLayerTypeSelector.propTypes = propTypes;\n\nexport default LayerTypeSelector;\n"]}
;