@superinterface/react 2.4.2 → 2.4.3

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.js CHANGED
@@ -2665,16 +2665,20 @@ var blobToData = function(blob) {
2665
2665
  import { useMemo as useMemo10 } from "react";
2666
2666
  var useStatus = function(param) {
2667
2667
  var messageAudioProps = param.messageAudioProps, recorderProps = param.recorderProps, createMessageProps = param.createMessageProps;
2668
+ var latestMessageProps = useLatestMessage();
2668
2669
  var status = useMemo10(function() {
2670
+ var _latestMessageProps_latestMessage;
2669
2671
  if (recorderProps.status === "recording") return "recording";
2670
2672
  if (createMessageProps.isPending) return "creatingMessage";
2671
- if (messageAudioProps.playing) return "playing";
2673
+ if (messageAudioProps.playing || messageAudioProps.isPending) return "playing";
2672
2674
  if (messageAudioProps.paused) return "playerPaused";
2673
2675
  if (!messageAudioProps.isReady) return "loading";
2676
+ if (((_latestMessageProps_latestMessage = latestMessageProps.latestMessage) === null || _latestMessageProps_latestMessage === void 0 ? void 0 : _latestMessageProps_latestMessage.status) === "in_progress") return "creatingMessage";
2674
2677
  if (recorderProps.status === "idle") return "idle";
2675
2678
  if (recorderProps.status === "paused") return "recorderPaused";
2676
2679
  return "loading";
2677
2680
  }, [
2681
+ latestMessageProps,
2678
2682
  messageAudioProps,
2679
2683
  recorderProps,
2680
2684
  createMessageProps
@@ -2877,24 +2881,31 @@ var useMessageAudio = function(param) {
2877
2881
  var superinterfaceContext = useSuperinterfaceContext();
2878
2882
  var _useState41 = _sliced_to_array(useState4(false), 2), isPlaying = _useState41[0], setIsPlaying = _useState41[1];
2879
2883
  var latestMessageProps = useLatestMessage();
2880
- useEffect5(function() {
2881
- if (isPlaying) return;
2882
- if (audioPlayer.playing) return;
2883
- if (!latestMessageProps.latestMessage) return;
2884
- if (latestMessageProps.latestMessage.role !== "assistant") return;
2884
+ var unplayedMessageSentences = useMemo12(function() {
2885
+ if (!latestMessageProps.latestMessage) return [];
2886
+ if (latestMessageProps.latestMessage.role !== "assistant") return [];
2885
2887
  var input2 = input({
2886
2888
  message: latestMessageProps.latestMessage
2887
2889
  });
2888
- if (!input2) return;
2890
+ if (!input2) return [];
2889
2891
  var messageSentences = getMessageSentences({
2890
2892
  messageId: latestMessageProps.latestMessage.id,
2891
2893
  input: input2
2892
2894
  });
2893
- var unplayedMessageSentences = messageSentences.filter(function(ms) {
2895
+ return messageSentences.filter(function(ms) {
2894
2896
  return !playedMessageSentences.find(function(pms) {
2895
2897
  return pms.messageId === ms.messageId && pms.sentence === ms.sentence;
2896
2898
  });
2897
2899
  });
2900
+ }, [
2901
+ latestMessageProps,
2902
+ playedMessageSentences
2903
+ ]);
2904
+ useEffect5(function() {
2905
+ if (isPlaying) return;
2906
+ if (audioPlayer.playing) return;
2907
+ if (!latestMessageProps.latestMessage) return;
2908
+ if (latestMessageProps.latestMessage.role !== "assistant") return;
2898
2909
  var firstUnplayedMessageSentence = unplayedMessageSentences[0];
2899
2910
  if (!firstUnplayedMessageSentence) {
2900
2911
  return;
@@ -2932,6 +2943,7 @@ var useMessageAudio = function(param) {
2932
2943
  })
2933
2944
  }));
2934
2945
  }, [
2946
+ unplayedMessageSentences,
2935
2947
  isPlaying,
2936
2948
  superinterfaceContext,
2937
2949
  latestMessageProps,
@@ -2972,7 +2984,15 @@ var useMessageAudio = function(param) {
2972
2984
  }, [
2973
2985
  audioEngine
2974
2986
  ]);
2975
- return _object_spread_props(_object_spread({}, audioPlayer), {
2987
+ var isPending = useMemo12(function() {
2988
+ return isPlaying || unplayedMessageSentences.length > 0;
2989
+ }, [
2990
+ isPlaying,
2991
+ unplayedMessageSentences
2992
+ ]);
2993
+ return _object_spread_props(_object_spread({
2994
+ isPending: isPending
2995
+ }, audioPlayer), {
2976
2996
  visualizationAnalyser: visualizationAnalyser
2977
2997
  });
2978
2998
  };
@@ -3330,9 +3350,9 @@ AudioThreadDialog.Trigger = Trigger;
3330
3350
  AudioThreadDialog.Button = Button2;
3331
3351
  AudioThreadDialog.Content = Content4;
3332
3352
  // src/components/suggestions/Suggestions/index.tsx
3333
- import { useMemo as useMemo15 } from "react";
3334
- // src/components/suggestions/Suggestions/Content.tsx
3335
3353
  import { useMemo as useMemo14 } from "react";
3354
+ // src/components/suggestions/Suggestions/Content.tsx
3355
+ import { useMemo as useMemo13 } from "react";
3336
3356
  import { isEmpty as isEmpty2 } from "radash";
3337
3357
  import { onlyText } from "react-children-utilities";
3338
3358
  import { Flex as Flex25 } from "@radix-ui/themes";
@@ -3389,7 +3409,7 @@ import { jsx as jsx63 } from "react/jsx-runtime";
3389
3409
  var Content6 = function(param) {
3390
3410
  var children = param.children;
3391
3411
  var isMutatingMessage = useIsMutatingMessage();
3392
- var suggestions = useMemo14(function() {
3412
+ var suggestions = useMemo13(function() {
3393
3413
  return onlyText(children).split(/\r?\n/).filter(function(c) {
3394
3414
  return !isEmpty2(c);
3395
3415
  }).map(function(c) {
@@ -3416,7 +3436,7 @@ import { jsx as jsx64 } from "react/jsx-runtime";
3416
3436
  var Suggestions = function(param) {
3417
3437
  var children = param.children;
3418
3438
  var latestMessageProps = useLatestMessage();
3419
- var isDisabled = useMemo15(function() {
3439
+ var isDisabled = useMemo14(function() {
3420
3440
  var // @ts-ignore-next-line
3421
3441
  _latestMessageProps_latestMessage_metadata, _latestMessageProps_latestMessage;
3422
3442
  return (_latestMessageProps_latestMessage = latestMessageProps.latestMessage) === null || _latestMessageProps_latestMessage === void 0 ? void 0 : (_latestMessageProps_latestMessage_metadata = _latestMessageProps_latestMessage.metadata) === null || _latestMessageProps_latestMessage_metadata === void 0 ? void 0 : _latestMessageProps_latestMessage_metadata.isBlocking;
@@ -3431,14 +3451,14 @@ var Suggestions = function(param) {
3431
3451
  };
3432
3452
  Suggestions.Item = Item;
3433
3453
  // src/components/markdown/MarkdownProvider/index.tsx
3434
- import { useMemo as useMemo16 } from "react";
3454
+ import { useMemo as useMemo15 } from "react";
3435
3455
  import { jsx as jsx65 } from "react/jsx-runtime";
3436
3456
  var MarkdownProvider = function(_param) {
3437
3457
  var children = _param.children, rest = _object_without_properties(_param, [
3438
3458
  "children"
3439
3459
  ]);
3440
3460
  var prevMarkdownContext = useMarkdownContext();
3441
- var value = useMemo16(function() {
3461
+ var value = useMemo15(function() {
3442
3462
  return merge(prevMarkdownContext, rest);
3443
3463
  }, [
3444
3464
  rest,