UNPKG

kepler.gl

Version:

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

154 lines (132 loc) 16 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 justify-content: space-between;\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 .note {\n color: ', ';\n font-size: 11px;\n }\n }\n\n .selection {\n padding-left: 50px;\n flex-grow: 1;\n\n .viewer {\n border: 1px solid ', ';\n background-color: white;\n border-radius: 2px;\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 height: 300px;\n width: 100%;\n overflow-y: scroll;\n }\n }\n'], ['\n display: flex;\n flex-direction: row;\n margin: 35px 0;\n width: 100%;\n justify-content: space-between;\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 .note {\n color: ', ';\n font-size: 11px;\n }\n }\n\n .selection {\n padding-left: 50px;\n flex-grow: 1;\n\n .viewer {\n border: 1px solid ', ';\n background-color: white;\n border-radius: 2px;\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 height: 300px;\n width: 100%;\n overflow-y: scroll;\n }\n }\n']), _templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n width: 100%;\n'], ['\n width: 100%;\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 _switch = require('../common/switch'); var _switch2 = _interopRequireDefault(_switch); var _reactJsonPretty = require('react-json-pretty'); var _reactJsonPretty2 = _interopRequireDefault(_reactJsonPretty); var _styledComponents3 = require('../common/styled-components'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var propTypes = { config: _propTypes2.default.object.required }; var StyledExportConfigSection = _styledComponents2.default.div(_templateObject, function (props) { return props.theme.textColorLT; }, function (props) { return props.theme.textColor; }, function (props) { return props.theme.errorColor; }, function (props) { return props.theme.selectBorderColorLT; }); var StyledModalContentInner = _styledComponents2.default.div(_templateObject2); var ExportConfigModal = function ExportConfigModal(_ref) { var data = _ref.data, config = _ref.config, onChangeExportData = _ref.onChangeExportData; return _react2.default.createElement( 'div', { className: 'export-config-modal' }, _react2.default.createElement( _styledComponents3.StyledModalContent, null, _react2.default.createElement( StyledModalContentInner, { className: 'export-config-modal__inner' }, _react2.default.createElement( StyledExportConfigSection, null, _react2.default.createElement( 'div', { className: 'description' }, _react2.default.createElement( 'div', { className: 'title' }, 'Current Config' ), _react2.default.createElement( 'div', { className: 'subtitle' }, 'You can copy or export the current Kepler.gl configuration.' ), _react2.default.createElement( 'div', { className: 'note' }, '* kepler.gl map config is coupled with loaded datasets. dataId key is used to bind layers and filters to a specific dataset. If you try to upload a configuration with a specific dataId you also need to make sure you existing dataset id match the dataId/s in the config.' ) ), _react2.default.createElement( 'div', { className: 'selection' }, _react2.default.createElement( 'div', { className: 'viewer' }, _react2.default.createElement(_reactJsonPretty2.default, { id: 'json-pretty', json: config }) ) ) ), _react2.default.createElement( StyledExportConfigSection, null, _react2.default.createElement( 'div', { className: 'description' }, _react2.default.createElement( 'div', { className: 'title' }, 'Export Current Map' ), _react2.default.createElement( 'div', { className: 'subtitle' }, 'Export current map, including data and config. You can later load the same map by loading this file to kepler.gl.' ) ), _react2.default.createElement( 'div', { className: 'selection' }, _react2.default.createElement(_switch2.default, { type: 'checkbox', id: 'export-map-config', checked: data, onChange: onChangeExportData }) ) ) ) ) ); }; ExportConfigModal.propTypes = propTypes; var ExportConfigModalFactory = function ExportConfigModalFactory() { return ExportConfigModal; }; exports.default = ExportConfigModalFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/export-config-modal.js"],"names":["propTypes","config","PropTypes","object","required","StyledExportConfigSection","styled","div","props","theme","textColorLT","textColor","errorColor","selectBorderColorLT","StyledModalContentInner","ExportConfigModal","data","onChangeExportData","ExportConfigModalFactory"],"mappings":";;;;;;;;;;;6GAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AAEA;;;;AAEA,IAAMA,YAAY;AAChBC,UAAQC,oBAAUC,MAAV,CAAiBC;AADT,CAAlB;;AAIA,IAAMC,4BAA4BC,2BAAOC,GAAnC,kBAYS;AAAA,SAASC,MAAMC,KAAN,CAAYC,WAArB;AAAA,CAZT,EAgBS;AAAA,SAASF,MAAMC,KAAN,CAAYE,SAArB;AAAA,CAhBT,EAqBS;AAAA,SAASH,MAAMC,KAAN,CAAYG,UAArB;AAAA,CArBT,EA+BoB;AAAA,SAASJ,MAAMC,KAAN,CAAYI,mBAArB;AAAA,CA/BpB,CAAN;;AAgDA,IAAMC,0BAA0BR,2BAAOC,GAAjC,kBAAN;;AAIA,IAAMQ,oBAAoB,SAApBA,iBAAoB;AAAA,MACxBC,IADwB,QACxBA,IADwB;AAAA,MAExBf,MAFwB,QAExBA,MAFwB;AAAA,MAIxBgB,kBAJwB,QAIxBA,kBAJwB;AAAA,SAMxB;AAAA;AAAA,MAAK,WAAU,qBAAf;AACE;AAAC,2CAAD;AAAA;AACE;AAAC,+BAAD;AAAA,UAAyB,WAAU,4BAAnC;AACE;AAAC,mCAAD;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;AAOE;AAAA;AAAA,gBAAK,WAAU,MAAf;AAAA;AAAA;AAPF,WADF;AAeE;AAAA;AAAA,cAAK,WAAU,WAAf;AACE;AAAA;AAAA,gBAAK,WAAU,QAAf;AACI,4CAAC,yBAAD,IAAY,IAAG,aAAf,EAA6B,MAAMhB,MAAnC;AADJ;AADF;AAfF,SADF;AAsBE;AAAC,mCAAD;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,0CAAC,gBAAD,IAAQ,MAAK,UAAb;AACQ,kBAAG,mBADX;AAEQ,uBAASe,IAFjB;AAGQ,wBAAUC,kBAHlB;AADF;AATF;AAtBF;AADF;AADF,GANwB;AAAA,CAA1B;;AAmDAF,kBAAkBf,SAAlB,GAA8BA,SAA9B;;AAEA,IAAMkB,2BAA2B,SAA3BA,wBAA2B;AAAA,SAAMH,iBAAN;AAAA,CAAjC;kBACeG,wB","file":"export-config-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';\nimport Switch from 'components/common/switch';\nimport JSONPretty from 'react-json-pretty';\n\nimport {StyledModalContent} from 'components/common/styled-components';\n\nconst propTypes = {\n  config: PropTypes.object.required\n};\n\nconst StyledExportConfigSection = styled.div`\n  display: flex;\n  flex-direction: row;\n  margin: 35px 0;\n  width: 100%;\n  justify-content: space-between;\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    .note {\n      color: ${props => props.theme.errorColor};\n      font-size: 11px;\n    }\n  }\n\n  .selection {\n    padding-left: 50px;\n    flex-grow: 1;\n\n    .viewer {\n      border: 1px solid ${props => props.theme.selectBorderColorLT};\n      background-color: white;\n      border-radius: 2px;\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      height: 300px;\n      width: 100%;\n      overflow-y: scroll;\n    }\n  }\n`;\n\nconst StyledModalContentInner = styled.div`\n  width: 100%;\n`;\n\nconst ExportConfigModal = ({\n  data,\n  config,\n  // actions\n  onChangeExportData\n}) => (\n  <div className=\"export-config-modal\">\n    <StyledModalContent>\n      <StyledModalContentInner className=\"export-config-modal__inner\">\n        <StyledExportConfigSection>\n          <div className=\"description\">\n            <div className=\"title\">\n              Current Config\n            </div>\n            <div className=\"subtitle\">\n              You can copy or export the current Kepler.gl configuration.\n            </div>\n            <div className=\"note\">\n              * kepler.gl map config is coupled with loaded datasets.\n              dataId key is used to bind layers and filters to a specific dataset.\n              If you try to upload a configuration with a specific dataId you also need to make sure\n              you existing dataset id match the dataId/s in the config.\n            </div>\n          </div>\n          <div className=\"selection\">\n            <div className=\"viewer\">\n                <JSONPretty id=\"json-pretty\" json={config}/>\n            </div>\n          </div>\n        </StyledExportConfigSection>\n        <StyledExportConfigSection>\n          <div className=\"description\">\n            <div className=\"title\">\n              Export Current Map\n            </div>\n            <div className=\"subtitle\">\n              Export current map, including data and config. You can later load the same map by loading this file to kepler.gl.\n            </div>\n          </div>\n          <div className=\"selection\">\n            <Switch type=\"checkbox\"\n                    id=\"export-map-config\"\n                    checked={data}\n                    onChange={onChangeExportData}/>\n          </div>\n        </StyledExportConfigSection>\n      </StyledModalContentInner>\n    </StyledModalContent>\n  </div>\n);\n\nExportConfigModal.propTypes = propTypes;\n\nconst ExportConfigModalFactory = () => ExportConfigModal;\nexport default ExportConfigModalFactory;\n"]}