UNPKG

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
"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":";;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AAEA;;AACA;;AACA;;AAOA;;AACA;;;;;;AAEA,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,cAAc,EAAER,sBAAUS,IAAV,CAAeP,UANf;AAOhBQ,EAAAA,OAAO,EAAEV,sBAAUS,IAAV,CAAeP,UAPR;AAQhBS,EAAAA,6BAA6B,EAAEX,sBAAUS,IAAV,CAAeP,UAR9B;AAShBU,EAAAA,sBAAsB,EAAEZ,sBAAUS,IAAV,CAAeP,UATvB;AAUhBW,EAAAA,sBAAsB,EAAEb,sBAAUS,IAAV,CAAeP;AAVvB,CAAlB;;AAaA,IAAMY,eAAe,GAAG,SAAlBA,eAAkB,CAACf,QAAD,EAAWI,eAAX,EAA4BG,QAA5B,EAAsCS,IAAtC,EAA+C;AACrE,MAAMC,YAAY,GAAGjB,QAAQ,CAACI,eAAD,CAA7B;;AACA,MAAI,CAACa,YAAL,EAAmB;AACjB,WAAOD,IAAI,CAACE,aAAL,CACL;AAACC,MAAAA,EAAE,EAAE;AAAL,KADK,EAEL;AAACC,MAAAA,SAAS,EAAEC,MAAM,CAACC,IAAP,CAAYtB,QAAZ,EAAsBuB;AAAlC,KAFK,CAAP;AAID;;AAPoE,MAQ9DC,aAR8D,GAQ7BP,YAR6B,CAQ9DO,aAR8D;AAAA,MAQ/CC,cAR+C,GAQ7BR,YAR6B,CAQ/CQ,cAR+C;;AAUrE,MAAIlB,QAAQ,IAAI,CAACkB,cAAjB,EAAiC;AAC/B,WAAO,GAAP;AACD;;AAED,MAAMC,QAAQ,GAAGnB,QAAQ,GAAGkB,cAAc,CAACF,MAAlB,GAA2BC,aAAa,CAACG,OAAd,EAApD;AAEA,SAAOX,IAAI,CAACE,aAAL,CACL;AAACC,IAAAA,EAAE,EAAE;AAAL,GADK,EAEL;AAACO,IAAAA,QAAQ,EAAEA,QAAQ,CAACE,cAAT;AAAX,GAFK,CAAP;AAID,CApBD;;AAsBA,IAAMC,sBAAsB,GAAG,SAAzBA,sBAAyB,GAAM;AAAA,MAC7BC,eAD6B;AAAA;;AAAA;;AAAA;AAAA;;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA,2GAOd,gBAAuB;AAAA,YAAZC,KAAY,QAArBC,MAAqB,CAAZD,KAAY;;AACxC,cAAKE,KAAL,CAAWxB,cAAX,CAA0BsB,KAA1B;;AACA,cAAKE,KAAL,CAAWrB,6BAAX,CAAyCmB,KAAzC;AACD,OAVgC;AAAA;AAAA;;AAAA;AAAA;AAAA,aAEjC,6BAAoB;AAClB,YAAMG,WAAW,GAAG,KAAKD,KAAL,CAAW7B,eAAX,IAA8BiB,MAAM,CAACC,IAAP,CAAY,KAAKW,KAAL,CAAWjC,QAAvB,CAAlD;AACA,aAAKiC,KAAL,CAAWxB,cAAX,CAA0ByB,WAA1B;AACD;AALgC;AAAA;AAAA,aAYjC,kBAAS;AAAA,0BAUH,KAAKD,KAVF;AAAA,YAELE,kBAFK,eAELA,kBAFK;AAAA,YAGLnC,QAHK,eAGLA,QAHK;AAAA,YAILI,eAJK,eAILA,eAJK;AAAA,YAKLE,QALK,eAKLA,QALK;AAAA,YAMLC,QANK,eAMLA,QANK;AAAA,YAOLM,sBAPK,eAOLA,sBAPK;AAAA,YAQLC,sBARK,eAQLA,sBARK;AAAA,YASLE,IATK,eASLA,IATK;AAYP,4BACE,gCAAC,oCAAD;AAAoB,UAAA,SAAS,EAAC;AAA9B,wBACE,0DACE,gCAAC,qCAAD,qBACE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CADF,eAIE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CAJF,CADF,eASE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE;AAAQ,UAAA,KAAK,EAAEZ,eAAf;AAAgC,UAAA,QAAQ,EAAE,KAAKgC;AAA/C,WACG,CAACpB,IAAI,CAACE,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CAAD,EACEkB,MADF,CACShB,MAAM,CAACC,IAAP,CAAYtB,QAAZ,CADT,EAEEsC,GAFF,CAEM,UAAAC,CAAC;AAAA,8BACJ;AAAQ,YAAA,GAAG,EAAEA,CAAb;AAAgB,YAAA,KAAK,EAAEA;AAAvB,aACIvC,QAAQ,CAACuC,CAAD,CAAR,IAAevC,QAAQ,CAACuC,CAAD,CAAR,CAAYC,KAA5B,IAAsCD,CADzC,CADI;AAAA,SAFP,CADH,CADF,CATF,CADF,eAsBE,gCAAC,qCAAD,qBACE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CADF,eAIE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CAJF,CADF,eASE;AAAK,UAAA,SAAS,EAAC;AAAf,WACGJ,kBAAkB,CAACG,GAAnB,CAAuB,UAAAG,EAAE;AAAA,8BACxB,gCAAC,4BAAD;AACE,YAAA,GAAG,EAAEA,EAAE,CAACtB,EADV;AAEE,YAAA,QAAQ,EAAEb,QAAQ,KAAKmC,EAAE,CAACtB,EAF5B;AAGE,YAAA,SAAS,EAAEsB,EAAE,CAACC,SAHhB;AAIE,YAAA,OAAO,EAAE;AAAA,qBAAMD,EAAE,CAACC,SAAH,IAAgB7B,sBAAsB,CAAC4B,EAAE,CAACtB,EAAJ,CAA5C;AAAA;AAJX,0BAME,gCAAC,eAAD;AAAU,YAAA,GAAG,EAAEsB,EAAE,CAACD,KAAlB;AAAyB,YAAA,MAAM,EAAC,MAAhC;AAAuC,YAAA,QAAQ,EAAC;AAAhD,YANF,EAOGlC,QAAQ,KAAKmC,EAAE,CAACtB,EAAhB,iBAAsB,gCAAC,2BAAD,OAPzB,CADwB;AAAA,SAAzB,CADH,CATF,CAtBF,eA6CE,gCAAC,qCAAD,qBACE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CADF,eAIE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CAJF,CADF,eASE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,sCAAD;AACE,UAAA,SAAS,EAAC,mBADZ;AAEE,UAAA,QAAQ,EAAE,CAACZ,QAFb;AAGE,UAAA,OAAO,EAAE;AAAA,mBAAMO,sBAAsB,CAAC,KAAD,CAA5B;AAAA;AAHX,wBAKE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CALF,eAQE;AAAK,UAAA,SAAS,EAAC;AAAf,WACGC,eAAe,CAACf,QAAD,EAAWI,eAAX,EAA4B,KAA5B,EAAmCY,IAAnC,CADlB,CARF,EAWG,CAACT,QAAD,iBAAa,gCAAC,2BAAD,OAXhB,CADF,eAcE,gCAAC,sCAAD;AACE,UAAA,SAAS,EAAC,iBADZ;AAEE,UAAA,QAAQ,EAAEA,QAFZ;AAGE,UAAA,OAAO,EAAE;AAAA,mBAAMO,sBAAsB,CAAC,IAAD,CAA5B;AAAA;AAHX,wBAKE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CALF,eAQE;AAAK,UAAA,SAAS,EAAC;AAAf,WACGC,eAAe,CAACf,QAAD,EAAWI,eAAX,EAA4B,IAA5B,EAAkCY,IAAlC,CADlB,CARF,EAWGT,QAAQ,iBAAI,gCAAC,2BAAD,OAXf,CAdF,CATF,CA7CF,CADF,CADF;AAwFD;AAhHgC;AAAA;AAAA,IACLoC,gBADK;;AAkHnCb,EAAAA,eAAe,CAAC/B,SAAhB,GAA4BA,SAA5B;AACA+B,EAAAA,eAAe,CAACc,YAAhB,GAA+B;AAC7BT,IAAAA,kBAAkB,EAAEU;AADS,GAA/B;AAIA,SAAO,2BAAWf,eAAX,CAAP;AACD,CAxHD;;eA0HeD,sB","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"]}