UNPKG

kepler.gl

Version:

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

188 lines (160 loc) 20.6 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral'); var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2); var _templateObject = (0, _taggedTemplateLiteral3.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'], ['\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']), _templateObject2 = (0, _taggedTemplateLiteral3.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'], ['\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']), _templateObject3 = (0, _taggedTemplateLiteral3.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'], ['\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']), _templateObject4 = (0, _taggedTemplateLiteral3.default)(['\n // override item-selector dropdown padding\n .item-selector .item-selector__dropdown {\n padding: 4px 10px 4px 2px;\n }\n'], ['\n // override item-selector dropdown padding\n .item-selector .item-selector__dropdown {\n padding: 4px 10px 4px 2px;\n }\n']); // Copyright (c) 2018 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _dropdownList = require('../../common/item-selector/dropdown-list'); var _itemSelector = require('../../common/item-selector/item-selector'); var _itemSelector2 = _interopRequireDefault(_itemSelector); var _defaultSettings = require('../../../constants/default-settings'); var _styledComponents3 = require('../../common/styled-components'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var ITEM_SIZE = { large: 60, small: 28 }; var StyledDropdownListItem = _styledComponents2.default.div(_templateObject, function (props) { return props.theme.activeColor; }, function (props) { return props.theme.textColor; }); var StyledListItem = _styledComponents2.default.div(_templateObject2, function (props) { return props.theme.activeColor; }, ITEM_SIZE.small, ITEM_SIZE.small, function (props) { return props.theme.labelColor; }, _defaultSettings.CLOUDFRONT + '/kepler.gl-layer-icon-bg.png', ITEM_SIZE.large, ITEM_SIZE.large, function (props) { return props.theme.labelColor; }); var DropdownListWrapper = _styledComponents2.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 _react2.default.createElement( StyledListItem, { className: (0, _classnames2.default)('layer-type-selector__item__inner', { list: !isTile }) }, _react2.default.createElement( 'div', { className: 'layer-type-selector__item__icon' }, _react2.default.createElement(value.icon, { height: (isTile ? ITEM_SIZE.large : ITEM_SIZE.small) + 'px' }) ), _react2.default.createElement( 'div', { className: 'layer-type-selector__item__label' }, value.label ) ); }; var LayerTypeDropdownList = function LayerTypeDropdownList(props) { return _react2.default.createElement( DropdownListWrapper, { className: _dropdownList.classList.list }, props.options.map(function (value, i) { return _react2.default.createElement( StyledDropdownListItem, { className: (0, _classnames2.default)('layer-type-selector__item', { selected: props.selectedItems.find(function (it) { return it.id === value.id; }), hover: props.selectionIndex === i }), key: value.id + '_' + i, onMouseDown: function onMouseDown(e) { e.preventDefault(); props.onOptionSelected(value, e); }, onClick: function onClick(e) { e.preventDefault(); props.onOptionSelected(value, e); } }, _react2.default.createElement(props.customListItemComponent, { value: value, isTile: true }) ); }) ); }; var propTypes = { layer: _propTypes2.default.object.isRequired, onSelect: _propTypes2.default.func.isRequired }; var StyledLayerTypeSelector = _styledComponents2.default.div(_templateObject4); var LayerTypeSelector = function LayerTypeSelector(_ref2) { var layer = _ref2.layer, layerTypeOptions = _ref2.layerTypeOptions, onSelect = _ref2.onSelect; return _react2.default.createElement( _styledComponents3.SidePanelSection, null, _react2.default.createElement( StyledLayerTypeSelector, { className: 'layer-config__type' }, _react2.default.createElement( _styledComponents3.PanelLabel, null, 'Layer type' ), _react2.default.createElement(_itemSelector2.default, { selectedItems: layerTypeOptions.find(function (op) { return op.id === layer.type; }), options: layerTypeOptions, multiSelect: false, placeholder: 'Select A Type', 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; exports.default = LayerTypeSelector; //# 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","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":";;;;;;;;;;;;;6UAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;AAEA;;AACA;;;;AACA;;AAEA;;;;AAKA,IAAMA,YAAY;AAChBC,SAAO,EADS;AAEhBC,SAAO;AAFS,CAAlB;;AAKA,IAAMC,yBAAyBC,2BAAOC,GAAhC,kBAcS;AAAA,SAASC,MAAMC,KAAN,CAAYC,WAArB;AAAA,CAdT,EAkBS;AAAA,SAASF,MAAMC,KAAN,CAAYE,SAArB;AAAA,CAlBT,CAAN;;AAuBA,IAAMC,iBAAiBN,2BAAOC,GAAxB,mBAMS;AAAA,SAASC,MAAMC,KAAN,CAAYC,WAArB;AAAA,CANT,EAOmBR,UAAUE,KAP7B,EAOwCF,UAAUE,KAPlD,EAaO;AAAA,SAASI,MAAMC,KAAN,CAAYI,UAArB;AAAA,CAbP,EAeyBC,2BAfzB,mCAgBiBZ,UAAUC,KAhB3B,EAgBsCD,UAAUC,KAhBhD,EAuBO;AAAA,SAASK,MAAMC,KAAN,CAAYI,UAArB;AAAA,CAvBP,CAAN;;AA2BA,IAAME,sBAAsBT,2BAAOC,GAA7B,mBACF;AAAA,SAASC,MAAMC,KAAN,CAAYO,YAArB;AAAA,CADE,EAEgB;AAAA,SAASR,MAAMC,KAAN,CAAYQ,eAArB;AAAA,CAFhB,EAGoB;AAAA,SAAST,MAAMC,KAAN,CAAYS,qBAArB;AAAA,CAHpB,CAAN;;AAUA,IAAMC,oBAAoB,SAApBA,iBAAoB;AAAA,MAAEC,KAAF,QAAEA,KAAF;AAAA,MAASC,MAAT,QAASA,MAAT;AAAA,SACxB;AAAC,kBAAD;AAAA;AACE,iBAAW,0BAAW,kCAAX,EAA+C,EAACC,MAAM,CAACD,MAAR,EAA/C;AADb;AAGE;AAAA;AAAA,QAAK,WAAU,iCAAf;AACE,oCAAC,KAAD,CAAO,IAAP;AACE,iBAAWA,SAASnB,UAAUC,KAAnB,GAA2BD,UAAUE,KAAhD;AADF;AADF,KAHF;AAQE;AAAA;AAAA,QAAK,WAAU,kCAAf;AAAmDgB,YAAMG;AAAzD;AARF,GADwB;AAAA,CAA1B;;AAaA,IAAMC,wBAAwB,SAAxBA,qBAAwB;AAAA,SAC5B;AAAC,uBAAD;AAAA,MAAqB,WAAWC,wBAAUH,IAA1C;AACGd,UAAMkB,OAAN,CAAcC,GAAd,CAAkB,UAACP,KAAD,EAAQQ,CAAR;AAAA,aACjB;AAAC,8BAAD;AAAA;AACE,qBAAW,0BAAW,2BAAX,EAAwC;AACjDC,sBAAUrB,MAAMsB,aAAN,CAAoBC,IAApB,CAAyB;AAAA,qBAAMC,GAAGC,EAAH,KAAUb,MAAMa,EAAtB;AAAA,aAAzB,CADuC;AAEjDC,mBAAO1B,MAAM2B,cAAN,KAAyBP;AAFiB,WAAxC,CADb;AAKE,eAAQR,MAAMa,EAAd,SAAoBL,CALtB;AAME,uBAAa,wBAAK;AAChBQ,cAAEC,cAAF;AACA7B,kBAAM8B,gBAAN,CAAuBlB,KAAvB,EAA8BgB,CAA9B;AACD,WATH;AAUE,mBAAS,oBAAK;AACZA,cAAEC,cAAF;AACA7B,kBAAM8B,gBAAN,CAAuBlB,KAAvB,EAA8BgB,CAA9B;AACD;AAbH;AAeE,sCAAC,KAAD,CAAO,uBAAP,IAA+B,OAAOhB,KAAtC,EAA6C,YAA7C;AAfF,OADiB;AAAA,KAAlB;AADH,GAD4B;AAAA,CAA9B;;AAwBA,IAAMmB,YAAY;AAChBC,SAAOC,oBAAUC,MAAV,CAAiBC,UADR;AAEhBC,YAAUH,oBAAUI,IAAV,CAAeF;AAFT,CAAlB;;AAKA,IAAMG,0BAA0BxC,2BAAOC,GAAjC,kBAAN;AAMA,IAAMwC,oBAAoB,SAApBA,iBAAoB;AAAA,MAAEP,KAAF,SAAEA,KAAF;AAAA,MAASQ,gBAAT,SAASA,gBAAT;AAAA,MAA2BJ,QAA3B,SAA2BA,QAA3B;AAAA,SACxB;AAAC,uCAAD;AAAA;AACE;AAAC,6BAAD;AAAA,QAAyB,WAAU,oBAAnC;AACE;AAAC,qCAAD;AAAA;AAAA;AAAA,OADF;AAEE,oCAAC,sBAAD;AACE,uBAAeI,iBAAiBjB,IAAjB,CAAsB;AAAA,iBAAMkB,GAAGhB,EAAH,KAAUO,MAAMU,IAAtB;AAAA,SAAtB,CADjB;AAEE,iBAASF,gBAFX;AAGE,qBAAa,KAHf;AAIE,qBAAY,eAJd;AAKE,kBAAUJ,QALZ;AAME,wBAAgB;AAAA,iBAAMK,GAAGhB,EAAT;AAAA,SANlB;AAOE,sBAAa,OAPf;AAQE,uBAAe;AAAA,iBAAMgB,GAAG1B,KAAT;AAAA,SARjB;AASE,yCAAiCJ,iBATnC;AAUE,iCAAyBK;AAV3B;AAFF;AADF,GADwB;AAAA,CAA1B;;AAoBAuB,kBAAkBR,SAAlB,GAA8BA,SAA9B;;kBAEeQ,iB","file":"layer-type-selector.js","sourcesContent":["// Copyright (c) 2018 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 {\n  PanelLabel,\n  SidePanelSection\n} from 'components/common/styled-components';\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\n    className={classNames('layer-type-selector__item__inner', {list: !isTile})}\n  >\n    <div className=\"layer-type-selector__item__icon\">\n      <value.icon\n        height={`${isTile ? ITEM_SIZE.large : ITEM_SIZE.small}px`}\n      />\n    </div>\n    <div className=\"layer-type-selector__item__label\">{value.label}</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      <PanelLabel>Layer type</PanelLabel>\n      <ItemSelector\n        selectedItems={layerTypeOptions.find(op => op.id === layer.type)}\n        options={layerTypeOptions}\n        multiSelect={false}\n        placeholder=\"Select A Type\"\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"]}