kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
93 lines (77 loc) • 13 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _localization = require("../../../localization");
var _styledComponents2 = require("../../common/styled-components");
var _columnSelector = _interopRequireDefault(require("./column-selector"));
var _templateObject;
var TopRow = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n"])));
LayerColumnConfigFactory.deps = [_columnSelector["default"]];
function LayerColumnConfigFactory(ColumnSelector) {
var LayerColumnConfig = function LayerColumnConfig(_ref) {
var columnPairs = _ref.columnPairs,
fieldPairs = _ref.fieldPairs,
columns = _ref.columns,
columnLabels = _ref.columnLabels,
fields = _ref.fields,
updateLayerConfig = _ref.updateLayerConfig,
assignColumn = _ref.assignColumn,
assignColumnPairs = _ref.assignColumnPairs;
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]);
return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "layer-config__column"
}, /*#__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"
}))), 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: enhancedFieldPairs,
onSelect: function onSelect(val) {
return onUpdateColumn(key, val);
}
});
}))));
};
LayerColumnConfig.propTypes = {
columns: _propTypes["default"].object.isRequired,
fields: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired,
assignColumnPairs: _propTypes["default"].func.isRequired,
assignColumn: _propTypes["default"].func.isRequired,
updateLayerConfig: _propTypes["default"].func.isRequired,
columnPairs: _propTypes["default"].object,
fieldPairs: _propTypes["default"].arrayOf(_propTypes["default"].any),
columnLabels: _propTypes["default"].object
};
return LayerColumnConfig;
}
var _default = LayerColumnConfigFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/layer-column-config.js"],"names":["TopRow","styled","div","LayerColumnConfigFactory","deps","ColumnSelectorFactory","ColumnSelector","LayerColumnConfig","columnPairs","fieldPairs","columns","columnLabels","fields","updateLayerConfig","assignColumn","assignColumnPairs","enhancedFieldPairs","map","fp","name","defaultName","type","pair","onUpdateColumn","key","value","assignedColumns","Object","keys","val","propTypes","PropTypes","object","isRequired","arrayOf","any","func"],"mappings":";;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAEA,IAAMA,MAAM,GAAGC,6BAAOC,GAAV,6IAAZ;;AAKAC,wBAAwB,CAACC,IAAzB,GAAgC,CAACC,0BAAD,CAAhC;;AAEA,SAASF,wBAAT,CAAkCG,cAAlC,EAAkD;AAChD,MAAMC,iBAAiB,GAAG,SAApBA,iBAAoB,OASpB;AAAA,QARJC,WAQI,QARJA,WAQI;AAAA,QAPJC,UAOI,QAPJA,UAOI;AAAA,QANJC,OAMI,QANJA,OAMI;AAAA,QALJC,YAKI,QALJA,YAKI;AAAA,QAJJC,MAII,QAJJA,MAII;AAAA,QAHJC,iBAGI,QAHJA,iBAGI;AAAA,QAFJC,YAEI,QAFJA,YAEI;AAAA,QADJC,iBACI,QADJA,iBACI;AACJ,QAAMC,kBAAkB,GAAG,oBACzB;AAAA,aACER,WAAW,IAAIC,UAAf,GACIA,UAAU,CAACQ,GAAX,CAAe,UAAAC,EAAE;AAAA,eAAK;AACpBC,UAAAA,IAAI,EAAED,EAAE,CAACE,WADW;AAEpBC,UAAAA,IAAI,EAAE,OAFc;AAGpBC,UAAAA,IAAI,EAAEJ,EAAE,CAACI;AAHW,SAAL;AAAA,OAAjB,CADJ,GAMI,IAPN;AAAA,KADyB,EASzB,CAACd,WAAD,EAAcC,UAAd,CATyB,CAA3B;AAYA,QAAMc,cAAc,GAAG,wBACrB,UAACC,GAAD,EAAMC,KAAN,EAAgB;AACd,UAAMC,eAAe,GACnBD,KAAK,IAAIA,KAAK,CAACH,IAAf,IAAuBd,WAAvB,GACIO,iBAAiB,CAACS,GAAD,EAAMC,KAAK,CAACH,IAAZ,CADrB,GAEIR,YAAY,CAACU,GAAD,EAAMC,KAAN,CAHlB;AAKAZ,MAAAA,iBAAiB,CAAC;AAACH,QAAAA,OAAO,EAAEgB;AAAV,OAAD,CAAjB;AACD,KARoB,EASrB,CAACb,iBAAD,EAAoBL,WAApB,EAAiCO,iBAAjC,EAAoDD,YAApD,CATqB,CAAvB;AAYA,wBACE,0DACE,gCAAC,mCAAD,qBACE;AAAK,MAAA,SAAS,EAAC;AAAf,oBACE,gCAAC,MAAD,qBACE,gCAAC,6BAAD,qBACE,gCAAC,8BAAD;AAAkB,MAAA,EAAE,EAAE;AAAtB,MADF,CADF,eAIE,gCAAC,6BAAD,qBACE,gCAAC,8BAAD;AAAkB,MAAA,EAAE,EAAC;AAArB,MADF,CAJF,CADF,EASGa,MAAM,CAACC,IAAP,CAAYlB,OAAZ,EAAqBO,GAArB,CAAyB,UAAAO,GAAG;AAAA,0BAC3B,gCAAC,cAAD;AACE,QAAA,MAAM,EAAEd,OAAO,CAACc,GAAD,CADjB;AAEE,QAAA,OAAO,EAAEd,OAFX;AAGE,QAAA,KAAK,EAAGC,YAAY,IAAIA,YAAY,CAACa,GAAD,CAA7B,IAAuCA,GAHhD;AAIE,QAAA,GAAG,EAAEA,GAJP;AAKE,QAAA,SAAS,EAAEZ,MALb;AAME,QAAA,UAAU,EAAEI,kBANd;AAOE,QAAA,QAAQ,EAAE,kBAAAa,GAAG;AAAA,iBAAIN,cAAc,CAACC,GAAD,EAAMK,GAAN,CAAlB;AAAA;AAPf,QAD2B;AAAA,KAA5B,CATH,CADF,CADF,CADF;AA2BD,GA7DD;;AA+DAtB,EAAAA,iBAAiB,CAACuB,SAAlB,GAA8B;AAC5BpB,IAAAA,OAAO,EAAEqB,sBAAUC,MAAV,CAAiBC,UADE;AAE5BrB,IAAAA,MAAM,EAAEmB,sBAAUG,OAAV,CAAkBH,sBAAUI,GAA5B,EAAiCF,UAFb;AAG5BlB,IAAAA,iBAAiB,EAAEgB,sBAAUK,IAAV,CAAeH,UAHN;AAI5BnB,IAAAA,YAAY,EAAEiB,sBAAUK,IAAV,CAAeH,UAJD;AAK5BpB,IAAAA,iBAAiB,EAAEkB,sBAAUK,IAAV,CAAeH,UALN;AAM5BzB,IAAAA,WAAW,EAAEuB,sBAAUC,MANK;AAO5BvB,IAAAA,UAAU,EAAEsB,sBAAUG,OAAV,CAAkBH,sBAAUI,GAA5B,CAPgB;AAQ5BxB,IAAAA,YAAY,EAAEoB,sBAAUC;AARI,GAA9B;AAWA,SAAOzB,iBAAP;AACD;;eAEcJ,wB","sourcesContent":["// Copyright (c) 2021 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, {useCallback, useMemo} from 'react';\nimport PropTypes from 'prop-types';\nimport styled from 'styled-components';\nimport {FormattedMessage} from 'localization';\nimport {PanelLabel, SidePanelSection} from 'components/common/styled-components';\nimport ColumnSelectorFactory from './column-selector';\n\nconst TopRow = styled.div`\n  display: flex;\n  justify-content: space-between;\n`;\n\nLayerColumnConfigFactory.deps = [ColumnSelectorFactory];\n\nfunction LayerColumnConfigFactory(ColumnSelector) {\n  const LayerColumnConfig = ({\n    columnPairs,\n    fieldPairs,\n    columns,\n    columnLabels,\n    fields,\n    updateLayerConfig,\n    assignColumn,\n    assignColumnPairs\n  }) => {\n    const enhancedFieldPairs = 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    return (\n      <div>\n        <SidePanelSection>\n          <div className=\"layer-config__column\">\n            <TopRow>\n              <PanelLabel>\n                <FormattedMessage id={'columns.title'} />\n              </PanelLabel>\n              <PanelLabel>\n                <FormattedMessage id=\"layer.required\" />\n              </PanelLabel>\n            </TopRow>\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={enhancedFieldPairs}\n                onSelect={val => onUpdateColumn(key, val)}\n              />\n            ))}\n          </div>\n        </SidePanelSection>\n      </div>\n    );\n  };\n\n  LayerColumnConfig.propTypes = {\n    columns: PropTypes.object.isRequired,\n    fields: PropTypes.arrayOf(PropTypes.any).isRequired,\n    assignColumnPairs: PropTypes.func.isRequired,\n    assignColumn: PropTypes.func.isRequired,\n    updateLayerConfig: PropTypes.func.isRequired,\n    columnPairs: PropTypes.object,\n    fieldPairs: PropTypes.arrayOf(PropTypes.any),\n    columnLabels: PropTypes.object\n  };\n\n  return LayerColumnConfig;\n}\n\nexport default LayerColumnConfigFactory;\n"]}