@liveblocks/react-ui 2.25.0-aiprivatebeta7 → 2.25.0-aiprivatebeta8
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/_private/index.cjs +10 -4
- package/dist/_private/index.cjs.map +1 -1
- package/dist/_private/index.d.cts +76 -10
- package/dist/_private/index.d.ts +76 -10
- package/dist/_private/index.js +4 -2
- package/dist/_private/index.js.map +1 -1
- package/dist/components/AiChat.cjs +24 -27
- package/dist/components/AiChat.cjs.map +1 -1
- package/dist/components/AiChat.js +24 -27
- package/dist/components/AiChat.js.map +1 -1
- package/dist/components/AiToolDebugger.cjs +74 -0
- package/dist/components/AiToolDebugger.cjs.map +1 -0
- package/dist/components/AiToolDebugger.js +72 -0
- package/dist/components/AiToolDebugger.js.map +1 -0
- package/dist/components/Thread.cjs +3 -3
- package/dist/components/Thread.cjs.map +1 -1
- package/dist/components/Thread.js +3 -3
- package/dist/components/Thread.js.map +1 -1
- package/dist/components/internal/AiChatAssistantMessage.cjs +127 -147
- package/dist/components/internal/AiChatAssistantMessage.cjs.map +1 -1
- package/dist/components/internal/AiChatAssistantMessage.js +129 -149
- package/dist/components/internal/AiChatAssistantMessage.js.map +1 -1
- package/dist/components/internal/AiChatComposer.cjs +28 -16
- package/dist/components/internal/AiChatComposer.cjs.map +1 -1
- package/dist/components/internal/AiChatComposer.js +28 -16
- package/dist/components/internal/AiChatComposer.js.map +1 -1
- package/dist/icon.cjs +2 -0
- package/dist/icon.cjs.map +1 -1
- package/dist/icon.js +1 -0
- package/dist/icon.js.map +1 -1
- package/dist/icons/{Resolve.cjs → CheckCircle.cjs} +3 -3
- package/dist/icons/CheckCircle.cjs.map +1 -0
- package/dist/icons/{Resolve.js → CheckCircle.js} +3 -3
- package/dist/icons/CheckCircle.js.map +1 -0
- package/dist/icons/{Resolved.cjs → CheckCircleFill.cjs} +3 -3
- package/dist/icons/CheckCircleFill.cjs.map +1 -0
- package/dist/icons/{Resolved.js → CheckCircleFill.js} +3 -3
- package/dist/icons/CheckCircleFill.js.map +1 -0
- package/dist/icons/index.cjs +4 -4
- package/dist/icons/index.js +2 -2
- package/dist/index.cjs +2 -0
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +27 -14
- package/dist/index.d.ts +27 -14
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/overrides.cjs +0 -4
- package/dist/overrides.cjs.map +1 -1
- package/dist/overrides.js +0 -4
- package/dist/overrides.js.map +1 -1
- package/dist/primitives/AiChatComposer/index.cjs +1 -2
- package/dist/primitives/AiChatComposer/index.cjs.map +1 -1
- package/dist/primitives/AiChatComposer/index.js +1 -2
- package/dist/primitives/AiChatComposer/index.js.map +1 -1
- package/dist/primitives/index.d.cts +0 -4
- package/dist/primitives/index.d.ts +0 -4
- package/dist/primitives/internal/Markdown.cjs +56 -25
- package/dist/primitives/internal/Markdown.cjs.map +1 -1
- package/dist/primitives/internal/Markdown.js +56 -25
- package/dist/primitives/internal/Markdown.js.map +1 -1
- package/dist/version.cjs +1 -1
- package/dist/version.js +1 -1
- package/package.json +5 -5
- package/src/styles/index.css +105 -61
- package/styles.css +1 -1
- package/styles.css.map +1 -1
- package/dist/icons/Resolve.cjs.map +0 -1
- package/dist/icons/Resolve.js.map +0 -1
- package/dist/icons/Resolved.cjs.map +0 -1
- package/dist/icons/Resolved.js.map +0 -1
|
@@ -6,64 +6,29 @@ var react$1 = require('@liveblocks/react');
|
|
|
6
6
|
var _private = require('@liveblocks/react/_private');
|
|
7
7
|
var marked = require('marked');
|
|
8
8
|
var react = require('react');
|
|
9
|
-
|
|
10
|
-
var
|
|
9
|
+
require('../../_private/index.cjs');
|
|
10
|
+
var components = require('../../components.cjs');
|
|
11
11
|
var Check = require('../../icons/Check.cjs');
|
|
12
|
-
var ChevronDown = require('../../icons/ChevronDown.cjs');
|
|
13
12
|
var ChevronRight = require('../../icons/ChevronRight.cjs');
|
|
14
13
|
var Copy = require('../../icons/Copy.cjs');
|
|
15
|
-
var Retry = require('../../icons/Retry.cjs');
|
|
16
14
|
var Warning = require('../../icons/Warning.cjs');
|
|
17
15
|
var overrides = require('../../overrides.cjs');
|
|
18
16
|
var index = require('../../primitives/internal/Collapsible/index.cjs');
|
|
19
17
|
var Markdown = require('../../primitives/internal/Markdown.cjs');
|
|
20
18
|
var classNames = require('../../utils/class-names.cjs');
|
|
21
|
-
var
|
|
19
|
+
var Button = require('./Button.cjs');
|
|
22
20
|
|
|
23
21
|
const AiChatAssistantMessage = react.memo(
|
|
24
22
|
react.forwardRef(
|
|
25
|
-
({
|
|
26
|
-
message,
|
|
27
|
-
showActions = false,
|
|
28
|
-
showRegenerate = false,
|
|
29
|
-
copilotId,
|
|
30
|
-
className,
|
|
31
|
-
overrides: overrides$1,
|
|
32
|
-
...props
|
|
33
|
-
}, forwardedRef) => {
|
|
23
|
+
({ message, className, overrides: overrides$1, components, ...props }, forwardedRef) => {
|
|
34
24
|
const $ = overrides.useOverrides(overrides$1);
|
|
35
25
|
let children = null;
|
|
36
|
-
function MessageActions({ text }) {
|
|
37
|
-
if (!showActions)
|
|
38
|
-
return null;
|
|
39
|
-
return /* @__PURE__ */ jsxRuntime.jsxs("div", {
|
|
40
|
-
className: "lb-ai-chat-message-actions",
|
|
41
|
-
children: [
|
|
42
|
-
/* @__PURE__ */ jsxRuntime.jsx(Tooltip.Tooltip, {
|
|
43
|
-
content: $.AI_CHAT_MESSAGE_COPY,
|
|
44
|
-
children: /* @__PURE__ */ jsxRuntime.jsx(CopyTextButton, {
|
|
45
|
-
text,
|
|
46
|
-
label: $.AI_CHAT_MESSAGE_COPY
|
|
47
|
-
})
|
|
48
|
-
}),
|
|
49
|
-
showRegenerate && /* @__PURE__ */ jsxRuntime.jsx(Tooltip.Tooltip, {
|
|
50
|
-
content: $.AI_CHAT_MESSAGE_TRY_AGAIN,
|
|
51
|
-
children: /* @__PURE__ */ jsxRuntime.jsx(RegenerateMessageButton, {
|
|
52
|
-
chatId: message.chatId,
|
|
53
|
-
messageId: message.id,
|
|
54
|
-
copilotId,
|
|
55
|
-
label: $.AI_CHAT_MESSAGE_TRY_AGAIN
|
|
56
|
-
})
|
|
57
|
-
})
|
|
58
|
-
]
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
26
|
if (message.deletedAt !== void 0) {
|
|
62
27
|
children = /* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
63
28
|
className: "lb-ai-chat-message-deleted",
|
|
64
29
|
children: $.AI_CHAT_MESSAGE_DELETED
|
|
65
30
|
});
|
|
66
|
-
} else if (message.status === "
|
|
31
|
+
} else if (message.status === "generating" || message.status === "awaiting-tool") {
|
|
67
32
|
if (message.contentSoFar.length === 0) {
|
|
68
33
|
children = /* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
69
34
|
className: "lb-ai-chat-message-thinking lb-ai-chat-pending",
|
|
@@ -72,52 +37,34 @@ const AiChatAssistantMessage = react.memo(
|
|
|
72
37
|
} else {
|
|
73
38
|
children = /* @__PURE__ */ jsxRuntime.jsx(AssistantMessageContent, {
|
|
74
39
|
content: message.contentSoFar,
|
|
75
|
-
chatId: message.chatId
|
|
40
|
+
chatId: message.chatId,
|
|
41
|
+
messageId: message.id,
|
|
42
|
+
components
|
|
76
43
|
});
|
|
77
44
|
}
|
|
78
45
|
} else if (message.status === "completed") {
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
}, "");
|
|
85
|
-
children = /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
86
|
-
children: [
|
|
87
|
-
/* @__PURE__ */ jsxRuntime.jsx(AssistantMessageContent, {
|
|
88
|
-
content: message.content,
|
|
89
|
-
chatId: message.chatId
|
|
90
|
-
}),
|
|
91
|
-
/* @__PURE__ */ jsxRuntime.jsx(MessageActions, {
|
|
92
|
-
text
|
|
93
|
-
})
|
|
94
|
-
]
|
|
46
|
+
children = /* @__PURE__ */ jsxRuntime.jsx(AssistantMessageContent, {
|
|
47
|
+
content: message.content,
|
|
48
|
+
chatId: message.chatId,
|
|
49
|
+
messageId: message.id,
|
|
50
|
+
components
|
|
95
51
|
});
|
|
96
52
|
} else if (message.status === "failed") {
|
|
97
|
-
const text = message.contentSoFar.reduce((acc, part) => {
|
|
98
|
-
if (part.type === "text") {
|
|
99
|
-
return acc + part.text;
|
|
100
|
-
}
|
|
101
|
-
return acc;
|
|
102
|
-
}, "");
|
|
103
53
|
if (message.errorReason === "Aborted by user") {
|
|
104
|
-
children = /* @__PURE__ */ jsxRuntime.
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
}),
|
|
110
|
-
/* @__PURE__ */ jsxRuntime.jsx(MessageActions, {
|
|
111
|
-
text
|
|
112
|
-
})
|
|
113
|
-
]
|
|
54
|
+
children = /* @__PURE__ */ jsxRuntime.jsx(AssistantMessageContent, {
|
|
55
|
+
content: message.contentSoFar,
|
|
56
|
+
chatId: message.chatId,
|
|
57
|
+
messageId: message.id,
|
|
58
|
+
components
|
|
114
59
|
});
|
|
115
60
|
} else {
|
|
116
61
|
children = /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
117
62
|
children: [
|
|
118
63
|
/* @__PURE__ */ jsxRuntime.jsx(AssistantMessageContent, {
|
|
119
64
|
content: message.contentSoFar,
|
|
120
|
-
chatId: message.chatId
|
|
65
|
+
chatId: message.chatId,
|
|
66
|
+
messageId: message.id,
|
|
67
|
+
components
|
|
121
68
|
}),
|
|
122
69
|
/* @__PURE__ */ jsxRuntime.jsxs("div", {
|
|
123
70
|
className: "lb-ai-chat-message-error",
|
|
@@ -128,71 +75,28 @@ const AiChatAssistantMessage = react.memo(
|
|
|
128
75
|
}),
|
|
129
76
|
message.errorReason
|
|
130
77
|
]
|
|
131
|
-
}),
|
|
132
|
-
/* @__PURE__ */ jsxRuntime.jsx(MessageActions, {
|
|
133
|
-
text
|
|
134
78
|
})
|
|
135
79
|
]
|
|
136
80
|
});
|
|
137
81
|
}
|
|
138
82
|
}
|
|
139
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
ref: forwardedRef,
|
|
148
|
-
children
|
|
149
|
-
})
|
|
83
|
+
return /* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
84
|
+
className: classNames.classNames(
|
|
85
|
+
"lb-ai-chat-message lb-ai-chat-assistant-message",
|
|
86
|
+
className
|
|
87
|
+
),
|
|
88
|
+
...props,
|
|
89
|
+
ref: forwardedRef,
|
|
90
|
+
children
|
|
150
91
|
});
|
|
151
92
|
}
|
|
152
93
|
)
|
|
153
94
|
);
|
|
154
|
-
function CopyTextButton({ text, label }) {
|
|
155
|
-
const [isCopied, setIsCopied] = react.useState(false);
|
|
156
|
-
react.useEffect(() => {
|
|
157
|
-
const timeoutId = setTimeout(() => {
|
|
158
|
-
setIsCopied(false);
|
|
159
|
-
}, 2e3);
|
|
160
|
-
return () => {
|
|
161
|
-
clearTimeout(timeoutId);
|
|
162
|
-
};
|
|
163
|
-
}, [isCopied]);
|
|
164
|
-
return /* @__PURE__ */ jsxRuntime.jsx(Button.Button, {
|
|
165
|
-
onClick: function() {
|
|
166
|
-
navigator.clipboard.writeText(text);
|
|
167
|
-
setIsCopied(true);
|
|
168
|
-
},
|
|
169
|
-
className: "lb-ai-chat-message-action",
|
|
170
|
-
"aria-label": label,
|
|
171
|
-
icon: isCopied ? /* @__PURE__ */ jsxRuntime.jsx(Check.CheckIcon, {}) : /* @__PURE__ */ jsxRuntime.jsx(Copy.CopyIcon, {})
|
|
172
|
-
});
|
|
173
|
-
}
|
|
174
|
-
function RegenerateMessageButton({
|
|
175
|
-
chatId,
|
|
176
|
-
messageId,
|
|
177
|
-
copilotId,
|
|
178
|
-
label
|
|
179
|
-
}) {
|
|
180
|
-
const client = react$1.useClient();
|
|
181
|
-
return /* @__PURE__ */ jsxRuntime.jsx(Button.Button, {
|
|
182
|
-
onClick: function() {
|
|
183
|
-
client[core.kInternal].ai.regenerateMessage(chatId, messageId, {
|
|
184
|
-
copilotId,
|
|
185
|
-
stream: true
|
|
186
|
-
});
|
|
187
|
-
},
|
|
188
|
-
className: "lb-ai-chat-message-action",
|
|
189
|
-
"aria-label": label,
|
|
190
|
-
icon: /* @__PURE__ */ jsxRuntime.jsx(Retry.RetryIcon, {})
|
|
191
|
-
});
|
|
192
|
-
}
|
|
193
95
|
function AssistantMessageContent({
|
|
194
96
|
content,
|
|
195
|
-
chatId
|
|
97
|
+
chatId,
|
|
98
|
+
messageId,
|
|
99
|
+
components
|
|
196
100
|
}) {
|
|
197
101
|
const isReasoning = content.some((part) => part.type === "reasoning") && content.every((part) => part.type === "reasoning");
|
|
198
102
|
return /* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
@@ -202,20 +106,22 @@ function AssistantMessageContent({
|
|
|
202
106
|
case "text": {
|
|
203
107
|
return /* @__PURE__ */ jsxRuntime.jsx(TextPart, {
|
|
204
108
|
text: part.text,
|
|
109
|
+
components,
|
|
205
110
|
className: "lb-ai-chat-message-text"
|
|
206
111
|
}, index);
|
|
207
112
|
}
|
|
208
|
-
case "tool-
|
|
209
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
113
|
+
case "tool-invocation": {
|
|
114
|
+
return /* @__PURE__ */ jsxRuntime.jsx(ToolInvocationPart, {
|
|
210
115
|
chatId,
|
|
211
|
-
|
|
212
|
-
|
|
116
|
+
messageId,
|
|
117
|
+
part
|
|
213
118
|
}, index);
|
|
214
119
|
}
|
|
215
120
|
case "reasoning": {
|
|
216
121
|
return /* @__PURE__ */ jsxRuntime.jsx(ReasoningPart, {
|
|
217
122
|
text: part.text,
|
|
218
|
-
isPending: isReasoning
|
|
123
|
+
isPending: isReasoning,
|
|
124
|
+
components
|
|
219
125
|
}, index);
|
|
220
126
|
}
|
|
221
127
|
default: {
|
|
@@ -226,7 +132,7 @@ function AssistantMessageContent({
|
|
|
226
132
|
});
|
|
227
133
|
}
|
|
228
134
|
const TextPart = react.forwardRef(
|
|
229
|
-
({ text, ...props }, forwardedRef) => {
|
|
135
|
+
({ text, components, ...props }, forwardedRef) => {
|
|
230
136
|
const tokens = react.useMemo(() => {
|
|
231
137
|
return new marked.Lexer().lex(text);
|
|
232
138
|
}, [text]);
|
|
@@ -235,16 +141,72 @@ const TextPart = react.forwardRef(
|
|
|
235
141
|
...props,
|
|
236
142
|
children: tokens.map((token, index) => {
|
|
237
143
|
return /* @__PURE__ */ jsxRuntime.jsx(MemoizedBlockTokenComp, {
|
|
238
|
-
token
|
|
144
|
+
token,
|
|
145
|
+
components
|
|
239
146
|
}, index);
|
|
240
147
|
})
|
|
241
148
|
});
|
|
242
149
|
}
|
|
243
150
|
);
|
|
151
|
+
function CodeBlock({
|
|
152
|
+
language,
|
|
153
|
+
code
|
|
154
|
+
}) {
|
|
155
|
+
const [isCopied, setCopied] = react.useState(false);
|
|
156
|
+
const timeoutRef = react.useRef(null);
|
|
157
|
+
react.useEffect(() => {
|
|
158
|
+
if (isCopied) {
|
|
159
|
+
timeoutRef.current = setTimeout(() => {
|
|
160
|
+
setCopied(false);
|
|
161
|
+
}, 1e3);
|
|
162
|
+
}
|
|
163
|
+
return () => {
|
|
164
|
+
if (timeoutRef.current) {
|
|
165
|
+
clearTimeout(timeoutRef.current);
|
|
166
|
+
}
|
|
167
|
+
};
|
|
168
|
+
}, [isCopied]);
|
|
169
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("div", {
|
|
170
|
+
className: "lb-code-block",
|
|
171
|
+
children: [
|
|
172
|
+
/* @__PURE__ */ jsxRuntime.jsxs("div", {
|
|
173
|
+
className: "lb-code-block-header",
|
|
174
|
+
children: [
|
|
175
|
+
/* @__PURE__ */ jsxRuntime.jsx("span", {
|
|
176
|
+
className: "lb-code-block-title",
|
|
177
|
+
children: language ?? "Plain text"
|
|
178
|
+
}),
|
|
179
|
+
/* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
180
|
+
className: "lb-code-block-header-actions",
|
|
181
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(Button.Button, {
|
|
182
|
+
className: "lb-code-block-header-action",
|
|
183
|
+
icon: isCopied ? /* @__PURE__ */ jsxRuntime.jsx(Check.CheckIcon, {}) : /* @__PURE__ */ jsxRuntime.jsx(Copy.CopyIcon, {}),
|
|
184
|
+
onClick: () => {
|
|
185
|
+
setCopied(true);
|
|
186
|
+
navigator.clipboard.writeText(code);
|
|
187
|
+
}
|
|
188
|
+
})
|
|
189
|
+
})
|
|
190
|
+
]
|
|
191
|
+
}),
|
|
192
|
+
/* @__PURE__ */ jsxRuntime.jsx("pre", {
|
|
193
|
+
className: "lb-code-block-content",
|
|
194
|
+
children: /* @__PURE__ */ jsxRuntime.jsx("code", {
|
|
195
|
+
children: code
|
|
196
|
+
})
|
|
197
|
+
})
|
|
198
|
+
]
|
|
199
|
+
});
|
|
200
|
+
}
|
|
244
201
|
const MemoizedBlockTokenComp = react.memo(
|
|
245
|
-
function BlockTokenComp({
|
|
202
|
+
function BlockTokenComp({
|
|
203
|
+
token,
|
|
204
|
+
components: components$1
|
|
205
|
+
}) {
|
|
206
|
+
const { Anchor } = components.useComponents(components$1);
|
|
246
207
|
return /* @__PURE__ */ jsxRuntime.jsx(Markdown.BlockTokenComp, {
|
|
247
|
-
token
|
|
208
|
+
token,
|
|
209
|
+
components: { CodeBlock, Anchor }
|
|
248
210
|
});
|
|
249
211
|
},
|
|
250
212
|
(prevProps, nextProps) => {
|
|
@@ -259,27 +221,42 @@ const MemoizedBlockTokenComp = react.memo(
|
|
|
259
221
|
return prevToken.raw === nextToken.raw;
|
|
260
222
|
}
|
|
261
223
|
);
|
|
262
|
-
function
|
|
224
|
+
function noop() {
|
|
225
|
+
}
|
|
226
|
+
function ToolInvocationPart({
|
|
263
227
|
chatId,
|
|
264
|
-
|
|
265
|
-
|
|
228
|
+
messageId,
|
|
229
|
+
part
|
|
266
230
|
}) {
|
|
267
231
|
const client = react$1.useClient();
|
|
268
|
-
const
|
|
269
|
-
|
|
232
|
+
const ai = client[core.kInternal].ai;
|
|
233
|
+
const tool = _private.useSignal(ai.signals.getToolDefinition\u03A3(chatId, part.toolName));
|
|
234
|
+
const respond = react.useCallback(
|
|
235
|
+
(result) => {
|
|
236
|
+
ai.setToolResult(
|
|
237
|
+
chatId,
|
|
238
|
+
messageId,
|
|
239
|
+
part.toolCallId,
|
|
240
|
+
result
|
|
241
|
+
);
|
|
242
|
+
},
|
|
243
|
+
[ai, chatId, messageId, part.toolCallId]
|
|
270
244
|
);
|
|
271
245
|
if (tool === void 0 || tool.render === void 0)
|
|
272
246
|
return null;
|
|
247
|
+
const { type: _, ...rest } = part;
|
|
273
248
|
return /* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
274
249
|
className: "lb-ai-chat-message-tool",
|
|
275
250
|
children: /* @__PURE__ */ jsxRuntime.jsx(tool.render, {
|
|
276
|
-
|
|
251
|
+
...rest,
|
|
252
|
+
respond: part.status === "executing" ? respond : noop
|
|
277
253
|
})
|
|
278
254
|
});
|
|
279
255
|
}
|
|
280
256
|
function ReasoningPart({
|
|
281
257
|
text,
|
|
282
|
-
isPending
|
|
258
|
+
isPending,
|
|
259
|
+
components
|
|
283
260
|
}) {
|
|
284
261
|
const [isOpen, setIsOpen] = react.useState(false);
|
|
285
262
|
return /* @__PURE__ */ jsxRuntime.jsxs(index.Root, {
|
|
@@ -295,14 +272,17 @@ function ReasoningPart({
|
|
|
295
272
|
children: [
|
|
296
273
|
"Reasoning",
|
|
297
274
|
/* @__PURE__ */ jsxRuntime.jsx("span", {
|
|
298
|
-
className: "lb-icon-container",
|
|
299
|
-
children:
|
|
275
|
+
className: "lb-ai-chat-message-collapsible-chevron lb-icon-container",
|
|
276
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(ChevronRight.ChevronRightIcon, {})
|
|
300
277
|
})
|
|
301
278
|
]
|
|
302
279
|
}),
|
|
303
280
|
/* @__PURE__ */ jsxRuntime.jsx(index.Content, {
|
|
304
281
|
className: "lb-ai-chat-message-collapsible-content",
|
|
305
|
-
children:
|
|
282
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(TextPart, {
|
|
283
|
+
text,
|
|
284
|
+
components
|
|
285
|
+
})
|
|
306
286
|
})
|
|
307
287
|
]
|
|
308
288
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AiChatAssistantMessage.cjs","sources":["../../../src/components/internal/AiChatAssistantMessage.tsx"],"sourcesContent":["import {\n type AiAssistantContentPart,\n type CopilotId,\n kInternal,\n type MessageId,\n type UiAssistantMessage,\n} from \"@liveblocks/core\";\nimport { useClient } from \"@liveblocks/react\";\nimport { useSignal } from \"@liveblocks/react/_private\";\nimport { Lexer } from \"marked\";\nimport {\n type ComponentProps,\n forwardRef,\n memo,\n type ReactNode,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\n\nimport { Button } from \"../../components/internal/Button\";\nimport { Tooltip, TooltipProvider } from \"../../components/internal/Tooltip\";\nimport { CheckIcon } from \"../../icons/Check\";\nimport { ChevronDownIcon } from \"../../icons/ChevronDown\";\nimport { ChevronRightIcon } from \"../../icons/ChevronRight\";\nimport { CopyIcon } from \"../../icons/Copy\";\nimport { RetryIcon } from \"../../icons/Retry\";\nimport { WarningIcon } from \"../../icons/Warning\";\nimport {\n type AiChatMessageOverrides,\n type GlobalOverrides,\n useOverrides,\n} from \"../../overrides\";\nimport * as CollapsiblePrimitive from \"../../primitives/internal/Collapsible\";\nimport {\n type BlockToken,\n BlockTokenComp as BlockTokenCompPrimitive,\n} from \"../../primitives/internal/Markdown\";\nimport { classNames } from \"../../utils/class-names\";\n\n/* -------------------------------------------------------------------------------------------------\n * AiChatAssistantMessage\n * -----------------------------------------------------------------------------------------------*/\nexport interface AiChatAssistantMessageProps extends ComponentProps<\"div\"> {\n /**\n * The message to display.\n */\n message: UiAssistantMessage;\n /**\n * Whether to show or hide message actions.\n * @internal\n */\n showActions?: boolean | \"hover\";\n /**\n * Override the component's strings.\n */\n overrides?: Partial<GlobalOverrides & AiChatMessageOverrides>;\n /**\n * @internal\n * Whether to show or hide the regenerate button.\n */\n showRegenerate?: boolean;\n /**\n * @internal\n * The id of the copilot to use to regenerate the message. Only used if `showRegenerate` is true.\n */\n copilotId?: CopilotId;\n}\n\nexport const AiChatAssistantMessage = memo(\n forwardRef<HTMLDivElement, AiChatAssistantMessageProps>(\n (\n {\n message,\n showActions = false,\n showRegenerate = false,\n copilotId,\n className,\n overrides,\n ...props\n },\n forwardedRef\n ) => {\n const $ = useOverrides(overrides);\n\n let children: ReactNode = null;\n\n function MessageActions({ text }: { text: string }) {\n if (!showActions) return null;\n\n return (\n <div className=\"lb-ai-chat-message-actions\">\n <Tooltip content={$.AI_CHAT_MESSAGE_COPY}>\n <CopyTextButton text={text} label={$.AI_CHAT_MESSAGE_COPY} />\n </Tooltip>\n\n {showRegenerate && (\n <Tooltip content={$.AI_CHAT_MESSAGE_TRY_AGAIN}>\n <RegenerateMessageButton\n chatId={message.chatId}\n messageId={message.id}\n copilotId={copilotId}\n label={$.AI_CHAT_MESSAGE_TRY_AGAIN}\n />\n </Tooltip>\n )}\n </div>\n );\n }\n\n if (message.deletedAt !== undefined) {\n children = (\n <div className=\"lb-ai-chat-message-deleted\">\n {$.AI_CHAT_MESSAGE_DELETED}\n </div>\n );\n } else if (message.status === \"pending\") {\n if (message.contentSoFar.length === 0) {\n children = (\n <div className=\"lb-ai-chat-message-thinking lb-ai-chat-pending\">\n {$.AI_CHAT_MESSAGE_THINKING}\n </div>\n );\n } else {\n children = (\n <AssistantMessageContent\n content={message.contentSoFar}\n chatId={message.chatId}\n />\n );\n }\n } else if (message.status === \"completed\") {\n const text: string = message.content.reduce((acc, part) => {\n if (part.type === \"text\") {\n return acc + part.text;\n }\n return acc;\n }, \"\");\n\n children = (\n <>\n <AssistantMessageContent\n content={message.content}\n chatId={message.chatId}\n />\n\n <MessageActions text={text} />\n </>\n );\n } else if (message.status === \"failed\") {\n const text: string = message.contentSoFar.reduce((acc, part) => {\n if (part.type === \"text\") {\n return acc + part.text;\n }\n return acc;\n }, \"\");\n\n // Do not include the error message if the user aborted the request.\n if (message.errorReason === \"Aborted by user\") {\n children = (\n <>\n <AssistantMessageContent\n content={message.contentSoFar}\n chatId={message.chatId}\n />\n <MessageActions text={text} />\n </>\n );\n } else {\n children = (\n <>\n <AssistantMessageContent\n content={message.contentSoFar}\n chatId={message.chatId}\n />\n\n <div className=\"lb-ai-chat-message-error\">\n <span className=\"lb-icon-container\">\n <WarningIcon />\n </span>\n {message.errorReason}\n </div>\n\n <MessageActions text={text} />\n </>\n );\n }\n }\n\n return (\n <TooltipProvider>\n <div\n className={classNames(\n \"lb-ai-chat-message lb-ai-chat-assistant-message\",\n showActions === \"hover\" &&\n \"lb-ai-chat-message:show-actions-hover\",\n className\n )}\n {...props}\n ref={forwardedRef}\n >\n {children}\n </div>\n </TooltipProvider>\n );\n }\n )\n);\n\nfunction CopyTextButton({ text, label }: { text: string; label: string }) {\n const [isCopied, setIsCopied] = useState(false);\n\n useEffect(() => {\n const timeoutId = setTimeout(() => {\n setIsCopied(false);\n }, 2000);\n return () => {\n clearTimeout(timeoutId);\n };\n }, [isCopied]);\n\n return (\n <Button\n onClick={function () {\n navigator.clipboard.writeText(text);\n setIsCopied(true);\n }}\n className=\"lb-ai-chat-message-action\"\n aria-label={label}\n icon={isCopied ? <CheckIcon /> : <CopyIcon />}\n />\n );\n}\n\nfunction RegenerateMessageButton({\n chatId,\n messageId,\n copilotId,\n label,\n}: {\n chatId: string;\n messageId: MessageId;\n copilotId?: CopilotId;\n label: string;\n}) {\n const client = useClient();\n\n return (\n <Button\n onClick={function () {\n client[kInternal].ai.regenerateMessage(chatId, messageId, {\n copilotId,\n stream: true,\n });\n }}\n className=\"lb-ai-chat-message-action\"\n aria-label={label}\n icon={<RetryIcon />}\n />\n );\n}\n\nfunction AssistantMessageContent({\n content,\n chatId,\n}: {\n content: AiAssistantContentPart[];\n chatId: string;\n}) {\n // A message is considered to be in \"reasoning\" state if it only contains reasoning parts and no other parts.\n const isReasoning =\n content.some((part) => part.type === \"reasoning\") &&\n content.every((part) => part.type === \"reasoning\");\n\n return (\n <div className=\"lb-ai-chat-message-content\">\n {content.map((part, index) => {\n switch (part.type) {\n case \"text\": {\n return (\n <TextPart\n key={index}\n text={part.text}\n className=\"lb-ai-chat-message-text\"\n />\n );\n }\n case \"tool-call\": {\n return (\n <ToolCallPart\n key={index}\n chatId={chatId}\n name={part.toolName}\n args={part.args}\n />\n );\n }\n case \"reasoning\": {\n return (\n <ReasoningPart\n key={index}\n text={part.text}\n isPending={isReasoning}\n />\n );\n }\n default: {\n return null;\n }\n }\n })}\n </div>\n );\n}\n\n/* -------------------------------------------------------------------------------------------------\n * TextPart\n * -----------------------------------------------------------------------------------------------*/\ninterface TextPartProps extends ComponentProps<\"div\"> {\n text: string;\n}\n\nconst TextPart = forwardRef<HTMLDivElement, TextPartProps>(\n ({ text, ...props }, forwardedRef) => {\n const tokens = useMemo(() => {\n return new Lexer().lex(text);\n }, [text]);\n\n return (\n <div ref={forwardedRef} {...props}>\n {tokens.map((token, index) => {\n return (\n <MemoizedBlockTokenComp token={token as BlockToken} key={index} />\n );\n })}\n </div>\n );\n }\n);\n\nconst MemoizedBlockTokenComp = memo(\n function BlockTokenComp({ token }: { token: BlockToken }) {\n return <BlockTokenCompPrimitive token={token} />;\n },\n (prevProps, nextProps) => {\n const prevToken = prevProps.token;\n const nextToken = nextProps.token;\n if (prevToken.raw.length !== nextToken.raw.length) {\n return false;\n }\n if (prevToken.type !== nextToken.type) {\n return false;\n }\n return prevToken.raw === nextToken.raw;\n }\n);\n\n/* -------------------------------------------------------------------------------------------------\n * ToolCallPart\n * -----------------------------------------------------------------------------------------------*/\nfunction ToolCallPart({\n chatId,\n name,\n args,\n}: {\n chatId: string;\n name: string;\n args: any;\n}) {\n const client = useClient();\n\n const tool = useSignal(\n client[kInternal].ai.signals.getToolDefinitionΣ(chatId, name)\n );\n if (tool === undefined || tool.render === undefined) return null;\n\n return (\n <div className=\"lb-ai-chat-message-tool\">\n <tool.render args={args as unknown} />\n </div>\n );\n}\n\n/* -------------------------------------------------------------------------------------------------\n * ReasoningPart\n * -----------------------------------------------------------------------------------------------*/\nfunction ReasoningPart({\n text,\n isPending,\n}: {\n text: string;\n isPending: boolean;\n}) {\n const [isOpen, setIsOpen] = useState(false);\n return (\n <CollapsiblePrimitive.Root\n className=\"lb-ai-chat-message-collapsible lb-ai-chat-message-reasoning\"\n open={isOpen}\n onOpenChange={setIsOpen}\n >\n <CollapsiblePrimitive.Trigger\n className={classNames(\n \"lb-ai-chat-message-collapsible-trigger\",\n isPending && \"lb-ai-chat-pending\"\n )}\n >\n Reasoning\n <span className=\"lb-icon-container\">\n {isOpen ? <ChevronDownIcon /> : <ChevronRightIcon />}\n </span>\n </CollapsiblePrimitive.Trigger>\n\n <CollapsiblePrimitive.Content className=\"lb-ai-chat-message-collapsible-content\">\n {text}\n </CollapsiblePrimitive.Content>\n </CollapsiblePrimitive.Root>\n );\n}\n"],"names":["memo","forwardRef","overrides","useOverrides","jsxs","jsx","Tooltip","Fragment","WarningIcon","TooltipProvider","classNames","useState","useEffect","Button","CheckIcon","CopyIcon","useClient","kInternal","RetryIcon","useMemo","Lexer","BlockTokenCompPrimitive","useSignal","CollapsiblePrimitive.Root","CollapsiblePrimitive.Trigger","ChevronDownIcon","ChevronRightIcon","CollapsiblePrimitive.Content"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"AiChatAssistantMessage.cjs","sources":["../../../src/components/internal/AiChatAssistantMessage.tsx"],"sourcesContent":["import type {\n AiAssistantContentPart,\n AiToolInvocationPart,\n Json,\n MessageId,\n UiAssistantMessage,\n} from \"@liveblocks/core\";\nimport { kInternal } from \"@liveblocks/core\";\nimport { useClient } from \"@liveblocks/react\";\nimport { useSignal } from \"@liveblocks/react/_private\";\nimport { Lexer } from \"marked\";\nimport {\n type ComponentProps,\n forwardRef,\n memo,\n type ReactNode,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\n\nimport { Button } from \"../../_private\";\nimport { type GlobalComponents, useComponents } from \"../../components\";\nimport { CheckIcon } from \"../../icons/Check\";\nimport { ChevronRightIcon } from \"../../icons/ChevronRight\";\nimport { CopyIcon } from \"../../icons/Copy\";\nimport { WarningIcon } from \"../../icons/Warning\";\nimport {\n type AiChatMessageOverrides,\n type GlobalOverrides,\n useOverrides,\n} from \"../../overrides\";\nimport * as CollapsiblePrimitive from \"../../primitives/internal/Collapsible\";\nimport {\n type BlockToken,\n BlockTokenComp as BlockTokenCompPrimitive,\n type MarkdownComponents,\n} from \"../../primitives/internal/Markdown\";\nimport { classNames } from \"../../utils/class-names\";\n\n/* -------------------------------------------------------------------------------------------------\n * AiChatAssistantMessage\n * -----------------------------------------------------------------------------------------------*/\nexport interface AiChatAssistantMessageProps extends ComponentProps<\"div\"> {\n /**\n * The message to display.\n */\n message: UiAssistantMessage;\n\n /**\n * Override the component's strings.\n */\n overrides?: Partial<GlobalOverrides & AiChatMessageOverrides>;\n\n /**\n * Override the component's components.\n */\n components?: Partial<GlobalComponents>;\n}\n\nexport const AiChatAssistantMessage = memo(\n forwardRef<HTMLDivElement, AiChatAssistantMessageProps>(\n ({ message, className, overrides, components, ...props }, forwardedRef) => {\n const $ = useOverrides(overrides);\n\n let children: ReactNode = null;\n\n if (message.deletedAt !== undefined) {\n children = (\n <div className=\"lb-ai-chat-message-deleted\">\n {$.AI_CHAT_MESSAGE_DELETED}\n </div>\n );\n } else if (\n message.status === \"generating\" ||\n message.status === \"awaiting-tool\"\n ) {\n if (message.contentSoFar.length === 0) {\n children = (\n <div className=\"lb-ai-chat-message-thinking lb-ai-chat-pending\">\n {$.AI_CHAT_MESSAGE_THINKING}\n </div>\n );\n } else {\n children = (\n <AssistantMessageContent\n content={message.contentSoFar}\n chatId={message.chatId}\n messageId={message.id}\n components={components}\n />\n );\n }\n } else if (message.status === \"completed\") {\n children = (\n <AssistantMessageContent\n content={message.content}\n chatId={message.chatId}\n messageId={message.id}\n components={components}\n />\n );\n } else if (message.status === \"failed\") {\n // Do not include the error message if the user aborted the request.\n if (message.errorReason === \"Aborted by user\") {\n children = (\n <AssistantMessageContent\n content={message.contentSoFar}\n chatId={message.chatId}\n messageId={message.id}\n components={components}\n />\n );\n } else {\n children = (\n <>\n <AssistantMessageContent\n content={message.contentSoFar}\n chatId={message.chatId}\n messageId={message.id}\n components={components}\n />\n\n <div className=\"lb-ai-chat-message-error\">\n <span className=\"lb-icon-container\">\n <WarningIcon />\n </span>\n {message.errorReason}\n </div>\n </>\n );\n }\n }\n\n return (\n <div\n className={classNames(\n \"lb-ai-chat-message lb-ai-chat-assistant-message\",\n className\n )}\n {...props}\n ref={forwardedRef}\n >\n {children}\n </div>\n );\n }\n )\n);\n\nfunction AssistantMessageContent({\n content,\n chatId,\n messageId,\n components,\n}: {\n content: AiAssistantContentPart[];\n chatId: string;\n messageId: MessageId;\n components: Partial<GlobalComponents> | undefined;\n}) {\n // A message is considered to be in \"reasoning\" state if it only contains reasoning parts and no other parts.\n const isReasoning =\n content.some((part) => part.type === \"reasoning\") &&\n content.every((part) => part.type === \"reasoning\");\n\n return (\n <div className=\"lb-ai-chat-message-content\">\n {content.map((part, index) => {\n switch (part.type) {\n case \"text\": {\n return (\n <TextPart\n key={index}\n text={part.text}\n components={components}\n className=\"lb-ai-chat-message-text\"\n />\n );\n }\n case \"tool-invocation\": {\n return (\n <ToolInvocationPart\n key={index}\n chatId={chatId}\n messageId={messageId}\n part={part}\n />\n );\n }\n case \"reasoning\": {\n return (\n <ReasoningPart\n key={index}\n text={part.text}\n isPending={isReasoning}\n components={components}\n />\n );\n }\n default: {\n return null;\n }\n }\n })}\n </div>\n );\n}\n\n/* -------------------------------------------------------------------------------------------------\n * TextPart\n * -----------------------------------------------------------------------------------------------*/\ninterface TextPartProps extends ComponentProps<\"div\"> {\n text: string;\n components: Partial<GlobalComponents> | undefined;\n}\n\nconst TextPart = forwardRef<HTMLDivElement, TextPartProps>(\n ({ text, components, ...props }, forwardedRef) => {\n const tokens = useMemo(() => {\n return new Lexer().lex(text);\n }, [text]);\n\n return (\n <div ref={forwardedRef} {...props}>\n {tokens.map((token, index) => {\n return (\n <MemoizedBlockTokenComp\n token={token as BlockToken}\n key={index}\n components={components}\n />\n );\n })}\n </div>\n );\n }\n);\n\n// TODO: Improve (better copy handling, tooltips, etc)\nfunction CodeBlock({\n language,\n code,\n}: ComponentProps<MarkdownComponents[\"CodeBlock\"]>) {\n const [isCopied, setCopied] = useState(false);\n const timeoutRef = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n useEffect(() => {\n if (isCopied) {\n timeoutRef.current = setTimeout(() => {\n setCopied(false);\n }, 1000);\n }\n\n return () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n };\n }, [isCopied]);\n\n return (\n <div className=\"lb-code-block\">\n <div className=\"lb-code-block-header\">\n <span className=\"lb-code-block-title\">{language ?? \"Plain text\"}</span>\n <div className=\"lb-code-block-header-actions\">\n <Button\n className=\"lb-code-block-header-action\"\n icon={isCopied ? <CheckIcon /> : <CopyIcon />}\n onClick={() => {\n setCopied(true);\n navigator.clipboard.writeText(code);\n }}\n />\n </div>\n </div>\n <pre className=\"lb-code-block-content\">\n <code>{code}</code>\n </pre>\n </div>\n );\n}\n\nconst MemoizedBlockTokenComp = memo(\n function BlockTokenComp({\n token,\n components,\n }: {\n token: BlockToken;\n components?: Partial<GlobalComponents>;\n }) {\n const { Anchor } = useComponents(components);\n\n return (\n <BlockTokenCompPrimitive\n token={token}\n components={{ CodeBlock, Anchor }}\n />\n );\n },\n (prevProps, nextProps) => {\n const prevToken = prevProps.token;\n const nextToken = nextProps.token;\n if (prevToken.raw.length !== nextToken.raw.length) {\n return false;\n }\n if (prevToken.type !== nextToken.type) {\n return false;\n }\n return prevToken.raw === nextToken.raw;\n }\n);\n\nfunction noop() {\n // Do nothing\n}\n\n/* -------------------------------------------------------------------------------------------------\n * ToolInvocationPart\n * -----------------------------------------------------------------------------------------------*/\nfunction ToolInvocationPart({\n chatId,\n messageId,\n part,\n}: {\n chatId: string;\n messageId: MessageId;\n part: AiToolInvocationPart;\n}) {\n const client = useClient();\n const ai = client[kInternal].ai;\n const tool = useSignal(ai.signals.getToolDefinitionΣ(chatId, part.toolName));\n const respond = useCallback(\n (result: Json) => {\n ai.setToolResult(\n chatId,\n messageId,\n part.toolCallId,\n result\n // TODO Pass in AiGenerationOptions here?\n );\n },\n [ai, chatId, messageId, part.toolCallId]\n );\n\n if (tool === undefined || tool.render === undefined) return null;\n\n const { type: _, ...rest } = part;\n return (\n <div className=\"lb-ai-chat-message-tool\">\n <tool.render\n {...rest}\n respond={\n // It only makes sense and is safe to call `respond()` in \"executing\" state.\n part.status === \"executing\" ? respond : noop\n }\n />\n </div>\n );\n}\n\n/* -------------------------------------------------------------------------------------------------\n * ReasoningPart\n * -----------------------------------------------------------------------------------------------*/\nfunction ReasoningPart({\n text,\n isPending,\n components,\n}: {\n text: string;\n isPending: boolean;\n components: Partial<GlobalComponents> | undefined;\n}) {\n const [isOpen, setIsOpen] = useState(false);\n return (\n <CollapsiblePrimitive.Root\n className=\"lb-ai-chat-message-collapsible lb-ai-chat-message-reasoning\"\n open={isOpen}\n onOpenChange={setIsOpen}\n >\n <CollapsiblePrimitive.Trigger\n className={classNames(\n \"lb-ai-chat-message-collapsible-trigger\",\n isPending && \"lb-ai-chat-pending\"\n )}\n >\n {/* TODO: If `isPending` is true, show \"Reasoning…\"/\"Thinking…\", otherwise show \"Reasoned/thought for x seconds\"? */}\n Reasoning\n <span className=\"lb-ai-chat-message-collapsible-chevron lb-icon-container\">\n <ChevronRightIcon />\n </span>\n </CollapsiblePrimitive.Trigger>\n\n <CollapsiblePrimitive.Content className=\"lb-ai-chat-message-collapsible-content\">\n <TextPart text={text} components={components} />\n </CollapsiblePrimitive.Content>\n </CollapsiblePrimitive.Root>\n );\n}\n"],"names":["memo","forwardRef","overrides","useOverrides","jsx","jsxs","Fragment","WarningIcon","classNames","useMemo","Lexer","useState","useRef","useEffect","Button","CheckIcon","CopyIcon","components","useComponents","BlockTokenCompPrimitive","useClient","kInternal","useSignal","useCallback","CollapsiblePrimitive.Root","CollapsiblePrimitive.Trigger","ChevronRightIcon","CollapsiblePrimitive.Content"],"mappings":"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"}
|