@copilotkit/react-ui 1.4.8 → 1.5.0-coagents-v0-3.0

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.
Files changed (65) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/dist/{chunk-CVHT5XCA.mjs → chunk-375NVWZM.mjs} +2 -2
  3. package/dist/{chunk-OMTPWC7T.mjs → chunk-3E7HY2UN.mjs} +5 -4
  4. package/dist/chunk-3E7HY2UN.mjs.map +1 -0
  5. package/dist/{chunk-RKPANT3F.mjs → chunk-7II4YL7R.mjs} +2 -6
  6. package/dist/chunk-7II4YL7R.mjs.map +1 -0
  7. package/dist/{chunk-46UJJGXP.mjs → chunk-DCNCY2PL.mjs} +113 -10
  8. package/dist/chunk-DCNCY2PL.mjs.map +1 -0
  9. package/dist/{chunk-DVMTTXGZ.mjs → chunk-F2W5FD7L.mjs} +2 -2
  10. package/dist/{chunk-4FIGRRFS.mjs → chunk-PNQVKBPN.mjs} +2 -2
  11. package/dist/{chunk-4FIGRRFS.mjs.map → chunk-PNQVKBPN.mjs.map} +1 -1
  12. package/dist/{chunk-752NGHCE.mjs → chunk-UWVGLGFQ.mjs} +7 -3
  13. package/dist/chunk-UWVGLGFQ.mjs.map +1 -0
  14. package/dist/{chunk-PNKBFDUI.mjs → chunk-WSMMTZCM.mjs} +2 -2
  15. package/dist/components/chat/Chat.d.ts +50 -5
  16. package/dist/components/chat/Chat.js +115 -12
  17. package/dist/components/chat/Chat.js.map +1 -1
  18. package/dist/components/chat/Chat.mjs +5 -5
  19. package/dist/components/chat/Messages.d.ts +3 -3
  20. package/dist/components/chat/Messages.js.map +1 -1
  21. package/dist/components/chat/Messages.mjs +1 -1
  22. package/dist/components/chat/Modal.d.ts +1 -1
  23. package/dist/components/chat/Modal.js +119 -12
  24. package/dist/components/chat/Modal.js.map +1 -1
  25. package/dist/components/chat/Modal.mjs +6 -6
  26. package/dist/components/chat/Popup.js +119 -12
  27. package/dist/components/chat/Popup.js.map +1 -1
  28. package/dist/components/chat/Popup.mjs +7 -7
  29. package/dist/components/chat/Sidebar.js +119 -12
  30. package/dist/components/chat/Sidebar.js.map +1 -1
  31. package/dist/components/chat/Sidebar.mjs +7 -7
  32. package/dist/components/chat/index.js +119 -12
  33. package/dist/components/chat/index.js.map +1 -1
  34. package/dist/components/chat/index.mjs +8 -8
  35. package/dist/components/chat/messages/RenderActionExecutionMessage.js +4 -3
  36. package/dist/components/chat/messages/RenderActionExecutionMessage.js.map +1 -1
  37. package/dist/components/chat/messages/RenderActionExecutionMessage.mjs +1 -1
  38. package/dist/components/dev-console/console.js +1 -1
  39. package/dist/components/dev-console/console.js.map +1 -1
  40. package/dist/components/dev-console/console.mjs +2 -2
  41. package/dist/components/dev-console/index.js +1 -1
  42. package/dist/components/dev-console/index.js.map +1 -1
  43. package/dist/components/dev-console/index.mjs +2 -2
  44. package/dist/components/dev-console/utils.js +1 -1
  45. package/dist/components/dev-console/utils.js.map +1 -1
  46. package/dist/components/dev-console/utils.mjs +1 -1
  47. package/dist/components/index.js +119 -12
  48. package/dist/components/index.js.map +1 -1
  49. package/dist/components/index.mjs +8 -8
  50. package/dist/index.js +121 -14
  51. package/dist/index.js.map +1 -1
  52. package/dist/index.mjs +8 -8
  53. package/package.json +4 -4
  54. package/src/components/chat/Chat.tsx +173 -7
  55. package/src/components/chat/Messages.tsx +2 -9
  56. package/src/components/chat/Modal.tsx +4 -0
  57. package/src/components/chat/messages/RenderActionExecutionMessage.tsx +10 -3
  58. package/src/components/dev-console/utils.ts +1 -1
  59. package/dist/chunk-46UJJGXP.mjs.map +0 -1
  60. package/dist/chunk-752NGHCE.mjs.map +0 -1
  61. package/dist/chunk-OMTPWC7T.mjs.map +0 -1
  62. package/dist/chunk-RKPANT3F.mjs.map +0 -1
  63. /package/dist/{chunk-CVHT5XCA.mjs.map → chunk-375NVWZM.mjs.map} +0 -0
  64. /package/dist/{chunk-DVMTTXGZ.mjs.map → chunk-F2W5FD7L.mjs.map} +0 -0
  65. /package/dist/{chunk-PNKBFDUI.mjs.map → chunk-WSMMTZCM.mjs.map} +0 -0
