kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
201 lines (172 loc) • 27.7 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _defaultSettings = require("../../constants/default-settings");
var _icons = require("../common/icons");
var _styledComponents2 = require("../common/styled-components");
function _templateObject3() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n align-items: center;\n border-radius: 2px;\n border: 1px solid ", ";\n cursor: pointer;\n display: flex;\n flex-direction: column;\n height: 60px;\n justify-content: center;\n margin: 4px;\n padding: 8px 12px;\n width: 140px;\n\n :hover {\n border: 1px solid ", ";\n }\n\n .filtered-title {\n color: ", ";\n font-size: 12px;\n font-weight: 500;\n }\n .filtered-subtitle {\n color: ", ";\n font-size: 11px;\n }\n"]);
_templateObject3 = function _templateObject3() {
return data;
};
return data;
}
function _templateObject2() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n border-radius: 2px;\n border: 1px solid ", ";\n color: ", ";\n cursor: pointer;\n font-weight: 500;\n height: 100px;\n margin: 4px;\n padding: 6px 10px;\n width: 100px;\n\n :hover {\n color: ", ";\n border: 1px solid ", ";\n }\n"]);
_templateObject2 = function _templateObject2() {
return data;
};
return data;
}
function _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n margin: 35px 0;\n width: 100%;\n\n .description {\n width: 185px;\n \n .title {\n font-weight: 500;\n color: ", ";\n font-size: 12px;\n }\n .subtitle {\n color: ", ";\n font-size: 11px;\n }\n }\n\n .selection {\n display: flex;\n flex-wrap: wrap;\n flex: 1;\n padding-left: 50px;\n\n select {\n background-color: white;\n border-radius: 1px;\n display: inline-block;\n font: inherit;\n line-height: 1.5em;\n padding: 0.5em 3.5em 0.5em 1em;\n margin: 0; \n box-sizing: border-box;\n appearance: none;\n width: 250px;\n height: 36px;\n\n background-image:\n linear-gradient(45deg, transparent 50%, gray 50%),\n linear-gradient(135deg, gray 50%, transparent 50%),\n linear-gradient(to right, #ccc, #ccc);\n background-position:\n calc(100% - 20px) calc(1em + 2px),\n calc(100% - 15px) calc(1em + 2px),\n calc(100% - 2.5em) 4.5em;\n background-size:\n 5px 5px,\n 5px 5px,\n 1px 1.5em;\n background-repeat: no-repeat;\n }\n\n select:focus {\n background-image:\n linear-gradient(45deg, green 50%, transparent 50%),\n linear-gradient(135deg, transparent 50%, green 50%),\n linear-gradient(to right, #ccc, #ccc);\n background-position:\n calc(100% - 15px) 1em,\n calc(100% - 20px) 1em,\n calc(100% - 2.5em) 4.5em;\n background-size:\n 5px 5px,\n 5px 5px,\n 1px 1.5em;\n background-repeat: no-repeat;\n border-color: green;\n outline: 0;\n }\n }\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
var StyledExportDataSection = _styledComponents["default"].div(_templateObject(), function (props) {
return props.theme.textColorLT;
}, function (props) {
return props.theme.textColor;
});
var StyledDataType = _styledComponents["default"].div(_templateObject2(), function (props) {
return props.selected ? props.theme.primaryBtnBgd : props.theme.selectBorderColorLT;
}, function (props) {
return props.selected ? props.theme.primaryBtnBgd : props.theme.selectBorderColorLT;
}, function (props) {
return props.available && props.theme.primaryBtnBgd;
}, function (props) {
return props.available && props.theme.primaryBtnBgd;
});
var StyledFilteredDataOption = _styledComponents["default"].div(_templateObject3(), function (props) {
return props.selected ? props.theme.primaryBtnBgd : props.theme.selectBorderColorLT;
}, function (props) {
return props.theme.primaryBtnBgd;
}, function (props) {
return props.theme.textColorLT;
}, function (props) {
return props.theme.textColor;
});
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,
onChangeExportConfig: _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('en'), " 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 _react["default"].createElement("div", {
className: "export-data-modal"
}, _react["default"].createElement(_styledComponents2.StyledModalContent, null, _react["default"].createElement("div", null, _react["default"].createElement(StyledExportDataSection, null, _react["default"].createElement("div", {
className: "description"
}, _react["default"].createElement("div", {
className: "title"
}, "Dataset"), _react["default"].createElement("div", {
className: "subtitle"
}, "Choose the datasets you want to export")), _react["default"].createElement("div", {
className: "selection"
}, _react["default"].createElement("select", {
value: selectedDataset,
onChange: function onChange(e) {
return onChangeExportSelectedDataset({
dataset: e.target.value
});
}
}, ['All'].concat(Object.keys(datasets)).map(function (d) {
return _react["default"].createElement("option", {
key: d,
value: d
}, datasets[d] && datasets[d].label || d);
})))), _react["default"].createElement(StyledExportDataSection, null, _react["default"].createElement("div", {
className: "description"
}, _react["default"].createElement("div", {
className: "title"
}, "Data Type"), _react["default"].createElement("div", {
className: "subtitle"
}, "Choose the type of data you want to export")), _react["default"].createElement("div", {
className: "selection"
}, _defaultSettings.EXPORT_DATA_TYPE_OPTIONS.map(function (op) {
return _react["default"].createElement(StyledDataType, {
key: op.id,
selected: dataType === op.id,
available: op.available,
onClick: function onClick() {
return op.available && onChangeExportDataType({
dataType: op.id
});
}
}, _react["default"].createElement(_icons.FileType, {
ext: op.label,
height: "80px",
fontSize: "11px"
}));
}))), _react["default"].createElement(StyledExportDataSection, null, _react["default"].createElement("div", {
className: "description"
}, _react["default"].createElement("div", {
className: "title"
}, "Filter Data"), _react["default"].createElement("div", {
className: "subtitle"
}, "You can choose exporting original data or filtered data")), _react["default"].createElement("div", {
className: "selection"
}, _react["default"].createElement(StyledFilteredDataOption, {
selected: !filtered,
onClick: function onClick() {
return onChangeExportFiltered({
filtered: false
});
}
}, _react["default"].createElement("div", {
className: "filtered-title"
}, "Unfiltered Data"), _react["default"].createElement("div", {
className: "filtered-subtitle"
}, getDataRowCount(datasets, selectedDataset, false))), _react["default"].createElement(StyledFilteredDataOption, {
selected: filtered,
onClick: function onClick() {
return onChangeExportFiltered({
filtered: true
});
}
}, _react["default"].createElement("div", {
className: "filtered-title"
}, "Filtered Data"), _react["default"].createElement("div", {
className: "filtered-subtitle"
}, getDataRowCount(datasets, selectedDataset, true))))))));
};
ExportDataModal.propTypes = propTypes;
var ExportDataModalFactory = function ExportDataModalFactory() {
return ExportDataModal;
};
var _default = ExportDataModalFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/export-data-modal.js"],"names":["StyledExportDataSection","styled","div","props","theme","textColorLT","textColor","StyledDataType","selected","primaryBtnBgd","selectBorderColorLT","available","StyledFilteredDataOption","propTypes","datasets","PropTypes","object","isRequired","selectedDataset","string","dataType","filtered","bool","onClose","func","onChangeExportSelectedDataset","onChangeExportDataType","onChangeExportFiltered","onChangeExportConfig","getDataRowCount","selectedData","Object","keys","length","allData","data","rowCount","toLocaleString","ExportDataModal","config","e","dataset","target","value","concat","map","d","label","EXPORT_DATA_TYPE_OPTIONS","op","id","ExportDataModalFactory"],"mappings":"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","sourcesContent":["// Copyright (c) 2019 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';\nimport styled from 'styled-components';\n\nimport {EXPORT_DATA_TYPE_OPTIONS} from 'constants/default-settings';\nimport {FileType} from 'components/common/icons';\nimport {StyledModalContent} from 'components/common/styled-components';\n\nconst StyledExportDataSection = styled.div`\n  display: flex;\n  flex-direction: row;\n  margin: 35px 0;\n  width: 100%;\n\n  .description {\n    width: 185px;\n    \n    .title {\n      font-weight: 500;\n      color: ${props => props.theme.textColorLT};\n      font-size: 12px;\n    }\n    .subtitle {\n      color: ${props => props.theme.textColor};\n      font-size: 11px;\n    }\n  }\n\n  .selection {\n    display: flex;\n    flex-wrap: wrap;\n    flex: 1;\n    padding-left: 50px;\n\n    select {\n      background-color: white;\n      border-radius: 1px;\n      display: inline-block;\n      font: inherit;\n      line-height: 1.5em;\n      padding: 0.5em 3.5em 0.5em 1em;\n      margin: 0;      \n      box-sizing: border-box;\n      appearance: none;\n      width: 250px;\n      height: 36px;\n\n      background-image:\n        linear-gradient(45deg, transparent 50%, gray 50%),\n        linear-gradient(135deg, gray 50%, transparent 50%),\n        linear-gradient(to right, #ccc, #ccc);\n      background-position:\n        calc(100% - 20px) calc(1em + 2px),\n        calc(100% - 15px) calc(1em + 2px),\n        calc(100% - 2.5em) 4.5em;\n      background-size:\n        5px 5px,\n        5px 5px,\n        1px 1.5em;\n      background-repeat: no-repeat;\n    }\n\n    select:focus {\n      background-image:\n        linear-gradient(45deg, green 50%, transparent 50%),\n        linear-gradient(135deg, transparent 50%, green 50%),\n        linear-gradient(to right, #ccc, #ccc);\n      background-position:\n        calc(100% - 15px) 1em,\n        calc(100% - 20px) 1em,\n        calc(100% - 2.5em) 4.5em;\n      background-size:\n        5px 5px,\n        5px 5px,\n        1px 1.5em;\n      background-repeat: no-repeat;\n      border-color: green;\n      outline: 0;\n    }\n  }\n`;\n\nconst StyledDataType = styled.div`\n  border-radius: 2px;\n  border: 1px solid ${props => props.selected ? props.theme.primaryBtnBgd : props.theme.selectBorderColorLT};\n  color: ${props => props.selected ? props.theme.primaryBtnBgd : props.theme.selectBorderColorLT};\n  cursor: pointer;\n  font-weight: 500;\n  height: 100px;\n  margin: 4px;\n  padding: 6px 10px;\n  width: 100px;\n\n  :hover {\n    color: ${props => props.available && props.theme.primaryBtnBgd};\n    border: 1px solid ${props => props.available && props.theme.primaryBtnBgd};\n  }\n`;\n\nconst StyledFilteredDataOption = styled.div`\n  align-items: center;\n  border-radius: 2px;\n  border: 1px solid ${props => props.selected ? props.theme.primaryBtnBgd : props.theme.selectBorderColorLT};\n  cursor: pointer;\n  display: flex;\n  flex-direction: column;\n  height: 60px;\n  justify-content: center;\n  margin: 4px;\n  padding: 8px 12px;\n  width: 140px;\n\n  :hover {\n    border: 1px solid ${props => props.theme.primaryBtnBgd};\n  }\n\n  .filtered-title {\n    color: ${props => props.theme.textColorLT};\n    font-size: 12px;\n    font-weight: 500;\n  }\n  .filtered-subtitle {\n    color: ${props => props.theme.textColor};\n    font-size: 11px;\n  }\n`;\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  onChangeExportConfig: 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('en')} 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  <div className=\"export-data-modal\">\n    <StyledModalContent>\n      <div>\n        <StyledExportDataSection>\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({dataset: 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        </StyledExportDataSection>\n\n        <StyledExportDataSection>\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              <StyledDataType\n                key={op.id}\n                selected={dataType === op.id}\n                available={op.available}\n                onClick={() => op.available && onChangeExportDataType({dataType: op.id})}\n              >\n                <FileType ext={op.label} height=\"80px\" fontSize=\"11px\" />\n              </StyledDataType>\n            )}\n          </div>\n        </StyledExportDataSection>\n\n        <StyledExportDataSection>\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            <StyledFilteredDataOption selected={!filtered} onClick={() => onChangeExportFiltered({filtered: false})}>\n              <div className=\"filtered-title\">Unfiltered Data</div>\n              <div className=\"filtered-subtitle\">{getDataRowCount(datasets, selectedDataset, false)}</div>\n            </StyledFilteredDataOption>\n            <StyledFilteredDataOption selected={filtered} onClick={() => onChangeExportFiltered({filtered: true})}>\n              <div className=\"filtered-title\">Filtered Data</div>\n              <div className=\"filtered-subtitle\">{getDataRowCount(datasets, selectedDataset, true)}</div>\n            </StyledFilteredDataOption>\n          </div>\n        </StyledExportDataSection>\n\n      </div>\n    </StyledModalContent>\n  </div>\n);\n\nExportDataModal.propTypes = propTypes;\n\nconst ExportDataModalFactory = () => ExportDataModal;\nexport default ExportDataModalFactory;\n"]}