kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
153 lines (138 loc) • 18.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _defaultSettings = require("../../constants/default-settings");
var _icons = require("../common/icons");
var _styledComponents = require("../common/styled-components");
// Copyright (c) 2023 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
var propTypes = {
datasets: _propTypes["default"].object.isRequired,
selectedDataset: _propTypes["default"].string,
dataType: _propTypes["default"].string.isRequired,
filtered: _propTypes["default"].bool.isRequired,
// callbacks
onClose: _propTypes["default"].func.isRequired,
onChangeExportSelectedDataset: _propTypes["default"].func.isRequired,
onChangeExportDataType: _propTypes["default"].func.isRequired,
onChangeExportFiltered: _propTypes["default"].func.isRequired
};
var getDataRowCount = function getDataRowCount(datasets, selectedDataset, filtered) {
var selectedData = datasets[selectedDataset];
if (!selectedData) {
return "".concat(Object.keys(datasets).length, " Files ");
}
var allData = selectedData.allData,
data = selectedData.data;
var rowCount = filtered ? data.length : allData.length;
return "".concat(rowCount.toLocaleString(), " Rows");
};
var ExportDataModal = function ExportDataModal(_ref) {
var datasets = _ref.datasets,
selectedDataset = _ref.selectedDataset,
dataType = _ref.dataType,
filtered = _ref.filtered,
config = _ref.config,
onChangeExportDataType = _ref.onChangeExportDataType,
onChangeExportSelectedDataset = _ref.onChangeExportSelectedDataset,
onChangeExportFiltered = _ref.onChangeExportFiltered;
return (/*#__PURE__*/_react["default"].createElement(_styledComponents.StyledModalContent, {
className: "export-data-modal"
}, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledExportSection, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "description"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "title"
}, "Dataset"), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, "Choose the datasets you want to export")), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, /*#__PURE__*/_react["default"].createElement("select", {
value: selectedDataset,
onChange: function onChange(e) {
return onChangeExportSelectedDataset(e.target.value);
}
}, ['All'].concat(Object.keys(datasets)).map(function (d) {
return (/*#__PURE__*/_react["default"].createElement("option", {
key: d,
value: d
}, datasets[d] && datasets[d].label || d)
);
})))), /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledExportSection, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "description"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "title"
}, "Data Type"), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, "Choose the type of data you want to export")), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, _defaultSettings.EXPORT_DATA_TYPE_OPTIONS.map(function (op) {
return (/*#__PURE__*/_react["default"].createElement(_styledComponents.StyledType, {
key: op.id,
selected: dataType === op.id,
available: op.available,
onClick: function onClick() {
return op.available && onChangeExportDataType(op.id);
}
}, /*#__PURE__*/_react["default"].createElement(_icons.FileType, {
ext: op.label,
height: "80px",
fontSize: "11px"
}))
);
}))), /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledExportSection, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "description"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "title"
}, "Filter Data"), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, "You can choose exporting original data or filtered data")), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledFilteredOption, {
selected: !filtered,
onClick: function onClick() {
return onChangeExportFiltered(false);
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "filtered-title"
}, "Unfiltered Data"), /*#__PURE__*/_react["default"].createElement("div", {
className: "filtered-subtitle"
}, getDataRowCount(datasets, selectedDataset, false))), /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledFilteredOption, {
selected: filtered,
onClick: function onClick() {
return onChangeExportFiltered(true);
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "filtered-title"
}, "Filtered Data"), /*#__PURE__*/_react["default"].createElement("div", {
className: "filtered-subtitle"
}, getDataRowCount(datasets, selectedDataset, true)))))))
);
};
ExportDataModal.propTypes = propTypes;
var ExportDataModalFactory = function ExportDataModalFactory() {
return ExportDataModal;
};
var _default = exports["default"] = ExportDataModalFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/export-data-modal.js"],"names":["propTypes","datasets","PropTypes","object","isRequired","selectedDataset","string","dataType","filtered","bool","onClose","func","onChangeExportSelectedDataset","onChangeExportDataType","onChangeExportFiltered","getDataRowCount","selectedData","Object","keys","length","allData","data","rowCount","toLocaleString","ExportDataModal","config","e","target","value","concat","map","d","label","EXPORT_DATA_TYPE_OPTIONS","op","id","available","ExportDataModalFactory"],"mappings":";;;;;;;;;AAoBA;;AACA;;AAEA;;AACA;;AACA;;AAzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAcA,IAAMA,SAAS,GAAG;AAChBC,EAAAA,QAAQ,EAAEC,sBAAUC,MAAV,CAAiBC,UADX;AAEhBC,EAAAA,eAAe,EAAEH,sBAAUI,MAFX;AAGhBC,EAAAA,QAAQ,EAAEL,sBAAUI,MAAV,CAAiBF,UAHX;AAIhBI,EAAAA,QAAQ,EAAEN,sBAAUO,IAAV,CAAeL,UAJT;AAKhB;AACAM,EAAAA,OAAO,EAAER,sBAAUS,IAAV,CAAeP,UANR;AAOhBQ,EAAAA,6BAA6B,EAAEV,sBAAUS,IAAV,CAAeP,UAP9B;AAQhBS,EAAAA,sBAAsB,EAAEX,sBAAUS,IAAV,CAAeP,UARvB;AAShBU,EAAAA,sBAAsB,EAAEZ,sBAAUS,IAAV,CAAeP;AATvB,CAAlB;;AAYA,IAAMW,eAAe,GAAG,SAAlBA,eAAkB,CAACd,QAAD,EAAWI,eAAX,EAA4BG,QAA5B,EAAyC;AAC/D,MAAMQ,YAAY,GAAGf,QAAQ,CAACI,eAAD,CAA7B;;AACA,MAAI,CAACW,YAAL,EAAmB;AACjB,qBAAUC,MAAM,CAACC,IAAP,CAAYjB,QAAZ,EAAsBkB,MAAhC;AACD;;AACD,MAAOC,OAAP,GAAwBJ,YAAxB,CAAOI,OAAP;AAAA,MAAgBC,IAAhB,GAAwBL,YAAxB,CAAgBK,IAAhB;AACA,MAAMC,QAAQ,GAAGd,QAAQ,GAAGa,IAAI,CAACF,MAAR,GAAiBC,OAAO,CAACD,MAAlD;AACA,mBAAUG,QAAQ,CAACC,cAAT,EAAV;AACD,CARD;;AAUA,IAAMC,eAAe,GAAG,SAAlBA,eAAkB;AAAA,MACtBvB,QADsB,QACtBA,QADsB;AAAA,MAEtBI,eAFsB,QAEtBA,eAFsB;AAAA,MAGtBE,QAHsB,QAGtBA,QAHsB;AAAA,MAItBC,QAJsB,QAItBA,QAJsB;AAAA,MAKtBiB,MALsB,QAKtBA,MALsB;AAAA,MAOtBZ,sBAPsB,QAOtBA,sBAPsB;AAAA,MAQtBD,6BARsB,QAQtBA,6BARsB;AAAA,MAStBE,sBATsB,QAStBA,sBATsB;AAAA,uBAWtB,gCAAC,oCAAD;AAAoB,MAAA,SAAS,EAAC;AAA9B,oBACE,0DACE,gCAAC,qCAAD,qBACE;AAAK,MAAA,SAAS,EAAC;AAAf,oBACE;AAAK,MAAA,SAAS,EAAC;AAAf,iBADF,eAIE;AAAK,MAAA,SAAS,EAAC;AAAf,gDAJF,CADF,eASE;AAAK,MAAA,SAAS,EAAC;AAAf,oBACE;AAAQ,MAAA,KAAK,EAAET,eAAf;AAAgC,MAAA,QAAQ,EAAE,kBAAAqB,CAAC;AAAA,eAAId,6BAA6B,CAACc,CAAC,CAACC,MAAF,CAASC,KAAV,CAAjC;AAAA;AAA3C,OACC,CAAC,KAAD,EAAQC,MAAR,CAAeZ,MAAM,CAACC,IAAP,CAAYjB,QAAZ,CAAf,EAAsC6B,GAAtC,CAA0C,UAAAC,CAAC;AAAA,2BAC1C;AAAQ,UAAA,GAAG,EAAEA,CAAb;AAAgB,UAAA,KAAK,EAAEA;AAAvB,WAA4B9B,QAAQ,CAAC8B,CAAD,CAAR,IAAe9B,QAAQ,CAAC8B,CAAD,CAAR,CAAYC,KAA5B,IAAsCD,CAAjE;AAD0C;AAAA,KAA3C,CADD,CADF,CATF,CADF,eAkBE,gCAAC,qCAAD,qBACE;AAAK,MAAA,SAAS,EAAC;AAAf,oBACE;AAAK,MAAA,SAAS,EAAC;AAAf,mBADF,eAIE;AAAK,MAAA,SAAS,EAAC;AAAf,oDAJF,CADF,eASE;AAAK,MAAA,SAAS,EAAC;AAAf,OACGE,0CAAyBH,GAAzB,CAA6B,UAAAI,EAAE;AAAA,2BAC9B,gCAAC,4BAAD;AACE,UAAA,GAAG,EAAEA,EAAE,CAACC,EADV;AAEE,UAAA,QAAQ,EAAE5B,QAAQ,KAAK2B,EAAE,CAACC,EAF5B;AAGE,UAAA,SAAS,EAAED,EAAE,CAACE,SAHhB;AAIE,UAAA,OAAO,EAAE;AAAA,mBAAMF,EAAE,CAACE,SAAH,IAAgBvB,sBAAsB,CAACqB,EAAE,CAACC,EAAJ,CAA5C;AAAA;AAJX,wBAME,gCAAC,eAAD;AAAU,UAAA,GAAG,EAAED,EAAE,CAACF,KAAlB;AAAyB,UAAA,MAAM,EAAC,MAAhC;AAAuC,UAAA,QAAQ,EAAC;AAAhD,UANF;AAD8B;AAAA,KAA/B,CADH,CATF,CAlBF,eAwCE,gCAAC,qCAAD,qBACE;AAAK,MAAA,SAAS,EAAC;AAAf,oBACE;AAAK,MAAA,SAAS,EAAC;AAAf,qBADF,eAIE;AAAK,MAAA,SAAS,EAAC;AAAf,iEAJF,CADF,eASE;AAAK,MAAA,SAAS,EAAC;AAAf,oBACE,gCAAC,sCAAD;AAAsB,MAAA,QAAQ,EAAE,CAACxB,QAAjC;AAA2C,MAAA,OAAO,EAAE;AAAA,eAAMM,sBAAsB,CAAC,KAAD,CAA5B;AAAA;AAApD,oBACE;AAAK,MAAA,SAAS,EAAC;AAAf,yBADF,eAEE;AAAK,MAAA,SAAS,EAAC;AAAf,OAAoCC,eAAe,CAACd,QAAD,EAAWI,eAAX,EAA4B,KAA5B,CAAnD,CAFF,CADF,eAKE,gCAAC,sCAAD;AAAsB,MAAA,QAAQ,EAAEG,QAAhC;AAA0C,MAAA,OAAO,EAAE;AAAA,eAAMM,sBAAsB,CAAC,IAAD,CAA5B;AAAA;AAAnD,oBACE;AAAK,MAAA,SAAS,EAAC;AAAf,uBADF,eAEE;AAAK,MAAA,SAAS,EAAC;AAAf,OAAoCC,eAAe,CAACd,QAAD,EAAWI,eAAX,EAA4B,IAA5B,CAAnD,CAFF,CALF,CATF,CAxCF,CADF;AAXsB;AAAA,CAAxB;;AA4EAmB,eAAe,CAACxB,SAAhB,GAA4BA,SAA5B;;AAEA,IAAMqC,sBAAsB,GAAG,SAAzBA,sBAAyB;AAAA,SAAMb,eAAN;AAAA,CAA/B;;oCACea,sB","sourcesContent":["// Copyright (c) 2023 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 from 'react';\nimport PropTypes from 'prop-types';\n\nimport {EXPORT_DATA_TYPE_OPTIONS} from 'constants/default-settings';\nimport {FileType} from 'components/common/icons';\nimport {\n  StyledModalContent,\n  StyledExportSection,\n  StyledFilteredOption,\n  StyledType\n} from 'components/common/styled-components';\n\nconst propTypes = {\n  datasets: PropTypes.object.isRequired,\n  selectedDataset: PropTypes.string,\n  dataType: PropTypes.string.isRequired,\n  filtered: PropTypes.bool.isRequired,\n  // callbacks\n  onClose: PropTypes.func.isRequired,\n  onChangeExportSelectedDataset: PropTypes.func.isRequired,\n  onChangeExportDataType: PropTypes.func.isRequired,\n  onChangeExportFiltered: PropTypes.func.isRequired\n};\n\nconst getDataRowCount = (datasets, selectedDataset, filtered) => {\n  const selectedData = datasets[selectedDataset];\n  if (!selectedData) {\n    return `${Object.keys(datasets).length} Files ` ;\n  }\n  const {allData, data} = selectedData;\n  const rowCount = filtered ? data.length : allData.length;\n  return `${rowCount.toLocaleString()} Rows`;\n};\n\nconst ExportDataModal = ({\n  datasets,\n  selectedDataset,\n  dataType,\n  filtered,\n  config,\n  // callbacks:\n  onChangeExportDataType,\n  onChangeExportSelectedDataset,\n  onChangeExportFiltered\n}) => (\n  <StyledModalContent className=\"export-data-modal\">\n    <div>\n      <StyledExportSection>\n        <div className=\"description\">\n          <div className=\"title\">\n            Dataset\n          </div>\n          <div className=\"subtitle\">\n            Choose the datasets you want to export\n          </div>\n        </div>\n        <div className=\"selection\">\n          <select value={selectedDataset} onChange={e => onChangeExportSelectedDataset(e.target.value)}>\n          {['All'].concat(Object.keys(datasets)).map(d => (\n            <option key={d} value={d}>{(datasets[d] && datasets[d].label) || d}</option>\n          ))}\n          </select>\n        </div>\n      </StyledExportSection>\n      <StyledExportSection>\n        <div className=\"description\">\n          <div className=\"title\">\n            Data Type\n          </div>\n          <div className=\"subtitle\">\n            Choose the type of data you want to export\n          </div>\n        </div>\n        <div className=\"selection\">\n          {EXPORT_DATA_TYPE_OPTIONS.map(op =>\n            <StyledType\n              key={op.id}\n              selected={dataType === op.id}\n              available={op.available}\n              onClick={() => op.available && onChangeExportDataType(op.id)}\n            >\n              <FileType ext={op.label} height=\"80px\" fontSize=\"11px\" />\n            </StyledType>\n          )}\n        </div>\n      </StyledExportSection>\n      <StyledExportSection>\n        <div className=\"description\">\n          <div className=\"title\">\n            Filter Data\n          </div>\n          <div className=\"subtitle\">\n            You can choose exporting original data or filtered data\n          </div>\n        </div>\n        <div className=\"selection\">\n          <StyledFilteredOption selected={!filtered} onClick={() => onChangeExportFiltered(false)}>\n            <div className=\"filtered-title\">Unfiltered Data</div>\n            <div className=\"filtered-subtitle\">{getDataRowCount(datasets, selectedDataset, false)}</div>\n          </StyledFilteredOption>\n          <StyledFilteredOption selected={filtered} onClick={() => onChangeExportFiltered(true)}>\n            <div className=\"filtered-title\">Filtered Data</div>\n            <div className=\"filtered-subtitle\">{getDataRowCount(datasets, selectedDataset, true)}</div>\n          </StyledFilteredOption>\n        </div>\n      </StyledExportSection>\n    </div>\n  </StyledModalContent>\n);\n\nExportDataModal.propTypes = propTypes;\n\nconst ExportDataModalFactory = () => ExportDataModal;\nexport default ExportDataModalFactory;\n"]}