@polpo-ai/react 0.4.2 → 0.4.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/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-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 +10 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -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":"AAAA,OAAO,EAAE,oBAAoB,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AAC/E,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAmBhD;;;;;;;;GAQG;AACH,MAAM,UAAU,eAAe;IAC7B,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,eAAe,EAAE,CAAC;IAE5C,6DAA6D;IAC7D,MAAM,WAAW,GAAG,oBAAoB,CACtC,KAAK,CAAC,SAAS,EACf,GAAG,EAAE,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,YAAY,EACtC,GAAG,EAAE,CAAC,KAAK,CAAC,iBAAiB,EAAE,CAAC,YAAY,CAC7C,CAAC;IAEF,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAgB,EAAE,CAAC,CAAC;IACtE,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC7C,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAEhD,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAEjE,SAAS,CAAC,GAAG,EAAE;QACb,UAAU,CAAC,IAAI,CAAC,CAAC;QACjB,MAAM,CAAC,UAAU,EAAE;aAChB,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;YACf,gBAAgB,CAAC,MAAM,CAAC,CAAC;YACzB,0EAA0E;YAC1E,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,YAAY,CAAC,CAAC;YACvD,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;gBACvB,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;YAC3C,CAAC;YACD,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC,CAAC;aACD,KAAK,CAAC,GAAG,EAAE,GAAqB,CAAC,CAAC;aAClC,OAAO,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;IACtC,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC;IAEhC,wEAAwE;IACxE,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC;IAEtD,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,WAAW,CAC3D,WAAW,CACT,KAAK,EAAE,SAAiB,EAAE,GAA2B,EAAE,EAAE;QACvD,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,eAAe,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QAC5D,OAAO,MAAM,CAAC;IAChB,CAAC,EACD,CAAC,MAAM,CAAC,CACT,EACD,EAAE,SAAS,EAAE,GAAG,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CACpC,CAAC;IAEF,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,WAAW,CAChE,WAAW,CACT,KAAK,EAAE,SAAiB,EAAE,SAAiB,EAAE,GAA8B,EAAE,EAAE;QAC7E,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,kBAAkB,CAAC,SAAS,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;QAC1E,OAAO,MAAM,CAAC;IAChB,CAAC,EACD,CAAC,MAAM,CAAC,CACT,EACD,EAAE,SAAS,EAAE,GAAG,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CACpC,CAAC;IAEF,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,WAAW,CAChE,WAAW,CACT,KAAK,EAAE,SAAiB,EAAE,SAAiB,EAAE,EAAE;QAC7C,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,kBAAkB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QACrE,OAAO,MAAM,CAAC;IAChB,CAAC,EACD,CAAC,MAAM,CAAC,CACT,EACD,EAAE,SAAS,EAAE,GAAG,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CACpC,CAAC;IAEF,OAAO;QACL,YAAY;QACZ,aAAa;QACb,OAAO;QACP,OAAO;QACP,QAAQ;QACR,QAAQ;QACR,WAAW;QACX,UAAU;QACV,WAAW;QACX,UAAU;KACX,CAAC;AACJ,CAAC"}
|
|
@@ -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,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":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAyChD;;;;;GAKG;AACH,MAAM,UAAU,YAAY;IAC1B,MAAM,EAAE,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAC;IAC9B,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAiB,EAAE,CAAC,CAAC;IAC/D,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;IAE7C,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE;QAC/B,IAAI,CAAC,MAAM;YAAE,OAAO;QACpB,UAAU,CAAC,IAAI,CAAC,CAAC;QACjB,MAAM;aACH,YAAY,EAAE;aACd,IAAI,CAAC,YAAY,CAAC;aAClB,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC;aACf,OAAO,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;IACtC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAEb,SAAS,CAAC,GAAG,EAAE;QACb,OAAO,EAAE,CAAC;IACZ,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEd,MAAM,WAAW,GAAG,WAAW,CAC7B,KAAK,EAAE,IAAY,EAAE,EAAE;QACrB,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QACvD,OAAO,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC,EACD,CAAC,MAAM,CAAC,CACT,CAAC;IAEF,MAAM,WAAW,GAAG,WAAW,CAC7B,KAAK,EACH,IAAY,EACZ,MAAkD,EAClD,EAAE;QACF,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QACvD,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACtD,mDAAmD;QACnD,OAAO,EAAE,CAAC;QACV,OAAO,MAAM,CAAC;IAChB,CAAC,EACD,CAAC,MAAM,EAAE,OAAO,CAAC,CAClB,CAAC;IAEF,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,WAAW,CACnE,WAAW,CACT,CAAC,GAA0B,EAAE,EAAE;QAC7B,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QACvD,OAAO,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;IACpC,CAAC,EACD,CAAC,MAAM,CAAC,CACT,EACD,EAAE,SAAS,EAAE,GAAG,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CACpC,CAAC;IAEF,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,WAAW,CACpE,WAAW,CACT,KAAK,EAAE,IAAY,EAAE,EAAE;QACrB,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QACvD,MAAM,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC,EACD,CAAC,MAAM,CAAC,CACT,EACD,EAAE,SAAS,EAAE,GAAG,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CACpC,CAAC;IAEF,OAAO;QACL,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW;QACrD,cAAc,EAAE,UAAU;QAC1B,cAAc,EAAE,eAAe,EAAE,UAAU;QAC3C,0BAA0B;QAC1B,SAAS,EAAE,SAAS;QACpB,WAAW,EAAE,WAAW;QACxB,WAAW,EAAE,WAAW;KACzB,CAAC;AACJ,CAAC;AAED,4CAA4C;AAC5C,MAAM,CAAC,MAAM,YAAY,GAAG,YAAY,CAAC"}
|
|
@@ -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,25 @@ 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 { useAttachments } from "./hooks/use-attachments.js";
|
|
40
|
+
export type { UseAttachmentsReturn } from "./hooks/use-attachments.js";
|
|
41
|
+
export { useFiles } from "./hooks/use-files.js";
|
|
42
|
+
export type { UseFilesReturn } from "./hooks/use-files.js";
|
|
35
43
|
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";
|
|
44
|
+
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, 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
45
|
//# 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,8 @@ 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 { useAttachments } from "./hooks/use-attachments.js";
|
|
30
|
+
export { useFiles } from "./hooks/use-files.js";
|
|
29
31
|
// Re-export client SDK for convenience (backward compat — consumers can also use @polpo-ai/sdk directly)
|
|
30
32
|
export { PolpoClient, ChatCompletionStream, PolpoApiError, EventSourceManager, PolpoStore, reduceEvent, selectTasks, selectTask, selectMissions, selectMission, selectMissionReport, selectProcesses, selectEvents, selectAssessmentProgress, selectAssessmentChecks, } from "@polpo-ai/sdk";
|
|
31
33
|
//# 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,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.3",
|
|
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.3"
|
|
21
21
|
},
|
|
22
22
|
"peerDependencies": {
|
|
23
23
|
"react": "^18.0.0 || ^19.0.0"
|