@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.cjs +30 -9
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +36 -15
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
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
|
-
|
|
2881
|
-
if (
|
|
2882
|
-
if (
|
|
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
|
-
|
|
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
|
-
|
|
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 =
|
|
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 =
|
|
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
|
|
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 =
|
|
3461
|
+
var value = useMemo15(function() {
|
|
3441
3462
|
return merge(prevMarkdownContext, rest);
|
|
3442
3463
|
}, [
|
|
3443
3464
|
rest,
|