@superinterface/react 5.4.3 → 5.4.4

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.cjs CHANGED
@@ -43292,94 +43292,160 @@ function _temp2(content2, index4) {
43292
43292
  content: content2
43293
43293
  }, index4);
43294
43294
  }
43295
- // src/components/threads/Thread/Message/lib/splitRunSteps.ts
43296
- var splitRunSteps = function(_ref) {
43297
- var messageId = _ref.messageId, runSteps = _ref.runSteps;
43298
- if (!runSteps.length) return [
43299
- [],
43300
- []
43301
- ];
43302
- var messageCreationRunStepIndex = runSteps.findIndex(function(runStep) {
43303
- if (runStep.step_details.type !== "message_creation") return;
43304
- return runStep.step_details.message_creation.message_id === messageId;
43305
- });
43306
- if (messageCreationRunStepIndex === -1) {
43307
- return [
43308
- [],
43309
- runSteps
43310
- ];
43311
- }
43312
- var prevMcIndex = runSteps.slice(0, messageCreationRunStepIndex).findLastIndex(function(runStep) {
43313
- return runStep.step_details.type === "message_creation";
43314
- });
43315
- var laterRunSteps = prevMcIndex === -1 ? runSteps.slice(0, messageCreationRunStepIndex) : [];
43316
- var prevRunStepIndex = runSteps.slice(messageCreationRunStepIndex + 1).findIndex(function(runStep) {
43317
- return runStep.step_details.type === "message_creation";
43318
- });
43319
- var olderRunSteps;
43320
- if (prevRunStepIndex === -1) {
43321
- olderRunSteps = runSteps.slice(messageCreationRunStepIndex + 1);
43322
- } else {
43323
- olderRunSteps = runSteps.slice(messageCreationRunStepIndex + 1, messageCreationRunStepIndex + 1 + prevRunStepIndex);
43324
- }
43325
- return [
43326
- olderRunSteps,
43327
- laterRunSteps
43328
- ];
43329
- };
43330
43295
  // src/components/threads/Thread/Message/index.tsx
43331
43296
  var import_jsx_runtime62 = require("react/jsx-runtime");
