UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

238 lines (205 loc) 26.4 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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); 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"); // Copyright (c) 2020 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 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 allData = selectedData.allData, filteredIdxCPU = selectedData.filteredIdxCPU; if (filtered && !filteredIdxCPU) { return '-'; } var rowCount = filtered ? filteredIdxCPU.length : allData.length; return intl.formatMessage({ id: 'modal.exportData.rowCount' }, { rowCount: rowCount.toLocaleString() }); }; var ExportDataModalFactory = function ExportDataModalFactory() { var ExportDataModal = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(ExportDataModal, _Component); function ExportDataModal() { var _getPrototypeOf2; 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 = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(ExportDataModal)).call.apply(_getPrototypeOf2, [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, 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 _react["default"].createElement(_styledComponents.StyledModalContent, { className: "export-data-modal" }, _react["default"].createElement("div", null, _react["default"].createElement(_styledComponents.StyledExportSection, null, _react["default"].createElement("div", { className: "description" }, _react["default"].createElement("div", { className: "title" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportData.datasetTitle' })), _react["default"].createElement("div", { className: "subtitle" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportData.datasetSubtitle' }))), _react["default"].createElement("div", { className: "selection" }, _react["default"].createElement("select", { value: selectedDataset, onChange: this._onSelectDataset }, [intl.formatMessage({ id: 'modal.exportData.allDatasets' })].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(_styledComponents.StyledExportSection, null, _react["default"].createElement("div", { className: "description" }, _react["default"].createElement("div", { className: "title" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportData.dataTypeTitle' })), _react["default"].createElement("div", { className: "subtitle" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportData.dataTypeSubtitle' }))), _react["default"].createElement("div", { className: "selection" }, _defaultSettings.EXPORT_DATA_TYPE_OPTIONS.map(function (op) { return _react["default"].createElement(_styledComponents.StyledType, { key: op.id, selected: dataType === op.id, available: op.available, onClick: function onClick() { return op.available && onChangeExportDataType(op.id); } }, _react["default"].createElement(_icons.FileType, { ext: op.label, height: "80px", fontSize: "11px" })); }))), _react["default"].createElement(_styledComponents.StyledExportSection, null, _react["default"].createElement("div", { className: "description" }, _react["default"].createElement("div", { className: "title" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportData.dataTypeTitle' })), _react["default"].createElement("div", { className: "subtitle" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportData.filterDataSubtitle' }))), _react["default"].createElement("div", { className: "selection" }, _react["default"].createElement(_styledComponents.StyledFilteredOption, { className: "unfiltered-option", selected: !filtered, onClick: function onClick() { return onChangeExportFiltered(false); } }, _react["default"].createElement("div", { className: "filter-option-title" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportData.unfilteredData' })), _react["default"].createElement("div", { className: "filter-option-subtitle" }, getDataRowCount(datasets, selectedDataset, false, intl))), _react["default"].createElement(_styledComponents.StyledFilteredOption, { className: "filtered-option", selected: filtered, onClick: function onClick() { return onChangeExportFiltered(true); } }, _react["default"].createElement("div", { className: "filter-option-title" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportData.filteredData' })), _react["default"].createElement("div", { className: "filter-option-subtitle" }, getDataRowCount(datasets, selectedDataset, true, intl))))))); } }]); return ExportDataModal; }(_react.Component); ExportDataModal.propTypes = propTypes; 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","allData","filteredIdxCPU","rowCount","toLocaleString","ExportDataModalFactory","ExportDataModal","value","target","props","toCPUFilter","_onSelectDataset","concat","map","d","label","EXPORT_DATA_TYPE_OPTIONS","op","available","Component"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AAEA;;AACA;;AACA;;AAMA;;AA/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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,OAR8D,GAQnCP,YARmC,CAQ9DO,OAR8D;AAAA,MAQrDC,cARqD,GAQnCR,YARmC,CAQrDQ,cARqD;;AAUrE,MAAIlB,QAAQ,IAAI,CAACkB,cAAjB,EAAiC;AAC/B,WAAO,GAAP;AACD;;AAED,MAAMC,QAAQ,GAAGnB,QAAQ,GAAGkB,cAAc,CAACF,MAAlB,GAA2BC,OAAO,CAACD,MAA5D;AAEA,SAAOP,IAAI,CAACE,aAAL,CACL;AAACC,IAAAA,EAAE,EAAE;AAAL,GADK,EAEL;AAACO,IAAAA,QAAQ,EAAEA,QAAQ,CAACC,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;;AAAA;AAAA,2GAOd,gBAAuB;AAAA,YAAZC,KAAY,QAArBC,MAAqB,CAAZD,KAAY;;AACxC,cAAKE,KAAL,CAAWvB,cAAX,CAA0BqB,KAA1B;;AACA,cAAKE,KAAL,CAAWpB,6BAAX,CAAyCkB,KAAzC;AACD,OAVgC;AAAA;AAAA;;AAAA;AAAA;AAAA,0CAEb;AAClB,YAAMG,WAAW,GAAG,KAAKD,KAAL,CAAW5B,eAAX,IAA8BiB,MAAM,CAACC,IAAP,CAAY,KAAKU,KAAL,CAAWhC,QAAvB,CAAlD;AACA,aAAKgC,KAAL,CAAWvB,cAAX,CAA0BwB,WAA1B;AACD;AALgC;AAAA;AAAA,+BAYxB;AAAA,0BASH,KAAKD,KATF;AAAA,YAELhC,QAFK,eAELA,QAFK;AAAA,YAGLI,eAHK,eAGLA,eAHK;AAAA,YAILE,QAJK,eAILA,QAJK;AAAA,YAKLC,QALK,eAKLA,QALK;AAAA,YAMLM,sBANK,eAMLA,sBANK;AAAA,YAOLC,sBAPK,eAOLA,sBAPK;AAAA,YAQLE,IARK,eAQLA,IARK;AAWP,eACE,gCAAC,oCAAD;AAAoB,UAAA,SAAS,EAAC;AAA9B,WACE,6CACE,gCAAC,qCAAD,QACE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE,gCAAC,2BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CADF,EAIE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE,gCAAC,2BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CAJF,CADF,EASE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE;AAAQ,UAAA,KAAK,EAAEZ,eAAf;AAAgC,UAAA,QAAQ,EAAE,KAAK8B;AAA/C,WACG,CAAClB,IAAI,CAACE,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CAAD,EACEgB,MADF,CACSd,MAAM,CAACC,IAAP,CAAYtB,QAAZ,CADT,EAEEoC,GAFF,CAEM,UAAAC,CAAC;AAAA,iBACJ;AAAQ,YAAA,GAAG,EAAEA,CAAb;AAAgB,YAAA,KAAK,EAAEA;AAAvB,aACIrC,QAAQ,CAACqC,CAAD,CAAR,IAAerC,QAAQ,CAACqC,CAAD,CAAR,CAAYC,KAA5B,IAAsCD,CADzC,CADI;AAAA,SAFP,CADH,CADF,CATF,CADF,EAsBE,gCAAC,qCAAD,QACE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE,gCAAC,2BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CADF,EAIE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE,gCAAC,2BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CAJF,CADF,EASE;AAAK,UAAA,SAAS,EAAC;AAAf,WACGE,0CAAyBH,GAAzB,CAA6B,UAAAI,EAAE;AAAA,iBAC9B,gCAAC,4BAAD;AACE,YAAA,GAAG,EAAEA,EAAE,CAACrB,EADV;AAEE,YAAA,QAAQ,EAAEb,QAAQ,KAAKkC,EAAE,CAACrB,EAF5B;AAGE,YAAA,SAAS,EAAEqB,EAAE,CAACC,SAHhB;AAIE,YAAA,OAAO,EAAE;AAAA,qBAAMD,EAAE,CAACC,SAAH,IAAgB5B,sBAAsB,CAAC2B,EAAE,CAACrB,EAAJ,CAA5C;AAAA;AAJX,aAME,gCAAC,eAAD;AAAU,YAAA,GAAG,EAAEqB,EAAE,CAACF,KAAlB;AAAyB,YAAA,MAAM,EAAC,MAAhC;AAAuC,YAAA,QAAQ,EAAC;AAAhD,YANF,CAD8B;AAAA,SAA/B,CADH,CATF,CAtBF,EA4CE,gCAAC,qCAAD,QACE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE,gCAAC,2BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CADF,EAIE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE,gCAAC,2BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CAJF,CADF,EASE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE,gCAAC,sCAAD;AACE,UAAA,SAAS,EAAC,mBADZ;AAEE,UAAA,QAAQ,EAAE,CAAC/B,QAFb;AAGE,UAAA,OAAO,EAAE;AAAA,mBAAMO,sBAAsB,CAAC,KAAD,CAA5B;AAAA;AAHX,WAKE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE,gCAAC,2BAAD;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,CADF,EAaE,gCAAC,sCAAD;AACE,UAAA,SAAS,EAAC,iBADZ;AAEE,UAAA,QAAQ,EAAET,QAFZ;AAGE,UAAA,OAAO,EAAE;AAAA,mBAAMO,sBAAsB,CAAC,IAAD,CAA5B;AAAA;AAHX,WAKE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE,gCAAC,2BAAD;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,CAbF,CATF,CA5CF,CADF,CADF;AAqFD;AA5GgC;AAAA;AAAA,IACL0B,gBADK;;AA8GnCb,EAAAA,eAAe,CAAC9B,SAAhB,GAA4BA,SAA5B;AACA,SAAO,2BAAW8B,eAAX,CAAP;AACD,CAhHD;;eAkHeD,sB","sourcesContent":["// Copyright (c) 2020 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} from 'components/common/styled-components';\nimport {FormattedMessage, injectIntl} from 'react-intl';\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 {allData, filteredIdxCPU} = selectedData;\n\n  if (filtered && !filteredIdxCPU) {\n    return '-';\n  }\n\n  const rowCount = filtered ? filteredIdxCPU.length : allData.length;\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        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                {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                  <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                </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                </StyledFilteredOption>\n              </div>\n            </StyledExportSection>\n          </div>\n        </StyledModalContent>\n      );\n    }\n  }\n  ExportDataModal.propTypes = propTypes;\n  return injectIntl(ExportDataModal);\n};\n\nexport default ExportDataModalFactory;\n"]}