UNPKG

kepler.gl

Version:

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

86 lines (84 loc) 16 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 _commonUtils = require("@kepler.gl/common-utils"); var _columnSelector = _interopRequireDefault(require("./column-selector")); var _styledComponents = require("../../common/styled-components"); 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 /** * only provide suggested field pairs if there is a match, * otherwise the user can select a suggested field pair that will create invalid columns and a hard crash */ function getValidFieldPairsSuggestionsForColumn(enhancedFieldPairs, columnPairs, columnKey) { if (enhancedFieldPairs && columnPairs !== null && columnPairs !== void 0 && columnPairs[columnKey]) { var columnPair = columnPairs[columnKey]; var matchingFieldPairs = enhancedFieldPairs.filter(function (_ref) { var pair = _ref.pair; return (0, _commonUtils.toArray)(columnPair.fieldPairKey).some(function (fieldPairKey) { return Object.prototype.hasOwnProperty.call(pair, fieldPairKey); }); }); return matchingFieldPairs.length > 0 ? matchingFieldPairs : null; } return null; } LayerColumnConfigFactory.deps = [_columnSelector["default"]]; function LayerColumnConfigFactory(ColumnSelector) { var LayerColumnConfig = function LayerColumnConfig(_ref2) { var columnPairs = _ref2.columnPairs, fieldPairs = _ref2.fieldPairs, columns = _ref2.columns, columnLabels = _ref2.columnLabels, fields = _ref2.fields, updateLayerConfig = _ref2.updateLayerConfig, assignColumn = _ref2.assignColumn, assignColumnPairs = _ref2.assignColumnPairs, isActive = _ref2.isActive; var enhancedFieldPairs = (0, _react.useMemo)(function () { return columnPairs && fieldPairs ? fieldPairs.map(function (fp) { return { name: fp.defaultName, type: 'point', pair: fp.pair }; }) : null; }, [columnPairs, fieldPairs]); var onUpdateColumn = (0, _react.useCallback)(function (key, value) { var assignedColumns = value && value.pair && columnPairs ? assignColumnPairs(key, value.pair) : assignColumn(key, value); updateLayerConfig({ columns: assignedColumns }); }, [updateLayerConfig, columnPairs, assignColumnPairs, assignColumn]); if (!Object.keys(columns).length) { // don't render if columns is empty return /*#__PURE__*/_react["default"].createElement("div", null); } return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_styledComponents.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement("div", { className: "layer-config__column" }, Object.keys(columns).map(function (key) { return /*#__PURE__*/_react["default"].createElement(ColumnSelector, { column: columns[key], columns: columns, label: columnLabels && columnLabels[key] || key, key: key, allFields: fields, fieldPairs: getValidFieldPairsSuggestionsForColumn(enhancedFieldPairs, columnPairs, key), onSelect: function onSelect(val) { return onUpdateColumn(key, val); }, isActive: isActive }); })))); }; return LayerColumnConfig; } var _default = exports["default"] = LayerColumnConfigFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_commonUtils","_columnSelector","_interopRequireDefault","_styledComponents","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","getValidFieldPairsSuggestionsForColumn","enhancedFieldPairs","columnPairs","columnKey","columnPair","matchingFieldPairs","filter","_ref","pair","toArray","fieldPairKey","some","prototype","length","LayerColumnConfigFactory","deps","ColumnSelectorFactory","ColumnSelector","LayerColumnConfig","_ref2","fieldPairs","columns","columnLabels","fields","updateLayerConfig","assignColumn","assignColumnPairs","isActive","useMemo","map","fp","name","defaultName","type","onUpdateColumn","useCallback","key","value","assignedColumns","keys","createElement","SidePanelSection","className","column","label","allFields","onSelect","val","_default","exports"],"sources":["../../../src/side-panel/layer-panel/layer-column-config.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\n\nimport {LayerBaseConfig} from '@kepler.gl/layers';\nimport {\n  FieldPair,\n  ColumnPairs,\n  LayerColumns,\n  ColumnLabels,\n  EnhancedFieldPair\n} from '@kepler.gl/types';\nimport {toArray} from '@kepler.gl/common-utils';\n\nimport ColumnSelectorFactory from './column-selector';\nimport {MinimalField} from '../../common/field-selector';\nimport {SidePanelSection} from '../../common/styled-components';\n\nexport type LayerColumnConfigProps<FieldOption extends MinimalField> = {\n  columns: LayerColumns;\n  fields: FieldOption[];\n  assignColumnPairs: (key: string, pair: FieldPair) => LayerColumns;\n  assignColumn: (key: string, field: FieldOption) => LayerColumns;\n  updateLayerConfig: (newConfig: Partial<LayerBaseConfig>) => void;\n  updateLayerType?: (newType: string) => void;\n  columnPairs?: ColumnPairs | null;\n  fieldPairs?: FieldPair[];\n  columnLabels: ColumnLabels | null;\n  isActive: boolean;\n};\n\n/**\n * only provide suggested field pairs if there is a match,\n * otherwise the user can select a suggested field pair that will create invalid columns and a hard crash\n */\nfunction getValidFieldPairsSuggestionsForColumn(\n  enhancedFieldPairs: EnhancedFieldPair[] | null,\n  columnPairs: ColumnPairs | null | undefined,\n  columnKey: string\n): EnhancedFieldPair[] | null {\n  if (enhancedFieldPairs && columnPairs?.[columnKey]) {\n    const columnPair = columnPairs[columnKey];\n    const matchingFieldPairs = enhancedFieldPairs.filter(({pair}) => {\n      return toArray(columnPair.fieldPairKey).some(fieldPairKey =>\n        Object.prototype.hasOwnProperty.call(pair, fieldPairKey)\n      );\n    });\n    return matchingFieldPairs.length > 0 ? matchingFieldPairs : null;\n  }\n  return null;\n}\n\nLayerColumnConfigFactory.deps = [ColumnSelectorFactory];\n\nfunction LayerColumnConfigFactory(ColumnSelector: ReturnType<typeof ColumnSelectorFactory>) {\n  const LayerColumnConfig: React.FC<LayerColumnConfigProps<MinimalField & {fieldIdx: number}>> = ({\n    columnPairs,\n    fieldPairs,\n    columns,\n    columnLabels,\n    fields,\n    updateLayerConfig,\n    assignColumn,\n    assignColumnPairs,\n    isActive\n  }) => {\n    const enhancedFieldPairs: EnhancedFieldPair[] | null = useMemo(\n      () =>\n        columnPairs && fieldPairs\n          ? fieldPairs.map(fp => ({\n              name: fp.defaultName,\n              type: 'point',\n              pair: fp.pair\n            }))\n          : null,\n      [columnPairs, fieldPairs]\n    );\n\n    const onUpdateColumn = useCallback(\n      (key, value) => {\n        const assignedColumns =\n          value && value.pair && columnPairs\n            ? assignColumnPairs(key, value.pair)\n            : assignColumn(key, value);\n\n        updateLayerConfig({columns: assignedColumns});\n      },\n      [updateLayerConfig, columnPairs, assignColumnPairs, assignColumn]\n    );\n\n    if (!Object.keys(columns).length) {\n      // don't render if columns is empty\n      return <div />;\n    }\n\n    return (\n      <div>\n        <SidePanelSection>\n          <div className=\"layer-config__column\">\n            {Object.keys(columns).map(key => (\n              <ColumnSelector\n                column={columns[key]}\n                columns={columns}\n                label={(columnLabels && columnLabels[key]) || key}\n                key={key}\n                allFields={fields}\n                fieldPairs={getValidFieldPairsSuggestionsForColumn(\n                  enhancedFieldPairs,\n                  columnPairs,\n                  key\n                )}\n                onSelect={val => onUpdateColumn(key, val)}\n                isActive={isActive}\n              />\n            ))}\n          </div>\n        </SidePanelSection>\n      </div>\n    );\n  };\n\n  return LayerColumnConfig;\n}\n\nexport default LayerColumnConfigFactory;\n"],"mappings":"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","ignoreList":[]}