@@ -1,19 +1,19 @@
1
1
  import {
2
2
  CopilotPopup
3
- } from "../../chunk-CVHT5XCA.mjs";
4
- import "../../chunk-752NGHCE.mjs";
3
+ } from "../../chunk-375NVWZM.mjs";
4
+ import "../../chunk-UWVGLGFQ.mjs";
5
5
  import "../../chunk-YAGE7RCE.mjs";
6
6
  import "../../chunk-VEC45H6Q.mjs";
7
7
  import "../../chunk-RQNJNK2W.mjs";
8
- import "../../chunk-46UJJGXP.mjs";
8
+ import "../../chunk-DCNCY2PL.mjs";
9
9
  import "../../chunk-6INMITFA.mjs";
10
10
  import "../../chunk-RU73BEZM.mjs";
11
11
  import "../../chunk-V7W6IM2V.mjs";
12
- import "../../chunk-OMTPWC7T.mjs";
12
+ import "../../chunk-3E7HY2UN.mjs";
13
13
  import "../../chunk-ZABXREBH.mjs";
14
14
  import "../../chunk-RJCZRKTV.mjs";
15
- import "../../chunk-DVMTTXGZ.mjs";
16
- import "../../chunk-4FIGRRFS.mjs";
15
+ import "../../chunk-F2W5FD7L.mjs";
16
+ import "../../chunk-PNQVKBPN.mjs";
17
17
  import "../../chunk-KXE2JCUH.mjs";
18
18
  import "../../chunk-TI7SY2RI.mjs";
19
19
  import "../../chunk-BH6PCAAL.mjs";
@@ -21,7 +21,7 @@ import "../../chunk-OTPAZXVR.mjs";
21
21
  import "../../chunk-EMQEEXUB.mjs";
22
22
  import "../../chunk-YQFVRDNC.mjs";
23
23
  import "../../chunk-YQ3D5IQV.mjs";
24
- import "../../chunk-RKPANT3F.mjs";
24
+ import "../../chunk-7II4YL7R.mjs";
25
25
  import "../../chunk-3XAXY2Z3.mjs";
26
26
  import "../../chunk-CBBFRI3Q.mjs";
27
27
  import "../../chunk-UPTB2MVO.mjs";
@@ -944,9 +944,9 @@ var import_react7 = require("react");
944
944
  var import_react_syntax_highlighter = require("react-syntax-highlighter");
945
945
 
946
946
  // src/hooks/use-copy-to-clipboard.tsx
