UNPKG

kepler.gl

Version:

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

97 lines (90 loc) 15.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.getQueryTool = getQueryTool; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _react = _interopRequireDefault(require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/node_modules/react")); var _duckdb = require("@openassistant/duckdb"); var _tables = require("@openassistant/tables"); var _utils = require("@openassistant/utils"); var _utils2 = require("./utils"); var _tableTool = require("./kepler-tools/table-tool"); function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project function getQueryTool(datasets, layers) { var toolCache = _utils.ToolCache.getInstance(); // context for query tools var getValues = /*#__PURE__*/function () { var _ref = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(datasetName, variableName) { var values; return _regenerator["default"].wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: values = (0, _utils2.getValuesFromDataset)(datasets, layers, datasetName, variableName); return _context.abrupt("return", values); case 2: case "end": return _context.stop(); } }, _callee); })); return function getValues(_x, _x2) { return _ref.apply(this, arguments); }; }(); // customize some query tools from localQuery tool function QueryToolComponent(props) { return /*#__PURE__*/_react["default"].createElement(_tables.QueryDuckDBComponent, (0, _extends2["default"])({}, props, { getValues: getValues, getDuckDB: _duckdb.getDuckDB })); } // this tool will execute a generic select SQL query against user's dataset var genericQuery = _objectSpread(_objectSpread({}, _duckdb.localQuery), {}, { description: "execute a generic select SQL query in duckdb to answer user's question. Please note:\n1. This tool is NOT for filtering the user dataset.\n2. This tool does NOT support geometry column and geometric operations.\n3. The variableNames should not be empty. If it is not provided, then pick a variable name from the dataset.\n4. There is no need to add a sub-query to add an auto-increment column 'row_index' to the original dataset.\n", context: _objectSpread(_objectSpread({}, _duckdb.localQuery.context), {}, { getValues: getValues }), component: QueryToolComponent }); // customize a filterDataset tool from localQuery tool // this tool will use the selected rows (row indexes) to filter the user dataset and save the result as a new dataset. var filterDataset = _objectSpread(_objectSpread({}, _duckdb.localQuery), {}, { description: "filter the user dataset by using a select SQL query in duckdb and save the result as a new dataset.\nPlease note:\n1. Do not use * to select all columns, instead use all the column names in dataset.\n", context: _objectSpread(_objectSpread({}, _duckdb.localQuery.context), {}, { getValues: getValues }), component: _tableTool.TableToolComponent }); // customize a table tool from localQuery tool to create a new table/dataset in kepler.gl using SQL query var tableTool = _objectSpread(_objectSpread({}, _duckdb.localQuery), {}, { description: "Create a new table/dataset in kepler.gl using SQL query which will\n1. add a new column to the original dataset\n2. delete a column from the original dataset\n3. rename a column in the original dataset\n4. change the column type in the original dataset.\nPlease note:\n1. Do not use * to select all columns, instead use all the column names in dataset.\n2. List all column names the new table or dataset will have.\n", context: _objectSpread(_objectSpread({}, _duckdb.localQuery.context), {}, { getValues: getValues }), component: _tableTool.TableToolComponent }); // customize a mergeTables tool from localQuery tool to merge two datasets into a new dataset var mergeTablesTool = _objectSpread(_objectSpread({}, _duckdb.mergeTables), {}, { context: { getValues: getValues }, onToolCompleted: function onToolCompleted(toolName, additionalData) { toolCache.addDataset(toolName, additionalData); } // component: MergeTablesToolComponent }); return { filterDataset: filterDataset, genericQuery: genericQuery, tableTool: tableTool, mergeTablesTool: mergeTablesTool }; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_duckdb","_tables","_utils","_utils2","_tableTool","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","getQueryTool","datasets","layers","toolCache","ToolCache","getInstance","getValues","_ref","_asyncToGenerator2","_regenerator","mark","_callee","datasetName","variableName","values","wrap","_callee$","_context","prev","next","getValuesFromDataset","abrupt","stop","_x","_x2","QueryToolComponent","props","createElement","QueryDuckDBComponent","_extends2","getDuckDB","genericQuery","localQuery","description","context","component","filterDataset","TableToolComponent","tableTool","mergeTablesTool","mergeTables","onToolCompleted","toolName","additionalData","addDataset"],"sources":["../../../src/ai-assistant/src/tools/query-tool.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React from 'react';\nimport {Datasets} from '@kepler.gl/table';\nimport {Layer} from '@kepler.gl/layers';\nimport {\n  getDuckDB,\n  localQuery,\n  LocalQueryTool,\n  mergeTables,\n  MergeTablesTool\n} from '@openassistant/duckdb';\nimport {QueryDuckDBComponent, QueryDuckDBOutputData} from '@openassistant/tables';\nimport {ToolCache} from '@openassistant/utils';\n\nimport {getValuesFromDataset} from './utils';\nimport {TableToolComponent} from './kepler-tools/table-tool';\n\nexport function getQueryTool(datasets: Datasets, layers: Layer[]) {\n  const toolCache = ToolCache.getInstance();\n\n  // context for query tools\n  const getValues = async (datasetName: string, variableName: string) => {\n    const values = getValuesFromDataset(datasets, layers, datasetName, variableName);\n    return values;\n  };\n\n  // customize some query tools from localQuery tool\n  function QueryToolComponent(props: QueryDuckDBOutputData) {\n    return <QueryDuckDBComponent {...props} getValues={getValues} getDuckDB={getDuckDB} />;\n  }\n\n  // this tool will execute a generic select SQL query against user's dataset\n  const genericQuery: LocalQueryTool = {\n    ...localQuery,\n    description: `execute a generic select SQL query in duckdb to answer user's question. Please note:\n1. This tool is NOT for filtering the user dataset.\n2. This tool does NOT support geometry column and geometric operations.\n3. The variableNames should not be empty. If it is not provided, then pick a variable name from the dataset.\n4. There is no need to add a sub-query to add an auto-increment column 'row_index' to the original dataset.\n`,\n    context: {\n      ...localQuery.context,\n      getValues\n    },\n    component: QueryToolComponent\n  };\n\n  // customize a filterDataset tool from localQuery tool\n  // this tool will use the selected rows (row indexes) to filter the user dataset and save the result as a new dataset.\n  const filterDataset: LocalQueryTool = {\n    ...localQuery,\n    description: `filter the user dataset by using a select SQL query in duckdb and save the result as a new dataset.\nPlease note:\n1. Do not use * to select all columns, instead use all the column names in dataset.\n`,\n    context: {\n      ...localQuery.context,\n      getValues\n    },\n    component: TableToolComponent\n  };\n\n  // customize a table tool from localQuery tool to create a new table/dataset in kepler.gl using SQL query\n  const tableTool: LocalQueryTool = {\n    ...localQuery,\n    description: `Create a new table/dataset in kepler.gl using SQL query which will\n1. add a new column to the original dataset\n2. delete a column from the original dataset\n3. rename a column in the original dataset\n4. change the column type in the original dataset.\nPlease note:\n1. Do not use * to select all columns, instead use all the column names in dataset.\n2. List all column names the new table or dataset will have.\n`,\n    context: {\n      ...localQuery.context,\n      getValues\n    },\n    component: TableToolComponent\n  };\n\n  // customize a mergeTables tool from localQuery tool to merge two datasets into a new dataset\n  const mergeTablesTool: MergeTablesTool = {\n    ...mergeTables,\n    context: {\n      getValues\n    },\n    onToolCompleted: (toolName: string, additionalData: unknown) => {\n      toolCache.addDataset(toolName, additionalData);\n    }\n    // component: MergeTablesToolComponent\n  };\n\n  return {\n    filterDataset,\n    genericQuery,\n    tableTool,\n    mergeTablesTool\n  };\n}\n"],"mappings":"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","ignoreList":[]}