UNPKG

kepler.gl.geoiq

Version:

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

107 lines (85 loc) 13.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _switch = _interopRequireDefault(require("../common/switch")); var _reactJsonPretty = _interopRequireDefault(require("react-json-pretty")); var _styledComponents2 = require("../common/styled-components"); function _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["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"]); _templateObject = function _templateObject() { return data; }; return data; } var propTypes = { config: _propTypes["default"].object.required }; var StyledExportConfigSection = _styledComponents["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 = _styledComponents["default"].div(_templateObject2()); var ExportConfigModal = function ExportConfigModal(_ref) { var data = _ref.data, config = _ref.config, onChangeExportData = _ref.onChangeExportData; return _react["default"].createElement("div", { className: "export-config-modal" }, _react["default"].createElement(_styledComponents2.StyledModalContent, null, _react["default"].createElement(StyledModalContentInner, { className: "export-config-modal__inner" }, _react["default"].createElement(StyledExportConfigSection, null, _react["default"].createElement("div", { className: "description" }, _react["default"].createElement("div", { className: "title" }, "Current Config"), _react["default"].createElement("div", { className: "subtitle" }, "You can copy or export the current Kepler.gl configuration."), _react["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.")), _react["default"].createElement("div", { className: "selection" }, _react["default"].createElement("div", { className: "viewer" }, _react["default"].createElement(_reactJsonPretty["default"], { id: "json-pretty", json: config })))), _react["default"].createElement(StyledExportConfigSection, null, _react["default"].createElement("div", { className: "description" }, _react["default"].createElement("div", { className: "title" }, "Export Current Map"), _react["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.")), _react["default"].createElement("div", { className: "selection" }, _react["default"].createElement(_switch["default"], { type: "checkbox", id: "export-map-config", checked: data, onChange: onChangeExportData })))))); }; ExportConfigModal.propTypes = propTypes; var ExportConfigModalFactory = function ExportConfigModalFactory() { return ExportConfigModal; }; var _default = ExportConfigModalFactory; exports["default"] = _default; //# 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":";;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,SAAS,GAAG;AAChBC,EAAAA,MAAM,EAAEC,sBAAUC,MAAV,CAAiBC;AADT,CAAlB;;AAIA,IAAMC,yBAAyB,GAAGC,6BAAOC,GAAV,oBAYhB,UAAAC,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYC,WAAhB;AAAA,CAZW,EAgBhB,UAAAF,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYE,SAAhB;AAAA,CAhBW,EAqBhB,UAAAH,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYG,UAAhB;AAAA,CArBW,EA+BL,UAAAJ,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYI,mBAAhB;AAAA,CA/BA,CAA/B;;AAgDA,IAAMC,uBAAuB,GAAGR,6BAAOC,GAAV,oBAA7B;;AAIA,IAAMQ,iBAAiB,GAAG,SAApBA,iBAAoB;AAAA,MACxBC,IADwB,QACxBA,IADwB;AAAA,MAExBf,MAFwB,QAExBA,MAFwB;AAAA,MAIxBgB,kBAJwB,QAIxBA,kBAJwB;AAAA,SAMxB;AAAK,IAAA,SAAS,EAAC;AAAf,KACE,gCAAC,qCAAD,QACE,gCAAC,uBAAD;AAAyB,IAAA,SAAS,EAAC;AAAnC,KACE,gCAAC,yBAAD,QACE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,sBADF,EAIE;AAAK,IAAA,SAAS,EAAC;AAAf,mEAJF,EAOE;AAAK,IAAA,SAAS,EAAC;AAAf,qRAPF,CADF,EAeE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,KACI,gCAAC,2BAAD;AAAY,IAAA,EAAE,EAAC,aAAf;AAA6B,IAAA,IAAI,EAAEhB;AAAnC,IADJ,CADF,CAfF,CADF,EAsBE,gCAAC,yBAAD,QACE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,0BADF,EAIE;AAAK,IAAA,SAAS,EAAC;AAAf,yHAJF,CADF,EASE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE,gCAAC,kBAAD;AAAQ,IAAA,IAAI,EAAC,UAAb;AACQ,IAAA,EAAE,EAAC,mBADX;AAEQ,IAAA,OAAO,EAAEe,IAFjB;AAGQ,IAAA,QAAQ,EAAEC;AAHlB,IADF,CATF,CAtBF,CADF,CADF,CANwB;AAAA,CAA1B;;AAmDAF,iBAAiB,CAACf,SAAlB,GAA8BA,SAA9B;;AAEA,IAAMkB,wBAAwB,GAAG,SAA3BA,wBAA2B;AAAA,SAAMH,iBAAN;AAAA,CAAjC;;eACeG,wB","sourcesContent":["// Copyright (c) 2019 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"]}