UNPKG

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
'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":"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","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"]}