kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
130 lines (128 loc) • 24.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = _interopRequireWildcard(require("react"));
var _timeRangeFilter = _interopRequireDefault(require("../time-range-filter"));
var _icons = require("../../common/icons");
var _utils = require("@kepler.gl/utils");
var _filterPanelHeader = _interopRequireDefault(require("../../side-panel/filter-panel/filter-panel-header"));
var _panelHeaderAction = _interopRequireDefault(require("../../side-panel/panel-header-action"));
var _fieldSelector = _interopRequireDefault(require("../../common/field-selector"));
var _styledComponents = require("../../common/styled-components");
var _newFilterPanel = require("./new-filter-panel");
var _constants = require("@kepler.gl/constants");
var _timeSyncedFieldSelector = _interopRequireDefault(require("./time-synced-field-selector"));
var _filterSyncedDatasetPanel = _interopRequireDefault(require("./filter-synced-dataset-panel"));
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
// SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
var SYNC_FILTER_ID_LENGTH = 2;
TimeRangeFilterPanelFactory.deps = [_timeRangeFilter["default"], _filterPanelHeader["default"], _fieldSelector["default"], _panelHeaderAction["default"], _timeSyncedFieldSelector["default"], _filterSyncedDatasetPanel["default"]];
function TimeRangeFilterPanelFactory(TimeRangeFilter, FilterPanelHeader, FieldSelector, PanelHeaderAction, TimeSyncedFieldSelector, FilterSyncedDatasetPanel) {
var TimeRangeFilterPanel = /*#__PURE__*/_react["default"].memo(function (_ref) {
var idx = _ref.idx,
datasets = _ref.datasets,
layers = _ref.layers,
allAvailableFields = _ref.allAvailableFields,
filter = _ref.filter,
enlargeFilter = _ref.enlargeFilter,
setFilter = _ref.setFilter,
setFilterPlot = _ref.setFilterPlot,
removeFilter = _ref.removeFilter,
toggleAnimation = _ref.toggleAnimation,
syncTimeFilterWithLayerTimeline = _ref.syncTimeFilterWithLayerTimeline;
var onSetFilterValue = (0, _react.useCallback)(function (value) {
return setFilter(idx, 'value', value);
}, [idx, setFilter]);
var onSetFilterPlot = (0, _react.useCallback)(function (newProp, valueIndex) {
return setFilterPlot(idx, newProp, valueIndex);
}, [idx, setFilterPlot]);
var isEnlarged = (0, _react.useMemo)(function () {
return !(0, _utils.isSideFilter)(filter);
}, [filter]);
var panelActions = (0, _react.useMemo)(function () {
return [{
id: filter.id,
onClick: enlargeFilter,
tooltip: 'tooltip.timePlayback',
iconComponent: _icons.Clock,
active: isEnlarged
}];
}, [filter.id, isEnlarged, enlargeFilter]);
var onFieldSelector = (0, _react.useCallback)(function (field, valueIndex) {
return setFilter(idx, 'name', field.name, valueIndex);
}, [setFilter, idx]);
var onSourceDataSelector = (0, _react.useCallback)(function (value) {
return setFilter(idx, 'dataId', value, 0);
}, [idx, setFilter]);
var dataset = datasets[filter.dataId[0]];
var supportedFields = (0, _react.useMemo)(function () {
return (0, _newFilterPanel.getSupportedFilterFields)(dataset.supportedFilterTypes, allAvailableFields);
}, [dataset.supportedFilterTypes, allAvailableFields]);
var isSynced = (0, _react.useMemo)(function () {
return filter.dataId.length >= SYNC_FILTER_ID_LENGTH && filter.type === _constants.FILTER_TYPES.timeRange;
}, [filter.dataId, filter.type]);
var isHistogramVisible = (0, _react.useMemo)(function () {
return filter.type && !isEnlarged;
}, [filter.type, isEnlarged]);
var timeline = (0, _utils.getTimelineFromFilter)(filter);
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(FilterPanelHeader, {
datasets: [dataset],
allAvailableFields: supportedFields,
idx: idx,
filter: filter,
removeFilter: removeFilter
}, isSynced ? /*#__PURE__*/_react["default"].createElement(TimeSyncedFieldSelector, null) : /*#__PURE__*/_react["default"].createElement(FieldSelector, {
inputTheme: "secondary",
fields: supportedFields,
value: Array.isArray(filter.name) ? filter.name[0] : filter.name,
erasable: false,
onSelect: function onSelect(field) {
return onFieldSelector(field, 0);
}
}), panelActions.map(function (panelAction) {
return /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, {
id: panelAction.id,
key: panelAction.id,
onClick: panelAction.onClick,
tooltip: panelAction.tooltip,
IconComponent: panelAction.iconComponent,
active: panelAction.active
});
})), /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledFilterContent, {
className: "filter-panel__content"
}, /*#__PURE__*/_react["default"].createElement(FilterSyncedDatasetPanel, {
datasets: datasets,
layers: layers,
filter: filter,
idx: idx,
onFieldSelector: onFieldSelector,
onSourceDataSelector: onSourceDataSelector,
setFilter: setFilter,
supportedFields: supportedFields,
syncTimeFilterWithLayerTimeline: syncTimeFilterWithLayerTimeline
}), isHistogramVisible && /*#__PURE__*/_react["default"].createElement("div", {
className: "filter-panel__filter"
}, /*#__PURE__*/_react["default"].createElement(TimeRangeFilter, {
filter: filter,
datasets: datasets,
layers: layers,
idx: idx,
toggleAnimation: toggleAnimation,
setFilter: onSetFilterValue,
setFilterPlot: onSetFilterPlot,
isAnimatable: true,
hideTimeTitle: true,
timeline: timeline
}))));
});
TimeRangeFilterPanel.displayName = 'TimeRangeFilterPanel';
return TimeRangeFilterPanel;
}
var _default = exports["default"] = TimeRangeFilterPanelFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_timeRangeFilter","_interopRequireDefault","_icons","_utils","_filterPanelHeader","_panelHeaderAction","_fieldSelector","_styledComponents","_newFilterPanel","_constants","_timeSyncedFieldSelector","_filterSyncedDatasetPanel","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","SYNC_FILTER_ID_LENGTH","TimeRangeFilterPanelFactory","deps","TimeRangeFilterFactory","FilterPanelHeaderFactory","FieldSelectorFactory","PanelHeaderActionFactory","TimeSyncedFieldSelectorFactory","FilterSyncedDatasetPanelFactory","TimeRangeFilter","FilterPanelHeader","FieldSelector","PanelHeaderAction","TimeSyncedFieldSelector","FilterSyncedDatasetPanel","TimeRangeFilterPanel","React","memo","_ref","idx","datasets","layers","allAvailableFields","filter","enlargeFilter","setFilter","setFilterPlot","removeFilter","toggleAnimation","syncTimeFilterWithLayerTimeline","onSetFilterValue","useCallback","value","onSetFilterPlot","newProp","valueIndex","isEnlarged","useMemo","isSideFilter","panelActions","id","onClick","tooltip","iconComponent","Clock","active","onFieldSelector","field","name","onSourceDataSelector","dataset","dataId","supportedFields","getSupportedFilterFields","supportedFilterTypes","isSynced","length","type","FILTER_TYPES","timeRange","isHistogramVisible","timeline","getTimelineFromFilter","createElement","Fragment","inputTheme","fields","Array","isArray","erasable","onSelect","map","panelAction","key","IconComponent","StyledFilterContent","className","isAnimatable","hideTimeTitle","displayName","_default","exports"],"sources":["../../../src/filters/filter-panels/time-range-filter-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\nimport TimeRangeFilterFactory from '../time-range-filter';\nimport {Clock} from '../../common/icons';\nimport {TimeRangeFilterPanelComponent} from './types';\nimport {isSideFilter, getTimelineFromFilter} from '@kepler.gl/utils';\nimport FilterPanelHeaderFactory from '../../side-panel/filter-panel/filter-panel-header';\nimport PanelHeaderActionFactory from '../../side-panel/panel-header-action';\nimport FieldSelectorFactory from '../../common/field-selector';\nimport {StyledFilterContent} from '../../common/styled-components';\nimport {getSupportedFilterFields} from './new-filter-panel';\nimport {FILTER_TYPES} from '@kepler.gl/constants';\nimport TimeSyncedFieldSelectorFactory from './time-synced-field-selector';\nimport FilterSyncedDatasetPanelFactory from './filter-synced-dataset-panel';\n\nconst SYNC_FILTER_ID_LENGTH = 2;\n\nTimeRangeFilterPanelFactory.deps = [\n  TimeRangeFilterFactory,\n  FilterPanelHeaderFactory,\n  FieldSelectorFactory,\n  PanelHeaderActionFactory,\n  TimeSyncedFieldSelectorFactory,\n  FilterSyncedDatasetPanelFactory\n];\n\nfunction TimeRangeFilterPanelFactory(\n  TimeRangeFilter: ReturnType<typeof TimeRangeFilterFactory>,\n  FilterPanelHeader: ReturnType<typeof FilterPanelHeaderFactory>,\n  FieldSelector: ReturnType<typeof FieldSelectorFactory>,\n  PanelHeaderAction: ReturnType<typeof PanelHeaderActionFactory>,\n  TimeSyncedFieldSelector: ReturnType<typeof TimeSyncedFieldSelectorFactory>,\n  FilterSyncedDatasetPanel: ReturnType<typeof FilterSyncedDatasetPanelFactory>\n) {\n  const TimeRangeFilterPanel: TimeRangeFilterPanelComponent = React.memo(\n    ({\n      idx,\n      datasets,\n      layers,\n      allAvailableFields,\n      filter,\n      enlargeFilter,\n      setFilter,\n      setFilterPlot,\n      removeFilter,\n      toggleAnimation,\n      syncTimeFilterWithLayerTimeline\n    }) => {\n      const onSetFilterValue = useCallback(\n        value => setFilter(idx, 'value', value),\n        [idx, setFilter]\n      );\n\n      const onSetFilterPlot = useCallback(\n        (newProp, valueIndex) => setFilterPlot(idx, newProp, valueIndex),\n        [idx, setFilterPlot]\n      );\n\n      const isEnlarged = useMemo(() => !isSideFilter(filter), [filter]);\n\n      const panelActions = useMemo(\n        () => [\n          {\n            id: filter.id,\n            onClick: enlargeFilter,\n            tooltip: 'tooltip.timePlayback',\n            iconComponent: Clock,\n            active: isEnlarged\n          }\n        ],\n        [filter.id, isEnlarged, enlargeFilter]\n      );\n\n      const onFieldSelector = useCallback(\n        (field, valueIndex) => setFilter(idx, 'name', field.name, valueIndex),\n        [setFilter, idx]\n      );\n\n      const onSourceDataSelector = useCallback(\n        value => setFilter(idx, 'dataId', value, 0),\n        [idx, setFilter]\n      );\n\n      const dataset = datasets[filter.dataId[0]];\n      const supportedFields = useMemo(\n        () => getSupportedFilterFields(dataset.supportedFilterTypes, allAvailableFields),\n        [dataset.supportedFilterTypes, allAvailableFields]\n      );\n\n      const isSynced = useMemo(() => {\n        return (\n          filter.dataId.length >= SYNC_FILTER_ID_LENGTH && filter.type === FILTER_TYPES.timeRange\n        );\n      }, [filter.dataId, filter.type]);\n\n      const isHistogramVisible = useMemo(\n        () => filter.type && !isEnlarged,\n        [filter.type, isEnlarged]\n      );\n\n      const timeline = getTimelineFromFilter(filter);\n\n      return (\n        <>\n          <FilterPanelHeader\n            datasets={[dataset]}\n            allAvailableFields={supportedFields}\n            idx={idx}\n            filter={filter}\n            removeFilter={removeFilter}\n          >\n            {isSynced ? (\n              <TimeSyncedFieldSelector />\n            ) : (\n              <FieldSelector\n                inputTheme=\"secondary\"\n                fields={supportedFields}\n                value={Array.isArray(filter.name) ? filter.name[0] : filter.name}\n                erasable={false}\n                onSelect={field => onFieldSelector(field, 0)}\n              />\n            )}\n            {panelActions.map(panelAction => (\n              <PanelHeaderAction\n                id={panelAction.id}\n                key={panelAction.id}\n                onClick={panelAction.onClick}\n                tooltip={panelAction.tooltip}\n                IconComponent={panelAction.iconComponent}\n                active={panelAction.active}\n              />\n            ))}\n          </FilterPanelHeader>\n          <StyledFilterContent className=\"filter-panel__content\">\n            <FilterSyncedDatasetPanel\n              datasets={datasets}\n              layers={layers}\n              filter={filter}\n              idx={idx}\n              onFieldSelector={onFieldSelector}\n              onSourceDataSelector={onSourceDataSelector}\n              setFilter={setFilter}\n              supportedFields={supportedFields}\n              syncTimeFilterWithLayerTimeline={syncTimeFilterWithLayerTimeline}\n            />\n            {isHistogramVisible && (\n              <div className=\"filter-panel__filter\">\n                <TimeRangeFilter\n                  filter={filter}\n                  datasets={datasets}\n                  layers={layers}\n                  idx={idx}\n                  toggleAnimation={toggleAnimation}\n                  setFilter={onSetFilterValue}\n                  setFilterPlot={onSetFilterPlot}\n                  isAnimatable\n                  hideTimeTitle\n                  timeline={timeline}\n                />\n              </div>\n            )}\n          </StyledFilterContent>\n        </>\n      );\n    }\n  );\n\n  TimeRangeFilterPanel.displayName = 'TimeRangeFilterPanel';\n\n  return TimeRangeFilterPanel;\n}\n\nexport default TimeRangeFilterPanelFactory;\n"],"mappings":"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","ignoreList":[]}