kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
434 lines (353 loc) • 46.4 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral');
var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2);
var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n height: 85%;\n width: 90%;\n top: 80px;\n padding: 32px 0 0 0;\n max-width: unset;\n'], ['\n height: 85%;\n width: 90%;\n top: 80px;\n padding: 32px 0 0 0;\n max-width: unset;\n']),
_templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n width: 40%;\n padding: 40px 40px 32px 40px;\n'], ['\n width: 40%;\n padding: 40px 40px 32px 40px;\n']),
_templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n top: 60px;\n'], ['\n top: 60px;\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.
// modals
exports.default = ModalContainerFactory;
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _styledComponents = require('styled-components');
var _reactDom = require('react-dom');
var _window = require('global/window');
var _modal = require('./common/modal');
var _modal2 = _interopRequireDefault(_modal);
var _dataProcessor = require('../processors/data-processor');
var _schemas = require('../schemas');
var _schemas2 = _interopRequireDefault(_schemas);
var _exportImageUtils = require('../utils/export-image-utils');
var _deleteDataModal = require('./modals/delete-data-modal');
var _deleteDataModal2 = _interopRequireDefault(_deleteDataModal);
var _dataTableModal = require('./modals/data-table-modal');
var _dataTableModal2 = _interopRequireDefault(_dataTableModal);
var _loadDataModal = require('./modals/load-data-modal');
var _loadDataModal2 = _interopRequireDefault(_loadDataModal);
var _exportImageModal = require('./modals/export-image-modal');
var _exportImageModal2 = _interopRequireDefault(_exportImageModal);
var _exportDataModal = require('./modals/export-data-modal');
var _exportDataModal2 = _interopRequireDefault(_exportDataModal);
var _exportConfigModal = require('./modals/export-config-modal');
var _exportConfigModal2 = _interopRequireDefault(_exportConfigModal);
var _addMapStyleModal = require('./modals/add-map-style-modal');
var _addMapStyleModal2 = _interopRequireDefault(_addMapStyleModal);
var _defaultSettings = require('../constants/default-settings');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var DataTableModalStyle = (0, _styledComponents.css)(_templateObject);
var DeleteDatasetModalStyled = (0, _styledComponents.css)(_templateObject2);
var LoadDataModalStyle = (0, _styledComponents.css)(_templateObject3);
ModalContainerFactory.deps = [_deleteDataModal2.default, _dataTableModal2.default, _loadDataModal2.default, _exportImageModal2.default, _exportDataModal2.default, _exportConfigModal2.default, _addMapStyleModal2.default];
function ModalContainerFactory(DeleteDatasetModal, DataTableModal, LoadDataModal, ExportImageModal, ExportDataModal, ExportConfigModal, AddMapStyleModal) {
var _class, _temp2;
var ModalWrapper = (_temp2 = _class = function (_Component) {
(0, _inherits3.default)(ModalWrapper, _Component);
function ModalWrapper() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, ModalWrapper);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = ModalWrapper.__proto__ || Object.getPrototypeOf(ModalWrapper)).call.apply(_ref, [this].concat(args))), _this), _this._closeModal = function () {
_this.props.uiStateActions.toggleModal(null);
}, _this._deleteDataset = function (key) {
_this.props.visStateActions.removeDataset(key);
_this._closeModal();
}, _this._onAddCustomMapStyle = function () {
_this.props.mapStyleActions.addCustomMapStyle();
_this._closeModal();
}, _this._onFileUpload = function (blob) {
_this.props.visStateActions.loadFiles(blob);
}, _this._onExportImage = function () {
var _this$props$uiState$e = _this.props.uiState.exportImage,
exporting = _this$props$uiState$e.exporting,
imageDataUri = _this$props$uiState$e.imageDataUri;
if (!exporting && imageDataUri) {
var file = (0, _exportImageUtils.dataURItoBlob)(imageDataUri);
(0, _exportImageUtils.downloadFile)(file, _defaultSettings.DEFAULT_EXPORT_IMAGE_NAME);
}
_this.props.uiStateActions.cleanupExportImage();
_this._closeModal();
}, _this._onExportData = function () {
var _this$props = _this.props,
visState = _this$props.visState,
uiState = _this$props.uiState;
var datasets = visState.datasets;
var _uiState$exportData = uiState.exportData,
selectedDataset = _uiState$exportData.selectedDataset,
dataType = _uiState$exportData.dataType,
filtered = _uiState$exportData.filtered;
// get the selected data
var filename = 'kepler-gl';
var selectedDatasets = datasets[selectedDataset] ? [datasets[selectedDataset]] : Object.values(datasets);
if (!selectedDatasets.length) {
// error: selected dataset not found.
_this._closeModal();
}
selectedDatasets.forEach(function (selectedData) {
var allData = selectedData.allData,
data = selectedData.data,
fields = selectedData.fields,
label = selectedData.label;
var exportData = filtered ? data : allData;
// start to export data according to selected data type
switch (dataType) {
case _defaultSettings.EXPORT_DATA_TYPE.CSV:
{
var type = 'text/csv';
var csv = (0, _dataProcessor.formatCsv)(exportData, fields);
_this._downloadFile(csv, type, filename + '_' + label + '.csv');
break;
}
// TODO: support more file types.
default:
break;
}
});
_this._closeModal();
}, _this._onExportConfig = function () {
var data = _this.props.uiState.exportData.data;
// we pass all props because we avoid to create new variables
var dump = data ? _schemas2.default.save(_this.props) : _schemas2.default.getConfigToSave(_this.props);
_this._downloadFile(JSON.stringify(dump, null, 2), 'application/json', 'keplergl.json');
_this._closeModal();
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
(0, _createClass3.default)(ModalWrapper, [{
key: '_downloadFile',
value: function _downloadFile(data, type, filename) {
var fileBlob = new _window.Blob([data], { type: type });
(0, _exportImageUtils.downloadFile)(fileBlob, filename);
}
}, {
key: 'render',
value: function render() {
var _this2 = this;
var _props = this.props,
containerW = _props.containerW,
containerH = _props.containerH,
mapStyle = _props.mapStyle,
mapState = _props.mapState,
uiState = _props.uiState,
visState = _props.visState,
rootNode = _props.rootNode,
visStateActions = _props.visStateActions;
var currentModal = uiState.currentModal,
datasetKeyToRemove = uiState.datasetKeyToRemove;
var datasets = visState.datasets,
layers = visState.layers,
editingDataset = visState.editingDataset;
var template = null;
var modalProps = {};
if (currentModal && currentModal.id && currentModal.template) {
// if currentMdoal template is already provided
// TODO: need to check whether template is valid
template = _react2.default.createElement(currentModal.template, null);
modalProps = currentModal.modalProps;
} else {
switch (currentModal) {
case _defaultSettings.DATA_TABLE_ID:
template = _react2.default.createElement(DataTableModal, {
width: containerW * 0.9,
height: containerH * 0.85,
datasets: datasets,
dataId: editingDataset,
showDatasetTable: visStateActions.showDatasetTable
});
modalProps.cssStyle = DataTableModalStyle;
break;
case _defaultSettings.DELETE_DATA_ID:
// validate options
if (datasetKeyToRemove && datasets && datasets[datasetKeyToRemove]) {
template = _react2.default.createElement(DeleteDatasetModal, {
dataset: datasets[datasetKeyToRemove],
layers: layers
});
modalProps = {
title: 'Delete Dataset',
cssStyle: DeleteDatasetModalStyled,
footer: true,
onConfirm: function onConfirm() {
return _this2._deleteDataset(datasetKeyToRemove);
},
onCancel: this._closeModal,
confirmButton: {
negative: true,
large: true,
children: 'Delete'
}
};
}
break; // in case we add a new case after this one
case _defaultSettings.ADD_DATA_ID:
template = _react2.default.createElement(LoadDataModal, {
onClose: this._closeModal,
onFileUpload: this._onFileUpload
});
modalProps = {
title: 'Add Data To Map',
cssStyle: LoadDataModalStyle,
footer: false,
onConfirm: this._closeModal
};
break;
case _defaultSettings.EXPORT_IMAGE_ID:
var _uiState$exportImage = uiState.exportImage,
ratio = _uiState$exportImage.ratio,
legend = _uiState$exportImage.legend,
resolution = _uiState$exportImage.resolution,
exporting = _uiState$exportImage.exporting,
imageDataUri = _uiState$exportImage.imageDataUri;
template = _react2.default.createElement(ExportImageModal, {
width: containerW,
height: containerH,
legend: legend,
ratio: ratio,
resolution: resolution,
exporting: exporting,
imageDataUri: imageDataUri,
onChangeRatio: this.props.uiStateActions.setRatio,
onChangeResolution: this.props.uiStateActions.setResolution,
onToggleLegend: this.props.uiStateActions.toggleLegend
});
modalProps = {
close: false,
title: 'Export Image',
footer: true,
onCancel: this._closeModal,
onConfirm: this._onExportImage,
confirmButton: {
large: true,
disabled: exporting,
children: 'Download'
}
};
break;
case _defaultSettings.EXPORT_DATA_ID:
template = _react2.default.createElement(ExportDataModal, (0, _extends3.default)({}, uiState.exportData, {
datasets: datasets,
onClose: this._closeModal,
onChangeExportDataType: this.props.uiStateActions.setExportDataType,
onChangeExportSelectedDataset: this.props.uiStateActions.setExportSelectedDataset,
onChangeExportFiltered: this.props.uiStateActions.setExportFiltered
}));
modalProps = {
close: false,
title: 'Export Data',
footer: true,
onCancel: this._closeModal,
onConfirm: this._onExportData,
confirmButton: {
large: true,
children: 'Export'
}
};
break;
case _defaultSettings.EXPORT_CONFIG_ID:
var keplerGlConfig = _schemas2.default.getConfigToSave({ mapStyle: mapStyle, visState: visState, mapState: mapState, uiState: uiState });
template = _react2.default.createElement(ExportConfigModal, {
config: keplerGlConfig,
data: uiState.exportData.data,
onClose: this._closeModal,
onChangeExportData: this.props.uiStateActions.setExportData
});
modalProps = {
close: false,
title: 'Export Config',
footer: true,
onCancel: this._closeModal,
onConfirm: this._onExportConfig,
confirmButton: {
large: true,
children: 'Export'
}
};
break;
case _defaultSettings.ADD_MAP_STYLE_ID:
template = _react2.default.createElement(AddMapStyleModal, {
mapboxApiAccessToken: this.props.mapboxApiAccessToken,
mapState: this.props.mapState,
inputStyle: mapStyle.inputStyle,
inputMapStyle: this.props.mapStyleActions.inputMapStyle,
loadCustomMapStyle: this.props.mapStyleActions.loadCustomMapStyle
});
modalProps = {
close: false,
title: 'Add Custom Mapbox Style',
footer: true,
onCancel: this._closeModal,
onConfirm: this._onAddCustomMapStyle,
confirmButton: {
large: true,
disabled: !mapStyle.inputStyle.style,
children: 'Add Style'
}
};
break;
default:
break;
}
}
return this.props.rootNode ? _react2.default.createElement(
_modal2.default,
(0, _extends3.default)({}, modalProps, {
parentSelector: function parentSelector() {
return (0, _reactDom.findDOMNode)(rootNode);
},
isOpen: Boolean(currentModal),
close: this._closeModal
}),
template
) : null;
}
}]);
return ModalWrapper;
}(_react.Component), _class.propTypes = {
rootNode: _propTypes2.default.object,
containerW: _propTypes2.default.number,
containerH: _propTypes2.default.number,
mapboxApiAccessToken: _propTypes2.default.string.isRequired,
mapState: _propTypes2.default.object.isRequired,
mapStyle: _propTypes2.default.object.isRequired,
uiState: _propTypes2.default.object.isRequired,
visState: _propTypes2.default.object.isRequired,
visStateActions: _propTypes2.default.object.isRequired,
uiStateActions: _propTypes2.default.object.isRequired,
mapStyleActions: _propTypes2.default.object.isRequired
}, _temp2);
return ModalWrapper;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/modal-container.js"],"names":["ModalContainerFactory","DataTableModalStyle","css","DeleteDatasetModalStyled","LoadDataModalStyle","deps","DeleteDatasetModalFactory","DataTableModalFactory","LoadDataModalFactory","ExportImageModalFactory","ExportDataModalFactory","ExportConfigModalFactory","AddMapStyleModalFactory","DeleteDatasetModal","DataTableModal","LoadDataModal","ExportImageModal","ExportDataModal","ExportConfigModal","AddMapStyleModal","ModalWrapper","_closeModal","props","uiStateActions","toggleModal","_deleteDataset","visStateActions","removeDataset","key","_onAddCustomMapStyle","mapStyleActions","addCustomMapStyle","_onFileUpload","loadFiles","blob","_onExportImage","uiState","exportImage","exporting","imageDataUri","file","DEFAULT_EXPORT_IMAGE_NAME","cleanupExportImage","_onExportData","visState","datasets","exportData","selectedDataset","dataType","filtered","filename","selectedDatasets","Object","values","length","forEach","allData","selectedData","data","fields","label","EXPORT_DATA_TYPE","CSV","type","csv","_downloadFile","_onExportConfig","dump","KeplerGlSchema","save","getConfigToSave","JSON","stringify","fileBlob","Blob","containerW","containerH","mapStyle","mapState","rootNode","currentModal","datasetKeyToRemove","layers","editingDataset","template","modalProps","id","DATA_TABLE_ID","showDatasetTable","cssStyle","DELETE_DATA_ID","title","footer","onConfirm","onCancel","confirmButton","negative","large","children","ADD_DATA_ID","EXPORT_IMAGE_ID","ratio","legend","resolution","setRatio","setResolution","toggleLegend","close","disabled","EXPORT_DATA_ID","setExportDataType","setExportSelectedDataset","setExportFiltered","EXPORT_CONFIG_ID","keplerGlConfig","setExportData","ADD_MAP_STYLE_ID","mapboxApiAccessToken","inputStyle","inputMapStyle","loadCustomMapStyle","style","Boolean","Component","propTypes","PropTypes","object","number","string","isRequired"],"mappings":"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","file":"modal-container.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, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {css} from 'styled-components';\nimport {findDOMNode} from 'react-dom';\nimport {Blob} from 'global/window';\n\nimport ModalDialog from './common/modal';\nimport {formatCsv} from 'processors/data-processor';\nimport KeplerGlSchema from 'schemas';\nimport {downloadFile, dataURItoBlob} from 'utils/export-image-utils';\n// modals\nimport DeleteDatasetModalFactory from './modals/delete-data-modal';\nimport DataTableModalFactory from './modals/data-table-modal';\nimport LoadDataModalFactory from './modals/load-data-modal';\nimport ExportImageModalFactory from './modals/export-image-modal';\nimport ExportDataModalFactory from './modals/export-data-modal';\nimport ExportConfigModalFactory from './modals/export-config-modal';\nimport AddMapStyleModalFactory from './modals/add-map-style-modal';\n\nimport {\n  ADD_DATA_ID,\n  DATA_TABLE_ID,\n  DEFAULT_EXPORT_IMAGE_NAME,\n  DELETE_DATA_ID,\n  EXPORT_DATA_ID,\n  EXPORT_DATA_TYPE,\n  EXPORT_IMAGE_ID,\n  EXPORT_CONFIG_ID,\n  ADD_MAP_STYLE_ID\n} from 'constants/default-settings';\n\nconst DataTableModalStyle = css`\n  height: 85%;\n  width: 90%;\n  top: 80px;\n  padding: 32px 0 0 0;\n  max-width: unset;\n`;\n\nconst DeleteDatasetModalStyled = css`\n  width: 40%;\n  padding: 40px 40px 32px 40px;\n`;\n\nconst LoadDataModalStyle = css`\n  top: 60px;\n`;\n\nModalContainerFactory.deps = [\n  DeleteDatasetModalFactory,\n  DataTableModalFactory,\n  LoadDataModalFactory,\n  ExportImageModalFactory,\n  ExportDataModalFactory,\n  ExportConfigModalFactory,\n  AddMapStyleModalFactory\n];\n\nexport default function ModalContainerFactory(\n  DeleteDatasetModal,\n  DataTableModal,\n  LoadDataModal,\n  ExportImageModal,\n  ExportDataModal,\n  ExportConfigModal,\n  AddMapStyleModal\n) {\n  class ModalWrapper extends Component {\n    static propTypes = {\n      rootNode: PropTypes.object,\n      containerW: PropTypes.number,\n      containerH: PropTypes.number,\n      mapboxApiAccessToken: PropTypes.string.isRequired,\n      mapState: PropTypes.object.isRequired,\n      mapStyle: PropTypes.object.isRequired,\n      uiState: PropTypes.object.isRequired,\n      visState: PropTypes.object.isRequired,\n      visStateActions: PropTypes.object.isRequired,\n      uiStateActions: PropTypes.object.isRequired,\n      mapStyleActions: PropTypes.object.isRequired\n    };\n\n    _closeModal = () => {\n      this.props.uiStateActions.toggleModal(null);\n    };\n\n    _deleteDataset = key => {\n      this.props.visStateActions.removeDataset(key);\n      this._closeModal();\n    };\n\n    _onAddCustomMapStyle = () => {\n      this.props.mapStyleActions.addCustomMapStyle();\n      this._closeModal();\n    };\n\n    _onFileUpload = blob => {\n      this.props.visStateActions.loadFiles(blob);\n    };\n\n    _onExportImage = () => {\n      const {exporting, imageDataUri} = this.props.uiState.exportImage;\n      if (!exporting && imageDataUri) {\n        const file = dataURItoBlob(imageDataUri);\n        downloadFile(file, DEFAULT_EXPORT_IMAGE_NAME);\n      }\n      this.props.uiStateActions.cleanupExportImage();\n      this._closeModal();\n    };\n\n    _downloadFile(data, type, filename) {\n      const fileBlob = new Blob([data], {type});\n      downloadFile(fileBlob, filename);\n    }\n\n    _onExportData = () => {\n      const {visState, uiState} = this.props;\n      const {datasets} = visState;\n      const {selectedDataset, dataType, filtered} = uiState.exportData;\n      // get the selected data\n      const filename = 'kepler-gl';\n      const selectedDatasets = datasets[selectedDataset] ? [datasets[selectedDataset]] : Object.values(datasets);\n      if (!selectedDatasets.length) {\n        // error: selected dataset not found.\n        this._closeModal();\n      }\n\n      selectedDatasets.forEach(selectedData => {\n        const {allData, data, fields, label} = selectedData;\n        const exportData = filtered ? data : allData;\n        // start to export data according to selected data type\n        switch (dataType) {\n          case EXPORT_DATA_TYPE.CSV: {\n            const type = 'text/csv';\n            const csv = formatCsv(exportData, fields);\n            this._downloadFile(csv, type, `${filename}_${label}.csv`);\n            break;\n          }\n          // TODO: support more file types.\n          default:\n            break;\n        }\n\n      });\n\n      this._closeModal();\n    };\n\n    _onExportConfig = () => {\n      const {data} = this.props.uiState.exportData;\n\n      // we pass all props because we avoid to create new variables\n      const dump = data ? KeplerGlSchema.save(this.props)\n        : KeplerGlSchema.getConfigToSave(this.props);\n\n      this._downloadFile(\n        JSON.stringify(dump, null, 2),\n        'application/json',\n        'keplergl.json'\n      );\n\n      this._closeModal();\n    };\n\n    render() {\n      const {\n        containerW,\n        containerH,\n        mapStyle,\n        mapState,\n        uiState,\n        visState,\n        rootNode,\n        visStateActions\n      } = this.props;\n      const {currentModal, datasetKeyToRemove} = uiState;\n      const {datasets, layers, editingDataset} = visState;\n\n      let template = null;\n      let modalProps = {};\n\n      if (currentModal && currentModal.id &&\n        currentModal.template) {\n        // if currentMdoal template is already provided\n        // TODO: need to check whether template is valid\n        template = (<currentModal.template/>);\n        modalProps = currentModal.modalProps;\n      } else {\n        switch (currentModal) {\n          case DATA_TABLE_ID:\n            template = (\n              <DataTableModal\n                width={containerW * 0.9}\n                height={containerH * 0.85}\n                datasets={datasets}\n                dataId={editingDataset}\n                showDatasetTable={visStateActions.showDatasetTable}\n              />\n            );\n            modalProps.cssStyle = DataTableModalStyle;\n            break;\n          case DELETE_DATA_ID:\n            // validate options\n            if (datasetKeyToRemove && datasets && datasets[datasetKeyToRemove]) {\n              template = (\n                <DeleteDatasetModal\n                  dataset={datasets[datasetKeyToRemove]}\n                  layers={layers}\n                />\n              );\n\n              modalProps = {\n                title: 'Delete Dataset',\n                cssStyle: DeleteDatasetModalStyled,\n                footer: true,\n                onConfirm: () => this._deleteDataset(datasetKeyToRemove),\n                onCancel: this._closeModal,\n                confirmButton: {\n                  negative: true,\n                  large: true,\n                  children: 'Delete'\n                }\n              };\n            }\n            break; // in case we add a new case after this one\n          case ADD_DATA_ID:\n            template = (\n              <LoadDataModal\n                onClose={this._closeModal}\n                onFileUpload={this._onFileUpload}\n              />\n            );\n            modalProps = {\n              title: 'Add Data To Map',\n              cssStyle: LoadDataModalStyle,\n              footer: false,\n              onConfirm: this._closeModal\n            };\n            break;\n\n          case EXPORT_IMAGE_ID:\n            const { ratio, legend, resolution, exporting, imageDataUri } = uiState.exportImage;\n            template = (\n              <ExportImageModal\n                width={containerW}\n                height={containerH}\n                legend={legend}\n                ratio={ratio}\n                resolution={resolution}\n                exporting={exporting}\n                imageDataUri={imageDataUri}\n                onChangeRatio={this.props.uiStateActions.setRatio}\n                onChangeResolution={this.props.uiStateActions.setResolution}\n                onToggleLegend={this.props.uiStateActions.toggleLegend}\n              />\n            );\n            modalProps = {\n              close: false,\n              title: 'Export Image',\n              footer: true,\n              onCancel: this._closeModal,\n              onConfirm: this._onExportImage,\n              confirmButton: {\n                large: true,\n                disabled: exporting,\n                children: 'Download'\n              }\n            };\n            break;\n\n          case EXPORT_DATA_ID:\n\n            template = (\n              <ExportDataModal\n                {...uiState.exportData}\n                datasets={datasets}\n                onClose={this._closeModal}\n                onChangeExportDataType={this.props.uiStateActions.setExportDataType}\n                onChangeExportSelectedDataset={this.props.uiStateActions.setExportSelectedDataset}\n                onChangeExportFiltered={this.props.uiStateActions.setExportFiltered}\n              />\n            );\n            modalProps = {\n              close: false,\n              title: 'Export Data',\n              footer: true,\n              onCancel: this._closeModal,\n              onConfirm: this._onExportData,\n              confirmButton: {\n                large: true,\n                children: 'Export'\n              }\n            };\n            break;\n\n          case EXPORT_CONFIG_ID:\n            const keplerGlConfig = KeplerGlSchema.getConfigToSave(\n              { mapStyle, visState, mapState, uiState }\n            );\n            template = (\n              <ExportConfigModal\n                config={keplerGlConfig}\n                data={uiState.exportData.data}\n                onClose={this._closeModal}\n                onChangeExportData={this.props.uiStateActions.setExportData}\n              />\n            );\n            modalProps = {\n              close: false,\n              title: 'Export Config',\n              footer: true,\n              onCancel: this._closeModal,\n              onConfirm: this._onExportConfig,\n              confirmButton: {\n                large: true,\n                children: 'Export'\n              }\n            };\n            break;\n\n          case ADD_MAP_STYLE_ID:\n            template = (\n              <AddMapStyleModal\n                mapboxApiAccessToken={this.props.mapboxApiAccessToken}\n                mapState={this.props.mapState}\n                inputStyle={mapStyle.inputStyle}\n                inputMapStyle={this.props.mapStyleActions.inputMapStyle}\n                loadCustomMapStyle={this.props.mapStyleActions.loadCustomMapStyle}\n              />\n            );\n            modalProps = {\n              close: false,\n              title: 'Add Custom Mapbox Style',\n              footer: true,\n              onCancel: this._closeModal,\n              onConfirm: this._onAddCustomMapStyle,\n              confirmButton: {\n                large: true,\n                disabled: !mapStyle.inputStyle.style,\n                children: 'Add Style'\n              }\n            };\n            break;\n          default:\n            break;\n        }\n      }\n\n      return this.props.rootNode ? (\n        <ModalDialog\n          {...modalProps}\n          parentSelector={() => findDOMNode(rootNode)}\n          isOpen={Boolean(currentModal)}\n          close={this._closeModal}\n        >\n          {template}\n        </ModalDialog>\n      ) : null;\n    }\n  }\n\n  return ModalWrapper;\n}\n"]}