43332
43297
  var Message = function(t0) {
43333
- var $ = (0, import_react_compiler_runtime60.c)(21);
43298
+ var $ = (0, import_react_compiler_runtime60.c)(40);
43334
43299
  var message = t0.message, className = t0.className, style = t0.style;
43335
43300
  var t1;
43336
- var t22;
43337
- if ($[0] !== message.id || $[1] !== message.runSteps) {
43338
- t22 = splitRunSteps({
43339
- messageId: message.id,
43340
- runSteps: message.runSteps
43341
- });
43342
- $[0] = message.id;
43343
- $[1] = message.runSteps;
43344
- $[2] = t22;
43345
- } else {
43346
- t22 = $[2];
43301
+ bb0: {
43302
+ if (!message.runSteps.length) {
43303
+ var _t;
43304
+ if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
43305
+ _t = [
43306
+ [],
43307
+ []
43308
+ ];
43309
+ $[0] = _t;
43310
+ } else {
43311
+ _t = $[0];
43312
+ }
43313
+ t1 = _t;
43314
+ break bb0;
43315
+ }
43316
+ var _t2;
43317
+ if ($[1] !== message.id) {
43318
+ _t2 = function(runStep) {
43319
+ if (runStep.step_details.type !== "message_creation") {
43320
+ return;
43321
+ }
43322
+ return runStep.step_details.message_creation.message_id === message.id;
43323
+ };
43324
+ $[1] = message.id;
43325
+ $[2] = _t2;
43326
+ } else {
43327
+ _t2 = $[2];
43328
+ }
43329
+ var messageCreationRunStepIndex = message.runSteps.findIndex(_t2);
43330
+ if (messageCreationRunStepIndex === -1) {
43331
+ var _t3;
43332
+ if ($[3] === Symbol.for("react.memo_cache_sentinel")) {
43333
+ _t3 = [];
43334
+ $[3] = _t3;
43335
+ } else {
43336
+ _t3 = $[3];
43337
+ }
43338
+ var _t4;
43339
+ if ($[4] !== message.runSteps) {
43340
+ _t4 = [
43341
+ _t3,
43342
+ message.runSteps
43343
+ ];
43344
+ $[4] = message.runSteps;
43345
+ $[5] = _t4;
43346
+ } else {
43347
+ _t4 = $[5];
43348
+ }
43349
+ t1 = _t4;
43350
+ break bb0;
43351
+ }
43352
+ var _t5;
43353
+ if ($[6] !== message.runSteps || $[7] !== messageCreationRunStepIndex) {
43354
+ var nextRunStepIndex = message.runSteps.slice(0, messageCreationRunStepIndex).findLastIndex(_temp3);
43355
+ if (nextRunStepIndex === -1) {
43356
+ nextRunStepIndex = 0;
43357
+ }
43358
+ _t5 = message.runSteps.slice(nextRunStepIndex, messageCreationRunStepIndex);
43359
+ $[6] = message.runSteps;
43360
+ $[7] = messageCreationRunStepIndex;
43361
+ $[8] = _t5;
43362
+ } else {
43363
+ _t5 = $[8];
43364
+ }
43365
+ var laterRunSteps = _t5;
43366
+ var _t6;
43367
+ if ($[9] !== message.runSteps || $[10] !== messageCreationRunStepIndex) {
43368
+ _t6 = message.runSteps.slice(messageCreationRunStepIndex + 1).findIndex(_temp22);
43369
+ $[9] = message.runSteps;
43370
+ $[10] = messageCreationRunStepIndex;
43371
+ $[11] = _t6;
43372
+ } else {
43373
+ _t6 = $[11];
43374
+ }
43375
+ var prevRunStepIndex = _t6;
43376
+ var olderRunSteps;
43377
+ if (prevRunStepIndex === -1) {
43378
+ var _t7;
43379
+ if ($[12] !== message.runSteps || $[13] !== messageCreationRunStepIndex) {
43380
+ _t7 = message.runSteps.slice(messageCreationRunStepIndex + 1);
43381
+ $[12] = message.runSteps;
43382
+ $[13] = messageCreationRunStepIndex;
43383
+ $[14] = _t7;
43384
+ } else {
43385
+ _t7 = $[14];
43386
+ }
43387
+ olderRunSteps = _t7;
43388
+ } else {
43389
+ var _t8;
43390
+ if ($[15] !== message.runSteps || $[16] !== messageCreationRunStepIndex || $[17] !== prevRunStepIndex) {
43391
+ _t8 = message.runSteps.slice(messageCreationRunStepIndex + 1, messageCreationRunStepIndex + prevRunStepIndex);
43392
+ $[15] = message.runSteps;
43393
+ $[16] = messageCreationRunStepIndex;
43394
+ $[17] = prevRunStepIndex;
43395
+ $[18] = _t8;
43396
+ } else {
43397
+ _t8 = $[18];
43398
+ }
43399
+ olderRunSteps = _t8;
43400
+ }
43401
+ var _t9;
43402
+ if ($[19] !== laterRunSteps || $[20] !== olderRunSteps) {
43403
+ _t9 = [
43404
+ olderRunSteps,
43405
+ laterRunSteps
43406
+ ];
43407
+ $[19] = laterRunSteps;
43408
+ $[20] = olderRunSteps;
43409
+ $[21] = _t9;
43410
+ } else {
43411
+ _t9 = $[21];
43412
+ }
43413
+ t1 = _t9;
43347
43414
  }
43348
- t1 = t22;
43349
- var _t1 = _sliced_to_array(t1, 2), olderRunSteps = _t1[0], laterRunSteps = _t1[1];
43350
- var t3;
43351
- if ($[3] !== message) {
43352
- t3 = {
43415
+ var _t1 = _sliced_to_array(t1, 2), olderRunSteps_0 = _t1[0], laterRunSteps_0 = _t1[1];
43416
+ var t22;
43417
+ if ($[22] !== message) {
43418
+ t22 = {
43353
43419
  message: message
43354
43420
  };
43355
- $[3] = message;
43356
- $[4] = t3;
43421
+ $[22] = message;
43422
+ $[23] = t22;
43357
43423
  } else {
43358
- t3 = $[4];
43424
+ t22 = $[23];
43359
43425
  }
43360
- var t4;
43361
- if ($[5] !== olderRunSteps) {
43362
- t4 = /* @__PURE__ */ (0, import_jsx_runtime62.jsx)(RunSteps, {
43363
- runSteps: olderRunSteps
43426
+ var t3;
43427
+ if ($[24] !== olderRunSteps_0) {
43428
+ t3 = /* @__PURE__ */ (0, import_jsx_runtime62.jsx)(RunSteps, {
43429
+ runSteps: olderRunSteps_0
43364
43430
  });
43365
- $[5] = olderRunSteps;
43366
- $[6] = t4;
43431
+ $[24] = olderRunSteps_0;
43432
+ $[25] = t3;
43367
43433
  } else {
43368
- t4 = $[6];
43434
+ t3 = $[25];
43369
43435
  }
43370
- var t5;
43371
- if ($[7] === Symbol.for("react.memo_cache_sentinel")) {
43372
- t5 = {
43436
+ var t4;
43437
+ if ($[26] === Symbol.for("react.memo_cache_sentinel")) {
43438
+ t4 = {
43373
43439
  wordBreak: "break-word"
43374
43440
  };
43375
- $[7] = t5;
43441
+ $[26] = t4;
43376
43442
  } else {
43377
- t5 = $[7];
43443
+ t4 = $[26];
43378
43444
  }
43379
- var t6;
43380
- if ($[8] !== message) {
43381
- t6 = /* @__PURE__ */ (0, import_jsx_runtime62.jsxs)(import_themes42.Box, {
43382
- style: t5,
43445
+ var t5;
43446
+ if ($[27] !== message) {
43447
+ t5 = /* @__PURE__ */ (0, import_jsx_runtime62.jsxs)(import_themes42.Box, {
43448
+ style: t4,
43383
43449
  children: [
43384
43450
  /* @__PURE__ */ (0, import_jsx_runtime62.jsx)(Attachments, {
43385
43451
  message: message
@@ -43389,55 +43455,61 @@ var Message = function(t0) {
43389
43455
  })
43390
43456
  ]
43391
43457
  });
43392
- $[8] = message;
43393
- $[9] = t6;
43458
+ $[27] = message;
43459
+ $[28] = t5;
43394
43460
  } else {
43395
- t6 = $[9];
43461
+ t5 = $[28];
43396
43462
  }
43397
- var t7;
43398
- if ($[10] !== laterRunSteps) {
43399
- t7 = /* @__PURE__ */ (0, import_jsx_runtime62.jsx)(RunSteps, {
43400
- runSteps: laterRunSteps
43463
+ var t6;
43464
+ if ($[29] !== laterRunSteps_0) {
43465
+ t6 = /* @__PURE__ */ (0, import_jsx_runtime62.jsx)(RunSteps, {
43466
+ runSteps: laterRunSteps_0
43401
43467
  });
43402
- $[10] = laterRunSteps;
43403
- $[11] = t7;
43468
+ $[29] = laterRunSteps_0;
43469
+ $[30] = t6;
43404
43470
  } else {
43405
- t7 = $[11];
43471
+ t6 = $[30];
43406
43472
  }
43407
- var t8;
43408
- if ($[12] !== className || $[13] !== style || $[14] !== t4 || $[15] !== t6 || $[16] !== t7) {
43409
- t8 = /* @__PURE__ */ (0, import_jsx_runtime62.jsxs)(import_themes42.Box, {
43473
+ var t7;
43474
+ if ($[31] !== className || $[32] !== style || $[33] !== t3 || $[34] !== t5 || $[35] !== t6) {
43475
+ t7 = /* @__PURE__ */ (0, import_jsx_runtime62.jsxs)(import_themes42.Box, {
43410
43476
  className: className,
43411
43477
  style: style,
43412
43478
  children: [
43413
- t4,
43414
- t6,
43415
- t7
43479
+ t3,
43480
+ t5,
43481
+ t6
43416
43482
  ]
43417
43483
  });
43418
- $[12] = className;
43419
- $[13] = style;
43420
- $[14] = t4;
43421
- $[15] = t6;
43422
- $[16] = t7;
43423
- $[17] = t8;
43484
+ $[31] = className;
43485
+ $[32] = style;
43486
+ $[33] = t3;
43487
+ $[34] = t5;
43488
+ $[35] = t6;
43489
+ $[36] = t7;
43424
43490
  } else {
43425
- t8 = $[17];
43491
+ t7 = $[36];
43426
43492
  }
43427
- var t9;
43428
- if ($[18] !== t3 || $[19] !== t8) {
43429
- t9 = /* @__PURE__ */ (0, import_jsx_runtime62.jsx)(Provider, {
43430
- value: t3,
43431
- children: t8
43493
+ var t8;
43494
+ if ($[37] !== t22 || $[38] !== t7) {
43495
+ t8 = /* @__PURE__ */ (0, import_jsx_runtime62.jsx)(Provider, {
43496
+ value: t22,
43497
+ children: t7
43432
43498
  });
43433
- $[18] = t3;
43434
- $[19] = t8;
43435
- $[20] = t9;
43499
+ $[37] = t22;
43500
+ $[38] = t7;
43501
+ $[39] = t8;
43436
43502
  } else {
43437
- t9 = $[20];
43503
+ t8 = $[39];
43438
43504
  }
43439
- return t9;
43505
+ return t8;
43440
43506
  };
43507
+ function _temp3(runStep_0) {
43508
+ return runStep_0.step_details.type === "message_creation";
43509
+ }
43510
+ function _temp22(runStep_1) {
43511
+ return runStep_1.step_details.type === "message_creation";
43512
+ }
43441
43513
  // src/components/threads/Thread/Messages/Content/index.tsx
43442
43514
  var import_react_compiler_runtime62 = require("react-compiler-runtime");
43443
43515
  var import_react45 = require("react");
@@ -45108,7 +45180,7 @@ var useCreateFile = function(t0) {
45108
45180
  var t1;
45109
45181
  if ($[0] !== t0) {
45110
45182
  t1 = t0 === void 0 ? {
45111
- onError: _temp3
45183
+ onError: _temp4
45112
45184
  } : t0;
45113
45185
  $[0] = t0;
45114
45186
  $[1] = t1;
@@ -45118,7 +45190,7 @@ var useCreateFile = function(t0) {
45118
45190
  var t22 = t1.onError;
45119
45191
  var t3;
45120
45192
  if ($[2] !== t22) {
45121
- t3 = t22 === void 0 ? _temp22 : t22;
45193
+ t3 = t22 === void 0 ? _temp23 : t22;
45122
45194
  $[2] = t22;
45123
45195
  $[3] = t3;
45124
45196
  } else {
@@ -45177,8 +45249,8 @@ var useCreateFile = function(t0) {
45177
45249
  }
45178
45250
  return t6;
45179
45251
  };
45180
- function _temp3() {}
45181
- function _temp22() {}
45252
+ function _temp4() {}
45253
+ function _temp23() {}
45182
45254
  // src/hooks/files/useChangeFilesField/index.ts
45183
45255
  function asyncGeneratorStep8(n4, t3, e3, r2, o2, a3, c2) {
45184
45256
  try {
@@ -45833,7 +45905,7 @@ var ToastsProvider = function(t0) {
45833
45905
  }
45834
45906
  var t5;
45835
45907
  if ($[4] !== toasts) {
45836
- t5 = Array.from(toasts).map(_temp4);
45908
+ t5 = Array.from(toasts).map(_temp5);
45837
45909
  $[4] = toasts;
45838
45910
  $[5] = t5;
45839
45911
  } else {
@@ -45893,7 +45965,7 @@ var ToastsProvider = function(t0) {
45893
45965
  }
45894
45966
  return t8;
45895
45967
  };
45896
- function _temp4(toast_0, index4) {
45968
+ function _temp5(toast_0, index4) {
45897
45969
  return /* @__PURE__ */ (0, import_jsx_runtime77.jsx)(CustomToast, {
45898
45970
  toast: toast_0
45899
45971
  }, index4);
@@ -46491,7 +46563,7 @@ var Root14 = function(t0) {
46491
46563
  var t3;
46492
46564
  if ($[2] !== setIsOpen) {
46493
46565
  t3 = function() {
46494
- return setIsOpen(_temp5);
46566
+ return setIsOpen(_temp6);
46495
46567
  };
46496
46568
  $[2] = setIsOpen;
46497
46569
  $[3] = t3;
@@ -46566,7 +46638,7 @@ var Trigger = function(args) {
46566
46638
  };
46567
46639
  Trigger.Root = Root14;
46568
46640
  Trigger.Button = Button4;
46569
- function _temp5(prev) {
46641
+ function _temp6(prev) {
46570
46642
  return !prev;
46571
46643
  }
46572
46644
  // src/components/threads/ThreadDialog/Content/index.tsx
@@ -46595,7 +46667,7 @@ var Close = function() {
46595
46667
  var t22;
46596
46668
  if ($[2] !== setIsOpen) {
46597
46669
  t22 = function() {
46598
- return setIsOpen(_temp6);
46670
+ return setIsOpen(_temp7);
46599
46671
  };
46600
46672
  $[2] = setIsOpen;
46601
46673
  $[3] = t22;
@@ -46645,7 +46717,7 @@ var Close = function() {
46645
46717
  }
46646
46718
  return t5;
46647
46719
  };
46648
- function _temp6(prev) {
46720
+ function _temp7(prev) {
46649
46721
  return !prev;
46650
46722
  }
46651
46723
  // src/components/threads/ThreadDialog/Content/index.tsx
@@ -47052,7 +47124,7 @@ var import_react_compiler_runtime87 = require("react-compiler-runtime");
47052
47124
  var import_react65 = require("react");
47053
47125
  var useInterval = function(callback, delay) {
47054
47126
  var $ = (0, import_react_compiler_runtime87.c)(5);
47055
- var savedCallback = (0, import_react65.useRef)(_temp7);
47127
+ var savedCallback = (0, import_react65.useRef)(_temp8);
47056
47128
  var t0;
47057
47129
  if ($[0] !== callback) {
47058
47130
  t0 = function() {
@@ -47089,7 +47161,7 @@ var useInterval = function(callback, delay) {
47089
47161
  }
47090
47162
  (0, import_react65.useEffect)(t1, t22);
47091
47163
  };
47092
- function _temp7() {}
47164
+ function _temp8() {}
47093
47165
  // src/hooks/audioThreads/useRecorder/index.ts
47094
47166
  function ownKeys46(e3, r2) {
47095
47167
  var t3 = Object.keys(e3);
@@ -73184,7 +73256,7 @@ var useMessageAudio = function(t0) {
73184
73256
  } else {
73185
73257
  t15 = $[55];
73186
73258
  }
73187
- (0, import_react67.useEffect)(_temp8, t15);
73259
+ (0, import_react67.useEffect)(_temp9, t15);
73188
73260
  var _ref4 = _sliced_to_array((0, import_react67.useState)(null), 2), audioEngine = _ref4[0], setAudioEngine = _ref4[1];
73189
73261
  var isAudioEngineInited = (0, import_react67.useRef)(false);
73190
73262
  var t16;
@@ -73268,7 +73340,7 @@ var useMessageAudio = function(t0) {
73268
73340
  }
73269
73341
  return t20;
73270
73342
  };
73271
- function _temp8() {
73343
+ function _temp9() {
73272
73344
  if (isHtmlAudioSupported) {
73273
73345
  var _Howler$_howls$;
73274
73346
  if (!(import_howler.Howler !== null && import_howler.Howler !== void 0 && (_Howler$_howls$ = import_howler.Howler._howls[0]) !== null && _Howler$_howls$ !== void 0 && (_Howler$_howls$ = _Howler$_howls$._sounds[0]) !== null && _Howler$_howls$ !== void 0 && _Howler$_howls$._node)) {
@@ -73421,7 +73493,7 @@ var useTtsAudioRuntime = function(t0) {
73421
73493
  if ($[4] !== createMessageProps) {
73422
73494
  t22 = {
73423
73495
  isStopOnSilence: true,
73424
- onStart: _temp9,
73496
+ onStart: _temp10,
73425
73497
  onStop: function() {
73426
73498
  var _onStop = _asyncToGenerator11(function(_event, chunks3) {
73427
73499
  var blob, audioContent;
@@ -73561,18 +73633,18 @@ var useTtsAudioRuntime = function(t0) {
73561
73633
  t5 = t8;
73562
73634
  return t5;
73563
73635
  };
73564
- function _temp9() {
73565
- return _temp23.apply(this, arguments);
73636
+ function _temp10() {
73637
+ return _temp24.apply(this, arguments);
73566
73638
  }
73567
- function _temp23() {
73568
- _temp23 = _asyncToGenerator11(function() {
73639
+ function _temp24() {
73640
+ _temp24 = _asyncToGenerator11(function() {
73569
73641
  return _ts_generator(this, function(_state) {
73570
73642
  return [
73571
73643
  2
73572
73644
  ];
73573
73645
  });
73574
73646
  });
73575
- return _temp23.apply(this, arguments);
73647
+ return _temp24.apply(this, arguments);
73576
73648
  }
73577
73649
  // src/components/audioRuntimes/TtsAudioRuntimeProvider.tsx
73578
73650
  var import_jsx_runtime87 = require("react/jsx-runtime");
@@ -75744,7 +75816,7 @@ var useLatestAssistantMessage = function() {
75744
75816
  var t1;
75745
75817
  if ($[0] !== messages2) {
75746
75818
  var _messages$find;
75747
- t1 = (_messages$find = messages2.find(_temp10)) !== null && _messages$find !== void 0 ? _messages$find : null;
75819
+ t1 = (_messages$find = messages2.find(_temp11)) !== null && _messages$find !== void 0 ? _messages$find : null;
75748
75820
  $[0] = messages2;
75749
75821
  $[1] = t1;
75750
75822
  } else {
@@ -75763,7 +75835,7 @@ var useLatestAssistantMessage = function() {
75763
75835
  t0 = t22;
75764
75836
  return t0;
75765
75837
  };
75766
- function _temp10(message) {
75838
+ function _temp11(message) {
75767
75839
  return message.role === "assistant";
75768
75840
  }
75769
75841
  // src/hooks/messages/useLatestAssistantMessageWithContent/index.ts
@@ -75777,7 +75849,7 @@ var useLatestAssistantMessageWithContent = function() {
75777
75849
  var t1;
75778
75850
  if ($[0] !== messages2) {
75779
75851
  var _messages$find;
75780
- t1 = (_messages$find = messages2.find(_temp24)) !== null && _messages$find !== void 0 ? _messages$find : null;
75852
+ t1 = (_messages$find = messages2.find(_temp25)) !== null && _messages$find !== void 0 ? _messages$find : null;
75781
75853
  $[0] = messages2;
75782
75854
  $[1] = t1;
75783
75855
  } else {
@@ -75796,11 +75868,11 @@ var useLatestAssistantMessageWithContent = function() {
75796
75868
  t0 = t22;
75797
75869
  return t0;
75798
75870
  };
75799
- function _temp11(content2) {
75871
+ function _temp12(content2) {
75800
75872
  return content2.type === "text" && !(0, import_radash18.isEmpty)(content2.text.value);
75801
75873
  }
75802
- function _temp24(message) {
75803
- return message.role === "assistant" && message.content.some(_temp11);
75874
+ function _temp25(message) {
75875
+ return message.role === "assistant" && message.content.some(_temp12);
75804
75876
  }
75805
75877
  // src/components/gui/Gui/index.tsx
75806
75878
  var import_jsx_runtime99 = require("react/jsx-runtime");
@@ -75880,7 +75952,7 @@ var Progress2 = function(t0) {
75880
75952
  var t22;
75881
75953
  if ($[0] !== latestAssistantMessage.runSteps) {
75882
75954
  var _latestAssistantMessa;
75883
- t22 = (_latestAssistantMessa = latestAssistantMessage.runSteps.find(_temp12)) !== null && _latestAssistantMessa !== void 0 ? _latestAssistantMessa : null;
75955
+ t22 = (_latestAssistantMessa = latestAssistantMessage.runSteps.find(_temp13)) !== null && _latestAssistantMessa !== void 0 ? _latestAssistantMessa : null;
75884
75956
  $[0] = latestAssistantMessage.runSteps;
75885
75957
  $[1] = t22;
75886
75958
  } else {
@@ -75985,7 +76057,7 @@ var Gui = function() {
75985
76057
  }
75986
76058
  return t22;
75987
76059
  };
75988
- function _temp12(rs) {
76060
+ function _temp13(rs) {
75989
76061
  return rs.status === "in_progress";
75990
76062
  }
75991
76063
  // src/components/markdown/MarkdownProvider/index.tsx