UNPKG

kepler.gl

Version:

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

107 lines (102 loc) 13.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.updateLayerColorFunctionDefinition = updateLayerColorFunctionDefinition; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); 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 updateLayerColorFunctionDefinition(context) { return { name: 'updateLayerColor', description: 'Update the color of a layer, e.g. fill color, stroke color.', properties: { layerId: { type: 'string', description: 'The id of the layer to update. This value should be returned from previous function calling tool. Otherwise, use the latest layerId.' }, numberOfColors: { type: 'number', description: 'The number of colors to update. The value should be returned from previous function calling tool. Otherwise, use the number of colors in the latest layer.' }, customColors: { type: 'array', items: { type: 'string' }, description: 'An array of hex color values. Please try to generate colors from user description like: van gogh starry night, water color etc.' } }, required: ['layerId', 'numberOfColors', 'customColors'], callbackFunction: updateLayerColorCallback, callbackFunctionContext: context }; } function updateLayerColorCallback(_ref) { var functionName = _ref.functionName, functionArgs = _ref.functionArgs, functionContext = _ref.functionContext; var _ref2 = functionArgs, layerId = _ref2.layerId, numberOfColors = _ref2.numberOfColors, customColors = _ref2.customColors; var _ref3 = functionContext, layers = _ref3.layers, layerVisualChannelConfigChange = _ref3.layerVisualChannelConfigChange; // get layer from visState by layerId var layer = layers.find(function (l) { return l.id === layerId; }); if (!layer) { return { type: 'layer', name: functionName, result: { success: false, details: "Layer with id ".concat(layerId, " not found") } }; } // verify numberOfColors is equal to customColors.length if (numberOfColors !== customColors.length) { return { type: 'layer', name: functionName, result: { success: false, details: "customColors array must contain exactly ".concat(numberOfColors, " colors") } }; } var channel = 'color'; var newConfig = { // colorScale: 'custom' }; var oldColorRange = layer.config.visConfig.colorRange; var newColorRange = _objectSpread(_objectSpread({}, oldColorRange), {}, { colors: customColors }, oldColorRange.colorMap ? { colorMap: (0, _toConsumableArray2["default"])(oldColorRange.colorMap.map(function (c, i) { return [c[0], customColors[i]]; })) } : {}); var newVisConfig = { colorRange: newColorRange, strokeColorRange: newColorRange }; layerVisualChannelConfigChange(layer, newConfig, channel, newVisConfig); return { type: 'updateLayer', name: functionName, result: { success: true, details: "Color updated successfully to ".concat(customColors.join(', '), " for layer ").concat(layerId) } }; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["updateLayerColorFunctionDefinition","context","name","description","properties","layerId","type","numberOfColors","customColors","items","required","callbackFunction","updateLayerColorCallback","callbackFunctionContext","_ref","functionName","functionArgs","functionContext","_ref2","_ref3","layers","layerVisualChannelConfigChange","layer","find","l","id","result","success","details","concat","length","channel","newConfig","oldColorRange","config","visConfig","colorRange","newColorRange","_objectSpread","colors","colorMap","_toConsumableArray2","map","c","i","newVisConfig","strokeColorRange","join"],"sources":["../../src/tools/layer-style-function.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 {\n  CallbackFunctionProps,\n  CustomFunctionContext,\n  CustomFunctionOutputProps,\n  ErrorCallbackResult\n} from '@openassistant/core';\nimport {ActionHandler, layerVisualChannelConfigChange} from '@kepler.gl/actions';\nimport {Layer, LayerBaseConfig} from '@kepler.gl/layers';\n\nexport function updateLayerColorFunctionDefinition(\n  context: CustomFunctionContext<ActionHandler<typeof layerVisualChannelConfigChange> | Layer[]>\n) {\n  return {\n    name: 'updateLayerColor',\n    description: 'Update the color of a layer, e.g. fill color, stroke color.',\n    properties: {\n      layerId: {\n        type: 'string',\n        description:\n          'The id of the layer to update. This value should be returned from previous function calling tool. Otherwise, use the latest layerId.'\n      },\n      numberOfColors: {\n        type: 'number',\n        description:\n          'The number of colors to update. The value should be returned from previous function calling tool. Otherwise, use the number of colors in the latest layer.'\n      },\n      customColors: {\n        type: 'array',\n        items: {\n          type: 'string'\n        },\n        description:\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    required: ['layerId', 'numberOfColors', 'customColors'],\n    callbackFunction: updateLayerColorCallback,\n    callbackFunctionContext: context\n  };\n}\n\ntype UpdateLayerColorArgs = {\n  layerId: string;\n  numberOfColors: number;\n  customColors: string[];\n};\n\ntype UpdateLayerColorFunctionContext = {\n  layers: Layer[];\n  layerVisualChannelConfigChange: ActionHandler<typeof layerVisualChannelConfigChange>;\n};\n\ntype OutputDataProps = {\n  layerId: string;\n};\n\ntype SuccessCallbackResult = {\n  success: true;\n  details: string;\n};\n\ntype UpdateLayerColorCallbackOutput = CustomFunctionOutputProps<\n  ErrorCallbackResult | SuccessCallbackResult,\n  OutputDataProps\n>;\n\nfunction updateLayerColorCallback({\n  functionName,\n  functionArgs,\n  functionContext\n}: CallbackFunctionProps): UpdateLayerColorCallbackOutput {\n  const {layerId, numberOfColors, customColors} = functionArgs as UpdateLayerColorArgs;\n  const {layers, layerVisualChannelConfigChange} =\n    functionContext as UpdateLayerColorFunctionContext;\n\n  // get layer from visState by layerId\n  const layer = layers.find(l => l.id === layerId);\n  if (!layer) {\n    return {\n      type: 'layer',\n      name: functionName,\n      result: {\n        success: false,\n        details: `Layer with id ${layerId} not found`\n      }\n    };\n  }\n\n  // verify numberOfColors is equal to customColors.length\n  if (numberOfColors !== customColors.length) {\n    return {\n      type: 'layer',\n      name: functionName,\n      result: {\n        success: false,\n        details: `customColors array must contain exactly ${numberOfColors} colors`\n      }\n    };\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  layerVisualChannelConfigChange(layer, newConfig, channel, newVisConfig);\n\n  return {\n    type: 'updateLayer',\n    name: functionName,\n    result: {\n      success: true,\n      details: `Color updated successfully to ${customColors.join(', ')} for layer ${layerId}`\n    }\n  };\n}\n"],"mappings":";;;;;;;;;;;AAAA;AACA;;AAEA;;AAWO,SAASA,kCAAkCA,CAChDC,OAA8F,EAC9F;EACA,OAAO;IACLC,IAAI,EAAE,kBAAkB;IACxBC,WAAW,EAAE,6DAA6D;IAC1EC,UAAU,EAAE;MACVC,OAAO,EAAE;QACPC,IAAI,EAAE,QAAQ;QACdH,WAAW,EACT;MACJ,CAAC;MACDI,cAAc,EAAE;QACdD,IAAI,EAAE,QAAQ;QACdH,WAAW,EACT;MACJ,CAAC;MACDK,YAAY,EAAE;QACZF,IAAI,EAAE,OAAO;QACbG,KAAK,EAAE;UACLH,IAAI,EAAE;QACR,CAAC;QACDH,WAAW,EACT;MACJ;IACF,CAAC;IACDO,QAAQ,EAAE,CAAC,SAAS,EAAE,gBAAgB,EAAE,cAAc,CAAC;IACvDC,gBAAgB,EAAEC,wBAAwB;IAC1CC,uBAAuB,EAAEZ;EAC3B,CAAC;AACH;AA2BA,SAASW,wBAAwBA,CAAAE,IAAA,EAIyB;EAAA,IAHxDC,YAAY,GAAAD,IAAA,CAAZC,YAAY;IACZC,YAAY,GAAAF,IAAA,CAAZE,YAAY;IACZC,eAAe,GAAAH,IAAA,CAAfG,eAAe;EAEf,IAAAC,KAAA,GAAgDF,YAAY;IAArDX,OAAO,GAAAa,KAAA,CAAPb,OAAO;IAAEE,cAAc,GAAAW,KAAA,CAAdX,cAAc;IAAEC,YAAY,GAAAU,KAAA,CAAZV,YAAY;EAC5C,IAAAW,KAAA,GACEF,eAAe;IADVG,MAAM,GAAAD,KAAA,CAANC,MAAM;IAAEC,8BAA8B,GAAAF,KAAA,CAA9BE,8BAA8B;;EAG7C;EACA,IAAMC,KAAK,GAAGF,MAAM,CAACG,IAAI,CAAC,UAAAC,CAAC;IAAA,OAAIA,CAAC,CAACC,EAAE,KAAKpB,OAAO;EAAA,EAAC;EAChD,IAAI,CAACiB,KAAK,EAAE;IACV,OAAO;MACLhB,IAAI,EAAE,OAAO;MACbJ,IAAI,EAAEa,YAAY;MAClBW,MAAM,EAAE;QACNC,OAAO,EAAE,KAAK;QACdC,OAAO,mBAAAC,MAAA,CAAmBxB,OAAO;MACnC;IACF,CAAC;EACH;;EAEA;EACA,IAAIE,cAAc,KAAKC,YAAY,CAACsB,MAAM,EAAE;IAC1C,OAAO;MACLxB,IAAI,EAAE,OAAO;MACbJ,IAAI,EAAEa,YAAY;MAClBW,MAAM,EAAE;QACNC,OAAO,EAAE,KAAK;QACdC,OAAO,6CAAAC,MAAA,CAA6CtB,cAAc;MACpE;IACF,CAAC;EACH;EAEA,IAAMwB,OAAO,GAAG,OAAO;EAEvB,IAAMC,SAAS,GAAG;IAChB;EAAA,CAC2B;EAE7B,IAAMC,aAAa,GAAGX,KAAK,CAACY,MAAM,CAACC,SAAS,CAACC,UAAU;EACvD,IAAMC,aAAa,GAAAC,aAAA,CAAAA,aAAA,KACdL,aAAa;IAChBM,MAAM,EAAE/B;EAAY,GAChByB,aAAa,CAACO,QAAQ,GACtB;IACEA,QAAQ,MAAAC,mBAAA,aAAMR,aAAa,CAACO,QAAQ,CAACE,GAAG,CAAC,UAACC,CAAC,EAAEC,CAAC;MAAA,OAAK,CAACD,CAAC,CAAC,CAAC,CAAC,EAAEnC,YAAY,CAACoC,CAAC,CAAC,CAAC;IAAA,EAAC;EAC7E,CAAC,GACD,CAAC,CAAC,CACP;EAED,IAAMC,YAAY,GAAG;IACnBT,UAAU,EAAEC,aAAa;IACzBS,gBAAgB,EAAET;EACpB,CAAC;EAEDhB,8BAA8B,CAACC,KAAK,EAAEU,SAAS,EAAED,OAAO,EAAEc,YAAY,CAAC;EAEvE,OAAO;IACLvC,IAAI,EAAE,aAAa;IACnBJ,IAAI,EAAEa,YAAY;IAClBW,MAAM,EAAE;MACNC,OAAO,EAAE,IAAI;MACbC,OAAO,mCAAAC,MAAA,CAAmCrB,YAAY,CAACuC,IAAI,CAAC,IAAI,CAAC,iBAAAlB,MAAA,CAAcxB,OAAO;IACxF;EACF,CAAC;AACH","ignoreList":[]}