947
- var React6 = __toESM(require("react"));
947
+ var React5 = __toESM(require("react"));
948
948
  function useCopyToClipboard({ timeout = 2e3 }) {
949
- const [isCopied, setIsCopied] = React6.useState(false);
949
+ const [isCopied, setIsCopied] = React5.useState(false);
950
950
  const copyToClipboard = (value) => {
951
951
  var _a;
952
952
  if (typeof window === "undefined" || !((_a = navigator.clipboard) == null ? void 0 : _a.writeText)) {
@@ -1442,8 +1442,8 @@ function RenderActionExecutionMessage(props) {
1442
1442
  const { chatComponentsCache } = (0, import_react_core3.useCopilotContext)();
1443
1443
  const { icons } = useChatContext();
1444
1444
  if (message.isActionExecutionMessage()) {
1445
- if (chatComponentsCache.current !== null && chatComponentsCache.current.actions[message.name]) {
1446
- const render = chatComponentsCache.current.actions[message.name];
1445
+ if (chatComponentsCache.current !== null && (chatComponentsCache.current.actions[message.name] || chatComponentsCache.current.actions["*"])) {
1446
+ const render = chatComponentsCache.current.actions[message.name] || chatComponentsCache.current.actions["*"];
1447
1447
  if (typeof render === "string") {
1448
1448
  if (isCurrentMessage && inProgress) {
1449
1449
  return /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)("div", { className: `copilotKitMessage copilotKitAssistantMessage`, children: [
@@ -1466,7 +1466,8 @@ function RenderActionExecutionMessage(props) {
1466
1466
  const toRender = render({
1467
1467
  status,
1468
1468
  args,
1469
- result: actionResult
1469
+ result: actionResult,
1470
+ name: message.name
1470
1471
  });
1471
1472
  if (!toRender && status === "complete") {
1472
1473
  return null;
@@ -1780,7 +1781,7 @@ function logMessages(context) {
1780
1781
  type: "ActionExecutionMessage",
1781
1782
  role: void 0,
1782
1783
  name: message.name,
1783
- scope: message.scope,
1784
+ scope: message.parentMessageId,
1784
1785
  content: message.arguments
1785
1786
  };
1786
1787
  } else if (message.isResultMessage()) {
@@ -2306,6 +2307,7 @@ function DebugMenuButton({
2306
2307
  }
2307
2308
 
2308
2309
  // src/components/chat/Chat.tsx
2310
+ var import_react_core9 = require("@copilotkit/react-core");
2309
2311
  var import_jsx_runtime21 = require("react/jsx-runtime");
2310
2312
  function CopilotChat({
2311
2313
  instructions,
@@ -2313,6 +2315,8 @@ function CopilotChat({
2313
2315
  makeSystemMessage,
2314
2316
  showResponseButton = true,
2315
2317
  onInProgress,
2318
+ onStopGeneration,
2319
+ onReloadMessages,
2316
2320
  Messages: Messages2 = Messages,
2317
2321
  RenderTextMessage: RenderTextMessage2 = RenderTextMessage,
2318
2322
  RenderActionExecutionMessage: RenderActionExecutionMessage2 = RenderActionExecutionMessage,
@@ -2335,7 +2339,13 @@ function CopilotChat({
2335
2339
  sendMessage,
2336
2340
  stopGeneration,
2337
2341
  reloadMessages
2338
- } = useCopilotChatLogic(makeSystemMessage, onInProgress, onSubmitMessage);
2342
+ } = useCopilotChatLogic(
2343
+ makeSystemMessage,
2344
+ onInProgress,
2345
+ onSubmitMessage,
2346
+ onStopGeneration,
2347
+ onReloadMessages
2348
+ );
2339
2349
  const chatContext = import_react12.default.useContext(ChatContext);
2340
2350
  const isVisible = chatContext ? chatContext.open : true;
2341
2351
  return /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)(WrappedCopilotChat, { icons, labels, className, children: [
@@ -2391,8 +2401,16 @@ function WrappedCopilotChat({
2391
2401
  return /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(import_jsx_runtime21.Fragment, { children });
2392
2402
  }
2393
2403
  var SUGGESTIONS_DEBOUNCE_TIMEOUT = 1e3;
2394
- var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage) => {
2395
- const { visibleMessages, appendMessage, reloadMessages, stopGeneration, isLoading } = (0, import_react_core8.useCopilotChat)({
2404
+ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage, onStopGeneration, onReloadMessages) => {
2405
+ var _a;
2406
+ const {
2407
+ visibleMessages,
2408
+ appendMessage,
2409
+ reloadMessages: defaultReloadMessages,
2410
+ stopGeneration: defaultStopGeneration,
2411
+ runChatCompletion,
2412
+ isLoading
2413
+ } = (0, import_react_core8.useCopilotChat)({
2396
2414
  id: (0, import_shared3.randomId)(),
2397
2415
  makeSystemMessage
2398
2416
  });
@@ -2400,8 +2418,8 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage) =>
2400
2418
  const suggestionsAbortControllerRef = (0, import_react12.useRef)(null);
2401
2419
  const debounceTimerRef = (0, import_react12.useRef)();
2402
2420
  const abortSuggestions = () => {
2403
- var _a;
2404
- (_a = suggestionsAbortControllerRef.current) == null ? void 0 : _a.abort();
2421
+ var _a2;
2422
+ (_a2 = suggestionsAbortControllerRef.current) == null ? void 0 : _a2.abort();
2405
2423
  suggestionsAbortControllerRef.current = null;
2406
2424
  };
2407
2425
  const generalContext = (0, import_react_core8.useCopilotContext)();
@@ -2427,7 +2445,13 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage) =>
2427
2445
  return () => {
2428
2446
  clearTimeout(debounceTimerRef.current);
2429
2447
  };
2430
- }, [isLoading, context.chatSuggestionConfiguration]);
2448
+ }, [
2449
+ isLoading,
2450
+ context.chatSuggestionConfiguration,
2451
+ // hackish way to trigger suggestions reload on reset, but better than moving suggestions to the
2452
+ // global context
2453
+ visibleMessages.length == 0
2454
+ ]);
2431
2455
  const sendMessage = (messageContent) => __async(void 0, null, function* () {
2432
2456
  abortSuggestions();
2433
2457
  setCurrentSuggestions([]);
@@ -2445,6 +2469,85 @@ var useCopilotChatLogic = (makeSystemMessage, onInProgress, onSubmitMessage) =>
2445
2469
  appendMessage(message);
2446
2470
  return message;
2447
2471
  });
2472
+ const messages = visibleMessages;
2473
+ const { setMessages } = messagesContext;
2474
+ const currentAgentName = (_a = generalContext.agentSession) == null ? void 0 : _a.agentName;
2475
+ const restartCurrentAgent = (hint) => __async(void 0, null, function* () {
2476
+ if (generalContext.agentSession) {
2477
+ generalContext.setAgentSession(__spreadProps(__spreadValues({}, generalContext.agentSession), {
2478
+ nodeName: void 0,
2479
+ threadId: void 0
2480
+ }));
2481
+ generalContext.setCoagentStates((prevAgentStates) => {
2482
+ return __spreadProps(__spreadValues({}, prevAgentStates), {
2483
+ [generalContext.agentSession.agentName]: __spreadProps(__spreadValues({}, prevAgentStates[generalContext.agentSession.agentName]), {
2484
+ threadId: void 0,
2485
+ nodeName: void 0,
2486
+ runId: void 0
2487
+ })
2488
+ });
2489
+ });
2490
+ }
2491
+ });
2492
+ const runCurrentAgent = (hint) => __async(void 0, null, function* () {
2493
+ if (generalContext.agentSession) {
2494
+ yield (0, import_react_core9.runAgent)(
2495
+ generalContext.agentSession.agentName,
2496
+ context,
2497
+ appendMessage,
2498
+ runChatCompletion,
2499
+ hint
2500
+ );
2501
+ }
2502
+ });
2503
+ const stopCurrentAgent = () => {
2504
+ if (generalContext.agentSession) {
2505
+ (0, import_react_core9.stopAgent)(generalContext.agentSession.agentName, context);
2506
+ }
2507
+ };
2508
+ const setCurrentAgentState = (state) => {
2509
+ if (generalContext.agentSession) {
2510
+ generalContext.setCoagentStates((prevAgentStates) => {
2511
+ return __spreadProps(__spreadValues({}, prevAgentStates), {
2512
+ [generalContext.agentSession.agentName]: {
2513
+ state
2514
+ }
2515
+ });
2516
+ });
2517
+ }
2518
+ };
2519
+ function stopGeneration() {
2520
+ if (onStopGeneration) {
2521
+ onStopGeneration({
2522
+ messages,
2523
+ setMessages,
2524
+ stopGeneration: defaultStopGeneration,
2525
+ currentAgentName,
2526
+ restartCurrentAgent,
2527
+ stopCurrentAgent,
2528
+ runCurrentAgent,
2529
+ setCurrentAgentState
2530
+ });
2531
+ } else {
2532
+ defaultStopGeneration();
2533
+ }
2534
+ }
2535
+ function reloadMessages() {
2536
+ if (onReloadMessages) {
2537
+ onReloadMessages({
2538
+ messages,
2539
+ setMessages,
2540
+ stopGeneration: defaultStopGeneration,
2541
+ currentAgentName,
2542
+ restartCurrentAgent,
2543
+ stopCurrentAgent,
2544
+ runCurrentAgent,
2545
+ setCurrentAgentState
2546
+ });
2547
+ } else {
2548
+ defaultReloadMessages();
2549
+ }
2550
+ }
2448
2551
  return {
2449
2552
  visibleMessages,
2450
2553
  isLoading,
@@ -2464,6 +2567,8 @@ var CopilotModal = ({
2464
2567
  hitEscapeToClose = true,
2465
2568
  onSetOpen,
2466
2569
  onSubmitMessage,
2570
+ onStopGeneration,
2571
+ onReloadMessages,
2467
2572
  shortcut = "/",
2468
2573
  icons,
2469
2574
  labels,
@@ -2501,6 +2606,8 @@ var CopilotModal = ({
2501
2606
  {
2502
2607
  instructions,
2503
2608
  onSubmitMessage,
2609
+ onStopGeneration,
2610
+ onReloadMessages,
2504
2611
  makeSystemMessage,
2505
2612
  showResponseButton,
2506
2613
  onInProgress,