UNPKG

kepler.gl

Version:

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

258 lines (235 loc) 31.8 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral'); var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2); var _templateObject = (0, _taggedTemplateLiteral3.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'], ['\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']), _templateObject2 = (0, _taggedTemplateLiteral3.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'], ['\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']), _templateObject3 = (0, _taggedTemplateLiteral3.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'], ['\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']); // Copyright (c) 2018 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 _react = require('react'); var _react2 = _interopRequireDefault(_react); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _defaultSettings = require('../../constants/default-settings'); var _icons = require('../common/icons'); var _styledComponents3 = require('../common/styled-components'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var StyledExportDataSection = _styledComponents2.default.div(_templateObject, function (props) { return props.theme.textColorLT; }, function (props) { return props.theme.textColor; }); var StyledDataType = _styledComponents2.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 = _styledComponents2.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: _propTypes2.default.object.isRequired, selectedDataset: _propTypes2.default.string, dataType: _propTypes2.default.string.isRequired, filtered: _propTypes2.default.bool.isRequired, // callbacks onClose: _propTypes2.default.func.isRequired, onChangeExportSelectedDataset: _propTypes2.default.func.isRequired, onChangeExportDataType: _propTypes2.default.func.isRequired, onChangeExportFiltered: _propTypes2.default.func.isRequired, onChangeExportConfig: _propTypes2.default.func.isRequired }; var getDataRowCount = function getDataRowCount(datasets, selectedDataset, filtered) { var selectedData = datasets[selectedDataset]; if (!selectedData) { return Object.keys(datasets).length + ' Files '; } var allData = selectedData.allData, data = selectedData.data; var rowCount = filtered ? data.length : allData.length; return 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 _react2.default.createElement( 'div', { className: 'export-data-modal' }, _react2.default.createElement( _styledComponents3.StyledModalContent, null, _react2.default.createElement( 'div', null, _react2.default.createElement( StyledExportDataSection, null, _react2.default.createElement( 'div', { className: 'description' }, _react2.default.createElement( 'div', { className: 'title' }, 'Dataset' ), _react2.default.createElement( 'div', { className: 'subtitle' }, 'Choose the datasets you want to export' ) ), _react2.default.createElement( 'div', { className: 'selection' }, _react2.default.createElement( 'select', { value: selectedDataset, onChange: function onChange(e) { return onChangeExportSelectedDataset({ dataset: e.target.value }); } }, ['All'].concat(Object.keys(datasets)).map(function (d) { return _react2.default.createElement( 'option', { key: d, value: d }, datasets[d] && datasets[d].label || d ); }) ) ) ), _react2.default.createElement( StyledExportDataSection, null, _react2.default.createElement( 'div', { className: 'description' }, _react2.default.createElement( 'div', { className: 'title' }, 'Data Type' ), _react2.default.createElement( 'div', { className: 'subtitle' }, 'Choose the type of data you want to export' ) ), _react2.default.createElement( 'div', { className: 'selection' }, _defaultSettings.EXPORT_DATA_TYPE_OPTIONS.map(function (op) { return _react2.default.createElement( StyledDataType, { key: op.id, selected: dataType === op.id, available: op.available, onClick: function onClick() { return op.available && onChangeExportDataType({ dataType: op.id }); } }, _react2.default.createElement(_icons.FileType, { ext: op.label, height: '80px', fontSize: '11px' }) ); }) ) ), _react2.default.createElement( StyledExportDataSection, null, _react2.default.createElement( 'div', { className: 'description' }, _react2.default.createElement( 'div', { className: 'title' }, 'Filter Data' ), _react2.default.createElement( 'div', { className: 'subtitle' }, 'You can choose exporting original data or filtered data' ) ), _react2.default.createElement( 'div', { className: 'selection' }, _react2.default.createElement( StyledFilteredDataOption, { selected: !filtered, onClick: function onClick() { return onChangeExportFiltered({ filtered: false }); } }, _react2.default.createElement( 'div', { className: 'filtered-title' }, 'Unfiltered Data' ), _react2.default.createElement( 'div', { className: 'filtered-subtitle' }, getDataRowCount(datasets, selectedDataset, false) ) ), _react2.default.createElement( StyledFilteredDataOption, { selected: filtered, onClick: function onClick() { return onChangeExportFiltered({ filtered: true }); } }, _react2.default.createElement( 'div', { className: 'filtered-title' }, 'Filtered Data' ), _react2.default.createElement( 'div', { className: 'filtered-subtitle' }, getDataRowCount(datasets, selectedDataset, true) ) ) ) ) ) ) ); }; ExportDataModal.propTypes = propTypes; var ExportDataModalFactory = function ExportDataModalFactory() { return ExportDataModal; }; exports.default = ExportDataModalFactory; //# 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","dataset","e","target","value","concat","map","d","label","EXPORT_DATA_TYPE_OPTIONS","op","id","ExportDataModalFactory"],"mappings":";;;;;;;;;;;;28BAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;AACA;;;;AACA;;;;AAEA;;AACA;;AACA;;;;AAEA,IAAMA,0BAA0BC,2BAAOC,GAAjC,kBAWS;AAAA,SAASC,MAAMC,KAAN,CAAYC,WAArB;AAAA,CAXT,EAeS;AAAA,SAASF,MAAMC,KAAN,CAAYE,SAArB;AAAA,CAfT,CAAN;;AA0EA,IAAMC,iBAAiBN,2BAAOC,GAAxB,mBAEgB;AAAA,SAASC,MAAMK,QAAN,GAAiBL,MAAMC,KAAN,CAAYK,aAA7B,GAA6CN,MAAMC,KAAN,CAAYM,mBAAlE;AAAA,CAFhB,EAGK;AAAA,SAASP,MAAMK,QAAN,GAAiBL,MAAMC,KAAN,CAAYK,aAA7B,GAA6CN,MAAMC,KAAN,CAAYM,mBAAlE;AAAA,CAHL,EAYO;AAAA,SAASP,MAAMQ,SAAN,IAAmBR,MAAMC,KAAN,CAAYK,aAAxC;AAAA,CAZP,EAakB;AAAA,SAASN,MAAMQ,SAAN,IAAmBR,MAAMC,KAAN,CAAYK,aAAxC;AAAA,CAblB,CAAN;;AAiBA,IAAMG,2BAA2BX,2BAAOC,GAAlC,mBAGgB;AAAA,SAASC,MAAMK,QAAN,GAAiBL,MAAMC,KAAN,CAAYK,aAA7B,GAA6CN,MAAMC,KAAN,CAAYM,mBAAlE;AAAA,CAHhB,EAckB;AAAA,SAASP,MAAMC,KAAN,CAAYK,aAArB;AAAA,CAdlB,EAkBO;AAAA,SAASN,MAAMC,KAAN,CAAYC,WAArB;AAAA,CAlBP,EAuBO;AAAA,SAASF,MAAMC,KAAN,CAAYE,SAArB;AAAA,CAvBP,CAAN;;AA4BA,IAAMO,YAAY;AAChBC,YAAUC,oBAAUC,MAAV,CAAiBC,UADX;AAEhBC,mBAAiBH,oBAAUI,MAFX;AAGhBC,YAAUL,oBAAUI,MAAV,CAAiBF,UAHX;AAIhBI,YAAUN,oBAAUO,IAAV,CAAeL,UAJT;AAKhB;AACAM,WAASR,oBAAUS,IAAV,CAAeP,UANR;AAOhBQ,iCAA+BV,oBAAUS,IAAV,CAAeP,UAP9B;AAQhBS,0BAAwBX,oBAAUS,IAAV,CAAeP,UARvB;AAShBU,0BAAwBZ,oBAAUS,IAAV,CAAeP,UATvB;AAUhBW,wBAAsBb,oBAAUS,IAAV,CAAeP;AAVrB,CAAlB;;AAaA,IAAMY,kBAAkB,SAAlBA,eAAkB,CAACf,QAAD,EAAWI,eAAX,EAA4BG,QAA5B,EAAyC;AAC/D,MAAMS,eAAehB,SAASI,eAAT,CAArB;AACA,MAAI,CAACY,YAAL,EAAmB;AACjB,WAAUC,OAAOC,IAAP,CAAYlB,QAAZ,EAAsBmB,MAAhC;AACD;AAJ8D,MAKxDC,OALwD,GAKvCJ,YALuC,CAKxDI,OALwD;AAAA,MAK/CC,IAL+C,GAKvCL,YALuC,CAK/CK,IAL+C;;AAM/D,MAAMC,WAAWf,WAAWc,KAAKF,MAAhB,GAAyBC,QAAQD,MAAlD;AACA,SAAUG,SAASC,cAAT,CAAwB,IAAxB,CAAV;AACD,CARD;;AAUA,IAAMC,kBAAkB,SAAlBA,eAAkB;AAAA,MACtBxB,QADsB,QACtBA,QADsB;AAAA,MAEtBI,eAFsB,QAEtBA,eAFsB;AAAA,MAGtBE,QAHsB,QAGtBA,QAHsB;AAAA,MAItBC,QAJsB,QAItBA,QAJsB;AAAA,MAKtBkB,MALsB,QAKtBA,MALsB;AAAA,MAOtBb,sBAPsB,QAOtBA,sBAPsB;AAAA,MAQtBD,6BARsB,QAQtBA,6BARsB;AAAA,MAStBE,sBATsB,QAStBA,sBATsB;AAAA,SAWtB;AAAA;AAAA,MAAK,WAAU,mBAAf;AACE;AAAC,2CAAD;AAAA;AACE;AAAA;AAAA;AACE;AAAC,iCAAD;AAAA;AACE;AAAA;AAAA,cAAK,WAAU,aAAf;AACE;AAAA;AAAA,gBAAK,WAAU,OAAf;AAAA;AAAA,aADF;AAIE;AAAA;AAAA,gBAAK,WAAU,UAAf;AAAA;AAAA;AAJF,WADF;AASE;AAAA;AAAA,cAAK,WAAU,WAAf;AACE;AAAA;AAAA,gBAAQ,OAAOT,eAAf,EAAgC,UAAU;AAAA,yBAAKO,8BAA8B,EAACe,SAASC,EAAEC,MAAF,CAASC,KAAnB,EAA9B,CAAL;AAAA,iBAA1C;AACC,eAAC,KAAD,EAAQC,MAAR,CAAeb,OAAOC,IAAP,CAAYlB,QAAZ,CAAf,EAAsC+B,GAAtC,CAA0C;AAAA,uBACzC;AAAA;AAAA,oBAAQ,KAAKC,CAAb,EAAgB,OAAOA,CAAvB;AAA4BhC,2BAASgC,CAAT,KAAehC,SAASgC,CAAT,EAAYC,KAA5B,IAAsCD;AAAjE,iBADyC;AAAA,eAA1C;AADD;AADF;AATF,SADF;AAmBE;AAAC,iCAAD;AAAA;AACE;AAAA;AAAA,cAAK,WAAU,aAAf;AACE;AAAA;AAAA,gBAAK,WAAU,OAAf;AAAA;AAAA,aADF;AAIE;AAAA;AAAA,gBAAK,WAAU,UAAf;AAAA;AAAA;AAJF,WADF;AASE;AAAA;AAAA,cAAK,WAAU,WAAf;AACGE,sDAAyBH,GAAzB,CAA6B;AAAA,qBAC5B;AAAC,8BAAD;AAAA;AACE,uBAAKI,GAAGC,EADV;AAEE,4BAAU9B,aAAa6B,GAAGC,EAF5B;AAGE,6BAAWD,GAAGtC,SAHhB;AAIE,2BAAS;AAAA,2BAAMsC,GAAGtC,SAAH,IAAgBe,uBAAuB,EAACN,UAAU6B,GAAGC,EAAd,EAAvB,CAAtB;AAAA;AAJX;AAME,8CAAC,eAAD,IAAU,KAAKD,GAAGF,KAAlB,EAAyB,QAAO,MAAhC,EAAuC,UAAS,MAAhD;AANF,eAD4B;AAAA,aAA7B;AADH;AATF,SAnBF;AA0CE;AAAC,iCAAD;AAAA;AACE;AAAA;AAAA,cAAK,WAAU,aAAf;AACE;AAAA;AAAA,gBAAK,WAAU,OAAf;AAAA;AAAA,aADF;AAIE;AAAA;AAAA,gBAAK,WAAU,UAAf;AAAA;AAAA;AAJF,WADF;AASE;AAAA;AAAA,cAAK,WAAU,WAAf;AACE;AAAC,sCAAD;AAAA,gBAA0B,UAAU,CAAC1B,QAArC,EAA+C,SAAS;AAAA,yBAAMM,uBAAuB,EAACN,UAAU,KAAX,EAAvB,CAAN;AAAA,iBAAxD;AACE;AAAA;AAAA,kBAAK,WAAU,gBAAf;AAAA;AAAA,eADF;AAEE;AAAA;AAAA,kBAAK,WAAU,mBAAf;AAAoCQ,gCAAgBf,QAAhB,EAA0BI,eAA1B,EAA2C,KAA3C;AAApC;AAFF,aADF;AAKE;AAAC,sCAAD;AAAA,gBAA0B,UAAUG,QAApC,EAA8C,SAAS;AAAA,yBAAMM,uBAAuB,EAACN,UAAU,IAAX,EAAvB,CAAN;AAAA,iBAAvD;AACE;AAAA;AAAA,kBAAK,WAAU,gBAAf;AAAA;AAAA,eADF;AAEE;AAAA;AAAA,kBAAK,WAAU,mBAAf;AAAoCQ,gCAAgBf,QAAhB,EAA0BI,eAA1B,EAA2C,IAA3C;AAApC;AAFF;AALF;AATF;AA1CF;AADF;AADF,GAXsB;AAAA,CAAxB;;AAiFAoB,gBAAgBzB,SAAhB,GAA4BA,SAA5B;;AAEA,IAAMsC,yBAAyB,SAAzBA,sBAAyB;AAAA,SAAMb,eAAN;AAAA,CAA/B;kBACea,sB","file":"export-data-modal.js","sourcesContent":["// Copyright (c) 2018 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"]}