kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
193 lines (192 loc) • 37.6 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ColumnModeConfigFactory = ColumnModeConfigFactory;
exports["default"] = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _styledComponents2 = require("../../common/styled-components");
var _checkbox = _interopRequireDefault(require("../../common/checkbox"));
var _panelHeaderAction = _interopRequireDefault(require("../panel-header-action"));
var _layerColumnConfig = _interopRequireDefault(require("./layer-column-config"));
var _localization = require("@kepler.gl/localization");
var _icons = require("../../common/icons");
var _templateObject, _templateObject2, _templateObject3; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
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; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
var TopRow = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n"])));
var Separator = (0, _styledComponents["default"])(function (_ref) {
var children = _ref.children,
className = _ref.className;
return /*#__PURE__*/_react["default"].createElement("div", {
className: className
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "separator-line-cell"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "separator-line"
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "separator-content"
}, children), /*#__PURE__*/_react["default"].createElement("div", {
className: "separator-line-cell"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "separator-line"
})));
})(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n & > * + * {\n margin-left: 10px;\n }\n & > .separator-line-cell {\n display: flex;\n flex-grow: 1;\n align-items: center;\n }\n & > .separator-content {\n color: ", ";\n }\n & > .separator-line-cell > .separator-line {\n display: flex;\n border-bottom: 1px solid ", ";\n width: 100%;\n line-height: 1px;\n height: 1px;\n }\n"])), function (props) {
return props.theme.labelColor;
}, function (props) {
return props.theme.labelColor;
});
var ConfigPanesContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n & > * + * {\n margin-top: 10px;\n }\n fieldset {\n border: 1px solid ", ";\n margin: 0;\n }\n legend {\n display: flex;\n label {\n color: ", ";\n }\n }\n"])), function (props) {
return props.theme.labelColor;
}, function (props) {
return props.theme.labelColor;
});
ColumnModeConfigFactory.deps = [_panelHeaderAction["default"]];
function ColumnModeConfigFactory(PanelHeaderAction) {
var ColumnModeConfig = function ColumnModeConfig(_ref2) {
var id = _ref2.id,
supportedColumnModes = _ref2.supportedColumnModes,
selectedColumnMode = _ref2.selectedColumnMode,
columns = _ref2.columns,
renderColumnConfig = _ref2.renderColumnConfig,
selectColumnMode = _ref2.selectColumnMode,
_ref2$getHelpHandler = _ref2.getHelpHandler,
getHelpHandler = _ref2$getHelpHandler === void 0 ? function () {
return null;
} : _ref2$getHelpHandler;
var columnModes = (0, _react.useMemo)(function () {
return supportedColumnModes ? supportedColumnModes.map(function (_ref3) {
var key = _ref3.key,
label = _ref3.label,
requiredColumns = _ref3.requiredColumns,
optionalColumns = _ref3.optionalColumns;
var allColumns = (requiredColumns || []).concat(optionalColumns || []).reduce(function (acc, k) {
acc[k] = columns[k];
return acc;
}, {});
return {
key: key,
label: label,
columns: allColumns
};
}) : Object.keys(columns).length > 0 ? [{
key: 'default',
label: '',
columns: columns
}] : [];
}, [supportedColumnModes, columns]);
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, columnModes.length > 0 ? /*#__PURE__*/_react["default"].createElement(TopRow, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'columns.title'
})), /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "layer.required"
}))) : null, /*#__PURE__*/_react["default"].createElement(ConfigPanesContainer, null, columnModes.map(function (modeConfig, i) {
var columnMode = modeConfig.key,
label = modeConfig.label;
var isSelected = selectedColumnMode === columnMode || columnModes.length === 1;
var columnPanel = renderColumnConfig(modeConfig, isSelected);
var helpHandler = getHelpHandler(modeConfig);
var selectColumnModeHandler = function selectColumnModeHandler() {
return selectColumnMode(modeConfig);
};
return /*#__PURE__*/_react["default"].createElement(_react.Fragment, {
key: columnMode
}, i > 0 ? /*#__PURE__*/_react["default"].createElement(Separator, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "layer.columnModesSeparator"
})) : null, columnModes.length > 1 ? /*#__PURE__*/_react["default"].createElement("div", {
className: "layer-column-mode-panel"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledPanelHeader, {
className: "interaction-panel__header"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelHeaderContent, {
className: "interaction-panel__header__content"
}, /*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
type: "radio",
name: "layer-".concat(id, "-input-modes"),
checked: isSelected,
id: "".concat(id, "-input-column-").concat(columnMode),
label: label,
onChange: selectColumnModeHandler
})), helpHandler ? /*#__PURE__*/_react["default"].createElement("div", {
className: "interaction-panel__header__actions"
}, /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, {
id: "".concat(id, "-help-button"),
className: "layer__help-button",
tooltip: 'layerConfiguration.howTo',
onClick: helpHandler,
IconComponent: _icons.Help
})) : null), /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelContent, {
className: "interaction-panel__content"
}, columnPanel)) : columnPanel);
})));
};
return ColumnModeConfig;
}
LayerColumnModeConfigFactory.deps = [_layerColumnConfig["default"], ColumnModeConfigFactory];
function LayerColumnModeConfigFactory(LayerColumnConfig, ColumnModeConfig) {
var LayerColumnModeConfig = function LayerColumnModeConfig(_ref4) {
var id = _ref4.id,
layer = _ref4.layer,
supportedColumnModes = _ref4.supportedColumnModes,
layerConfig = _ref4.layerConfig,
fields = _ref4.fields,
fieldPairs = _ref4.fieldPairs,
openModal = _ref4.openModal,
_updateLayerConfig = _ref4.updateLayerConfig;
var columns = layerConfig.columns;
var selectColumnMode = (0, _react.useCallback)(function (_ref5) {
var columnMode = _ref5.key;
_updateLayerConfig({
columnMode: columnMode
});
}, [_updateLayerConfig]);
var renderColumnConfig = (0, _react.useCallback)(function (_ref6, isSelected) {
var columnMode = _ref6.key,
cols = _ref6.columns;
return /*#__PURE__*/_react["default"].createElement(LayerColumnConfig, {
columnPairs: layer.columnPairs,
columns: cols,
assignColumnPairs: layer.assignColumnPairs.bind(layer),
assignColumn: layer.assignColumn.bind(layer),
columnLabels: layer.columnLabels,
fields: fields,
fieldPairs: fieldPairs,
updateLayerConfig: function updateLayerConfig(config) {
return _updateLayerConfig(_objectSpread(_objectSpread({}, config), !isSelected && columnMode !== 'defaut' ? {
columnMode: columnMode
} : {}));
},
isActive: isSelected
});
}, [layer, _updateLayerConfig, fieldPairs, fields]);
var getHelpHandler = (0, _react.useCallback)(function (_ref7) {
var _layer$layerInfoModal;
var columnMode = _ref7.key;
var modal = (_layer$layerInfoModal = layer.layerInfoModal) === null || _layer$layerInfoModal === void 0 ? void 0 : _layer$layerInfoModal[columnMode];
if (modal) {
return function () {
return openModal(modal);
};
}
return null;
}, [layer, openModal]);
return /*#__PURE__*/_react["default"].createElement(ColumnModeConfig, {
id: id,
supportedColumnModes: supportedColumnModes,
selectedColumnMode: layerConfig.columnMode,
columns: columns,
selectColumnMode: selectColumnMode,
renderColumnConfig: renderColumnConfig,
getHelpHandler: getHelpHandler
});
};
return LayerColumnModeConfig;
}
var _default = exports["default"] = LayerColumnModeConfigFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_styledComponents2","_checkbox","_panelHeaderAction","_layerColumnConfig","_localization","_icons","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","TopRow","styled","div","_taggedTemplateLiteral2","Separator","_ref","children","className","createElement","props","theme","labelColor","ConfigPanesContainer","ColumnModeConfigFactory","deps","PanelHeaderActionFactory","PanelHeaderAction","ColumnModeConfig","_ref2","id","supportedColumnModes","selectedColumnMode","columns","renderColumnConfig","selectColumnMode","_ref2$getHelpHandler","getHelpHandler","columnModes","useMemo","map","_ref3","key","label","requiredColumns","optionalColumns","allColumns","concat","reduce","acc","k","Fragment","PanelLabel","FormattedMessage","modeConfig","columnMode","isSelected","columnPanel","helpHandler","selectColumnModeHandler","StyledPanelHeader","PanelHeaderContent","type","name","checked","onChange","tooltip","onClick","IconComponent","Help","PanelContent","LayerColumnModeConfigFactory","LayerColumnConfigFactory","LayerColumnConfig","LayerColumnModeConfig","_ref4","layer","layerConfig","fields","fieldPairs","openModal","updateLayerConfig","useCallback","_ref5","_ref6","cols","columnPairs","assignColumnPairs","bind","assignColumn","columnLabels","config","isActive","_ref7","_layer$layerInfoModal","modal","layerInfoModal","_default","exports"],"sources":["../../../src/side-panel/layer-panel/layer-column-mode-config.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {Fragment, useCallback, useMemo} from 'react';\nimport styled from 'styled-components';\n\nimport {\n  PanelHeaderContent,\n  PanelLabel,\n  StyledPanelHeader,\n  PanelContent\n} from '../../common/styled-components';\nimport Checkbox from '../../common/checkbox';\nimport {MinimalField} from '../../common/field-selector';\nimport PanelHeaderActionFactory from '../panel-header-action';\nimport LayerColumnConfigFactory from './layer-column-config';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {Layer, LayerInfoModal, LayerBaseConfig} from '@kepler.gl/layers';\nimport {SupportedColumnMode, FieldPair, LayerColumns} from '@kepler.gl/types';\nimport {BaseComponentProps} from '../../types';\n\nimport {Help} from '../../common/icons';\n\nconst TopRow = styled.div`\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst Separator = styled(({children, className}: BaseComponentProps) => (\n  <div className={className}>\n    <div className=\"separator-line-cell\">\n      <div className=\"separator-line\" />\n    </div>\n    <div className=\"separator-content\">{children}</div>\n    <div className=\"separator-line-cell\">\n      <div className=\"separator-line\" />\n    </div>\n  </div>\n))`\n  display: flex;\n  flex-direction: row;\n  & > * + * {\n    margin-left: 10px;\n  }\n  & > .separator-line-cell {\n    display: flex;\n    flex-grow: 1;\n    align-items: center;\n  }\n  & > .separator-content {\n    color: ${props => props.theme.labelColor};\n  }\n  & > .separator-line-cell > .separator-line {\n    display: flex;\n    border-bottom: 1px solid ${props => props.theme.labelColor};\n    width: 100%;\n    line-height: 1px;\n    height: 1px;\n  }\n`;\n\nconst ConfigPanesContainer = styled.div`\n  display: flex;\n  flex-direction: column;\n  & > * + * {\n    margin-top: 10px;\n  }\n  fieldset {\n    border: 1px solid ${props => props.theme.labelColor};\n    margin: 0;\n  }\n  legend {\n    display: flex;\n    label {\n      color: ${props => props.theme.labelColor};\n    }\n  }\n`;\n\ninterface FieldOption extends MinimalField {\n  fieldIdx: number;\n}\nexport type SupportedColumnModeConfig = {\n  key: string;\n  label: string;\n  columns: LayerColumns;\n};\nexport type ColumnModeConfigProps = {\n  supportedColumnModes: SupportedColumnMode[] | null;\n  selectedColumnMode?: string;\n  id: string;\n  columns: LayerColumns;\n  renderColumnConfig: (\n    mode: {key: string; label: string; columns: any},\n    selected: boolean\n  ) => JSX.Element;\n  selectColumnMode: (mode: SupportedColumnModeConfig) => void;\n  getHelpHandler?: (mode: SupportedColumnModeConfig) => (() => void) | null;\n};\n\nColumnModeConfigFactory.deps = [PanelHeaderActionFactory];\n\nexport function ColumnModeConfigFactory(\n  PanelHeaderAction: ReturnType<typeof PanelHeaderActionFactory>\n) {\n  const ColumnModeConfig: React.FC<ColumnModeConfigProps> = ({\n    id,\n    supportedColumnModes,\n    selectedColumnMode,\n    columns,\n    renderColumnConfig,\n    selectColumnMode,\n    getHelpHandler = () => null\n  }: ColumnModeConfigProps) => {\n    const columnModes = useMemo(\n      () =>\n        supportedColumnModes\n          ? supportedColumnModes.map(({key, label, requiredColumns, optionalColumns}) => {\n              const allColumns = (requiredColumns || [])\n                .concat(optionalColumns || [])\n                .reduce((acc, k) => {\n                  acc[k] = columns[k];\n                  return acc;\n                }, {});\n              return {key, label, columns: allColumns};\n            })\n          : Object.keys(columns).length > 0\n          ? [{key: 'default', label: '', columns}]\n          : [],\n      [supportedColumnModes, columns]\n    );\n\n    return (\n      <>\n        {columnModes.length > 0 ? (\n          <TopRow>\n            <PanelLabel>\n              <FormattedMessage id={'columns.title'} />\n            </PanelLabel>\n            <PanelLabel>\n              <FormattedMessage id=\"layer.required\" />\n            </PanelLabel>\n          </TopRow>\n        ) : null}\n        <ConfigPanesContainer>\n          {columnModes.map((modeConfig, i) => {\n            const {key: columnMode, label} = modeConfig;\n\n            const isSelected = selectedColumnMode === columnMode || columnModes.length === 1;\n            const columnPanel = renderColumnConfig(modeConfig, isSelected);\n            const helpHandler = getHelpHandler(modeConfig);\n            const selectColumnModeHandler = () => selectColumnMode(modeConfig);\n\n            return (\n              <Fragment key={columnMode}>\n                {i > 0 ? (\n                  <Separator>\n                    <FormattedMessage id=\"layer.columnModesSeparator\" />\n                  </Separator>\n                ) : null}\n                {columnModes.length > 1 ? (\n                  <div className=\"layer-column-mode-panel\">\n                    <StyledPanelHeader className=\"interaction-panel__header\">\n                      <PanelHeaderContent className=\"interaction-panel__header__content\">\n                        <Checkbox\n                          type=\"radio\"\n                          name={`layer-${id}-input-modes`}\n                          checked={isSelected}\n                          id={`${id}-input-column-${columnMode}`}\n                          label={label}\n                          onChange={selectColumnModeHandler}\n                        />\n                      </PanelHeaderContent>\n                      {helpHandler ? (\n                        <div className=\"interaction-panel__header__actions\">\n                          <PanelHeaderAction\n                            id={`${id}-help-button`}\n                            className=\"layer__help-button\"\n                            tooltip={'layerConfiguration.howTo'}\n                            onClick={helpHandler}\n                            IconComponent={Help}\n                          />\n                        </div>\n                      ) : null}\n                    </StyledPanelHeader>\n                    <PanelContent className=\"interaction-panel__content\">\n                      {columnPanel}\n                    </PanelContent>\n                  </div>\n                ) : (\n                  columnPanel\n                )}\n              </Fragment>\n            );\n          })}\n        </ConfigPanesContainer>\n      </>\n    );\n  };\n\n  return ColumnModeConfig;\n}\n\nexport type LayerColumnModeConfigProps = {\n  layer: Layer;\n  layerConfig: LayerBaseConfig;\n  supportedColumnModes: SupportedColumnMode[] | null;\n  id: string;\n  fields: FieldOption[];\n  fieldPairs?: FieldPair[];\n  openModal: (l: LayerInfoModal) => void;\n  updateLayerConfig: (config: Partial<LayerBaseConfig>) => void;\n  updateLayerType: (type: string) => void;\n};\n\nLayerColumnModeConfigFactory.deps = [LayerColumnConfigFactory, ColumnModeConfigFactory];\n\nfunction LayerColumnModeConfigFactory(\n  LayerColumnConfig: ReturnType<typeof LayerColumnConfigFactory>,\n  ColumnModeConfig: ReturnType<typeof ColumnModeConfigFactory>\n) {\n  const LayerColumnModeConfig = ({\n    id,\n    layer,\n    supportedColumnModes,\n    layerConfig,\n    fields,\n    fieldPairs,\n    openModal,\n    updateLayerConfig\n  }: LayerColumnModeConfigProps) => {\n    const {columns} = layerConfig;\n\n    const selectColumnMode = useCallback(\n      ({key: columnMode}) => {\n        updateLayerConfig({columnMode});\n      },\n      [updateLayerConfig]\n    );\n\n    const renderColumnConfig = useCallback(\n      ({key: columnMode, columns: cols}, isSelected) => (\n        <LayerColumnConfig\n          columnPairs={layer.columnPairs}\n          columns={cols}\n          assignColumnPairs={layer.assignColumnPairs.bind(layer)}\n          assignColumn={layer.assignColumn.bind(layer)}\n          columnLabels={layer.columnLabels}\n          fields={fields}\n          fieldPairs={fieldPairs}\n          updateLayerConfig={config =>\n            updateLayerConfig({\n              ...config,\n              // if column mode not currently selected\n              // set column mode along with the columns\n              ...(!isSelected && columnMode !== 'defaut' ? {columnMode} : {})\n            })\n          }\n          isActive={isSelected}\n        />\n      ),\n      [layer, updateLayerConfig, fieldPairs, fields]\n    );\n\n    const getHelpHandler = useCallback(\n      ({key: columnMode}) => {\n        const modal = layer.layerInfoModal?.[columnMode];\n        if (modal) {\n          return () => openModal(modal);\n        }\n        return null;\n      },\n      [layer, openModal]\n    );\n\n    return (\n      <ColumnModeConfig\n        id={id}\n        supportedColumnModes={supportedColumnModes}\n        selectedColumnMode={layerConfig.columnMode}\n        columns={columns}\n        selectColumnMode={selectColumnMode}\n        renderColumnConfig={renderColumnConfig}\n        getHelpHandler={getHelpHandler}\n      />\n    );\n  };\n\n  return LayerColumnModeConfig;\n}\n\nexport default LayerColumnModeConfigFactory;\n"],"mappings":"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","ignoreList":[]}
;