@trops/dash-core 0.1.319 → 0.1.321

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.esm.js CHANGED
@@ -8583,7 +8583,7 @@ hasPropertyDescriptors.hasArrayLengthDefineBug = function hasArrayLengthDefineBu
8583
8583
  var hasPropertyDescriptors_1 = hasPropertyDescriptors;
8584
8584
 
8585
8585
  var keys = objectKeys$2;
8586
- var hasSymbols$5 = typeof Symbol === 'function' && typeof Symbol('foo') === 'symbol';
8586
+ var hasSymbols$4 = typeof Symbol === 'function' && typeof Symbol('foo') === 'symbol';
8587
8587
 
8588
8588
  var toStr$4 = Object.prototype.toString;
8589
8589
  var concat = Array.prototype.concat;
@@ -8616,7 +8616,7 @@ var defineProperty$1 = function (object, name, value, predicate) {
8616
8616
  var defineProperties$1 = function (object, map) {
8617
8617
  var predicates = arguments.length > 2 ? arguments[2] : {};
8618
8618
  var props = keys(map);
8619
- if (hasSymbols$5) {
8619
+ if (hasSymbols$4) {
8620
8620
  props = concat.call(props, Object.getOwnPropertySymbols(map));
8621
8621
  }
8622
8622
  for (var i = 0; i < props.length; i += 1) {
@@ -8682,11 +8682,11 @@ var sign$1 = function sign(number) {
8682
8682
  };
8683
8683
 
8684
8684
  var shams$1;
8685
- var hasRequiredShams;
8685
+ var hasRequiredShams$1;
8686
8686
 
8687
- function requireShams () {
8688
- if (hasRequiredShams) return shams$1;
8689
- hasRequiredShams = 1;
8687
+ function requireShams$1 () {
8688
+ if (hasRequiredShams$1) return shams$1;
8689
+ hasRequiredShams$1 = 1;
8690
8690
 
8691
8691
  /** @type {import('./shams')} */
8692
8692
  /* eslint complexity: [2, 18], max-statements: [2, 33] */
@@ -8735,10 +8735,10 @@ function requireShams () {
8735
8735
  }
8736
8736
 
8737
8737
  var origSymbol = typeof Symbol !== 'undefined' && Symbol;
8738
- var hasSymbolSham = requireShams();
8738
+ var hasSymbolSham = requireShams$1();
8739
8739
 
8740
8740
  /** @type {import('.')} */
8741
- var hasSymbols$4 = function hasNativeSymbols() {
8741
+ var hasSymbols$3 = function hasNativeSymbols() {
8742
8742
  if (typeof origSymbol !== 'function') { return false; }
8743
8743
  if (typeof Symbol !== 'function') { return false; }
8744
8744
  if (typeof origSymbol('foo') !== 'symbol') { return false; }
@@ -9042,7 +9042,7 @@ var ThrowTypeError = $gOPD$1
9042
9042
  }())
9043
9043
  : throwTypeError;
9044
9044
 
9045
- var hasSymbols$3 = hasSymbols$4();
9045
+ var hasSymbols$2 = hasSymbols$3();
9046
9046
 
9047
9047
  var getProto$2 = getProto$3;
9048
9048
  var $ObjectGPO = requireObject_getPrototypeOf();
@@ -9060,7 +9060,7 @@ var INTRINSICS = {
9060
9060
  '%AggregateError%': typeof AggregateError === 'undefined' ? undefined$1 : AggregateError,
9061
9061
  '%Array%': Array,
9062
9062
  '%ArrayBuffer%': typeof ArrayBuffer === 'undefined' ? undefined$1 : ArrayBuffer,
9063
- '%ArrayIteratorPrototype%': hasSymbols$3 && getProto$2 ? getProto$2([][Symbol.iterator]()) : undefined$1,
9063
+ '%ArrayIteratorPrototype%': hasSymbols$2 && getProto$2 ? getProto$2([][Symbol.iterator]()) : undefined$1,
9064
9064
  '%AsyncFromSyncIteratorPrototype%': undefined$1,
9065
9065
  '%AsyncFunction%': needsEval,
9066
9066
  '%AsyncGenerator%': needsEval,
@@ -9091,10 +9091,10 @@ var INTRINSICS = {
9091
9091
  '%Int32Array%': typeof Int32Array === 'undefined' ? undefined$1 : Int32Array,
9092
9092
  '%isFinite%': isFinite,
9093
9093
  '%isNaN%': isNaN,
9094
- '%IteratorPrototype%': hasSymbols$3 && getProto$2 ? getProto$2(getProto$2([][Symbol.iterator]())) : undefined$1,
9094
+ '%IteratorPrototype%': hasSymbols$2 && getProto$2 ? getProto$2(getProto$2([][Symbol.iterator]())) : undefined$1,
9095
9095
  '%JSON%': typeof JSON === 'object' ? JSON : undefined$1,
9096
9096
  '%Map%': typeof Map === 'undefined' ? undefined$1 : Map,
9097
- '%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols$3 || !getProto$2 ? undefined$1 : getProto$2(new Map()[Symbol.iterator]()),
9097
+ '%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols$2 || !getProto$2 ? undefined$1 : getProto$2(new Map()[Symbol.iterator]()),
9098
9098
  '%Math%': Math,
9099
9099
  '%Number%': Number,
9100
9100
  '%Object%': $Object$2,
@@ -9108,11 +9108,11 @@ var INTRINSICS = {
9108
9108
  '%Reflect%': typeof Reflect === 'undefined' ? undefined$1 : Reflect,
9109
9109
  '%RegExp%': RegExp,
9110
9110
  '%Set%': typeof Set === 'undefined' ? undefined$1 : Set,
9111
- '%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols$3 || !getProto$2 ? undefined$1 : getProto$2(new Set()[Symbol.iterator]()),
9111
+ '%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols$2 || !getProto$2 ? undefined$1 : getProto$2(new Set()[Symbol.iterator]()),
9112
9112
  '%SharedArrayBuffer%': typeof SharedArrayBuffer === 'undefined' ? undefined$1 : SharedArrayBuffer,
9113
9113
  '%String%': String,
9114
- '%StringIteratorPrototype%': hasSymbols$3 && getProto$2 ? getProto$2(''[Symbol.iterator]()) : undefined$1,
9115
- '%Symbol%': hasSymbols$3 ? Symbol : undefined$1,
9114
+ '%StringIteratorPrototype%': hasSymbols$2 && getProto$2 ? getProto$2(''[Symbol.iterator]()) : undefined$1,
9115
+ '%Symbol%': hasSymbols$2 ? Symbol : undefined$1,
9116
9116
  '%SyntaxError%': $SyntaxError$1,
9117
9117
  '%ThrowTypeError%': ThrowTypeError,
9118
9118
  '%TypedArray%': TypedArray,
@@ -9465,12 +9465,12 @@ var callBound$i = function callBoundIntrinsic(name, allowMissing) {
9465
9465
 
9466
9466
  // modified from https://github.com/es-shims/es6-shim
9467
9467
  var objectKeys$1 = objectKeys$2;
9468
- var hasSymbols$2 = requireShams()();
9468
+ var hasSymbols$1 = requireShams$1()();
9469
9469
  var callBound$h = callBound$i;
9470
9470
  var $Object$1 = esObjectAtoms;
9471
9471
  var $push = callBound$h('Array.prototype.push');
9472
9472
  var $propIsEnumerable = callBound$h('Object.prototype.propertyIsEnumerable');
9473
- var originalGetSymbols = hasSymbols$2 ? $Object$1.getOwnPropertySymbols : null;
9473
+ var originalGetSymbols = hasSymbols$1 ? $Object$1.getOwnPropertySymbols : null;
9474
9474
 
9475
9475
  // eslint-disable-next-line no-unused-vars
9476
9476
  var implementation$8 = function assign(target, source1) {
@@ -9484,7 +9484,7 @@ var implementation$8 = function assign(target, source1) {
9484
9484
 
9485
9485
  // step 3.a.ii:
9486
9486
  var keys = objectKeys$1(from);
9487
- var getSymbols = hasSymbols$2 && ($Object$1.getOwnPropertySymbols || originalGetSymbols);
9487
+ var getSymbols = hasSymbols$1 && ($Object$1.getOwnPropertySymbols || originalGetSymbols);
9488
9488
  if (getSymbols) {
9489
9489
  var syms = getSymbols(from);
9490
9490
  for (var j = 0; j < syms.length; ++j) {
@@ -9781,14 +9781,23 @@ var regexp_prototype_flags = flagsBound;
9781
9781
 
9782
9782
  var esGetIterator = {exports: {}};
9783
9783
 
9784
- var hasSymbols$1 = requireShams();
9784
+ var shams;
9785
+ var hasRequiredShams;
9785
9786
 
9786
- /** @type {import('.')} */
9787
- var shams = function hasToStringTagShams() {
9788
- return hasSymbols$1() && !!Symbol.toStringTag;
9789
- };
9787
+ function requireShams () {
9788
+ if (hasRequiredShams) return shams;
9789
+ hasRequiredShams = 1;
9790
9790
 
9791
- var hasToStringTag$7 = shams();
9791
+ var hasSymbols = requireShams$1();
9792
+
9793
+ /** @type {import('.')} */
9794
+ shams = function hasToStringTagShams() {
9795
+ return hasSymbols() && !!Symbol.toStringTag;
9796
+ };
9797
+ return shams;
9798
+ }
9799
+
9800
+ var hasToStringTag$7 = requireShams()();
9792
9801
  var callBound$f = callBound$i;
9793
9802
 
9794
9803
  var $toString$7 = callBound$f('Object.prototype.toString');
@@ -10825,7 +10834,7 @@ var tryStringObject = function tryStringObject(value) {
10825
10834
  /** @type {(receiver: ThisParameterType<typeof Object.prototype.toString>, ...args: Parameters<typeof Object.prototype.toString>) => ReturnType<typeof Object.prototype.toString>} */
10826
10835
  var $toString$6 = callBound$c('Object.prototype.toString');
10827
10836
  var strClass = '[object String]';
10828
- var hasToStringTag$6 = shams();
10837
+ var hasToStringTag$6 = requireShams()();
10829
10838
 
10830
10839
  /** @type {import('.')} */
10831
10840
  var isString$2 = function isString(value) {
@@ -10941,7 +10950,7 @@ var isSet$2 = exported$1 || function isSet(x) {
10941
10950
  var isArguments$1 = isArguments$2;
10942
10951
  var getStopIterationIterator = stopIterationIterator;
10943
10952
 
10944
- if (hasSymbols$4() || requireShams()()) {
10953
+ if (hasSymbols$3() || requireShams$1()()) {
10945
10954
  var $iterator = Symbol.iterator;
10946
10955
  // Symbol is available natively or shammed
10947
10956
  // natively:
@@ -11230,7 +11239,7 @@ var tryDateObject = function tryDateGetDayCall(value) {
11230
11239
  /** @type {(value: unknown) => string} */
11231
11240
  var toStr$2 = callBound$9('Object.prototype.toString');
11232
11241
  var dateClass = '[object Date]';
11233
- var hasToStringTag$5 = shams();
11242
+ var hasToStringTag$5 = requireShams()();
11234
11243
 
11235
11244
  /** @type {import('.')} */
11236
11245
  var isDateObject = function isDateObject(value) {
@@ -11241,7 +11250,7 @@ var isDateObject = function isDateObject(value) {
11241
11250
  };
11242
11251
 
11243
11252
  var callBound$8 = callBound$i;
11244
- var hasToStringTag$4 = shams();
11253
+ var hasToStringTag$4 = requireShams()();
11245
11254
  var hasOwn = hasown;
11246
11255
  var gOPD$1 = gopd$1;
11247
11256
 
@@ -11346,7 +11355,7 @@ var tryNumberObject = function tryNumberObject(value) {
11346
11355
  };
11347
11356
  var $toString$3 = callBound$6('Object.prototype.toString');
11348
11357
  var numClass = '[object Number]';
11349
- var hasToStringTag$3 = shams();
11358
+ var hasToStringTag$3 = requireShams()();
11350
11359
 
11351
11360
  /** @type {import('.')} */
11352
11361
  var isNumberObject = function isNumberObject(value) {
@@ -11373,7 +11382,7 @@ var tryBooleanObject = function booleanBrandCheck(value) {
11373
11382
  }
11374
11383
  };
11375
11384
  var boolClass = '[object Boolean]';
11376
- var hasToStringTag$2 = shams();
11385
+ var hasToStringTag$2 = requireShams()();
11377
11386
 
11378
11387
  /** @type {import('.')} */
11379
11388
  var isBooleanObject = function isBoolean(value) {
@@ -11415,7 +11424,7 @@ function requireSafeRegexTest () {
11415
11424
 
11416
11425
  var callBound$4 = callBound$i;
11417
11426
  var $toString$1 = callBound$4('Object.prototype.toString');
11418
- var hasSymbols = hasSymbols$4();
11427
+ var hasSymbols = hasSymbols$3();
11419
11428
  var safeRegexTest = requireSafeRegexTest();
11420
11429
 
11421
11430
  if (hasSymbols) {
@@ -11861,7 +11870,7 @@ var gOPD = gopd$1;
11861
11870
  var getProto = getProto$3;
11862
11871
 
11863
11872
  var $toString = callBound$2('Object.prototype.toString');
11864
- var hasToStringTag = shams();
11873
+ var hasToStringTag = requireShams()();
11865
11874
 
11866
11875
  var g = typeof globalThis === 'undefined' ? commonjsGlobal : globalThis;
11867
11876
  var typedArrays = availableTypedArrays();
@@ -20418,6 +20427,58 @@ var LayoutBuilder = function LayoutBuilder(_ref) {
20418
20427
  // eslint-disable-next-line react-hooks/exhaustive-deps
20419
20428
  }, [currentWorkspace]);
20420
20429
 
20430
+ // Ref for current workspace state (avoids stale closure in event listener)
20431
+ var wsRef = useRef(currentWorkspace);
20432
+ useEffect(function () {
20433
+ wsRef.current = currentWorkspace;
20434
+ }, [currentWorkspace]);
20435
+
20436
+ // Listen for AI widget builder placement — modifies layout state directly
20437
+ useEffect(function () {
20438
+ var handler = function handler(e) {
20439
+ var _ref4 = e.detail || {},
20440
+ widgetComponentName = _ref4.widgetComponentName,
20441
+ cellNumber = _ref4.cellNumber,
20442
+ gridItemId = _ref4.gridItemId;
20443
+ if (!widgetComponentName || !cellNumber || !gridItemId) return;
20444
+ var ws = wsRef.current;
20445
+ if (!(ws !== null && ws !== void 0 && ws.layout)) return;
20446
+ var gridItem = ws.layout.find(function (item) {
20447
+ return item.id === gridItemId;
20448
+ });
20449
+ if (!(gridItem !== null && gridItem !== void 0 && gridItem.grid)) return;
20450
+ var config = ComponentManager.config(widgetComponentName);
20451
+ if (!config) {
20452
+ return;
20453
+ }
20454
+ try {
20455
+ var hasChildren = config.type === "workspace";
20456
+ var newLayout = addItemToItemLayout(ws.layout, gridItem.id, _objectSpread$z(_objectSpread$z({}, config), {}, {
20457
+ component: widgetComponentName
20458
+ }), hasChildren);
20459
+ var newWidgetId = newLayout[newLayout.length - 1].id;
20460
+ var updatedGrid = newLayout.find(function (item) {
20461
+ return item.id === gridItem.id;
20462
+ });
20463
+ if (updatedGrid !== null && updatedGrid !== void 0 && updatedGrid.grid) {
20464
+ updatedGrid.grid[cellNumber] = {
20465
+ component: newWidgetId,
20466
+ hide: false
20467
+ };
20468
+ }
20469
+ var newWorkspace = JSON.parse(JSON.stringify(ws));
20470
+ newWorkspace.layout = newLayout;
20471
+ setCurrentWorkspace(newWorkspace);
20472
+ } catch (err) {
20473
+ }
20474
+ };
20475
+ window.addEventListener("dash:place-widget-in-cell", handler);
20476
+ return function () {
20477
+ return window.removeEventListener("dash:place-widget-in-cell", handler);
20478
+ };
20479
+ // eslint-disable-next-line react-hooks/exhaustive-deps
20480
+ }, []);
20481
+
20421
20482
  /**
20422
20483
  * onClickAdd
20423
20484
  * From the Widget or Container, clicked plus button to add a widget
@@ -20829,11 +20890,11 @@ var LayoutBuilder = function LayoutBuilder(_ref) {
20829
20890
 
20830
20891
  // Grid Operation Handlers
20831
20892
 
20832
- function handleSplitCell(_ref4) {
20833
- var cellNumber = _ref4.cellNumber,
20834
- direction = _ref4.direction,
20835
- count = _ref4.count,
20836
- gridContainer = _ref4.gridContainer;
20893
+ function handleSplitCell(_ref5) {
20894
+ var cellNumber = _ref5.cellNumber,
20895
+ direction = _ref5.direction,
20896
+ count = _ref5.count,
20897
+ gridContainer = _ref5.gridContainer;
20837
20898
  try {
20838
20899
  var dashboard = new DashboardModel(currentWorkspace);
20839
20900
  var result = dashboard.splitGridCell(gridContainer.id, cellNumber, direction, count);
@@ -20845,10 +20906,10 @@ var LayoutBuilder = function LayoutBuilder(_ref) {
20845
20906
  } catch (e) {
20846
20907
  }
20847
20908
  }
20848
- function handleMergeCells(_ref5) {
20849
- var cellNumbers = _ref5.cellNumbers,
20850
- gridContainer = _ref5.gridContainer,
20851
- keepComponent = _ref5.keepComponent;
20909
+ function handleMergeCells(_ref6) {
20910
+ var cellNumbers = _ref6.cellNumbers,
20911
+ gridContainer = _ref6.gridContainer,
20912
+ keepComponent = _ref6.keepComponent;
20852
20913
  try {
20853
20914
  var dashboard = new DashboardModel(currentWorkspace);
20854
20915
  var result = dashboard.mergeGridCells(gridContainer.id, cellNumbers);
@@ -25101,7 +25162,13 @@ var LayoutGridContainer = /*#__PURE__*/memo(function (_ref3) {
25101
25162
  })]
25102
25163
  }), /*#__PURE__*/jsxs("button", {
25103
25164
  onClick: function onClick() {
25104
- return window.dispatchEvent(new Event("dash:open-widget-builder"));
25165
+ return window.dispatchEvent(new CustomEvent("dash:open-widget-builder", {
25166
+ detail: {
25167
+ cellNumber: cellNumber,
25168
+ gridItemId: item.id,
25169
+ workspaceId: workspace === null || workspace === void 0 ? void 0 : workspace.id
25170
+ }
25171
+ }));
25105
25172
  },
25106
25173
  className: "flex items-center gap-1.5 px-3 py-1 rounded-md text-xs text-indigo-400/70 hover:text-indigo-300 hover:bg-indigo-900/20 transition-colors",
25107
25174
  children: [/*#__PURE__*/jsx(FontAwesomeIcon, {
@@ -54185,7 +54252,9 @@ function ChatCore(_ref) {
54185
54252
  _ref$onPublishEvent = _ref.onPublishEvent,
54186
54253
  onPublishEvent = _ref$onPublishEvent === void 0 ? null : _ref$onPublishEvent,
54187
54254
  _ref$hideToolsBanner = _ref.hideToolsBanner,
54188
- hideToolsBanner = _ref$hideToolsBanner === void 0 ? false : _ref$hideToolsBanner;
54255
+ hideToolsBanner = _ref$hideToolsBanner === void 0 ? false : _ref$hideToolsBanner,
54256
+ _ref$cwd = _ref.cwd,
54257
+ cwd = _ref$cwd === void 0 ? null : _ref$cwd;
54189
54258
  var mainApi = window.mainApi;
54190
54259
 
54191
54260
  // Conversation state
@@ -54494,7 +54563,8 @@ function ChatCore(_ref) {
54494
54563
  toolServerMap: toolServerMap,
54495
54564
  systemPrompt: systemPrompt,
54496
54565
  maxToolRounds: parseInt(maxToolRounds, 10) || 10,
54497
- widgetUuid: uuid || persistKey
54566
+ widgetUuid: uuid || persistKey,
54567
+ cwd: cwd || undefined
54498
54568
  });
54499
54569
  }, [mainApi, isLoading, messages, servers, enabledTools, apiKey, model, systemPrompt, maxToolRounds, uuid, persistKey, onPublishEvent, backend, isAnthropicBackend]);
54500
54570