kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
159 lines (155 loc) • 19.5 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.TableToolComponent = TableToolComponent;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _reactRedux = require("react-redux");
var _react = _interopRequireWildcard(require("react"));
var _duckdb = require("@openassistant/duckdb");
var _actions = require("@kepler.gl/actions");
var _processors = require("@kepler.gl/processors");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
// SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
// This component will create a new table using the SQL query which will
// 1. add a new column
// 2. delete a column
// 3. rename a column
// 4. change the variable type of a column
function TableToolComponent(_ref) {
var sql = _ref.sql,
dbTableName = _ref.dbTableName,
newDatasetName = _ref.queryDatasetName;
var datasets = (0, _reactRedux.useSelector)(function (state) {
return state.demo.keplerGl.map.visState.datasets;
});
var queryInProgress = (0, _react.useRef)(null);
var dispatch = (0, _reactRedux.useDispatch)();
var _useState = (0, _react.useState)(null),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
error = _useState2[0],
setError = _useState2[1];
(0, _react.useEffect)(function () {
// check if the newDatasetName is already in the datasets
var newDatasetId = Object.keys(datasets).find(function (dataId) {
return datasets[dataId].label === newDatasetName;
});
// if the newDatasetName is already in the datasets, return
if (newDatasetId) return;
var addTable = /*#__PURE__*/function () {
var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
return _regenerator["default"].wrap(function _callee2$(_context2) {
while (1) switch (_context2.prev = _context2.next) {
case 0:
if (!queryInProgress.current) {
_context2.next = 3;
break;
}
_context2.next = 3;
return queryInProgress.current;
case 3:
// Create a new promise for this query
queryInProgress.current = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
var duckDB, conn, arrowResult, jsonResult, processedData;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
_context.prev = 0;
_context.next = 3;
return (0, _duckdb.getDuckDB)();
case 3:
duckDB = _context.sent;
if (duckDB) {
_context.next = 6;
break;
}
throw new Error('DuckDB instance is not initialized');
case 6:
if (!(dbTableName && sql)) {
_context.next = 22;
break;
}
_context.next = 9;
return duckDB.connect();
case 9:
conn = _context.sent;
_context.next = 12;
return conn.query(sql);
case 12:
arrowResult = _context.sent;
// convert arrowResult to a JSON object
jsonResult = arrowResult.toArray().map(function (row) {
return (0, _duckdb.convertArrowRowToObject)(row);
}); // use processFileData to process the rowObject
_context.next = 16;
return (0, _processors.processFileData)({
content: {
fileName: newDatasetName,
data: jsonResult
},
fileCache: []
});
case 16:
processedData = _context.sent;
// add the new dataset to the map
dispatch((0, _actions.addDataToMap)({
datasets: processedData,
options: {
autoCreateLayers: true,
centerMap: true
}
}));
// delete the table from the database
_context.next = 20;
return conn.query("DROP TABLE ".concat(dbTableName));
case 20:
_context.next = 22;
return conn.close();
case 22:
_context.next = 28;
break;
case 24:
_context.prev = 24;
_context.t0 = _context["catch"](0);
console.error(_context.t0);
setError(_context.t0 instanceof Error ? _context.t0.message : 'Unknown error occurred');
case 28:
_context.prev = 28;
queryInProgress.current = null;
return _context.finish(28);
case 31:
case "end":
return _context.stop();
}
}, _callee, null, [[0, 24, 28, 31]]);
}))();
// Wait for the query to complete
_context2.next = 6;
return queryInProgress.current;
case 6:
case "end":
return _context2.stop();
}
}, _callee2);
}));
return function addTable() {
return _ref2.apply(this, arguments);
};
}();
addTable();
// eslint-disable-next-line react-hooks/exhaustive-deps
}, []);
return error ? /*#__PURE__*/_react["default"].createElement("div", {
style: {
color: 'red',
fontSize: '8px'
}
}, error) : null;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_reactRedux","require","_react","_interopRequireWildcard","_duckdb","_actions","_processors","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","TableToolComponent","_ref","sql","dbTableName","newDatasetName","queryDatasetName","datasets","useSelector","state","demo","keplerGl","map","visState","queryInProgress","useRef","dispatch","useDispatch","_useState","useState","_useState2","_slicedToArray2","error","setError","useEffect","newDatasetId","keys","find","dataId","label","addTable","_ref2","_asyncToGenerator2","_regenerator","mark","_callee2","wrap","_callee2$","_context2","prev","next","current","_callee","duckDB","conn","arrowResult","jsonResult","processedData","_callee$","_context","getDuckDB","sent","Error","connect","query","toArray","row","convertArrowRowToObject","processFileData","content","fileName","data","fileCache","addDataToMap","options","autoCreateLayers","centerMap","concat","close","t0","console","message","finish","stop","apply","arguments","createElement","style","color","fontSize"],"sources":["../../../src/tools/kepler-tools/table-tool.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {useSelector} from 'react-redux';\nimport React, {useEffect, useRef, useState} from 'react';\nimport {useDispatch} from 'react-redux';\nimport {getDuckDB, LocalQueryAdditionalData, convertArrowRowToObject} from '@openassistant/duckdb';\n\nimport {State} from '../../components/ai-assistant-manager';\nimport {addDataToMap} from '@kepler.gl/actions';\nimport {processFileData} from '@kepler.gl/processors';\n\n// This component will create a new table using the SQL query which will\n// 1. add a new column\n// 2. delete a column\n// 3. rename a column\n// 4. change the variable type of a column\nexport function TableToolComponent({\n  sql,\n  dbTableName,\n  queryDatasetName: newDatasetName\n}: LocalQueryAdditionalData) {\n  const datasets = useSelector((state: State) => state.demo.keplerGl.map.visState.datasets);\n  const queryInProgress = useRef<Promise<void> | null>(null);\n  const dispatch = useDispatch();\n\n  const [error, setError] = useState<string | null>(null);\n\n  useEffect(() => {\n    // check if the newDatasetName is already in the datasets\n    const newDatasetId = Object.keys(datasets).find(\n      dataId => datasets[dataId].label === newDatasetName\n    );\n    // if the newDatasetName is already in the datasets, return\n    if (newDatasetId) return;\n\n    const addTable = async () => {\n      // If a query is already in progress, wait for it to complete\n      if (queryInProgress.current) {\n        await queryInProgress.current;\n      }\n\n      // Create a new promise for this query\n      queryInProgress.current = (async () => {\n        try {\n          const duckDB = await getDuckDB();\n          if (!duckDB) {\n            throw new Error('DuckDB instance is not initialized');\n          }\n          if (dbTableName && sql) {\n            // connect to the database\n            const conn = await duckDB.connect();\n\n            // Execute the provided SQL query\n            const arrowResult = await conn.query(sql);\n\n            // convert arrowResult to a JSON object\n            const jsonResult = arrowResult.toArray().map(row => convertArrowRowToObject(row));\n\n            // use processFileData to process the rowObject\n            const processedData = await processFileData({\n              content: {fileName: newDatasetName, data: jsonResult},\n              fileCache: []\n            });\n\n            // add the new dataset to the map\n            dispatch(\n              addDataToMap({\n                datasets: processedData,\n                options: {autoCreateLayers: true, centerMap: true}\n              })\n            );\n\n            // delete the table from the database\n            await conn.query(`DROP TABLE ${dbTableName}`);\n\n            // close the connection\n            await conn.close();\n          }\n        } catch (error) {\n          console.error(error);\n          setError(error instanceof Error ? error.message : 'Unknown error occurred');\n        } finally {\n          queryInProgress.current = null;\n        }\n      })();\n\n      // Wait for the query to complete\n      await queryInProgress.current;\n    };\n\n    addTable();\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, []);\n\n  return error ? <div style={{color: 'red', fontSize: '8px'}}>{error}</div> : null;\n}\n"],"mappings":"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","ignoreList":[]}