kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
238 lines (188 loc) • 23 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = undefined;
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral');
var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2);
var _class, _temp2;
var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n margin-bottom: 12px;\n border-radius: 1px;\n\n .filter-panel__filter {\n margin-top: 24px;\n }\n'], ['\n margin-bottom: 12px;\n border-radius: 1px;\n\n .filter-panel__filter {\n margin-top: 24px;\n }\n']),
_templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n cursor: pointer;\n padding: 10px 12px;\n'], ['\n cursor: pointer;\n padding: 10px 12px;\n']),
_templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n background-color: ', ';\n padding: 12px;\n'], ['\n background-color: ', ';\n padding: 12px;\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 _reselect = require('reselect');
var _styledComponents = require('styled-components');
var _styledComponents2 = _interopRequireDefault(_styledComponents);
var _panelHeaderAction = require('../panel-header-action');
var _panelHeaderAction2 = _interopRequireDefault(_panelHeaderAction);
var _fieldSelector = require('../../common/field-selector');
var _fieldSelector2 = _interopRequireDefault(_fieldSelector);
var _icons = require('../../common/icons');
var _sourceDataSelector = require('../source-data-selector');
var _sourceDataSelector2 = _interopRequireDefault(_sourceDataSelector);
var _styledComponents3 = require('../../common/styled-components');
var _filters = require('../../filters');
var Filters = _interopRequireWildcard(_filters);
var _filterUtils = require('../../../utils/filter-utils');
var _defaultSettings = require('../../../constants/default-settings');
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var StyledFilterPanel = _styledComponents2.default.div(_templateObject);
var StyledFilterHeader = _styledComponents3.StyledPanelHeader.extend(_templateObject2);
var StyledFilterContent = _styledComponents2.default.div(_templateObject3, function (props) {
return props.theme.panelBackground;
});
var FilterPanel = (_temp2 = _class = function (_Component) {
(0, _inherits3.default)(FilterPanel, _Component);
function FilterPanel() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, FilterPanel);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = FilterPanel.__proto__ || Object.getPrototypeOf(FilterPanel)).call.apply(_ref, [this].concat(args))), _this), _this.fieldsSelector = function (props) {
return props.filter.dataId && props.datasets[props.filter.dataId].fields || [];
}, _this.filterSelector = function (props) {
return props.filters;
}, _this.nameSelector = function (props) {
return props.filter.name;
}, _this.dataIdSelector = function (props) {
return props.filter.dataId;
}, _this.availableFieldsSelector = (0, _reselect.createSelector)(_this.fieldsSelector, _this.filterSelector, _this.nameSelector, _this.dataIdSelector, function (fields, filters, name, dataId) {
return fields.filter(function (f) {
return f.type && f.type !== _defaultSettings.ALL_FIELD_TYPES.geojson && (f.name === name || !filters.find(function (d) {
return d.name === f.name && d.dataId === dataId;
}));
});
}), _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
/* selectors */
// only show current field and field that's not already been used as a filter
(0, _createClass3.default)(FilterPanel, [{
key: 'render',
value: function render() {
var _props = this.props,
datasets = _props.datasets,
enlargeFilter = _props.enlargeFilter,
filter = _props.filter,
idx = _props.idx,
isAnyFilterAnimating = _props.isAnyFilterAnimating,
removeFilter = _props.removeFilter,
_setFilter = _props.setFilter,
toggleAnimation = _props.toggleAnimation;
var name = filter.name,
enlarged = filter.enlarged,
type = filter.type,
dataId = filter.dataId;
var FilterComponent = type && Filters[_filterUtils.FILTER_COMPONENTS[type]];
var allAvailableFields = this.availableFieldsSelector(this.props);
return _react2.default.createElement(
StyledFilterPanel,
{ className: 'filter-panel' },
_react2.default.createElement(
StyledFilterHeader,
{ className: 'filter-panel__header',
labelRCGColorValues: datasets[dataId].color },
_react2.default.createElement(
'div',
{ style: { flexGrow: 1 } },
_react2.default.createElement(_fieldSelector2.default, {
inputTheme: 'secondary',
fields: allAvailableFields,
value: name,
erasable: false,
onSelect: function onSelect(value) {
return _setFilter(idx, 'name', value.name);
}
})
),
_react2.default.createElement(_panelHeaderAction2.default, {
id: filter.id,
tooltip: 'delete',
tooltipType: 'error',
onClick: removeFilter,
hoverColor: 'errorColor',
IconComponent: _icons.Trash
}),
type === _filterUtils.FILTER_TYPES.timeRange && _react2.default.createElement(_panelHeaderAction2.default, {
id: filter.id,
onClick: enlargeFilter,
tooltip: 'Time Playback',
IconComponent: _icons.Clock,
active: enlarged
})
),
_react2.default.createElement(
StyledFilterContent,
{ className: 'filter-panel__content' },
Object.keys(datasets).length > 1 && _react2.default.createElement(_sourceDataSelector2.default, {
inputTheme: 'secondary',
datasets: datasets,
disabled: filter.freeze,
dataId: filter.dataId,
onSelect: function onSelect(value) {
return _setFilter(idx, 'dataId', value);
}
}),
type && !enlarged && _react2.default.createElement(
'div',
{ className: 'filter-panel__filter' },
_react2.default.createElement(FilterComponent, {
filter: filter,
idx: idx,
isAnyFilterAnimating: isAnyFilterAnimating,
toggleAnimation: toggleAnimation,
setFilter: function setFilter(value) {
return _setFilter(idx, 'value', value);
}
})
)
)
);
}
}]);
return FilterPanel;
}(_react.Component), _class.propTypes = {
idx: _propTypes2.default.number,
filters: _propTypes2.default.arrayOf(_propTypes2.default.any).isRequired,
filter: _propTypes2.default.object.isRequired,
setFilter: _propTypes2.default.func.isRequired,
removeFilter: _propTypes2.default.func.isRequired,
enlargeFilter: _propTypes2.default.func.isRequired,
toggleAnimation: _propTypes2.default.func.isRequired,
datasets: _propTypes2.default.object,
showDatasetTable: _propTypes2.default.func,
isAnyFilterAnimating: _propTypes2.default.bool
}, _temp2);
exports.default = FilterPanel;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/filter-panel/filter-panel.js"],"names":["Filters","StyledFilterPanel","styled","div","StyledFilterHeader","StyledPanelHeader","extend","StyledFilterContent","props","theme","panelBackground","FilterPanel","fieldsSelector","filter","dataId","datasets","fields","filterSelector","filters","nameSelector","name","dataIdSelector","availableFieldsSelector","f","type","ALL_FIELD_TYPES","geojson","find","d","enlargeFilter","idx","isAnyFilterAnimating","removeFilter","setFilter","toggleAnimation","enlarged","FilterComponent","FILTER_COMPONENTS","allAvailableFields","color","flexGrow","value","id","Trash","FILTER_TYPES","timeRange","Clock","Object","keys","length","freeze","Component","propTypes","PropTypes","number","arrayOf","any","isRequired","object","func","showDatasetTable","bool"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uKAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;AACA;;;;AACA;;AACA;;;;AACA;;;;AACA;;;;AACA;;AACA;;;;AACA;;AACA;;IAAYA,O;;AAEZ;;AACA;;;;;;AAEA,IAAMC,oBAAoBC,2BAAOC,GAA3B,iBAAN;;AASA,IAAMC,qBAAqBC,qCAAkBC,MAAvC,kBAAN;;AAKA,IAAMC,sBAAsBL,2BAAOC,GAA7B,mBACgB;AAAA,SAASK,MAAMC,KAAN,CAAYC,eAArB;AAAA,CADhB,CAAN;;IAKqBC,W;;;;;;;;;;;;;;8MAenBC,c,GAAiB;AAAA,aACdJ,MAAMK,MAAN,CAAaC,MAAb,IAAuBN,MAAMO,QAAN,CAAeP,MAAMK,MAAN,CAAaC,MAA5B,EAAoCE,MAA5D,IAAuE,EADxD;AAAA,K,QAEjBC,c,GAAiB;AAAA,aAAST,MAAMU,OAAf;AAAA,K,QACjBC,Y,GAAe;AAAA,aAASX,MAAMK,MAAN,CAAaO,IAAtB;AAAA,K,QACfC,c,GAAiB;AAAA,aAASb,MAAMK,MAAN,CAAaC,MAAtB;AAAA,K,QAGjBQ,uB,GAA0B,8BACxB,MAAKV,cADmB,EAExB,MAAKK,cAFmB,EAGxB,MAAKE,YAHmB,EAIxB,MAAKE,cAJmB,EAKxB,UAACL,MAAD,EAASE,OAAT,EAAkBE,IAAlB,EAAwBN,MAAxB;AAAA,aACEE,OAAOH,MAAP,CACE;AAAA,eACEU,EAAEC,IAAF,IACAD,EAAEC,IAAF,KAAWC,iCAAgBC,OAD3B,KAECH,EAAEH,IAAF,KAAWA,IAAX,IACC,CAACF,QAAQS,IAAR,CAAa;AAAA,iBAAKC,EAAER,IAAF,KAAWG,EAAEH,IAAb,IAAqBQ,EAAEd,MAAF,KAAaA,MAAvC;AAAA,SAAb,CAHH,CADF;AAAA,OADF,CADF;AAAA,KALwB,C;;;AAR1B;;;AAOA;;;;;6BAgBS;AAAA,mBAUH,KAAKN,KAVF;AAAA,UAELO,QAFK,UAELA,QAFK;AAAA,UAGLc,aAHK,UAGLA,aAHK;AAAA,UAILhB,MAJK,UAILA,MAJK;AAAA,UAKLiB,GALK,UAKLA,GALK;AAAA,UAMLC,oBANK,UAMLA,oBANK;AAAA,UAOLC,YAPK,UAOLA,YAPK;AAAA,UAQLC,UARK,UAQLA,SARK;AAAA,UASLC,eATK,UASLA,eATK;AAAA,UAWAd,IAXA,GAWgCP,MAXhC,CAWAO,IAXA;AAAA,UAWMe,QAXN,GAWgCtB,MAXhC,CAWMsB,QAXN;AAAA,UAWgBX,IAXhB,GAWgCX,MAXhC,CAWgBW,IAXhB;AAAA,UAWsBV,MAXtB,GAWgCD,MAXhC,CAWsBC,MAXtB;;AAYP,UAAMsB,kBAAkBZ,QAAQxB,QAAQqC,+BAAkBb,IAAlB,CAAR,CAAhC;AACA,UAAMc,qBAAqB,KAAKhB,uBAAL,CAA6B,KAAKd,KAAlC,CAA3B;;AAEA,aACE;AAAC,yBAAD;AAAA,UAAmB,WAAU,cAA7B;AACE;AAAC,4BAAD;AAAA,YAAoB,WAAU,sBAA9B;AACE,iCAAqBO,SAASD,MAAT,EAAiByB,KADxC;AAEE;AAAA;AAAA,cAAK,OAAO,EAACC,UAAU,CAAX,EAAZ;AACE,0CAAC,uBAAD;AACE,0BAAW,WADb;AAEE,sBAAQF,kBAFV;AAGE,qBAAOlB,IAHT;AAIE,wBAAU,KAJZ;AAKE,wBAAU;AAAA,uBAASa,WAAUH,GAAV,EAAe,MAAf,EAAuBW,MAAMrB,IAA7B,CAAT;AAAA;AALZ;AADF,WAFF;AAWE,wCAAC,2BAAD;AACE,gBAAIP,OAAO6B,EADb;AAEE,qBAAQ,QAFV;AAGE,yBAAY,OAHd;AAIE,qBAASV,YAJX;AAKE,wBAAY,YALd;AAME,2BAAeW;AANjB,YAXF;AAmBGnB,mBAASoB,0BAAaC,SAAtB,IACC,8BAAC,2BAAD;AACE,gBAAIhC,OAAO6B,EADb;AAEE,qBAASb,aAFX;AAGE,qBAAQ,eAHV;AAIE,2BAAeiB,YAJjB;AAKE,oBAAQX;AALV;AApBJ,SADF;AA8BE;AAAC,6BAAD;AAAA,YAAqB,WAAU,uBAA/B;AACGY,iBAAOC,IAAP,CAAYjC,QAAZ,EAAsBkC,MAAtB,GAA+B,CAA/B,IACC,8BAAC,4BAAD;AACE,wBAAW,WADb;AAEE,sBAAUlC,QAFZ;AAGE,sBAAUF,OAAOqC,MAHnB;AAIE,oBAAQrC,OAAOC,MAJjB;AAKE,sBAAU;AAAA,qBAASmB,WAAUH,GAAV,EAAe,QAAf,EAAyBW,KAAzB,CAAT;AAAA;AALZ,YAFJ;AAUGjB,kBACD,CAACW,QADA,IAEC;AAAA;AAAA,cAAK,WAAU,sBAAf;AACE,0CAAC,eAAD;AACE,sBAAQtB,MADV;AAEE,mBAAKiB,GAFP;AAGE,oCAAsBC,oBAHxB;AAIE,+BAAiBG,eAJnB;AAKE,yBAAW;AAAA,uBAASD,WAAUH,GAAV,EAAe,OAAf,EAAwBW,KAAxB,CAAT;AAAA;AALb;AADF;AAZJ;AA9BF,OADF;AAwDD;;;EA5GsCU,gB,UAChCC,S,GAAY;AACjBtB,OAAKuB,oBAAUC,MADE;AAEjBpC,WAASmC,oBAAUE,OAAV,CAAkBF,oBAAUG,GAA5B,EAAiCC,UAFzB;AAGjB5C,UAAQwC,oBAAUK,MAAV,CAAiBD,UAHR;AAIjBxB,aAAWoB,oBAAUM,IAAV,CAAeF,UAJT;AAKjBzB,gBAAcqB,oBAAUM,IAAV,CAAeF,UALZ;AAMjB5B,iBAAewB,oBAAUM,IAAV,CAAeF,UANb;AAOjBvB,mBAAiBmB,oBAAUM,IAAV,CAAeF,UAPf;AAQjB1C,YAAUsC,oBAAUK,MARH;AASjBE,oBAAkBP,oBAAUM,IATX;AAUjB5B,wBAAsBsB,oBAAUQ;AAVf,C;kBADAlD,W","file":"filter-panel.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, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {createSelector} from 'reselect';\nimport styled from 'styled-components';\nimport PanelHeaderAction from 'components/side-panel/panel-header-action';\nimport FieldSelector from 'components/common/field-selector';\nimport {Trash, Clock} from 'components/common/icons';\nimport SourceDataSelector from 'components/side-panel/source-data-selector';\nimport {StyledPanelHeader} from 'components/common/styled-components';\nimport * as Filters from 'components/filters';\n\nimport {FILTER_TYPES, FILTER_COMPONENTS} from 'utils/filter-utils';\nimport {ALL_FIELD_TYPES} from 'constants/default-settings';\n\nconst StyledFilterPanel = styled.div`\n  margin-bottom: 12px;\n  border-radius: 1px;\n\n  .filter-panel__filter {\n    margin-top: 24px;\n  }\n`;\n\nconst StyledFilterHeader = StyledPanelHeader.extend`\n  cursor: pointer;\n  padding: 10px 12px;\n`;\n\nconst StyledFilterContent = styled.div`\n  background-color: ${props => props.theme.panelBackground};\n  padding: 12px;\n`;\n\nexport default class FilterPanel extends Component {\n  static propTypes = {\n    idx: PropTypes.number,\n    filters: PropTypes.arrayOf(PropTypes.any).isRequired,\n    filter: PropTypes.object.isRequired,\n    setFilter: PropTypes.func.isRequired,\n    removeFilter: PropTypes.func.isRequired,\n    enlargeFilter: PropTypes.func.isRequired,\n    toggleAnimation: PropTypes.func.isRequired,\n    datasets: PropTypes.object,\n    showDatasetTable: PropTypes.func,\n    isAnyFilterAnimating: PropTypes.bool\n  };\n\n  /* selectors */\n  fieldsSelector = props =>\n    (props.filter.dataId && props.datasets[props.filter.dataId].fields) || [];\n  filterSelector = props => props.filters;\n  nameSelector = props => props.filter.name;\n  dataIdSelector = props => props.filter.dataId;\n\n  // only show current field and field that's not already been used as a filter\n  availableFieldsSelector = createSelector(\n    this.fieldsSelector,\n    this.filterSelector,\n    this.nameSelector,\n    this.dataIdSelector,\n    (fields, filters, name, dataId) =>\n      fields.filter(\n        f =>\n          f.type &&\n          f.type !== ALL_FIELD_TYPES.geojson &&\n          (f.name === name ||\n            !filters.find(d => d.name === f.name && d.dataId === dataId))\n      )\n  );\n\n  render() {\n    const {\n      datasets,\n      enlargeFilter,\n      filter,\n      idx,\n      isAnyFilterAnimating,\n      removeFilter,\n      setFilter,\n      toggleAnimation\n    } = this.props;\n    const {name, enlarged, type, dataId} = filter;\n    const FilterComponent = type && Filters[FILTER_COMPONENTS[type]];\n    const allAvailableFields = this.availableFieldsSelector(this.props);\n\n    return (\n      <StyledFilterPanel className=\"filter-panel\">\n        <StyledFilterHeader className=\"filter-panel__header\"\n          labelRCGColorValues={datasets[dataId].color}>\n          <div style={{flexGrow: 1}}>\n            <FieldSelector\n              inputTheme=\"secondary\"\n              fields={allAvailableFields}\n              value={name}\n              erasable={false}\n              onSelect={value => setFilter(idx, 'name', value.name)}\n            />\n          </div>\n          <PanelHeaderAction\n            id={filter.id}\n            tooltip=\"delete\"\n            tooltipType=\"error\"\n            onClick={removeFilter}\n            hoverColor={'errorColor'}\n            IconComponent={Trash}\n          />\n          {type === FILTER_TYPES.timeRange && (\n            <PanelHeaderAction\n              id={filter.id}\n              onClick={enlargeFilter}\n              tooltip=\"Time Playback\"\n              IconComponent={Clock}\n              active={enlarged}\n            />\n          )}\n        </StyledFilterHeader>\n        <StyledFilterContent className=\"filter-panel__content\">\n          {Object.keys(datasets).length > 1 && (\n            <SourceDataSelector\n              inputTheme=\"secondary\"\n              datasets={datasets}\n              disabled={filter.freeze}\n              dataId={filter.dataId}\n              onSelect={value => setFilter(idx, 'dataId', value)}\n            />\n          )}\n          {type &&\n          !enlarged && (\n            <div className=\"filter-panel__filter\">\n              <FilterComponent\n                filter={filter}\n                idx={idx}\n                isAnyFilterAnimating={isAnyFilterAnimating}\n                toggleAnimation={toggleAnimation}\n                setFilter={value => setFilter(idx, 'value', value)}\n              />\n            </div>\n          )}\n        </StyledFilterContent>\n      </StyledFilterPanel>\n    );\n  }\n}\n"]}