@superinterface/react 2.4.1 → 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,
@@ -2947,6 +2959,7 @@ var useMessageAudio = function(param) {
2947
2959
  isInited.current = true;
2948
2960
  if (isHtmlAudioSupported) {
2949
2961
  var audioContext = new AudioContext();
2962
+ Howler._howls[0]._sounds[0]._node.crossOrigin = "anonymous";
2950
2963
  setAudioEngine({
2951
2964
  // @ts-ignore-next-line
2952
2965
  source: audioContext.createMediaElementSource(Howler._howls[0]._sounds[0]._node),
@@ -2971,7 +2984,15 @@ var useMessageAudio = function(param) {
2971
2984
  }, [
2972
2985
  audioEngine
2973
2986
  ]);
2974
- 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), {
2975
2996
  visualizationAnalyser: visualizationAnalyser
2976
2997
  });
2977
2998
  };
@@ -3329,9 +3350,9 @@ AudioThreadDialog.Trigger = Trigger;
3329
3350
  AudioThreadDialog.Button = Button2;
3330
3351
  AudioThreadDialog.Content = Content4;
3331
3352
  // src/components/suggestions/Suggestions/index.tsx
3332
- import { useMemo as useMemo15 } from "react";
3333
- // src/components/suggestions/Suggestions/Content.tsx
3334
3353
  import { useMemo as useMemo14 } from "react";
3354
+ // src/components/suggestions/Suggestions/Content.tsx
3355
+ import { useMemo as useMemo13 } from "react";
3335
3356
  import { isEmpty as isEmpty2 } from "radash";
3336
3357
  import { onlyText } from "react-children-utilities";
3337
3358
  import { Flex as Flex25 } from "@radix-ui/themes";
@@ -3388,7 +3409,7 @@ import { jsx as jsx63 } from "react/jsx-runtime";
3388
3409
  var Content6 = function(param) {
3389
3410
  var children = param.children;
3390
3411
  var isMutatingMessage = useIsMutatingMessage();
3391
- var suggestions = useMemo14(function() {
3412
+ var suggestions = useMemo13(function() {
3392
3413
  return onlyText(children).split(/\r?\n/).filter(function(c) {
3393
3414
  return !isEmpty2(c);
3394
3415
  }).map(function(c) {
@@ -3415,7 +3436,7 @@ import { jsx as jsx64 } from "react/jsx-runtime";
3415
3436
  var Suggestions = function(param) {
3416
3437
  var children = param.children;
3417
3438
  var latestMessageProps = useLatestMessage();
3418
- var isDisabled = useMemo15(function() {
3439
+ var isDisabled = useMemo14(function() {
3419
3440
  var // @ts-ignore-next-line
3420
3441
  _latestMessageProps_latestMessage_metadata, _latestMessageProps_latestMessage;
3421
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;
@@ -3430,14 +3451,14 @@ var Suggestions = function(param) {
3430
3451
  };
3431
3452
  Suggestions.Item = Item;
3432
3453
  // src/components/markdown/MarkdownProvider/index.tsx
3433
- import { useMemo as useMemo16 } from "react";
3454
+ import { useMemo as useMemo15 } from "react";
3434
3455
  import { jsx as jsx65 } from "react/jsx-runtime";
3435
3456
  var MarkdownProvider = function(_param) {
3436
3457
  var children = _param.children, rest = _object_without_properties(_param, [
3437
3458
  "children"
3438
3459
  ]);
3439
3460
  var prevMarkdownContext = useMarkdownContext();
3440
- var value = useMemo16(function() {
3461
+ var value = useMemo15(function() {
3441
3462
  return merge(prevMarkdownContext, rest);
3442
3463
  }, [
3443
3464
  rest,