@polpo-ai/react 0.4.2 → 0.4.4
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/hooks/use-active-delays.d.ts +9 -1
- package/dist/hooks/use-active-delays.d.ts.map +1 -1
- package/dist/hooks/use-active-delays.js +27 -1
- package/dist/hooks/use-active-delays.js.map +1 -1
- package/dist/hooks/use-attachments.d.ts +13 -0
- package/dist/hooks/use-attachments.d.ts.map +1 -0
- package/dist/hooks/use-attachments.js +51 -0
- package/dist/hooks/use-attachments.js.map +1 -0
- package/dist/hooks/use-chat.d.ts +54 -0
- package/dist/hooks/use-chat.d.ts.map +1 -0
- package/dist/hooks/use-chat.js +177 -0
- package/dist/hooks/use-chat.js.map +1 -0
- package/dist/hooks/use-files.d.ts +15 -0
- package/dist/hooks/use-files.d.ts.map +1 -0
- package/dist/hooks/use-files.js +73 -0
- package/dist/hooks/use-files.js.map +1 -0
- package/dist/hooks/use-playbooks.d.ts +10 -1
- package/dist/hooks/use-playbooks.d.ts.map +1 -1
- package/dist/hooks/use-playbooks.js +13 -0
- package/dist/hooks/use-playbooks.js.map +1 -1
- package/dist/hooks/use-schedules.d.ts +7 -1
- package/dist/hooks/use-schedules.d.ts.map +1 -1
- package/dist/hooks/use-schedules.js +16 -1
- package/dist/hooks/use-schedules.js.map +1 -1
- package/dist/hooks/use-skills.d.ts +14 -1
- package/dist/hooks/use-skills.d.ts.map +1 -1
- package/dist/hooks/use-skills.js +26 -1
- package/dist/hooks/use-skills.js.map +1 -1
- package/dist/hooks/use-vault-entries.d.ts +31 -0
- package/dist/hooks/use-vault-entries.d.ts.map +1 -1
- package/dist/hooks/use-vault-entries.js +27 -1
- package/dist/hooks/use-vault-entries.js.map +1 -1
- package/dist/index.d.ts +12 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { ActiveDelay } from "@polpo-ai/sdk";
|
|
1
|
+
import type { ActiveDelay, AddMissionDelayRequest, UpdateMissionDelayRequest, Mission } from "@polpo-ai/sdk";
|
|
2
2
|
export interface UseActiveDelaysReturn {
|
|
3
3
|
/** Active delays from SSE events (live, updated by delay:started/delay:expired). */
|
|
4
4
|
activeDelays: ActiveDelay[];
|
|
@@ -7,6 +7,12 @@ export interface UseActiveDelaysReturn {
|
|
|
7
7
|
/** Refetch from server. */
|
|
8
8
|
refetch: () => void;
|
|
9
9
|
loading: boolean;
|
|
10
|
+
addDelay: (missionId: string, req: AddMissionDelayRequest) => Promise<Mission>;
|
|
11
|
+
isAdding: boolean;
|
|
12
|
+
updateDelay: (missionId: string, delayName: string, req: UpdateMissionDelayRequest) => Promise<Mission>;
|
|
13
|
+
isUpdating: boolean;
|
|
14
|
+
removeDelay: (missionId: string, delayName: string) => Promise<Mission>;
|
|
15
|
+
isRemoving: boolean;
|
|
10
16
|
}
|
|
11
17
|
/**
|
|
12
18
|
* Hook for accessing active delay timers.
|
|
@@ -14,6 +20,8 @@ export interface UseActiveDelaysReturn {
|
|
|
14
20
|
* Combines two sources:
|
|
15
21
|
* 1. SSE events (delay:started / delay:expired) → store.activeDelays (real-time)
|
|
16
22
|
* 2. Initial fetch from GET /missions/delays (catches delays that started before SSE connected)
|
|
23
|
+
*
|
|
24
|
+
* Includes mutations: addDelay, updateDelay, removeDelay — each auto-refetches on success.
|
|
17
25
|
*/
|
|
18
26
|
export declare function useActiveDelays(): UseActiveDelaysReturn;
|
|
19
27
|
//# sourceMappingURL=use-active-delays.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-active-delays.d.ts","sourceRoot":"","sources":["../../src/hooks/use-active-delays.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"use-active-delays.d.ts","sourceRoot":"","sources":["../../src/hooks/use-active-delays.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,WAAW,EAAE,sBAAsB,EAAE,yBAAyB,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAE7G,MAAM,WAAW,qBAAqB;IACpC,oFAAoF;IACpF,YAAY,EAAE,WAAW,EAAE,CAAC;IAC5B,4DAA4D;IAC5D,aAAa,EAAE,WAAW,EAAE,CAAC;IAC7B,2BAA2B;IAC3B,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,sBAAsB,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IAC/E,QAAQ,EAAE,OAAO,CAAC;IAClB,WAAW,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,yBAAyB,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IACxG,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IACxE,UAAU,EAAE,OAAO,CAAC;CACrB;AAED;;;;;;;;GAQG;AACH,wBAAgB,eAAe,IAAI,qBAAqB,CAgFvD"}
|
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
import { useSyncExternalStore, useState, useEffect, useCallback } from "react";
|
|
2
2
|
import { usePolpoContext } from "../provider/polpo-context.js";
|
|
3
|
+
import { useMutation } from "./use-mutation.js";
|
|
3
4
|
/**
|
|
4
5
|
* Hook for accessing active delay timers.
|
|
5
6
|
*
|
|
6
7
|
* Combines two sources:
|
|
7
8
|
* 1. SSE events (delay:started / delay:expired) → store.activeDelays (real-time)
|
|
8
9
|
* 2. Initial fetch from GET /missions/delays (catches delays that started before SSE connected)
|
|
10
|
+
*
|
|
11
|
+
* Includes mutations: addDelay, updateDelay, removeDelay — each auto-refetches on success.
|
|
9
12
|
*/
|
|
10
13
|
export function useActiveDelays() {
|
|
11
14
|
const { client, store } = usePolpoContext();
|
|
@@ -32,6 +35,29 @@ export function useActiveDelays() {
|
|
|
32
35
|
}, [client, store, fetchCount]);
|
|
33
36
|
// Merge: store has real-time data, fetched fills in pre-existing delays
|
|
34
37
|
const activeDelays = Array.from(storeDelays.values());
|
|
35
|
-
|
|
38
|
+
const { mutate: addDelay, isPending: isAdding } = useMutation(useCallback(async (missionId, req) => {
|
|
39
|
+
const result = await client.addMissionDelay(missionId, req);
|
|
40
|
+
return result;
|
|
41
|
+
}, [client]), { onSuccess: () => { refetch(); } });
|
|
42
|
+
const { mutate: updateDelay, isPending: isUpdating } = useMutation(useCallback(async (missionId, delayName, req) => {
|
|
43
|
+
const result = await client.updateMissionDelay(missionId, delayName, req);
|
|
44
|
+
return result;
|
|
45
|
+
}, [client]), { onSuccess: () => { refetch(); } });
|
|
46
|
+
const { mutate: removeDelay, isPending: isRemoving } = useMutation(useCallback(async (missionId, delayName) => {
|
|
47
|
+
const result = await client.removeMissionDelay(missionId, delayName);
|
|
48
|
+
return result;
|
|
49
|
+
}, [client]), { onSuccess: () => { refetch(); } });
|
|
50
|
+
return {
|
|
51
|
+
activeDelays,
|
|
52
|
+
fetchedDelays,
|
|
53
|
+
refetch,
|
|
54
|
+
loading,
|
|
55
|
+
addDelay,
|
|
56
|
+
isAdding,
|
|
57
|
+
updateDelay,
|
|
58
|
+
isUpdating,
|
|
59
|
+
removeDelay,
|
|
60
|
+
isRemoving,
|
|
61
|
+
};
|
|
36
62
|
}
|
|
37
63
|
//# sourceMappingURL=use-active-delays.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-active-delays.js","sourceRoot":"","sources":["../../src/hooks/use-active-delays.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AAC/E,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"use-active-delays.js","sourceRoot":"","sources":["../../src/hooks/use-active-delays.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Attachment } from "@polpo-ai/sdk";
|
|
2
|
+
export interface UseAttachmentsReturn {
|
|
3
|
+
attachments: Attachment[];
|
|
4
|
+
isLoading: boolean;
|
|
5
|
+
error: Error | null;
|
|
6
|
+
uploadAttachment: (file: File | Blob, filename: string) => Promise<Attachment>;
|
|
7
|
+
isUploading: boolean;
|
|
8
|
+
deleteAttachment: (id: string) => Promise<void>;
|
|
9
|
+
isDeleting: boolean;
|
|
10
|
+
refetch: () => Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
export declare function useAttachments(sessionId: string | undefined): UseAttachmentsReturn;
|
|
13
|
+
//# sourceMappingURL=use-attachments.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-attachments.d.ts","sourceRoot":"","sources":["../../src/hooks/use-attachments.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAEhD,MAAM,WAAW,oBAAoB;IACnC,WAAW,EAAE,UAAU,EAAE,CAAC;IAC1B,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,gBAAgB,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,EAAE,QAAQ,EAAE,MAAM,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;IAC/E,WAAW,EAAE,OAAO,CAAC;IACrB,gBAAgB,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAChD,UAAU,EAAE,OAAO,CAAC;IACpB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9B;AAED,wBAAgB,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,SAAS,GAAG,oBAAoB,CA2DlF"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { useCallback, useEffect, useState } from "react";
|
|
2
|
+
import { usePolpoContext } from "../provider/polpo-context.js";
|
|
3
|
+
import { useMutation } from "./use-mutation.js";
|
|
4
|
+
export function useAttachments(sessionId) {
|
|
5
|
+
const { client } = usePolpoContext();
|
|
6
|
+
const [attachments, setAttachments] = useState([]);
|
|
7
|
+
const [isLoading, setIsLoading] = useState(true);
|
|
8
|
+
const [error, setError] = useState(null);
|
|
9
|
+
const refetch = useCallback(async () => {
|
|
10
|
+
if (!sessionId)
|
|
11
|
+
return;
|
|
12
|
+
try {
|
|
13
|
+
const data = await client.listAttachments(sessionId);
|
|
14
|
+
setAttachments(data);
|
|
15
|
+
}
|
|
16
|
+
catch (err) {
|
|
17
|
+
setError(err);
|
|
18
|
+
}
|
|
19
|
+
}, [client, sessionId]);
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
if (!sessionId) {
|
|
22
|
+
setAttachments([]);
|
|
23
|
+
setIsLoading(false);
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
setIsLoading(true);
|
|
27
|
+
refetch().finally(() => setIsLoading(false));
|
|
28
|
+
}, [refetch, sessionId]);
|
|
29
|
+
const { mutate: uploadAttachment, isPending: isUploading } = useMutation(useCallback(async (file, filename) => {
|
|
30
|
+
if (!sessionId)
|
|
31
|
+
throw new Error("sessionId is required");
|
|
32
|
+
const attachment = await client.uploadAttachment(sessionId, file, filename);
|
|
33
|
+
setAttachments((prev) => [...prev, attachment]);
|
|
34
|
+
return attachment;
|
|
35
|
+
}, [client, sessionId]));
|
|
36
|
+
const { mutate: deleteAttachment, isPending: isDeleting } = useMutation(useCallback(async (id) => {
|
|
37
|
+
await client.deleteAttachment(id);
|
|
38
|
+
setAttachments((prev) => prev.filter((a) => a.id !== id));
|
|
39
|
+
}, [client]));
|
|
40
|
+
return {
|
|
41
|
+
attachments,
|
|
42
|
+
isLoading,
|
|
43
|
+
error,
|
|
44
|
+
uploadAttachment,
|
|
45
|
+
isUploading,
|
|
46
|
+
deleteAttachment,
|
|
47
|
+
isDeleting,
|
|
48
|
+
refetch,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=use-attachments.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-attachments.js","sourceRoot":"","sources":["../../src/hooks/use-attachments.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAchD,MAAM,UAAU,cAAc,CAAC,SAA6B;IAC1D,MAAM,EAAE,MAAM,EAAE,GAAG,eAAe,EAAE,CAAC;IAErC,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAe,EAAE,CAAC,CAAC;IACjE,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;IACjD,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IAEvD,MAAM,OAAO,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QACrC,IAAI,CAAC,SAAS;YAAE,OAAO;QACvB,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;YACrD,cAAc,CAAC,IAAI,CAAC,CAAC;QACvB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,QAAQ,CAAC,GAAY,CAAC,CAAC;QACzB,CAAC;IACH,CAAC,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;IAExB,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,cAAc,CAAC,EAAE,CAAC,CAAC;YACnB,YAAY,CAAC,KAAK,CAAC,CAAC;YACpB,OAAO;QACT,CAAC;QACD,YAAY,CAAC,IAAI,CAAC,CAAC;QACnB,OAAO,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;IAC/C,CAAC,EAAE,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC;IAEzB,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,WAAW,CACtE,WAAW,CACT,KAAK,EAAE,IAAiB,EAAE,QAAgB,EAAE,EAAE;QAC5C,IAAI,CAAC,SAAS;YAAE,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;QACzD,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC;QAC5E,cAAc,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC;QAChD,OAAO,UAAU,CAAC;IACpB,CAAC,EACD,CAAC,MAAM,EAAE,SAAS,CAAC,CACpB,CACF,CAAC;IAEF,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,WAAW,CACrE,WAAW,CACT,KAAK,EAAE,EAAU,EAAE,EAAE;QACnB,MAAM,MAAM,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC;QAClC,cAAc,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;IAC5D,CAAC,EACD,CAAC,MAAM,CAAC,CACT,CACF,CAAC;IAEF,OAAO;QACL,WAAW;QACX,SAAS;QACT,KAAK;QACL,gBAAgB;QAChB,WAAW;QACX,gBAAgB;QAChB,UAAU;QACV,OAAO;KACR,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import type { ChatMessage, ChatCompletionChunk, AskUserPayload, MissionPreviewPayload, VaultPreviewPayload, OpenFilePayload, NavigateToPayload, OpenTabPayload, ToolCallEvent } from "@polpo-ai/sdk";
|
|
2
|
+
export interface UseChatOptions {
|
|
3
|
+
/** Target a specific agent for direct conversation. Omit for orchestrator mode. */
|
|
4
|
+
agent?: string;
|
|
5
|
+
/** Resume an existing session by ID. If omitted, the server auto-creates or reuses one (30-min window). */
|
|
6
|
+
sessionId?: string;
|
|
7
|
+
/** Called on each streaming text chunk. */
|
|
8
|
+
onChunk?: (chunk: ChatCompletionChunk) => void;
|
|
9
|
+
/** Called when the stream completes. */
|
|
10
|
+
onFinish?: (text: string) => void;
|
|
11
|
+
/** Called on error. */
|
|
12
|
+
onError?: (error: Error) => void;
|
|
13
|
+
/** Called when the agent asks clarifying questions. */
|
|
14
|
+
onAskUser?: (payload: AskUserPayload) => void;
|
|
15
|
+
/** Called when the agent proposes a mission for review. */
|
|
16
|
+
onMissionPreview?: (payload: MissionPreviewPayload) => void;
|
|
17
|
+
/** Called when the agent proposes a vault entry. */
|
|
18
|
+
onVaultPreview?: (payload: VaultPreviewPayload) => void;
|
|
19
|
+
/** Called when the agent wants to open a file. */
|
|
20
|
+
onOpenFile?: (payload: OpenFilePayload) => void;
|
|
21
|
+
/** Called when the agent wants to navigate the UI. */
|
|
22
|
+
onNavigateTo?: (payload: NavigateToPayload) => void;
|
|
23
|
+
/** Called when the agent wants to open a URL. */
|
|
24
|
+
onOpenTab?: (payload: OpenTabPayload) => void;
|
|
25
|
+
/** Called when a tool call event is emitted. */
|
|
26
|
+
onToolCall?: (toolCall: ToolCallEvent) => void;
|
|
27
|
+
}
|
|
28
|
+
export type ChatStatus = "idle" | "streaming" | "error";
|
|
29
|
+
export interface UseChatReturn {
|
|
30
|
+
/** All messages in the current session (user + assistant). */
|
|
31
|
+
messages: ChatMessage[];
|
|
32
|
+
/** Send a message (text or multimodal content parts). Streams the response automatically. */
|
|
33
|
+
sendMessage: (content: string | import("@polpo-ai/sdk").ContentPart[]) => Promise<void>;
|
|
34
|
+
/** Current session ID. `null` until the first response from the server. */
|
|
35
|
+
sessionId: string | null;
|
|
36
|
+
/** Set the session ID manually (e.g. to resume a different session). Loads its messages. */
|
|
37
|
+
setSessionId: (id: string | null) => Promise<void>;
|
|
38
|
+
/** Start a new session. Clears messages and session ID. */
|
|
39
|
+
newSession: () => void;
|
|
40
|
+
/** Current status. */
|
|
41
|
+
status: ChatStatus;
|
|
42
|
+
/** Last error, if any. */
|
|
43
|
+
error: Error | null;
|
|
44
|
+
/** Whether a response is currently streaming. */
|
|
45
|
+
isStreaming: boolean;
|
|
46
|
+
/** The text being streamed for the current assistant response. */
|
|
47
|
+
streamingText: string;
|
|
48
|
+
/** Active tool calls during the current response. */
|
|
49
|
+
activeToolCalls: ToolCallEvent[];
|
|
50
|
+
/** Abort the current streaming response. */
|
|
51
|
+
abort: () => void;
|
|
52
|
+
}
|
|
53
|
+
export declare function useChat(options?: UseChatOptions): UseChatReturn;
|
|
54
|
+
//# sourceMappingURL=use-chat.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-chat.d.ts","sourceRoot":"","sources":["../../src/hooks/use-chat.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,WAAW,EACX,mBAAmB,EAEnB,cAAc,EACd,qBAAqB,EACrB,mBAAmB,EACnB,eAAe,EACf,iBAAiB,EACjB,cAAc,EACd,aAAa,EACd,MAAM,eAAe,CAAC;AAKvB,MAAM,WAAW,cAAc;IAC7B,mFAAmF;IACnF,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,2GAA2G;IAC3G,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,2CAA2C;IAC3C,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,mBAAmB,KAAK,IAAI,CAAC;IAC/C,wCAAwC;IACxC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,uBAAuB;IACvB,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IACjC,uDAAuD;IACvD,SAAS,CAAC,EAAE,CAAC,OAAO,EAAE,cAAc,KAAK,IAAI,CAAC;IAC9C,2DAA2D;IAC3D,gBAAgB,CAAC,EAAE,CAAC,OAAO,EAAE,qBAAqB,KAAK,IAAI,CAAC;IAC5D,oDAAoD;IACpD,cAAc,CAAC,EAAE,CAAC,OAAO,EAAE,mBAAmB,KAAK,IAAI,CAAC;IACxD,kDAAkD;IAClD,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,eAAe,KAAK,IAAI,CAAC;IAChD,sDAAsD;IACtD,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,IAAI,CAAC;IACpD,iDAAiD;IACjD,SAAS,CAAC,EAAE,CAAC,OAAO,EAAE,cAAc,KAAK,IAAI,CAAC;IAC9C,gDAAgD;IAChD,UAAU,CAAC,EAAE,CAAC,QAAQ,EAAE,aAAa,KAAK,IAAI,CAAC;CAChD;AAED,MAAM,MAAM,UAAU,GAAG,MAAM,GAAG,WAAW,GAAG,OAAO,CAAC;AAExD,MAAM,WAAW,aAAa;IAC5B,8DAA8D;IAC9D,QAAQ,EAAE,WAAW,EAAE,CAAC;IACxB,6FAA6F;IAC7F,WAAW,EAAE,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,eAAe,EAAE,WAAW,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACxF,2EAA2E;IAC3E,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,4FAA4F;IAC5F,YAAY,EAAE,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACnD,2DAA2D;IAC3D,UAAU,EAAE,MAAM,IAAI,CAAC;IACvB,sBAAsB;IACtB,MAAM,EAAE,UAAU,CAAC;IACnB,0BAA0B;IAC1B,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,iDAAiD;IACjD,WAAW,EAAE,OAAO,CAAC;IACrB,kEAAkE;IAClE,aAAa,EAAE,MAAM,CAAC;IACtB,qDAAqD;IACrD,eAAe,EAAE,aAAa,EAAE,CAAC;IACjC,4CAA4C;IAC5C,KAAK,EAAE,MAAM,IAAI,CAAC;CACnB;AAID,wBAAgB,OAAO,CAAC,OAAO,GAAE,cAAmB,GAAG,aAAa,CAgMnE"}
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
import { useCallback, useRef, useState } from "react";
|
|
2
|
+
import { usePolpoContext } from "../provider/polpo-context.js";
|
|
3
|
+
import { ChatCompletionStream } from "@polpo-ai/sdk";
|
|
4
|
+
// ── Hook ─────────────────────────────────────────────────
|
|
5
|
+
export function useChat(options = {}) {
|
|
6
|
+
const { client } = usePolpoContext();
|
|
7
|
+
const [messages, setMessages] = useState([]);
|
|
8
|
+
const [sessionId, setSessionIdState] = useState(options.sessionId ?? null);
|
|
9
|
+
const [status, setStatus] = useState("idle");
|
|
10
|
+
const [error, setError] = useState(null);
|
|
11
|
+
const [streamingText, setStreamingText] = useState("");
|
|
12
|
+
const [activeToolCalls, setActiveToolCalls] = useState([]);
|
|
13
|
+
const streamRef = useRef(null);
|
|
14
|
+
const sessionIdRef = useRef(options.sessionId ?? null);
|
|
15
|
+
const setSessionId = useCallback(async (id) => {
|
|
16
|
+
setSessionIdState(id);
|
|
17
|
+
sessionIdRef.current = id;
|
|
18
|
+
if (id) {
|
|
19
|
+
try {
|
|
20
|
+
const data = await client.getSessionMessages(id);
|
|
21
|
+
setMessages(data.messages);
|
|
22
|
+
}
|
|
23
|
+
catch {
|
|
24
|
+
setMessages([]);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
setMessages([]);
|
|
29
|
+
}
|
|
30
|
+
setStatus("idle");
|
|
31
|
+
setError(null);
|
|
32
|
+
setStreamingText("");
|
|
33
|
+
setActiveToolCalls([]);
|
|
34
|
+
}, [client]);
|
|
35
|
+
const newSession = useCallback(() => {
|
|
36
|
+
streamRef.current?.abort();
|
|
37
|
+
setSessionIdState(null);
|
|
38
|
+
sessionIdRef.current = null;
|
|
39
|
+
setMessages([]);
|
|
40
|
+
setStatus("idle");
|
|
41
|
+
setError(null);
|
|
42
|
+
setStreamingText("");
|
|
43
|
+
setActiveToolCalls([]);
|
|
44
|
+
}, []);
|
|
45
|
+
const abort = useCallback(() => {
|
|
46
|
+
streamRef.current?.abort();
|
|
47
|
+
}, []);
|
|
48
|
+
const sendMessage = useCallback(async (content) => {
|
|
49
|
+
const userText = typeof content === "string" ? content : content.filter(p => p.type === "text").map(p => p.text).join(" ");
|
|
50
|
+
// Optimistic: add user message immediately
|
|
51
|
+
const userMsg = {
|
|
52
|
+
id: `tmp-${Date.now()}`,
|
|
53
|
+
role: "user",
|
|
54
|
+
content: userText,
|
|
55
|
+
ts: new Date().toISOString(),
|
|
56
|
+
};
|
|
57
|
+
setMessages((prev) => [...prev, userMsg]);
|
|
58
|
+
setStatus("streaming");
|
|
59
|
+
setError(null);
|
|
60
|
+
setStreamingText("");
|
|
61
|
+
setActiveToolCalls([]);
|
|
62
|
+
try {
|
|
63
|
+
// Build messages array: full history + new message
|
|
64
|
+
const historyMessages = messages.map((m) => ({
|
|
65
|
+
role: m.role,
|
|
66
|
+
content: m.content,
|
|
67
|
+
}));
|
|
68
|
+
historyMessages.push({
|
|
69
|
+
role: "user",
|
|
70
|
+
content: typeof content === "string" ? content : content,
|
|
71
|
+
});
|
|
72
|
+
const stream = client.chatCompletionsStream({
|
|
73
|
+
messages: historyMessages,
|
|
74
|
+
sessionId: sessionIdRef.current ?? undefined,
|
|
75
|
+
agent: options.agent,
|
|
76
|
+
});
|
|
77
|
+
streamRef.current = stream;
|
|
78
|
+
let fullText = "";
|
|
79
|
+
for await (const chunk of stream) {
|
|
80
|
+
// Capture session ID from the stream (set after first chunk)
|
|
81
|
+
if (stream.sessionId && !sessionIdRef.current) {
|
|
82
|
+
sessionIdRef.current = stream.sessionId;
|
|
83
|
+
setSessionIdState(stream.sessionId);
|
|
84
|
+
}
|
|
85
|
+
const choice = chunk.choices[0];
|
|
86
|
+
if (!choice)
|
|
87
|
+
continue;
|
|
88
|
+
// Text content
|
|
89
|
+
if (choice.delta.content) {
|
|
90
|
+
fullText += choice.delta.content;
|
|
91
|
+
setStreamingText(fullText);
|
|
92
|
+
}
|
|
93
|
+
// Tool calls
|
|
94
|
+
if (choice.tool_call) {
|
|
95
|
+
setActiveToolCalls((prev) => {
|
|
96
|
+
const idx = prev.findIndex((tc) => tc.id === choice.tool_call.id);
|
|
97
|
+
if (idx >= 0) {
|
|
98
|
+
const next = [...prev];
|
|
99
|
+
next[idx] = choice.tool_call;
|
|
100
|
+
return next;
|
|
101
|
+
}
|
|
102
|
+
return [...prev, choice.tool_call];
|
|
103
|
+
});
|
|
104
|
+
options.onToolCall?.(choice.tool_call);
|
|
105
|
+
}
|
|
106
|
+
// Special finish reasons
|
|
107
|
+
if (choice.finish_reason === "ask_user" && choice.ask_user) {
|
|
108
|
+
options.onAskUser?.(choice.ask_user);
|
|
109
|
+
}
|
|
110
|
+
if (choice.finish_reason === "mission_preview" && choice.mission_preview) {
|
|
111
|
+
options.onMissionPreview?.(choice.mission_preview);
|
|
112
|
+
}
|
|
113
|
+
if (choice.finish_reason === "vault_preview" && choice.vault_preview) {
|
|
114
|
+
options.onVaultPreview?.(choice.vault_preview);
|
|
115
|
+
}
|
|
116
|
+
if (choice.finish_reason === "open_file" && choice.open_file) {
|
|
117
|
+
options.onOpenFile?.(choice.open_file);
|
|
118
|
+
}
|
|
119
|
+
if (choice.finish_reason === "navigate_to" && choice.navigate_to) {
|
|
120
|
+
options.onNavigateTo?.(choice.navigate_to);
|
|
121
|
+
}
|
|
122
|
+
if (choice.finish_reason === "open_tab" && choice.open_tab) {
|
|
123
|
+
options.onOpenTab?.(choice.open_tab);
|
|
124
|
+
}
|
|
125
|
+
options.onChunk?.(chunk);
|
|
126
|
+
}
|
|
127
|
+
// Stream finished — add assistant message
|
|
128
|
+
if (fullText) {
|
|
129
|
+
const assistantMsg = {
|
|
130
|
+
id: `msg-${Date.now()}`,
|
|
131
|
+
role: "assistant",
|
|
132
|
+
content: fullText,
|
|
133
|
+
ts: new Date().toISOString(),
|
|
134
|
+
};
|
|
135
|
+
setMessages((prev) => [...prev, assistantMsg]);
|
|
136
|
+
}
|
|
137
|
+
setStreamingText("");
|
|
138
|
+
setActiveToolCalls([]);
|
|
139
|
+
setStatus("idle");
|
|
140
|
+
streamRef.current = null;
|
|
141
|
+
options.onFinish?.(fullText);
|
|
142
|
+
}
|
|
143
|
+
catch (err) {
|
|
144
|
+
if (err?.name === "AbortError") {
|
|
145
|
+
// User aborted — keep partial text as message if any
|
|
146
|
+
const partial = streamingText;
|
|
147
|
+
if (partial) {
|
|
148
|
+
setMessages((prev) => [
|
|
149
|
+
...prev,
|
|
150
|
+
{ id: `msg-${Date.now()}`, role: "assistant", content: partial, ts: new Date().toISOString() },
|
|
151
|
+
]);
|
|
152
|
+
}
|
|
153
|
+
setStreamingText("");
|
|
154
|
+
setActiveToolCalls([]);
|
|
155
|
+
setStatus("idle");
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
setError(err);
|
|
159
|
+
setStatus("error");
|
|
160
|
+
options.onError?.(err);
|
|
161
|
+
}
|
|
162
|
+
}, [client, messages, options, streamingText]);
|
|
163
|
+
return {
|
|
164
|
+
messages,
|
|
165
|
+
sendMessage,
|
|
166
|
+
sessionId,
|
|
167
|
+
setSessionId,
|
|
168
|
+
newSession,
|
|
169
|
+
status,
|
|
170
|
+
error,
|
|
171
|
+
isStreaming: status === "streaming",
|
|
172
|
+
streamingText,
|
|
173
|
+
activeToolCalls,
|
|
174
|
+
abort,
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
//# sourceMappingURL=use-chat.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-chat.js","sourceRoot":"","sources":["../../src/hooks/use-chat.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { FileRoot, FileEntry, FilePreview } from "@polpo-ai/sdk";
|
|
2
|
+
export interface UseFilesReturn {
|
|
3
|
+
roots: FileRoot[];
|
|
4
|
+
entries: FileEntry[];
|
|
5
|
+
currentPath: string | null;
|
|
6
|
+
isLoading: boolean;
|
|
7
|
+
error: Error | null;
|
|
8
|
+
listFiles: (root: string, path?: string) => Promise<FileEntry[]>;
|
|
9
|
+
isListing: boolean;
|
|
10
|
+
previewFile: (root: string, path: string, maxLines?: number) => Promise<FilePreview>;
|
|
11
|
+
isPreviewing: boolean;
|
|
12
|
+
refetchRoots: () => Promise<void>;
|
|
13
|
+
}
|
|
14
|
+
export declare function useFiles(root?: string, path?: string): UseFilesReturn;
|
|
15
|
+
//# sourceMappingURL=use-files.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-files.d.ts","sourceRoot":"","sources":["../../src/hooks/use-files.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAEtE,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,OAAO,EAAE,SAAS,EAAE,CAAC;IACrB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,SAAS,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;IACjE,SAAS,EAAE,OAAO,CAAC;IACnB,WAAW,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,WAAW,CAAC,CAAC;IACrF,YAAY,EAAE,OAAO,CAAC;IACtB,YAAY,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;CACnC;AAED,wBAAgB,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,cAAc,CAoFrE"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { useCallback, useEffect, useState } from "react";
|
|
2
|
+
import { usePolpoContext } from "../provider/polpo-context.js";
|
|
3
|
+
import { useMutation } from "./use-mutation.js";
|
|
4
|
+
export function useFiles(root, path) {
|
|
5
|
+
const { client } = usePolpoContext();
|
|
6
|
+
const [roots, setRoots] = useState([]);
|
|
7
|
+
const [entries, setEntries] = useState([]);
|
|
8
|
+
const [currentPath, setCurrentPath] = useState(null);
|
|
9
|
+
const [isLoading, setIsLoading] = useState(true);
|
|
10
|
+
const [error, setError] = useState(null);
|
|
11
|
+
const refetchRoots = useCallback(async () => {
|
|
12
|
+
try {
|
|
13
|
+
const data = await client.getFileRoots();
|
|
14
|
+
setRoots(data.roots);
|
|
15
|
+
}
|
|
16
|
+
catch (err) {
|
|
17
|
+
setError(err);
|
|
18
|
+
}
|
|
19
|
+
}, [client]);
|
|
20
|
+
// Fetch roots on mount
|
|
21
|
+
useEffect(() => {
|
|
22
|
+
setIsLoading(true);
|
|
23
|
+
refetchRoots().finally(() => setIsLoading(false));
|
|
24
|
+
}, [refetchRoots]);
|
|
25
|
+
// Auto-fetch entries when root/path changes
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
if (!root) {
|
|
28
|
+
setEntries([]);
|
|
29
|
+
setCurrentPath(null);
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
let cancelled = false;
|
|
33
|
+
setIsLoading(true);
|
|
34
|
+
client
|
|
35
|
+
.listFiles(root, path)
|
|
36
|
+
.then((data) => {
|
|
37
|
+
if (!cancelled) {
|
|
38
|
+
setEntries(data.entries);
|
|
39
|
+
setCurrentPath(data.path);
|
|
40
|
+
setIsLoading(false);
|
|
41
|
+
}
|
|
42
|
+
})
|
|
43
|
+
.catch((err) => {
|
|
44
|
+
if (!cancelled) {
|
|
45
|
+
setError(err);
|
|
46
|
+
setIsLoading(false);
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
return () => { cancelled = true; };
|
|
50
|
+
}, [client, root, path]);
|
|
51
|
+
const { mutate: listFiles, isPending: isListing } = useMutation(useCallback(async (listRoot, listPath) => {
|
|
52
|
+
const data = await client.listFiles(listRoot, listPath);
|
|
53
|
+
setEntries(data.entries);
|
|
54
|
+
setCurrentPath(data.path);
|
|
55
|
+
return data.entries;
|
|
56
|
+
}, [client]));
|
|
57
|
+
const { mutate: previewFile, isPending: isPreviewing } = useMutation(useCallback(async (previewRoot, previewPath, maxLines) => {
|
|
58
|
+
return client.previewFile(previewRoot, previewPath, maxLines);
|
|
59
|
+
}, [client]));
|
|
60
|
+
return {
|
|
61
|
+
roots,
|
|
62
|
+
entries,
|
|
63
|
+
currentPath,
|
|
64
|
+
isLoading,
|
|
65
|
+
error,
|
|
66
|
+
listFiles,
|
|
67
|
+
isListing,
|
|
68
|
+
previewFile,
|
|
69
|
+
isPreviewing,
|
|
70
|
+
refetchRoots,
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=use-files.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-files.js","sourceRoot":"","sources":["../../src/hooks/use-files.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { PlaybookInfo, PlaybookDefinition, PlaybookRunResult } from "@polpo-ai/sdk";
|
|
1
|
+
import type { PlaybookInfo, PlaybookDefinition, PlaybookRunResult, CreatePlaybookRequest } from "@polpo-ai/sdk";
|
|
2
2
|
export interface UsePlaybooksReturn {
|
|
3
3
|
/** List of discovered playbooks (lightweight metadata). */
|
|
4
4
|
playbooks: PlaybookInfo[];
|
|
@@ -10,6 +10,15 @@ export interface UsePlaybooksReturn {
|
|
|
10
10
|
getPlaybook: (name: string) => Promise<PlaybookDefinition>;
|
|
11
11
|
/** Run a playbook with parameters. */
|
|
12
12
|
runPlaybook: (name: string, params?: Record<string, string | number | boolean>) => Promise<PlaybookRunResult>;
|
|
13
|
+
/** Create or update a playbook definition. */
|
|
14
|
+
createPlaybook: (req: CreatePlaybookRequest) => Promise<{
|
|
15
|
+
name: string;
|
|
16
|
+
path: string;
|
|
17
|
+
}>;
|
|
18
|
+
isCreating: boolean;
|
|
19
|
+
/** Delete a playbook by name. */
|
|
20
|
+
deletePlaybook: (name: string) => Promise<void>;
|
|
21
|
+
isDeleting: boolean;
|
|
13
22
|
/** @deprecated Use playbooks instead. */
|
|
14
23
|
templates: PlaybookInfo[];
|
|
15
24
|
/** @deprecated Use getPlaybook instead. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-playbooks.d.ts","sourceRoot":"","sources":["../../src/hooks/use-playbooks.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"use-playbooks.d.ts","sourceRoot":"","sources":["../../src/hooks/use-playbooks.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,YAAY,EACZ,kBAAkB,EAClB,iBAAiB,EACjB,qBAAqB,EACtB,MAAM,eAAe,CAAC;AAEvB,MAAM,WAAW,kBAAkB;IACjC,2DAA2D;IAC3D,SAAS,EAAE,YAAY,EAAE,CAAC;IAC1B,2CAA2C;IAC3C,OAAO,EAAE,OAAO,CAAC;IACjB,iDAAiD;IACjD,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,uEAAuE;IACvE,WAAW,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAC3D,sCAAsC;IACtC,WAAW,EAAE,CACX,IAAI,EAAE,MAAM,EACZ,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,KAC/C,OAAO,CAAC,iBAAiB,CAAC,CAAC;IAChC,8CAA8C;IAC9C,cAAc,EAAE,CAAC,GAAG,EAAE,qBAAqB,KAAK,OAAO,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACxF,UAAU,EAAE,OAAO,CAAC;IACpB,iCAAiC;IACjC,cAAc,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAChD,UAAU,EAAE,OAAO,CAAC;IAGpB,yCAAyC;IACzC,SAAS,EAAE,YAAY,EAAE,CAAC;IAC1B,2CAA2C;IAC3C,WAAW,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAC3D,2CAA2C;IAC3C,WAAW,EAAE,CACX,IAAI,EAAE,MAAM,EACZ,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,KAC/C,OAAO,CAAC,iBAAiB,CAAC,CAAC;CACjC;AAED;;;;;GAKG;AACH,wBAAgB,YAAY,IAAI,kBAAkB,CAwEjD;AAED,4CAA4C;AAC5C,eAAO,MAAM,YAAY,qBAAe,CAAC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { useState, useEffect, useCallback } from "react";
|
|
2
2
|
import { usePolpo } from "./use-polpo.js";
|
|
3
|
+
import { useMutation } from "./use-mutation.js";
|
|
3
4
|
/**
|
|
4
5
|
* Hook for listing, inspecting, and running playbooks.
|
|
5
6
|
*
|
|
@@ -36,8 +37,20 @@ export function usePlaybooks() {
|
|
|
36
37
|
refetch();
|
|
37
38
|
return result;
|
|
38
39
|
}, [client, refetch]);
|
|
40
|
+
const { mutate: createPlaybook, isPending: isCreating } = useMutation(useCallback((req) => {
|
|
41
|
+
if (!client)
|
|
42
|
+
throw new Error("Client not initialized");
|
|
43
|
+
return client.createPlaybook(req);
|
|
44
|
+
}, [client]), { onSuccess: () => { refetch(); } });
|
|
45
|
+
const { mutate: deletePlaybook_, isPending: isDeleting } = useMutation(useCallback(async (name) => {
|
|
46
|
+
if (!client)
|
|
47
|
+
throw new Error("Client not initialized");
|
|
48
|
+
await client.deletePlaybook(name);
|
|
49
|
+
}, [client]), { onSuccess: () => { refetch(); } });
|
|
39
50
|
return {
|
|
40
51
|
playbooks, loading, refetch, getPlaybook, runPlaybook,
|
|
52
|
+
createPlaybook, isCreating,
|
|
53
|
+
deletePlaybook: deletePlaybook_, isDeleting,
|
|
41
54
|
// Backward-compat aliases
|
|
42
55
|
templates: playbooks,
|
|
43
56
|
getTemplate: getPlaybook,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-playbooks.js","sourceRoot":"","sources":["../../src/hooks/use-playbooks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"use-playbooks.js","sourceRoot":"","sources":["../../src/hooks/use-playbooks.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +1,15 @@
|
|
|
1
|
-
import type { ScheduleEntry } from "@polpo-ai/sdk";
|
|
1
|
+
import type { ScheduleEntry, CreateScheduleRequest, UpdateScheduleRequest } from "@polpo-ai/sdk";
|
|
2
2
|
export interface UseSchedulesReturn {
|
|
3
3
|
schedules: ScheduleEntry[];
|
|
4
4
|
isLoading: boolean;
|
|
5
5
|
error: Error | null;
|
|
6
6
|
refetch: () => Promise<void>;
|
|
7
|
+
createSchedule: (req: CreateScheduleRequest) => Promise<ScheduleEntry>;
|
|
8
|
+
isCreating: boolean;
|
|
9
|
+
updateSchedule: (missionId: string, req: UpdateScheduleRequest) => Promise<ScheduleEntry>;
|
|
10
|
+
isUpdating: boolean;
|
|
11
|
+
deleteSchedule: (missionId: string) => Promise<void>;
|
|
12
|
+
isDeleting: boolean;
|
|
7
13
|
}
|
|
8
14
|
export declare function useSchedules(): UseSchedulesReturn;
|
|
9
15
|
//# sourceMappingURL=use-schedules.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-schedules.d.ts","sourceRoot":"","sources":["../../src/hooks/use-schedules.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"use-schedules.d.ts","sourceRoot":"","sources":["../../src/hooks/use-schedules.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,aAAa,EACb,qBAAqB,EACrB,qBAAqB,EACtB,MAAM,eAAe,CAAC;AAEvB,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,aAAa,EAAE,CAAC;IAC3B,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,cAAc,EAAE,CAAC,GAAG,EAAE,qBAAqB,KAAK,OAAO,CAAC,aAAa,CAAC,CAAC;IACvE,UAAU,EAAE,OAAO,CAAC;IACpB,cAAc,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,qBAAqB,KAAK,OAAO,CAAC,aAAa,CAAC,CAAC;IAC1F,UAAU,EAAE,OAAO,CAAC;IACpB,cAAc,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACrD,UAAU,EAAE,OAAO,CAAC;CACrB;AAID,wBAAgB,YAAY,IAAI,kBAAkB,CAmEjD"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { useCallback, useEffect, useState, useRef } from "react";
|
|
2
2
|
import { usePolpoContext } from "../provider/polpo-context.js";
|
|
3
3
|
import { useEvents } from "./use-events.js";
|
|
4
|
+
import { useMutation } from "./use-mutation.js";
|
|
4
5
|
const SCHEDULE_EVENTS = ["schedule:created", "schedule:triggered", "schedule:completed"];
|
|
5
6
|
export function useSchedules() {
|
|
6
7
|
const { client } = usePolpoContext();
|
|
@@ -30,6 +31,20 @@ export function useSchedules() {
|
|
|
30
31
|
fetchSchedules();
|
|
31
32
|
}
|
|
32
33
|
}, [events.length, fetchSchedules]);
|
|
33
|
-
|
|
34
|
+
const { mutate: createSchedule, isPending: isCreating } = useMutation(useCallback((req) => client.createSchedule(req), [client]), { onSuccess: () => { fetchSchedules(); } });
|
|
35
|
+
const { mutate: updateSchedule, isPending: isUpdating } = useMutation(useCallback((missionId, req) => client.updateSchedule(missionId, req), [client]), { onSuccess: () => { fetchSchedules(); } });
|
|
36
|
+
const { mutate: deleteSchedule_, isPending: isDeleting } = useMutation(useCallback(async (missionId) => { await client.deleteSchedule(missionId); }, [client]), { onSuccess: () => { fetchSchedules(); } });
|
|
37
|
+
return {
|
|
38
|
+
schedules,
|
|
39
|
+
isLoading,
|
|
40
|
+
error,
|
|
41
|
+
refetch: fetchSchedules,
|
|
42
|
+
createSchedule,
|
|
43
|
+
isCreating,
|
|
44
|
+
updateSchedule,
|
|
45
|
+
isUpdating,
|
|
46
|
+
deleteSchedule: deleteSchedule_,
|
|
47
|
+
isDeleting,
|
|
48
|
+
};
|
|
34
49
|
}
|
|
35
50
|
//# sourceMappingURL=use-schedules.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-schedules.js","sourceRoot":"","sources":["../../src/hooks/use-schedules.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"use-schedules.js","sourceRoot":"","sources":["../../src/hooks/use-schedules.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +1,22 @@
|
|
|
1
|
-
import type { SkillWithAssignment } from "@polpo-ai/sdk";
|
|
1
|
+
import type { SkillWithAssignment, CreateSkillRequest, InstallSkillsResult, InstallSkillsOptions } from "@polpo-ai/sdk";
|
|
2
2
|
export interface UseSkillsReturn {
|
|
3
3
|
skills: SkillWithAssignment[];
|
|
4
4
|
isLoading: boolean;
|
|
5
5
|
error: Error | null;
|
|
6
6
|
refetch: () => Promise<void>;
|
|
7
|
+
createSkill: (req: CreateSkillRequest) => Promise<{
|
|
8
|
+
name: string;
|
|
9
|
+
path: string;
|
|
10
|
+
}>;
|
|
11
|
+
isCreating: boolean;
|
|
12
|
+
installSkills: (source: string, opts?: InstallSkillsOptions) => Promise<InstallSkillsResult>;
|
|
13
|
+
isInstalling: boolean;
|
|
14
|
+
deleteSkill: (name: string) => Promise<void>;
|
|
15
|
+
isDeleting: boolean;
|
|
16
|
+
assignSkill: (skillName: string, agentName: string) => Promise<void>;
|
|
17
|
+
isAssigning: boolean;
|
|
18
|
+
unassignSkill: (skillName: string, agentName: string) => Promise<void>;
|
|
19
|
+
isUnassigning: boolean;
|
|
7
20
|
}
|
|
8
21
|
/**
|
|
9
22
|
* Fetch available project-level skills with agent assignment info.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-skills.d.ts","sourceRoot":"","sources":["../../src/hooks/use-skills.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"use-skills.d.ts","sourceRoot":"","sources":["../../src/hooks/use-skills.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,mBAAmB,EACnB,kBAAkB,EAClB,mBAAmB,EACnB,oBAAoB,EACrB,MAAM,eAAe,CAAC;AAEvB,MAAM,WAAW,eAAe;IAC9B,MAAM,EAAE,mBAAmB,EAAE,CAAC;IAC9B,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,WAAW,EAAE,CAAC,GAAG,EAAE,kBAAkB,KAAK,OAAO,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAClF,UAAU,EAAE,OAAO,CAAC;IACpB,aAAa,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,oBAAoB,KAAK,OAAO,CAAC,mBAAmB,CAAC,CAAC;IAC7F,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7C,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACrE,WAAW,EAAE,OAAO,CAAC;IACrB,aAAa,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACvE,aAAa,EAAE,OAAO,CAAC;CACxB;AAED;;;GAGG;AACH,wBAAgB,SAAS,IAAI,eAAe,CAiF3C"}
|
package/dist/hooks/use-skills.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { useCallback, useEffect, useState } from "react";
|
|
2
2
|
import { usePolpoContext } from "../provider/polpo-context.js";
|
|
3
|
+
import { useMutation } from "./use-mutation.js";
|
|
3
4
|
/**
|
|
4
5
|
* Fetch available project-level skills with agent assignment info.
|
|
5
6
|
* Skills are not reactive (no SSE updates) — they're discovered on demand.
|
|
@@ -23,6 +24,30 @@ export function useSkills() {
|
|
|
23
24
|
setIsLoading(true);
|
|
24
25
|
fetch_().finally(() => setIsLoading(false));
|
|
25
26
|
}, [fetch_]);
|
|
26
|
-
|
|
27
|
+
const { mutate: createSkill, isPending: isCreating } = useMutation(useCallback((req) => client.createSkill(req), [client]), { onSuccess: () => { fetch_(); } });
|
|
28
|
+
const { mutate: installSkills, isPending: isInstalling } = useMutation(useCallback((source, opts) => client.installSkills(source, opts), [client]), { onSuccess: () => { fetch_(); } });
|
|
29
|
+
const { mutate: deleteSkill_, isPending: isDeleting } = useMutation(useCallback(async (name) => { await client.deleteSkill(name); }, [client]), { onSuccess: () => { fetch_(); } });
|
|
30
|
+
const { mutate: assignSkill_, isPending: isAssigning } = useMutation(useCallback(async (skillName, agentName) => {
|
|
31
|
+
await client.assignSkill(skillName, agentName);
|
|
32
|
+
}, [client]), { onSuccess: () => { fetch_(); } });
|
|
33
|
+
const { mutate: unassignSkill_, isPending: isUnassigning } = useMutation(useCallback(async (skillName, agentName) => {
|
|
34
|
+
await client.unassignSkill(skillName, agentName);
|
|
35
|
+
}, [client]), { onSuccess: () => { fetch_(); } });
|
|
36
|
+
return {
|
|
37
|
+
skills,
|
|
38
|
+
isLoading,
|
|
39
|
+
error,
|
|
40
|
+
refetch: fetch_,
|
|
41
|
+
createSkill,
|
|
42
|
+
isCreating,
|
|
43
|
+
installSkills,
|
|
44
|
+
isInstalling,
|
|
45
|
+
deleteSkill: deleteSkill_,
|
|
46
|
+
isDeleting,
|
|
47
|
+
assignSkill: assignSkill_,
|
|
48
|
+
isAssigning,
|
|
49
|
+
unassignSkill: unassignSkill_,
|
|
50
|
+
isUnassigning,
|
|
51
|
+
};
|
|
27
52
|
}
|
|
28
53
|
//# sourceMappingURL=use-skills.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-skills.js","sourceRoot":"","sources":["../../src/hooks/use-skills.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"use-skills.js","sourceRoot":"","sources":["../../src/hooks/use-skills.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,44 @@
|
|
|
1
1
|
import type { VaultEntryMeta } from "@polpo-ai/sdk";
|
|
2
|
+
export interface SaveVaultEntryRequest {
|
|
3
|
+
agent: string;
|
|
4
|
+
service: string;
|
|
5
|
+
type: "smtp" | "imap" | "oauth" | "api_key" | "login" | "custom";
|
|
6
|
+
credentials: Record<string, string>;
|
|
7
|
+
label?: string;
|
|
8
|
+
}
|
|
2
9
|
export interface UseVaultEntriesReturn {
|
|
3
10
|
entries: VaultEntryMeta[];
|
|
4
11
|
isLoading: boolean;
|
|
5
12
|
error: Error | null;
|
|
6
13
|
refetch: () => Promise<void>;
|
|
14
|
+
saveEntry: (req: SaveVaultEntryRequest) => Promise<{
|
|
15
|
+
agent: string;
|
|
16
|
+
service: string;
|
|
17
|
+
type: string;
|
|
18
|
+
keys: string[];
|
|
19
|
+
}>;
|
|
20
|
+
isSaving: boolean;
|
|
21
|
+
patchEntry: (agent: string, service: string, patch: {
|
|
22
|
+
type?: string;
|
|
23
|
+
label?: string;
|
|
24
|
+
credentials?: Record<string, string>;
|
|
25
|
+
}) => Promise<{
|
|
26
|
+
agent: string;
|
|
27
|
+
service: string;
|
|
28
|
+
type: string;
|
|
29
|
+
keys: string[];
|
|
30
|
+
}>;
|
|
31
|
+
isPatching: boolean;
|
|
32
|
+
removeEntry: (agent: string, service: string) => Promise<{
|
|
33
|
+
removed: boolean;
|
|
34
|
+
}>;
|
|
35
|
+
isRemoving: boolean;
|
|
7
36
|
}
|
|
8
37
|
/**
|
|
9
38
|
* Fetch vault entry metadata for an agent (service names, types, credential key names).
|
|
10
39
|
* Never exposes secret values — only field names with "***" masking.
|
|
40
|
+
*
|
|
41
|
+
* Includes mutations: saveEntry, patchEntry, removeEntry — each auto-refetches on success.
|
|
11
42
|
*/
|
|
12
43
|
export declare function useVaultEntries(agentName: string): UseVaultEntriesReturn;
|
|
13
44
|
//# sourceMappingURL=use-vault-entries.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-vault-entries.d.ts","sourceRoot":"","sources":["../../src/hooks/use-vault-entries.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"use-vault-entries.d.ts","sourceRoot":"","sources":["../../src/hooks/use-vault-entries.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAEpD,MAAM,WAAW,qBAAqB;IACpC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,SAAS,GAAG,OAAO,GAAG,QAAQ,CAAC;IACjE,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,qBAAqB;IACpC,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,SAAS,EAAE,CAAC,GAAG,EAAE,qBAAqB,KAAK,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC,CAAC;IACrH,QAAQ,EAAE,OAAO,CAAC;IAClB,UAAU,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;KAAE,KAAK,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC,CAAC;IAC1M,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC;QAAE,OAAO,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;IAC/E,UAAU,EAAE,OAAO,CAAC;CACrB;AAED;;;;;GAKG;AACH,wBAAgB,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,qBAAqB,CAsExE"}
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import { useCallback, useEffect, useState } from "react";
|
|
2
2
|
import { usePolpoContext } from "../provider/polpo-context.js";
|
|
3
|
+
import { useMutation } from "./use-mutation.js";
|
|
3
4
|
/**
|
|
4
5
|
* Fetch vault entry metadata for an agent (service names, types, credential key names).
|
|
5
6
|
* Never exposes secret values — only field names with "***" masking.
|
|
7
|
+
*
|
|
8
|
+
* Includes mutations: saveEntry, patchEntry, removeEntry — each auto-refetches on success.
|
|
6
9
|
*/
|
|
7
10
|
export function useVaultEntries(agentName) {
|
|
8
11
|
const { client } = usePolpoContext();
|
|
@@ -27,6 +30,29 @@ export function useVaultEntries(agentName) {
|
|
|
27
30
|
setIsLoading(true);
|
|
28
31
|
fetch_().finally(() => setIsLoading(false));
|
|
29
32
|
}, [fetch_]);
|
|
30
|
-
|
|
33
|
+
const { mutate: saveEntry, isPending: isSaving } = useMutation(useCallback(async (req) => {
|
|
34
|
+
const result = await client.saveVaultEntry(req);
|
|
35
|
+
return result;
|
|
36
|
+
}, [client]), { onSuccess: () => { fetch_(); } });
|
|
37
|
+
const { mutate: patchEntry, isPending: isPatching } = useMutation(useCallback(async (agent, service, patch) => {
|
|
38
|
+
const result = await client.patchVaultEntry(agent, service, patch);
|
|
39
|
+
return result;
|
|
40
|
+
}, [client]), { onSuccess: () => { fetch_(); } });
|
|
41
|
+
const { mutate: removeEntry, isPending: isRemoving } = useMutation(useCallback(async (agent, service) => {
|
|
42
|
+
const result = await client.removeVaultEntry(agent, service);
|
|
43
|
+
return result;
|
|
44
|
+
}, [client]), { onSuccess: () => { fetch_(); } });
|
|
45
|
+
return {
|
|
46
|
+
entries,
|
|
47
|
+
isLoading,
|
|
48
|
+
error,
|
|
49
|
+
refetch: fetch_,
|
|
50
|
+
saveEntry,
|
|
51
|
+
isSaving,
|
|
52
|
+
patchEntry,
|
|
53
|
+
isPatching,
|
|
54
|
+
removeEntry,
|
|
55
|
+
isRemoving,
|
|
56
|
+
};
|
|
31
57
|
}
|
|
32
58
|
//# sourceMappingURL=use-vault-entries.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-vault-entries.js","sourceRoot":"","sources":["../../src/hooks/use-vault-entries.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"use-vault-entries.js","sourceRoot":"","sources":["../../src/hooks/use-vault-entries.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -21,17 +21,27 @@ export { useLogs } from "./hooks/use-logs.js";
|
|
|
21
21
|
export { useSessions } from "./hooks/use-sessions.js";
|
|
22
22
|
export { useTaskActivity } from "./hooks/use-task-activity.js";
|
|
23
23
|
export { useSkills } from "./hooks/use-skills.js";
|
|
24
|
+
export type { UseSkillsReturn } from "./hooks/use-skills.js";
|
|
24
25
|
export { useOrchestratorSkills } from "./hooks/use-orchestrator-skills.js";
|
|
25
26
|
export { useNotifications } from "./hooks/use-notifications.js";
|
|
26
27
|
export { useApprovals } from "./hooks/use-approvals.js";
|
|
27
28
|
export type { UseApprovalsReturn } from "./hooks/use-approvals.js";
|
|
28
29
|
export { useActiveDelays } from "./hooks/use-active-delays.js";
|
|
30
|
+
export type { UseActiveDelaysReturn } from "./hooks/use-active-delays.js";
|
|
29
31
|
export { usePlaybooks, useTemplates } from "./hooks/use-playbooks.js";
|
|
32
|
+
export type { UsePlaybooksReturn } from "./hooks/use-playbooks.js";
|
|
30
33
|
export { useSchedules } from "./hooks/use-schedules.js";
|
|
34
|
+
export type { UseSchedulesReturn } from "./hooks/use-schedules.js";
|
|
31
35
|
export { useVaultEntries } from "./hooks/use-vault-entries.js";
|
|
32
|
-
export type { UseVaultEntriesReturn } from "./hooks/use-vault-entries.js";
|
|
36
|
+
export type { UseVaultEntriesReturn, SaveVaultEntryRequest } from "./hooks/use-vault-entries.js";
|
|
33
37
|
export { useAuthStatus } from "./hooks/use-auth-status.js";
|
|
34
38
|
export { useAssessmentProgress } from "./hooks/use-assessment-progress.js";
|
|
39
|
+
export { useChat } from "./hooks/use-chat.js";
|
|
40
|
+
export type { UseChatReturn, UseChatOptions, ChatStatus } from "./hooks/use-chat.js";
|
|
41
|
+
export { useAttachments } from "./hooks/use-attachments.js";
|
|
42
|
+
export type { UseAttachmentsReturn } from "./hooks/use-attachments.js";
|
|
43
|
+
export { useFiles } from "./hooks/use-files.js";
|
|
44
|
+
export type { UseFilesReturn } from "./hooks/use-files.js";
|
|
35
45
|
export { PolpoClient, ChatCompletionStream, PolpoApiError, EventSourceManager, PolpoStore, reduceEvent, selectTasks, selectTask, selectMissions, selectMission, selectMissionReport, selectProcesses, selectEvents, selectAssessmentProgress, selectAssessmentChecks, } from "@polpo-ai/sdk";
|
|
36
|
-
export type { PolpoClientConfig, ConnectionStatus, EventSourceConfig, Task, TaskStatus, TaskResult, TaskExpectation, TaskPhase, TaskOutcome, ExpectedOutcome, OutcomeType, Mission, MissionStatus, MissionReport, MissionDelay, AgentConfig, AgentIdentity, AgentResponsibility, AgentProcess, AgentActivity, Team, AssessmentResult, AssessmentTrigger, DimensionScore, DimensionScoreEvidence, EvalDimension, CheckResult, ReviewerResult, ReviewerMessage, ReviewerExploration, MetricResult, PolpoState, PolpoConfig, PolpoSettings, ReasoningLevel, ModelConfig, ModelAllowlistEntry, CustomModelDef, ProviderConfig, SSEEvent, ActiveDelay, CreateTaskRequest, UpdateTaskRequest, CreateMissionRequest, UpdateMissionRequest, AddMissionTaskRequest, UpdateMissionTaskRequest, ReorderMissionTasksRequest, AddMissionCheckpointRequest, UpdateMissionCheckpointRequest, AddMissionDelayRequest, UpdateMissionDelayRequest, AddMissionQualityGateRequest, UpdateMissionQualityGateRequest, AddMissionTeamMemberRequest, UpdateMissionTeamMemberRequest, UpdateMissionNotificationsRequest, ExecuteMissionResult, ResumeMissionResult, AddAgentRequest, UpdateAgentRequest, UpdateSettingsRequest, AddTeamRequest, TaskFilters, LogSession, LogEntry, RunActivityEntry, ChatSession, ChatMessage, ChatCompletionMessage, TextContentPart, ImageUrlContentPart, ContentPart, ChatCompletionRequest, ChatCompletionResponse, ChatCompletionChoice, ChatCompletionChunk, ChatCompletionChunkDelta, ToolCallState, ToolCallEvent, AskUserOption, AskUserQuestion, AskUserPayload, AskUserAnswer, MissionPreviewPayload, VaultEntryMeta, VaultPreviewPayload, AuthProfileStatus, AuthProfileType, AuthProfileMeta, ProviderAuthInfo, AuthStatusResponse, SkillInfo, LoadedSkill, SkillWithAssignment, SkillIndexEntry, SkillIndex, NotificationChannelType, NotificationChannelConfig, ChannelGatewayConfig, DmPolicy, NotificationRule, NotificationRecord, NotificationStats, NotificationSeverity, NotificationStatus, ScopedNotificationRules, SendNotificationRequest, SendNotificationResult, ApprovalRequest, ApprovalStatus, ScheduleEntry, QualityMetrics, PlaybookParameter, PlaybookInfo, PlaybookDefinition, PlaybookRunResult, TemplateParameter, TemplateInfo, TemplateDefinition, TemplateRunResult, StoreState, PolpoStats, AssessmentProgressEntry, AssessmentCheckStatus, TaskFilter, } from "@polpo-ai/sdk";
|
|
46
|
+
export type { PolpoClientConfig, ConnectionStatus, EventSourceConfig, Task, TaskStatus, TaskResult, TaskExpectation, TaskPhase, TaskOutcome, ExpectedOutcome, OutcomeType, Mission, MissionStatus, MissionReport, MissionDelay, AgentConfig, AgentIdentity, AgentResponsibility, AgentProcess, AgentActivity, Team, AssessmentResult, AssessmentTrigger, DimensionScore, DimensionScoreEvidence, EvalDimension, CheckResult, ReviewerResult, ReviewerMessage, ReviewerExploration, MetricResult, PolpoState, PolpoConfig, PolpoSettings, ReasoningLevel, ModelConfig, ModelAllowlistEntry, CustomModelDef, ProviderConfig, SSEEvent, ActiveDelay, CreateTaskRequest, UpdateTaskRequest, CreateMissionRequest, UpdateMissionRequest, AddMissionTaskRequest, UpdateMissionTaskRequest, ReorderMissionTasksRequest, AddMissionCheckpointRequest, UpdateMissionCheckpointRequest, AddMissionDelayRequest, UpdateMissionDelayRequest, AddMissionQualityGateRequest, UpdateMissionQualityGateRequest, AddMissionTeamMemberRequest, UpdateMissionTeamMemberRequest, UpdateMissionNotificationsRequest, ExecuteMissionResult, ResumeMissionResult, AddAgentRequest, UpdateAgentRequest, UpdateSettingsRequest, AddTeamRequest, TaskFilters, LogSession, LogEntry, RunActivityEntry, ChatSession, ChatMessage, ChatCompletionMessage, TextContentPart, ImageUrlContentPart, ContentPart, ChatCompletionRequest, ChatCompletionResponse, ChatCompletionChoice, ChatCompletionChunk, ChatCompletionChunkDelta, ToolCallState, ToolCallEvent, AskUserOption, AskUserQuestion, AskUserPayload, AskUserAnswer, MissionPreviewPayload, VaultEntryMeta, VaultPreviewPayload, OpenFilePayload, NavigateToPayload, OpenTabPayload, AuthProfileStatus, AuthProfileType, AuthProfileMeta, ProviderAuthInfo, AuthStatusResponse, SkillInfo, LoadedSkill, SkillWithAssignment, SkillIndexEntry, SkillIndex, NotificationChannelType, NotificationChannelConfig, ChannelGatewayConfig, DmPolicy, NotificationRule, NotificationRecord, NotificationStats, NotificationSeverity, NotificationStatus, ScopedNotificationRules, SendNotificationRequest, SendNotificationResult, ApprovalRequest, ApprovalStatus, ScheduleEntry, CreateScheduleRequest, UpdateScheduleRequest, QualityMetrics, PlaybookParameter, PlaybookInfo, PlaybookDefinition, PlaybookRunResult, CreatePlaybookRequest, CreateSkillRequest, InstallSkillsResult, InstallSkillsOptions, TemplateParameter, TemplateInfo, TemplateDefinition, TemplateRunResult, Attachment, FileRoot, FileEntry, FilePreview, StoreState, PolpoStats, AssessmentProgressEntry, AssessmentCheckStatus, TaskFilter, } from "@polpo-ai/sdk";
|
|
37
47
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,YAAY,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAGvE,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,YAAY,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,YAAY,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,YAAY,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,YAAY,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,YAAY,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAC3E,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,YAAY,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,YAAY,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/index.js
CHANGED
|
@@ -26,6 +26,9 @@ export { useSchedules } from "./hooks/use-schedules.js";
|
|
|
26
26
|
export { useVaultEntries } from "./hooks/use-vault-entries.js";
|
|
27
27
|
export { useAuthStatus } from "./hooks/use-auth-status.js";
|
|
28
28
|
export { useAssessmentProgress } from "./hooks/use-assessment-progress.js";
|
|
29
|
+
export { useChat } from "./hooks/use-chat.js";
|
|
30
|
+
export { useAttachments } from "./hooks/use-attachments.js";
|
|
31
|
+
export { useFiles } from "./hooks/use-files.js";
|
|
29
32
|
// Re-export client SDK for convenience (backward compat — consumers can also use @polpo-ai/sdk directly)
|
|
30
33
|
export { PolpoClient, ChatCompletionStream, PolpoApiError, EventSourceManager, PolpoStore, reduceEvent, selectTasks, selectTask, selectMissions, selectMission, selectMissionReport, selectProcesses, selectEvents, selectAssessmentProgress, selectAssessmentChecks, } from "@polpo-ai/sdk";
|
|
31
34
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,WAAW;AACX,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAG7D,QAAQ;AACR,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAEtD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAEtD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAElD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,WAAW;AACX,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAG7D,QAAQ;AACR,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAEtD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAEtD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAElD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAElD,OAAO,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAC3E,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAExD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAE/D,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAEtE,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAExD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAE/D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAC3E,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAE9C,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAE5D,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAGhD,yGAAyG;AACzG,OAAO,EACL,WAAW,EACX,oBAAoB,EACpB,aAAa,EACb,kBAAkB,EAClB,UAAU,EACV,WAAW,EACX,WAAW,EACX,UAAU,EACV,cAAc,EACd,aAAa,EACb,mBAAmB,EACnB,eAAe,EACf,YAAY,EACZ,wBAAwB,EACxB,sBAAsB,GACvB,MAAM,eAAe,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@polpo-ai/react",
|
|
3
|
-
"version": "0.4.
|
|
3
|
+
"version": "0.4.4",
|
|
4
4
|
"description": "React SDK for OpenPolpo — hooks with real-time SSE updates, built on @polpo-ai/sdk",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -17,7 +17,7 @@
|
|
|
17
17
|
},
|
|
18
18
|
"sideEffects": false,
|
|
19
19
|
"dependencies": {
|
|
20
|
-
"@polpo-ai/sdk": "0.4.
|
|
20
|
+
"@polpo-ai/sdk": "0.4.4"
|
|
21
21
|
},
|
|
22
22
|
"peerDependencies": {
|
|
23
23
|
"react": "^18.0.0 || ^19.0.0"
|