kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
227 lines (191 loc) • 27.7 kB
JavaScript
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(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");
var _reactIntl = require("react-intl");
var _localization = require("../../localization");
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
var propTypes = {
datasets: _propTypes["default"].object.isRequired,
selectedDataset: _propTypes["default"].string,
dataType: _propTypes["default"].string.isRequired,
filtered: _propTypes["default"].bool.isRequired,
// callbacks
applyCPUFilter: _propTypes["default"].func.isRequired,
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, intl) {
var selectedData = datasets[selectedDataset];
if (!selectedData) {
return intl.formatMessage({
id: 'modal.exportData.fileCount'
}, {
fileCount: Object.keys(datasets).length
});
}
var dataContainer = selectedData.dataContainer,
filteredIdxCPU = selectedData.filteredIdxCPU;
if (filtered && !filteredIdxCPU) {
return '-';
}
var rowCount = filtered ? filteredIdxCPU.length : dataContainer.numRows();
return intl.formatMessage({
id: 'modal.exportData.rowCount'
}, {
rowCount: rowCount.toLocaleString()
});
};
var ExportDataModalFactory = function ExportDataModalFactory() {
var ExportDataModal = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(ExportDataModal, _Component);
var _super = _createSuper(ExportDataModal);
function ExportDataModal() {
var _this;
(0, _classCallCheck2["default"])(this, ExportDataModal);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _super.call.apply(_super, [this].concat(args));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onSelectDataset", function (_ref) {
var value = _ref.target.value;
_this.props.applyCPUFilter(value);
_this.props.onChangeExportSelectedDataset(value);
});
return _this;
}
(0, _createClass2["default"])(ExportDataModal, [{
key: "componentDidMount",
value: function componentDidMount() {
var toCPUFilter = this.props.selectedDataset || Object.keys(this.props.datasets);
this.props.applyCPUFilter(toCPUFilter);
}
}, {
key: "render",
value: function render() {
var _this$props = this.props,
supportedDataTypes = _this$props.supportedDataTypes,
datasets = _this$props.datasets,
selectedDataset = _this$props.selectedDataset,
dataType = _this$props.dataType,
filtered = _this$props.filtered,
onChangeExportDataType = _this$props.onChangeExportDataType,
onChangeExportFiltered = _this$props.onChangeExportFiltered,
intl = _this$props.intl;
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"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.exportData.datasetTitle'
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.exportData.datasetSubtitle'
}))), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, /*#__PURE__*/_react["default"].createElement("select", {
value: selectedDataset,
onChange: this._onSelectDataset
}, [intl.formatMessage({
id: 'modal.exportData.allDatasets'
})].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"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.exportData.dataTypeTitle'
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.exportData.dataTypeSubtitle'
}))), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, supportedDataTypes.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"
}), dataType === op.id && /*#__PURE__*/_react["default"].createElement(_styledComponents.CheckMark, null));
}))), /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledExportSection, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "description"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "title"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.exportData.dataTypeTitle'
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.exportData.filterDataSubtitle'
}))), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledFilteredOption, {
className: "unfiltered-option",
selected: !filtered,
onClick: function onClick() {
return onChangeExportFiltered(false);
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "filter-option-title"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.exportData.unfilteredData'
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "filter-option-subtitle"
}, getDataRowCount(datasets, selectedDataset, false, intl)), !filtered && /*#__PURE__*/_react["default"].createElement(_styledComponents.CheckMark, null)), /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledFilteredOption, {
className: "filtered-option",
selected: filtered,
onClick: function onClick() {
return onChangeExportFiltered(true);
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "filter-option-title"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.exportData.filteredData'
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "filter-option-subtitle"
}, getDataRowCount(datasets, selectedDataset, true, intl)), filtered && /*#__PURE__*/_react["default"].createElement(_styledComponents.CheckMark, null))))));
}
}]);
return ExportDataModal;
}(_react.Component);
ExportDataModal.propTypes = propTypes;
ExportDataModal.defaultProps = {
supportedDataTypes: _defaultSettings.EXPORT_DATA_TYPE_OPTIONS
};
return (0, _reactIntl.injectIntl)(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":["propTypes","datasets","PropTypes","object","isRequired","selectedDataset","string","dataType","filtered","bool","applyCPUFilter","func","onClose","onChangeExportSelectedDataset","onChangeExportDataType","onChangeExportFiltered","getDataRowCount","intl","selectedData","formatMessage","id","fileCount","Object","keys","length","dataContainer","filteredIdxCPU","rowCount","numRows","toLocaleString","ExportDataModalFactory","ExportDataModal","value","target","props","toCPUFilter","supportedDataTypes","_onSelectDataset","concat","map","d","label","op","available","Component","defaultProps","EXPORT_DATA_TYPE_OPTIONS"],"mappings":"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","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, {Component} 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  StyledExportSection,\n  StyledFilteredOption,\n  StyledModalContent,\n  StyledType,\n  CheckMark\n} from 'components/common/styled-components';\nimport {injectIntl} from 'react-intl';\nimport {FormattedMessage} from 'localization';\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  applyCPUFilter: PropTypes.func.isRequired,\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, intl) => {\n  const selectedData = datasets[selectedDataset];\n  if (!selectedData) {\n    return intl.formatMessage(\n      {id: 'modal.exportData.fileCount'},\n      {fileCount: Object.keys(datasets).length}\n    );\n  }\n  const {dataContainer, filteredIdxCPU} = selectedData;\n\n  if (filtered && !filteredIdxCPU) {\n    return '-';\n  }\n\n  const rowCount = filtered ? filteredIdxCPU.length : dataContainer.numRows();\n\n  return intl.formatMessage(\n    {id: 'modal.exportData.rowCount'},\n    {rowCount: rowCount.toLocaleString()}\n  );\n};\n\nconst ExportDataModalFactory = () => {\n  class ExportDataModal extends Component {\n    componentDidMount() {\n      const toCPUFilter = this.props.selectedDataset || Object.keys(this.props.datasets);\n      this.props.applyCPUFilter(toCPUFilter);\n    }\n\n    _onSelectDataset = ({target: {value}}) => {\n      this.props.applyCPUFilter(value);\n      this.props.onChangeExportSelectedDataset(value);\n    };\n\n    render() {\n      const {\n        supportedDataTypes,\n        datasets,\n        selectedDataset,\n        dataType,\n        filtered,\n        onChangeExportDataType,\n        onChangeExportFiltered,\n        intl\n      } = this.props;\n\n      return (\n        <StyledModalContent className=\"export-data-modal\">\n          <div>\n            <StyledExportSection>\n              <div className=\"description\">\n                <div className=\"title\">\n                  <FormattedMessage id={'modal.exportData.datasetTitle'} />\n                </div>\n                <div className=\"subtitle\">\n                  <FormattedMessage id={'modal.exportData.datasetSubtitle'} />\n                </div>\n              </div>\n              <div className=\"selection\">\n                <select value={selectedDataset} onChange={this._onSelectDataset}>\n                  {[intl.formatMessage({id: 'modal.exportData.allDatasets'})]\n                    .concat(Object.keys(datasets))\n                    .map(d => (\n                      <option key={d} value={d}>\n                        {(datasets[d] && datasets[d].label) || d}\n                      </option>\n                    ))}\n                </select>\n              </div>\n            </StyledExportSection>\n            <StyledExportSection>\n              <div className=\"description\">\n                <div className=\"title\">\n                  <FormattedMessage id={'modal.exportData.dataTypeTitle'} />\n                </div>\n                <div className=\"subtitle\">\n                  <FormattedMessage id={'modal.exportData.dataTypeSubtitle'} />\n                </div>\n              </div>\n              <div className=\"selection\">\n                {supportedDataTypes.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                    {dataType === op.id && <CheckMark />}\n                  </StyledType>\n                ))}\n              </div>\n            </StyledExportSection>\n            <StyledExportSection>\n              <div className=\"description\">\n                <div className=\"title\">\n                  <FormattedMessage id={'modal.exportData.dataTypeTitle'} />\n                </div>\n                <div className=\"subtitle\">\n                  <FormattedMessage id={'modal.exportData.filterDataSubtitle'} />\n                </div>\n              </div>\n              <div className=\"selection\">\n                <StyledFilteredOption\n                  className=\"unfiltered-option\"\n                  selected={!filtered}\n                  onClick={() => onChangeExportFiltered(false)}\n                >\n                  <div className=\"filter-option-title\">\n                    <FormattedMessage id={'modal.exportData.unfilteredData'} />\n                  </div>\n                  <div className=\"filter-option-subtitle\">\n                    {getDataRowCount(datasets, selectedDataset, false, intl)}\n                  </div>\n                  {!filtered && <CheckMark />}\n                </StyledFilteredOption>\n                <StyledFilteredOption\n                  className=\"filtered-option\"\n                  selected={filtered}\n                  onClick={() => onChangeExportFiltered(true)}\n                >\n                  <div className=\"filter-option-title\">\n                    <FormattedMessage id={'modal.exportData.filteredData'} />\n                  </div>\n                  <div className=\"filter-option-subtitle\">\n                    {getDataRowCount(datasets, selectedDataset, true, intl)}\n                  </div>\n                  {filtered && <CheckMark />}\n                </StyledFilteredOption>\n              </div>\n            </StyledExportSection>\n          </div>\n        </StyledModalContent>\n      );\n    }\n  }\n  ExportDataModal.propTypes = propTypes;\n  ExportDataModal.defaultProps = {\n    supportedDataTypes: EXPORT_DATA_TYPE_OPTIONS\n  };\n\n  return injectIntl(ExportDataModal);\n};\n\nexport default ExportDataModalFactory;\n"]}