kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
336 lines (322 loc) • 39.2 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.checkDatasetNotExists = checkDatasetNotExists;
exports.checkFieldNotExists = checkFieldNotExists;
exports.getDatasetContext = getDatasetContext;
exports.getGeometriesFromDataset = getGeometriesFromDataset;
exports.getScatterplotValuesFromDataset = getScatterplotValuesFromDataset;
exports.getValuesFromDataset = getValuesFromDataset;
exports.highlightRows = highlightRows;
exports.highlightRowsByColumnValues = highlightRowsByColumnValues;
exports.interpolateColor = interpolateColor;
exports.saveAsDataset = saveAsDataset;
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _colorInterpolate = _interopRequireDefault(require("color-interpolate"));
var _constants = require("@kepler.gl/constants");
// SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
/**
* Check if the dataset exists
* @param datasets The kepler.gl datasets
* @param datasetName The name of the dataset
* @param functionName The name of the function
* @returns The result of the check
*/
function checkDatasetNotExists(datasets, datasetName, functionName) {
var datasetId = Object.keys(datasets).find(function (dataId) {
return datasets[dataId].label === datasetName;
});
if (!datasetId) {
return {
name: functionName,
result: {
success: false,
details: "Dataset not found. Please specify one from the following datasets: ".concat(Object.keys(datasets).join(', '))
}
};
}
return null;
}
/**
* Check if the field exists
* @param dataset The kepler.gl dataset
* @param fieldName The name of the field
* @param functionName The name of the function
* @returns The result of the check
*/
function checkFieldNotExists(dataset, fieldName, functionName) {
var field = dataset.fields.find(function (f) {
return f.name === fieldName;
});
if (!field) {
return {
type: 'layer',
name: functionName,
result: {
success: false,
details: "Field not found. Please specify one from the following fields: ".concat(dataset.fields.map(function (f) {
return f.name;
}).join(', '))
}
};
}
return null;
}
/**
* Interpolate the colors from the original colors with the given number of colors
* @param originalColors The original colors
* @param numberOfColors The number of colors
* @returns The interpolated colors
*/
function interpolateColor(originalColors, numberOfColors) {
if (originalColors.length === numberOfColors) {
return originalColors;
}
var interp = (0, _colorInterpolate["default"])(originalColors);
var colors = Array.from({
length: numberOfColors
}, function (_, j) {
return interp(j / (numberOfColors - 1));
});
// convert colors from 'rgb(255, 255, 255)' to '#ffffff'
var hexColors = colors.map(function (color) {
var rgb = color.match(/\d+/g);
return "#".concat(rgb === null || rgb === void 0 ? void 0 : rgb.map(function (c) {
return parseInt(c).toString(16).padStart(2, '0');
}).join(''));
});
return hexColors;
}
/**
* Get the values from a dataset for a variable
* @param datasets
* @param datasetName
* @param variableName
* @returns {number[]}
*/
function getValuesFromDataset(datasets, datasetName, variableName) {
// find which dataset has the variableName
var datasetId = Object.keys(datasets).find(function (dataId) {
return datasets[dataId].label === datasetName;
});
if (!datasetId) return [];
var dataset = datasets[datasetId];
if (dataset) {
return Array.from({
length: dataset.length
}, function (_, i) {
return dataset.getValue(variableName, i);
});
}
return [];
}
/**
* Get the x and y values from a dataset for a scatterplot
* @param datasets
* @param datasetName
* @param xVariableName
* @param yVariableName
* @returns {x: number[], y: number[]}
*/
function getScatterplotValuesFromDataset(datasets, datasetName, xVariableName, yVariableName) {
var xValues = getValuesFromDataset(datasets, datasetName, xVariableName);
var yValues = getValuesFromDataset(datasets, datasetName, yVariableName);
return {
x: xValues,
y: yValues
};
}
/**
* Highlight the rows in a dataset
* @param datasets The kepler.gl datasets
* @param layers The kepler.gl layers
* @param datasetName The name of the dataset
* @param selectedRowIndices The indices of the rows to highlight
* @param layerSetIsValid The function to set the layer validity
*/
function highlightRows(datasets, layers, datasetName, selectedRowIndices, layerSetIsValid) {
// update the filteredIndex in the dataset
var datasetId = Object.keys(datasets).find(function (dataId) {
return datasets[dataId].label === datasetName;
});
if (!datasetId) return;
var dataset = datasets[datasetId];
if (dataset) {
dataset.filteredIndex = selectedRowIndices.length === 0 ? dataset.allIndexes : selectedRowIndices;
// get all layers that use this dataset
var selectLayers = layers.filter(function (layer) {
return layer.config.dataId === dataset.id;
});
selectLayers.forEach(function (layer) {
layer.formatLayerData(datasets);
// trigger a re-render using layerSetIsValid() to update the top layer
layerSetIsValid(layer, true);
});
}
}
/**
* Get the dataset context, which is used to provide the dataset information to the AI assistant
* @param datasets The kepler.gl datasets
* @param layers The kepler.gl layers
* @returns The dataset context
*/
function getDatasetContext(datasets, layers) {
var context = 'Please remember the following dataset context:';
var dataMeta = Object.values(datasets).map(function (dataset) {
return {
datasetName: dataset.label,
datasetId: dataset.id,
fields: dataset.fields.map(function (field) {
return (0, _defineProperty2["default"])({}, field.name, field.type);
}),
layers: layers.filter(function (layer) {
return layer.config.dataId === dataset.id;
}).map(function (layer) {
return {
id: layer.id,
label: layer.config.label,
type: layer.type,
geometryMode: layer.config.columnMode,
// get the valid geometry columns as string
geometryColumns: Object.fromEntries(Object.entries(layer.config.columns).filter(function (_ref2) {
var _ref3 = (0, _slicedToArray2["default"])(_ref2, 2),
value = _ref3[1];
return value !== null;
}).map(function (_ref4) {
var _ref5 = (0, _slicedToArray2["default"])(_ref4, 2),
key = _ref5[0],
value = _ref5[1];
return [key, (0, _typeof2["default"])(value) === 'object' && value !== null ? Object.fromEntries(Object.entries(value).filter(function (_ref6) {
var _ref7 = (0, _slicedToArray2["default"])(_ref6, 2),
v = _ref7[1];
return v !== null;
})) : value];
}))
};
})
};
});
return "".concat(context, "\n").concat(JSON.stringify(dataMeta));
}
/**
* Get the geometries from a dataset
* @param datasets The kepler.gl datasets
* @param layers The kepler.gl layers
* @param layerData The layer data
* @param datasetName The name of the dataset
* @returns The geometries
*/
function getGeometriesFromDataset(datasets, layers, layerData, datasetName) {
var datasetId = Object.keys(datasets).find(function (dataId) {
return datasets[dataId].label === datasetName;
});
if (!datasetId) return [];
var dataset = datasets[datasetId];
// get the index of the layer
var layerIndex = layers.findIndex(function (layer) {
return layer.config.dataId === dataset.id;
});
if (layerIndex === -1) return [];
var geometries = layerData[layerIndex];
return geometries === null || geometries === void 0 ? void 0 : geometries.data;
}
/**
* Save the data as a new dataset by joining it with the left dataset
* @param datasets The kepler.gl datasets
* @param datasetName The name of the left dataset
* @param data The data to save
* @param addDataToMap The function to add the data to the map
*/
function saveAsDataset(datasets, datasetName, data, addDataToMap) {
// find datasetId from datasets
var datasetId = Object.keys(datasets).find(function (dataId) {
return datasets[dataId].label === datasetName;
});
if (!datasetId) return;
var leftDataset = datasets[datasetId];
var numRows = leftDataset.length;
var fields = [].concat((0, _toConsumableArray2["default"])(Object.keys(data).map(function (fieldName, index) {
return {
name: fieldName,
id: "".concat(fieldName, "_").concat(index),
displayName: fieldName,
type: determineFieldType(data[fieldName][0])
};
})), (0, _toConsumableArray2["default"])(leftDataset.fields.map(function (field, index) {
return {
name: field.name,
id: field.id || "".concat(field.name, "_").concat(index),
displayName: field.displayName,
type: field.type
};
})));
// Pre-calculate data values array
var dataValues = Object.values(data);
var rows = Array(numRows).fill(null).map(function (_, rowIdx) {
return [].concat((0, _toConsumableArray2["default"])(dataValues.map(function (col) {
return col[rowIdx];
})), (0, _toConsumableArray2["default"])(leftDataset.fields.map(function (field) {
return leftDataset.getValue(field.name, rowIdx);
})));
});
// create new dataset
var newDatasetName = "".concat(datasetName, "_joined");
var newDataset = {
info: {
id: newDatasetName,
label: newDatasetName
},
data: {
fields: fields,
rows: rows
}
};
addDataToMap({
datasets: [newDataset],
options: {
autoCreateLayers: true,
centerMap: true
}
});
}
/**
* Helper function to determine field type
* @param value The value to determine the field type
* @returns The field type
*/
function determineFieldType(value) {
return typeof value === 'number' ? Number.isInteger(value) ? _constants.ALL_FIELD_TYPES.integer : _constants.ALL_FIELD_TYPES.real : _constants.ALL_FIELD_TYPES.string;
}
function highlightRowsByColumnValues(datasets, layers, datasetName, columnName, selectedValues, layerSetIsValid) {
var datasetId = Object.keys(datasets).find(function (dataId) {
return datasets[dataId].label === datasetName;
});
if (!datasetId) return;
var dataset = datasets[datasetId];
if (dataset) {
// get the values of the column
var values = Array.from({
length: dataset.length
}, function (_, i) {
return dataset.getValue(columnName, i);
});
// create a dict using the values
var valueDict = values.reduce(function (acc, value, index) {
acc[value] = index;
return acc;
}, {});
// need to fix the type error of value here
var selectedIndices = selectedValues.map(function (value) {
return valueDict[value];
});
// highlight the rows
highlightRows(datasets, layers, datasetName, selectedIndices, layerSetIsValid);
}
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_colorInterpolate","_interopRequireDefault","require","_constants","checkDatasetNotExists","datasets","datasetName","functionName","datasetId","Object","keys","find","dataId","label","name","result","success","details","concat","join","checkFieldNotExists","dataset","fieldName","field","fields","f","type","map","interpolateColor","originalColors","numberOfColors","length","interp","interpolate","colors","Array","from","_","j","hexColors","color","rgb","match","c","parseInt","toString","padStart","getValuesFromDataset","variableName","i","getValue","getScatterplotValuesFromDataset","xVariableName","yVariableName","xValues","yValues","x","y","highlightRows","layers","selectedRowIndices","layerSetIsValid","filteredIndex","allIndexes","selectLayers","filter","layer","config","id","forEach","formatLayerData","getDatasetContext","context","dataMeta","values","_defineProperty2","geometryMode","columnMode","geometryColumns","fromEntries","entries","columns","_ref2","_ref3","_slicedToArray2","value","_ref4","_ref5","key","_typeof2","_ref6","_ref7","v","JSON","stringify","getGeometriesFromDataset","layerData","layerIndex","findIndex","geometries","data","saveAsDataset","addDataToMap","leftDataset","numRows","_toConsumableArray2","index","displayName","determineFieldType","dataValues","rows","fill","rowIdx","col","newDatasetName","newDataset","info","options","autoCreateLayers","centerMap","Number","isInteger","ALL_FIELD_TYPES","integer","real","string","highlightRowsByColumnValues","columnName","selectedValues","valueDict","reduce","acc","selectedIndices"],"sources":["../../src/tools/utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport interpolate from 'color-interpolate';\n\nimport {Layer} from '@kepler.gl/layers';\nimport {Datasets, KeplerTable} from '@kepler.gl/table';\nimport {SpatialJoinGeometries} from '@openassistant/geoda';\nimport {ALL_FIELD_TYPES} from '@kepler.gl/constants';\nimport {AddDataToMapPayload, ProtoDataset, ProtoDatasetField} from '@kepler.gl/types';\n\n/**\n * Check if the dataset exists\n * @param datasets The kepler.gl datasets\n * @param datasetName The name of the dataset\n * @param functionName The name of the function\n * @returns The result of the check\n */\nexport function checkDatasetNotExists(\n  datasets: Datasets,\n  datasetName: string,\n  functionName: string\n) {\n  const datasetId = Object.keys(datasets).find(dataId => datasets[dataId].label === datasetName);\n  if (!datasetId) {\n    return {\n      name: functionName,\n      result: {\n        success: false,\n        details: `Dataset not found. Please specify one from the following datasets: ${Object.keys(\n          datasets\n        ).join(', ')}`\n      }\n    };\n  }\n  return null;\n}\n\n/**\n * Check if the field exists\n * @param dataset The kepler.gl dataset\n * @param fieldName The name of the field\n * @param functionName The name of the function\n * @returns The result of the check\n */\nexport function checkFieldNotExists(dataset: KeplerTable, fieldName: string, functionName: string) {\n  const field = dataset.fields.find(f => f.name === fieldName);\n  if (!field) {\n    return {\n      type: 'layer',\n      name: functionName,\n      result: {\n        success: false,\n        details: `Field not found. Please specify one from the following fields: ${dataset.fields\n          .map(f => f.name)\n          .join(', ')}`\n      }\n    };\n  }\n  return null;\n}\n\n/**\n * Interpolate the colors from the original colors with the given number of colors\n * @param originalColors The original colors\n * @param numberOfColors The number of colors\n * @returns The interpolated colors\n */\nexport function interpolateColor(originalColors: string[], numberOfColors: number) {\n  if (originalColors.length === numberOfColors) {\n    return originalColors;\n  }\n  const interp = interpolate(originalColors);\n  const colors = Array.from({length: numberOfColors}, (_, j) => interp(j / (numberOfColors - 1)));\n  // convert colors from 'rgb(255, 255, 255)' to '#ffffff'\n  const hexColors = colors.map(color => {\n    const rgb = color.match(/\\d+/g);\n    return `#${rgb?.map(c => parseInt(c).toString(16).padStart(2, '0')).join('')}`;\n  });\n  return hexColors;\n}\n\n/**\n * Get the values from a dataset for a variable\n * @param datasets\n * @param datasetName\n * @param variableName\n * @returns {number[]}\n */\nexport function getValuesFromDataset(\n  datasets: Datasets,\n  datasetName: string,\n  variableName: string\n): number[] {\n  // find which dataset has the variableName\n  const datasetId = Object.keys(datasets).find(dataId => datasets[dataId].label === datasetName);\n  if (!datasetId) return [];\n  const dataset = datasets[datasetId];\n  if (dataset) {\n    return Array.from({length: dataset.length}, (_, i) => dataset.getValue(variableName, i));\n  }\n  return [];\n}\n\n/**\n * Get the x and y values from a dataset for a scatterplot\n * @param datasets\n * @param datasetName\n * @param xVariableName\n * @param yVariableName\n * @returns {x: number[], y: number[]}\n */\nexport function getScatterplotValuesFromDataset(\n  datasets: Datasets,\n  datasetName: string,\n  xVariableName: string,\n  yVariableName: string\n): {x: number[]; y: number[]} {\n  const xValues = getValuesFromDataset(datasets, datasetName, xVariableName);\n  const yValues = getValuesFromDataset(datasets, datasetName, yVariableName);\n  return {x: xValues, y: yValues};\n}\n\n/**\n * Highlight the rows in a dataset\n * @param datasets The kepler.gl datasets\n * @param layers The kepler.gl layers\n * @param datasetName The name of the dataset\n * @param selectedRowIndices The indices of the rows to highlight\n * @param layerSetIsValid The function to set the layer validity\n */\nexport function highlightRows(\n  datasets: Datasets,\n  layers: Layer[],\n  datasetName: string,\n  selectedRowIndices: number[],\n  layerSetIsValid: (layer: Layer, isValid: boolean) => void\n) {\n  // update the filteredIndex in the dataset\n  const datasetId = Object.keys(datasets).find(dataId => datasets[dataId].label === datasetName);\n  if (!datasetId) return;\n  const dataset = datasets[datasetId];\n  if (dataset) {\n    dataset.filteredIndex =\n      selectedRowIndices.length === 0 ? dataset.allIndexes : selectedRowIndices;\n    // get all layers that use this dataset\n    const selectLayers = layers.filter(layer => layer.config.dataId === dataset.id);\n    selectLayers.forEach(layer => {\n      layer.formatLayerData(datasets);\n      // trigger a re-render using layerSetIsValid() to update the top layer\n      layerSetIsValid(layer, true);\n    });\n  }\n}\n\n/**\n * Get the dataset context, which is used to provide the dataset information to the AI assistant\n * @param datasets The kepler.gl datasets\n * @param layers The kepler.gl layers\n * @returns The dataset context\n */\nexport function getDatasetContext(datasets: Datasets, layers: Layer[]) {\n  const context = 'Please remember the following dataset context:';\n  const dataMeta = Object.values(datasets).map((dataset: KeplerTable) => ({\n    datasetName: dataset.label,\n    datasetId: dataset.id,\n    fields: dataset.fields.map(field => ({[field.name]: field.type})),\n    layers: layers\n      .filter(layer => layer.config.dataId === dataset.id)\n      .map(layer => ({\n        id: layer.id,\n        label: layer.config.label,\n        type: layer.type,\n        geometryMode: layer.config.columnMode,\n        // get the valid geometry columns as string\n        geometryColumns: Object.fromEntries(\n          Object.entries(layer.config.columns)\n            .filter(([, value]) => value !== null)\n            .map(([key, value]) => [\n              key,\n              typeof value === 'object' && value !== null\n                ? Object.fromEntries(Object.entries(value).filter(([, v]) => v !== null))\n                : value\n            ])\n        )\n      }))\n  }));\n  return `${context}\\n${JSON.stringify(dataMeta)}`;\n}\n\n/**\n * Get the geometries from a dataset\n * @param datasets The kepler.gl datasets\n * @param layers The kepler.gl layers\n * @param layerData The layer data\n * @param datasetName The name of the dataset\n * @returns The geometries\n */\nexport function getGeometriesFromDataset(\n  datasets: Datasets,\n  layers: Layer[],\n  layerData: any[],\n  datasetName: string\n): SpatialJoinGeometries {\n  const datasetId = Object.keys(datasets).find(dataId => datasets[dataId].label === datasetName);\n  if (!datasetId) return [];\n  const dataset = datasets[datasetId];\n\n  // get the index of the layer\n  const layerIndex = layers.findIndex(layer => layer.config.dataId === dataset.id);\n  if (layerIndex === -1) return [];\n\n  const geometries = layerData[layerIndex];\n\n  return geometries?.data;\n}\n\n/**\n * Save the data as a new dataset by joining it with the left dataset\n * @param datasets The kepler.gl datasets\n * @param datasetName The name of the left dataset\n * @param data The data to save\n * @param addDataToMap The function to add the data to the map\n */\nexport function saveAsDataset(\n  datasets: Datasets,\n  datasetName: string,\n  data: Record<string, number[]>,\n  addDataToMap: (data: AddDataToMapPayload) => void\n) {\n  // find datasetId from datasets\n  const datasetId = Object.keys(datasets).find(dataId => datasets[dataId].label === datasetName);\n  if (!datasetId) return;\n\n  const leftDataset = datasets[datasetId];\n  const numRows = leftDataset.length;\n\n  const fields: ProtoDatasetField[] = [\n    // New fields from data\n    ...Object.keys(data).map((fieldName, index) => ({\n      name: fieldName,\n      id: `${fieldName}_${index}`,\n      displayName: fieldName,\n      type: determineFieldType(data[fieldName][0])\n    })),\n    // Existing fields from leftDataset\n    ...leftDataset.fields.map((field, index) => ({\n      name: field.name,\n      id: field.id || `${field.name}_${index}`,\n      displayName: field.displayName,\n      type: field.type\n    }))\n  ];\n\n  // Pre-calculate data values array\n  const dataValues = Object.values(data);\n\n  const rows = Array(numRows)\n    .fill(null)\n    .map((_, rowIdx) => [\n      // New data values\n      ...dataValues.map(col => col[rowIdx]),\n      // Existing dataset values\n      ...leftDataset.fields.map(field => leftDataset.getValue(field.name, rowIdx))\n    ]);\n\n  // create new dataset\n  const newDatasetName = `${datasetName}_joined`;\n  const newDataset: ProtoDataset = {\n    info: {\n      id: newDatasetName,\n      label: newDatasetName\n    },\n    data: {\n      fields,\n      rows\n    }\n  };\n\n  addDataToMap({datasets: [newDataset], options: {autoCreateLayers: true, centerMap: true}});\n}\n\n/**\n * Helper function to determine field type\n * @param value The value to determine the field type\n * @returns The field type\n */\nfunction determineFieldType(value: unknown): keyof typeof ALL_FIELD_TYPES {\n  return typeof value === 'number'\n    ? Number.isInteger(value)\n      ? ALL_FIELD_TYPES.integer\n      : ALL_FIELD_TYPES.real\n    : ALL_FIELD_TYPES.string;\n}\n\nexport function highlightRowsByColumnValues(\n  datasets: Datasets,\n  layers: Layer[],\n  datasetName: string,\n  columnName: string,\n  selectedValues: unknown[],\n  layerSetIsValid: (layer: Layer, isValid: boolean) => void\n) {\n  const datasetId = Object.keys(datasets).find(dataId => datasets[dataId].label === datasetName);\n  if (!datasetId) return;\n  const dataset = datasets[datasetId];\n  if (dataset) {\n    // get the values of the column\n    const values = Array.from({length: dataset.length}, (_, i) => dataset.getValue(columnName, i));\n    // create a dict using the values\n    const valueDict = values.reduce((acc, value, index) => {\n      acc[value] = index;\n      return acc;\n    }, {});\n    // need to fix the type error of value here\n    const selectedIndices = selectedValues.map(value => valueDict[value as any]);\n    // highlight the rows\n    highlightRows(datasets, layers, datasetName, selectedIndices, layerSetIsValid);\n  }\n}\n"],"mappings":"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","ignoreList":[]}
;