kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
152 lines (150 loc) • 21.9 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.updateLayerColor = void 0;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
var _react = require("react");
var _utils = require("@openassistant/utils");
var _actions = require("@kepler.gl/actions");
var _zod = require("zod");
var _reactRedux = require("react-redux");
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
// This file is used to call the LAYER_VISUAL_CHANNEL_CHANGE to update the layer style
function UpdateLayerColorToolComponent(_ref) {
var layer = _ref.layer,
newConfig = _ref.newConfig,
channel = _ref.channel,
newVisConfig = _ref.newVisConfig;
var dispatch = (0, _reactRedux.useDispatch)();
(0, _react.useEffect)(function () {
dispatch((0, _actions.layerVisualChannelConfigChange)(layer, newConfig, channel, newVisConfig));
// eslint-disable-next-line react-hooks/exhaustive-deps
}, []);
return null;
}
/**
* Update the color of a layer
* NOTE: this tool should be updated to updateLayerStyle including color, size, opacity, etc.
*/
var updateLayerColor = exports.updateLayerColor = (0, _utils.tool)({
description: 'Update the color of a layer',
parameters: _zod.z.object({
layerId: _zod.z.string(),
numberOfColors: _zod.z.number(),
customColors: _zod.z.array(_zod.z.string()).describe('An array of hex color values. Please try to generate colors from user description like: van gogh starry night, water color etc.')
}),
execute: executeUpdateLayerColor,
context: {
getLayers: function getLayers() {
throw new Error('getLayers() not implemented.');
},
layerVisualChannelConfigChange: function layerVisualChannelConfigChange() {
throw new Error('layerVisualChannelConfigChange() not implemented.');
}
},
component: UpdateLayerColorToolComponent
});
function isUpdateLayerColorArgs(args) {
return (0, _typeof2["default"])(args) === 'object' && args !== null && typeof args.layerId === 'string' && typeof args.numberOfColors === 'number' && Array.isArray(args.customColors) && args.customColors.every(function (color) {
return typeof color === 'string';
});
}
function isUpdateLayerColorFunctionContext(context) {
return (0, _typeof2["default"])(context) === 'object' && context !== null && typeof context.getLayers === 'function';
}
function executeUpdateLayerColor(_x, _x2) {
return _executeUpdateLayerColor.apply(this, arguments);
}
function _executeUpdateLayerColor() {
_executeUpdateLayerColor = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(args, options) {
var layerId, numberOfColors, customColors, getLayers, layers, layer, channel, newConfig, oldColorRange, newColorRange, newVisConfig;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
_context.prev = 0;
if (isUpdateLayerColorArgs(args)) {
_context.next = 3;
break;
}
throw new Error('Invalid updateLayerColor arguments');
case 3:
if (isUpdateLayerColorFunctionContext(options.context)) {
_context.next = 5;
break;
}
throw new Error('Invalid updateLayerColor function context');
case 5:
layerId = args.layerId, numberOfColors = args.numberOfColors, customColors = args.customColors;
getLayers = options.context.getLayers; // get layer from visState by layerId
layers = getLayers();
layer = layers.find(function (l) {
return l.id === layerId;
});
if (layer) {
_context.next = 11;
break;
}
throw new Error("Layer with id ".concat(layerId, " not found"));
case 11:
if (!(numberOfColors !== customColors.length)) {
_context.next = 13;
break;
}
throw new Error("customColors array must contain exactly ".concat(numberOfColors, " colors"));
case 13:
channel = 'color';
newConfig = {
// colorScale: 'custom'
};
oldColorRange = layer.config.visConfig.colorRange;
newColorRange = _objectSpread(_objectSpread({}, oldColorRange), {}, {
colors: customColors
}, oldColorRange.colorMap ? {
colorMap: (0, _toConsumableArray2["default"])(oldColorRange.colorMap.map(function (c, i) {
return [c[0], customColors[i]];
}))
} : {});
newVisConfig = {
colorRange: newColorRange,
strokeColorRange: newColorRange
};
return _context.abrupt("return", {
llmResult: {
success: true,
details: "Color updated successfully to ".concat(customColors.join(', '), " for layer ").concat(layerId)
},
additionalData: {
layerId: layerId,
layer: layer,
newConfig: newConfig,
channel: channel,
newVisConfig: newVisConfig
}
});
case 21:
_context.prev = 21;
_context.t0 = _context["catch"](0);
return _context.abrupt("return", {
llmResult: {
success: false,
error: _context.t0 instanceof Error ? _context.t0.message : 'Unknown error',
instruction: "Try to fix the error. If the error persists, pause the execution and ask the user to try with different prompt and context."
}
});
case 24:
case "end":
return _context.stop();
}
}, _callee, null, [[0, 21]]);
}));
return _executeUpdateLayerColor.apply(this, arguments);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_utils","_actions","_zod","_reactRedux","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","UpdateLayerColorToolComponent","_ref","layer","newConfig","channel","newVisConfig","dispatch","useDispatch","useEffect","layerVisualChannelConfigChange","updateLayerColor","exports","tool","description","parameters","z","object","layerId","string","numberOfColors","number","customColors","array","describe","execute","executeUpdateLayerColor","context","getLayers","Error","component","isUpdateLayerColorArgs","args","_typeof2","Array","isArray","every","color","isUpdateLayerColorFunctionContext","_x","_x2","_executeUpdateLayerColor","_asyncToGenerator2","_regenerator","mark","_callee","options","layers","oldColorRange","newColorRange","wrap","_callee$","_context","prev","next","find","l","id","concat","config","visConfig","colorRange","colors","colorMap","_toConsumableArray2","map","c","i","strokeColorRange","abrupt","llmResult","success","details","join","additionalData","t0","error","message","instruction","stop"],"sources":["../../../src/tools/kepler-tools/layer-style-tool.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\n// This file is used to call the LAYER_VISUAL_CHANNEL_CHANGE to update the layer style\n\nimport {useEffect} from 'react';\nimport {tool} from '@openassistant/utils';\nimport {layerVisualChannelConfigChange} from '@kepler.gl/actions';\nimport {Layer, LayerBaseConfig} from '@kepler.gl/layers';\nimport {LayerVisConfig} from '@kepler.gl/types';\nimport {z} from 'zod';\nimport {useDispatch} from 'react-redux';\n\nfunction UpdateLayerColorToolComponent({layer, newConfig, channel, newVisConfig}) {\n  const dispatch = useDispatch();\n\n  useEffect(() => {\n    dispatch(layerVisualChannelConfigChange(layer, newConfig, channel, newVisConfig));\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, []);\n\n  return null;\n}\n\n/**\n * Update the color of a layer\n * NOTE: this tool should be updated to updateLayerStyle including color, size, opacity, etc.\n */\nexport const updateLayerColor = tool({\n  description: 'Update the color of a layer',\n  parameters: z.object({\n    layerId: z.string(),\n    numberOfColors: z.number(),\n    customColors: z\n      .array(z.string())\n      .describe(\n        'An array of hex color values. Please try to generate colors from user description like: van gogh starry night, water color etc.'\n      )\n  }),\n  execute: executeUpdateLayerColor,\n  context: {\n    getLayers: () => {\n      throw new Error('getLayers() not implemented.');\n    },\n    layerVisualChannelConfigChange: () => {\n      throw new Error('layerVisualChannelConfigChange() not implemented.');\n    }\n  },\n  component: UpdateLayerColorToolComponent\n});\n\ntype UpdateLayerColorArgs = {\n  layerId: string;\n  numberOfColors: number;\n  customColors: string[];\n};\n\nfunction isUpdateLayerColorArgs(args: any): args is UpdateLayerColorArgs {\n  return (\n    typeof args === 'object' &&\n    args !== null &&\n    typeof args.layerId === 'string' &&\n    typeof args.numberOfColors === 'number' &&\n    Array.isArray(args.customColors) &&\n    args.customColors.every(color => typeof color === 'string')\n  );\n}\n\ntype UpdateLayerColorFunctionContext = {\n  getLayers: () => Layer[];\n};\n\nfunction isUpdateLayerColorFunctionContext(\n  context: any\n): context is UpdateLayerColorFunctionContext {\n  return typeof context === 'object' && context !== null && typeof context.getLayers === 'function';\n}\n\ntype ExecuteUpdateLayerColorResult = {\n  llmResult: {\n    success: boolean;\n    details?: string;\n    error?: string;\n    instruction?: string;\n  };\n  additionalData?: {\n    layerId: string;\n    layer: Layer;\n    newConfig: Partial<LayerBaseConfig>;\n    channel: string;\n    newVisConfig: Partial<LayerVisConfig>;\n  };\n};\n\nasync function executeUpdateLayerColor(args, options): Promise<ExecuteUpdateLayerColorResult> {\n  try {\n    if (!isUpdateLayerColorArgs(args)) {\n      throw new Error('Invalid updateLayerColor arguments');\n    }\n    if (!isUpdateLayerColorFunctionContext(options.context)) {\n      throw new Error('Invalid updateLayerColor function context');\n    }\n\n    const {layerId, numberOfColors, customColors} = args;\n    const {getLayers} = options.context;\n\n    // get layer from visState by layerId\n    const layers = getLayers();\n    const layer = layers.find(l => l.id === layerId);\n    if (!layer) {\n      throw new Error(`Layer with id ${layerId} not found`);\n    }\n\n    // verify numberOfColors is equal to customColors.length\n    if (numberOfColors !== customColors.length) {\n      throw new Error(`customColors array must contain exactly ${numberOfColors} colors`);\n    }\n\n    const channel = 'color';\n\n    const newConfig = {\n      // colorScale: 'custom'\n    } as Partial<LayerBaseConfig>;\n\n    const oldColorRange = layer.config.visConfig.colorRange;\n    const newColorRange = {\n      ...oldColorRange,\n      colors: customColors,\n      ...(oldColorRange.colorMap\n        ? {\n            colorMap: [...oldColorRange.colorMap.map((c, i) => [c[0], customColors[i]])]\n          }\n        : {})\n    };\n\n    const newVisConfig = {\n      colorRange: newColorRange,\n      strokeColorRange: newColorRange\n    };\n\n    return {\n      llmResult: {\n        success: true,\n        details: `Color updated successfully to ${customColors.join(', ')} for layer ${layerId}`\n      },\n      additionalData: {\n        layerId,\n        layer,\n        newConfig,\n        channel,\n        newVisConfig\n      }\n    };\n  } catch (error) {\n    return {\n      llmResult: {\n        success: false,\n        error: error instanceof Error ? error.message : 'Unknown error',\n        instruction: `Try to fix the error. If the error persists, pause the execution and ask the user to try with different prompt and context.`\n      }\n    };\n  }\n}\n"],"mappings":"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","ignoreList":[]}
;