UNPKG

kepler.gl

Version:

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

78 lines (76 loc) 15.9 kB
"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 _styledComponents = require("../../common/styled-components"); var _filterPanelHeader = _interopRequireDefault(require("../../side-panel/filter-panel/filter-panel-header")); var _panelHeaderAction = _interopRequireDefault(require("../../side-panel/panel-header-action")); var _sourceDataSelector = _interopRequireDefault(require("../../side-panel/common/source-data-selector")); var _fieldSelector = _interopRequireDefault(require("../../common/field-selector")); var _newFilterPanel = require("./new-filter-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 FieldPanelWithFieldSelectFactory.deps = [_filterPanelHeader["default"], _sourceDataSelector["default"], _fieldSelector["default"], _panelHeaderAction["default"]]; function FieldPanelWithFieldSelectFactory(FilterPanelHeader, SourceDataSelector, FieldSelector, PanelHeaderAction) { var FilterPanelWithFieldSelect = /*#__PURE__*/_react["default"].memo(function (_ref) { var children = _ref.children, allAvailableFields = _ref.allAvailableFields, datasets = _ref.datasets, filter = _ref.filter, idx = _ref.idx, removeFilter = _ref.removeFilter, setFilter = _ref.setFilter, _ref$panelActions = _ref.panelActions, panelActions = _ref$panelActions === void 0 ? [] : _ref$panelActions; var onFieldSelector = (0, _react.useCallback)(function (field) { return setFilter(idx, 'name', field.name); }, [idx, setFilter]); var onSourceDataSelector = (0, _react.useCallback)(function (value) { return setFilter(idx, 'dataId', value, 0); }, [idx, setFilter]); var fieldValue = (0, _react.useMemo)(function () { return Array.isArray(filter.name) ? filter.name[0] : filter.name; }, [filter.name]); var dataset = datasets[filter.dataId[0]]; var supportedFields = (0, _react.useMemo)(function () { return (0, _newFilterPanel.getSupportedFilterFields)(dataset.supportedFilterTypes, allAvailableFields); }, [dataset.supportedFilterTypes, allAvailableFields]); return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(FilterPanelHeader, { datasets: [dataset], filter: filter, removeFilter: removeFilter }, /*#__PURE__*/_react["default"].createElement(FieldSelector, { inputTheme: "secondary", fields: supportedFields, value: fieldValue, erasable: false, onSelect: onFieldSelector }), 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" }, Object.keys(datasets).length > 1 && /*#__PURE__*/_react["default"].createElement(SourceDataSelector, { inputTheme: "secondary", datasets: datasets, dataId: filter.dataId, onSelect: onSourceDataSelector }), children)); }); FilterPanelWithFieldSelect.displayName = 'FilterPanelWithFieldSelect'; return FilterPanelWithFieldSelect; } var _default = exports["default"] = FieldPanelWithFieldSelectFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_filterPanelHeader","_interopRequireDefault","_panelHeaderAction","_sourceDataSelector","_fieldSelector","_newFilterPanel","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","FieldPanelWithFieldSelectFactory","deps","FilterPanelHeaderFactory","SourceDataSelectorFactory","FieldSelectorFactory","PanelHeaderActionFactory","FilterPanelHeader","SourceDataSelector","FieldSelector","PanelHeaderAction","FilterPanelWithFieldSelect","React","memo","_ref","children","allAvailableFields","datasets","filter","idx","removeFilter","setFilter","_ref$panelActions","panelActions","onFieldSelector","useCallback","field","name","onSourceDataSelector","value","fieldValue","useMemo","Array","isArray","dataset","dataId","supportedFields","getSupportedFilterFields","supportedFilterTypes","createElement","Fragment","inputTheme","fields","erasable","onSelect","map","panelAction","id","key","onClick","tooltip","IconComponent","iconComponent","active","StyledFilterContent","className","keys","length","displayName","_default","exports"],"sources":["../../../src/filters/filter-panels/filter-panel-with-field-select.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\nimport {StyledFilterContent} from '../../common/styled-components';\nimport FilterPanelHeaderFactory from '../../side-panel/filter-panel/filter-panel-header';\nimport PanelHeaderActionFactory from '../../side-panel/panel-header-action';\nimport SourceDataSelectorFactory from '../../side-panel/common/source-data-selector';\nimport FieldSelectorFactory from '../../common/field-selector';\nimport {getSupportedFilterFields} from './new-filter-panel';\nimport {FilterPanelWithFieldSelectComponent} from './types';\nimport {KeplerTable} from '@kepler.gl/table';\n\nFieldPanelWithFieldSelectFactory.deps = [\n  FilterPanelHeaderFactory,\n  SourceDataSelectorFactory,\n  FieldSelectorFactory,\n  PanelHeaderActionFactory\n];\n\nfunction FieldPanelWithFieldSelectFactory(\n  FilterPanelHeader: ReturnType<typeof FilterPanelHeaderFactory>,\n  SourceDataSelector: ReturnType<typeof SourceDataSelectorFactory>,\n  FieldSelector: ReturnType<typeof FieldSelectorFactory>,\n  PanelHeaderAction: ReturnType<typeof PanelHeaderActionFactory>\n) {\n  const FilterPanelWithFieldSelect: FilterPanelWithFieldSelectComponent = React.memo(\n    ({\n      children,\n      allAvailableFields,\n      datasets,\n      filter,\n      idx,\n      removeFilter,\n      setFilter,\n      panelActions = []\n    }) => {\n      const onFieldSelector = useCallback(\n        field => setFilter(idx, 'name', field.name),\n        [idx, setFilter]\n      );\n\n      const onSourceDataSelector = useCallback(\n        value => setFilter(idx, 'dataId', value, 0),\n        [idx, setFilter]\n      );\n\n      const fieldValue = useMemo(\n        () => (Array.isArray(filter.name) ? filter.name[0] : filter.name),\n        [filter.name]\n      );\n\n      const dataset: KeplerTable = datasets[filter.dataId[0]];\n      const supportedFields = useMemo(\n        () => getSupportedFilterFields(dataset.supportedFilterTypes, allAvailableFields),\n        [dataset.supportedFilterTypes, allAvailableFields]\n      );\n      return (\n        <>\n          <FilterPanelHeader datasets={[dataset]} filter={filter} removeFilter={removeFilter}>\n            <FieldSelector\n              inputTheme=\"secondary\"\n              fields={supportedFields}\n              value={fieldValue}\n              erasable={false}\n              onSelect={onFieldSelector}\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            {Object.keys(datasets).length > 1 && (\n              <SourceDataSelector\n                inputTheme=\"secondary\"\n                datasets={datasets}\n                dataId={filter.dataId}\n                onSelect={onSourceDataSelector}\n              />\n            )}\n            {children}\n          </StyledFilterContent>\n        </>\n      );\n    }\n  );\n\n  FilterPanelWithFieldSelect.displayName = 'FilterPanelWithFieldSelect';\n\n  return FilterPanelWithFieldSelect;\n}\n\nexport default FieldPanelWithFieldSelectFactory;\n"],"mappings":"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","ignoreList":[]}