@stigmer/react 0.0.101 → 0.1.1
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/agent/AgentPicker.js +1 -1
- package/agent/AgentPicker.js.map +1 -1
- package/agent/__tests__/useDefaultAgent.test.d.ts +2 -0
- package/agent/__tests__/useDefaultAgent.test.d.ts.map +1 -0
- package/agent/__tests__/useDefaultAgent.test.js +252 -0
- package/agent/__tests__/useDefaultAgent.test.js.map +1 -0
- package/agent/useAgent.d.ts +2 -0
- package/agent/useAgent.d.ts.map +1 -1
- package/agent/useAgent.js +14 -37
- package/agent/useAgent.js.map +1 -1
- package/agent/useAgentCount.d.ts +1 -1
- package/agent/useAgentCount.d.ts.map +1 -1
- package/agent/useAgentList.d.ts +2 -2
- package/agent/useAgentList.d.ts.map +1 -1
- package/agent/useDefaultAgent.d.ts +6 -2
- package/agent/useDefaultAgent.d.ts.map +1 -1
- package/agent/useDefaultAgent.js +51 -31
- package/agent/useDefaultAgent.js.map +1 -1
- package/agent-instance/useAgentInstance.d.ts +2 -0
- package/agent-instance/useAgentInstance.d.ts.map +1 -1
- package/agent-instance/useAgentInstance.js +6 -33
- package/agent-instance/useAgentInstance.js.map +1 -1
- package/agent-instance/useAgentInstanceList.d.ts +2 -0
- package/agent-instance/useAgentInstanceList.d.ts.map +1 -1
- package/agent-instance/useAgentInstanceList.js +22 -40
- package/agent-instance/useAgentInstanceList.js.map +1 -1
- package/api-key/useApiKeyList.d.ts +2 -0
- package/api-key/useApiKeyList.d.ts.map +1 -1
- package/api-key/useApiKeyList.js +3 -27
- package/api-key/useApiKeyList.js.map +1 -1
- package/composer/ComposerToolbar.d.ts +1 -5
- package/composer/ComposerToolbar.d.ts.map +1 -1
- package/composer/ComposerToolbar.js +3 -4
- package/composer/ComposerToolbar.js.map +1 -1
- package/composer/ContextChip.d.ts +1 -1
- package/composer/ContextChip.d.ts.map +1 -1
- package/composer/ContextChip.js +1 -0
- package/composer/ContextChip.js.map +1 -1
- package/composer/SessionComposer.d.ts.map +1 -1
- package/composer/SessionComposer.js +77 -4
- package/composer/SessionComposer.js.map +1 -1
- package/composer/icons.d.ts +1 -0
- package/composer/icons.d.ts.map +1 -1
- package/composer/icons.js +3 -0
- package/composer/icons.js.map +1 -1
- package/environment/useEnvironment.d.ts +2 -0
- package/environment/useEnvironment.d.ts.map +1 -1
- package/environment/useEnvironment.js +6 -33
- package/environment/useEnvironment.js.map +1 -1
- package/environment/useEnvironmentList.d.ts +2 -0
- package/environment/useEnvironmentList.d.ts.map +1 -1
- package/environment/useEnvironmentList.js +23 -53
- package/environment/useEnvironmentList.js.map +1 -1
- package/execution/ArtifactPreviewModal.js +1 -1
- package/execution/ArtifactPreviewModal.js.map +1 -1
- package/execution/useArtifactContent.d.ts +4 -2
- package/execution/useArtifactContent.d.ts.map +1 -1
- package/execution/useArtifactContent.js +23 -45
- package/execution/useArtifactContent.js.map +1 -1
- package/iam-policy/usePrincipalsCount.d.ts +2 -0
- package/iam-policy/usePrincipalsCount.d.ts.map +1 -1
- package/iam-policy/usePrincipalsCount.js +7 -46
- package/iam-policy/usePrincipalsCount.js.map +1 -1
- package/iam-policy/useResourceAccess.d.ts +2 -0
- package/iam-policy/useResourceAccess.d.ts.map +1 -1
- package/iam-policy/useResourceAccess.js +12 -47
- package/iam-policy/useResourceAccess.js.map +1 -1
- package/identity-provider/useIdentityProvider.d.ts +2 -0
- package/identity-provider/useIdentityProvider.d.ts.map +1 -1
- package/identity-provider/useIdentityProvider.js +3 -33
- package/identity-provider/useIdentityProvider.js.map +1 -1
- package/identity-provider/useIdentityProviderList.d.ts +2 -0
- package/identity-provider/useIdentityProviderList.d.ts.map +1 -1
- package/identity-provider/useIdentityProviderList.js +7 -33
- package/identity-provider/useIdentityProviderList.js.map +1 -1
- package/index.d.ts +2 -2
- package/index.d.ts.map +1 -1
- package/index.js +1 -1
- package/index.js.map +1 -1
- package/internal/__tests__/useFetch.test.d.ts +2 -0
- package/internal/__tests__/useFetch.test.d.ts.map +1 -0
- package/internal/__tests__/useFetch.test.js +95 -0
- package/internal/__tests__/useFetch.test.js.map +1 -0
- package/internal/useFetch.d.ts +51 -0
- package/internal/useFetch.d.ts.map +1 -0
- package/internal/useFetch.js +75 -0
- package/internal/useFetch.js.map +1 -0
- package/invitation/useInvitationPreview.d.ts +2 -0
- package/invitation/useInvitationPreview.d.ts.map +1 -1
- package/invitation/useInvitationPreview.js +5 -35
- package/invitation/useInvitationPreview.js.map +1 -1
- package/invitation/useOrgInvitations.d.ts +2 -0
- package/invitation/useOrgInvitations.d.ts.map +1 -1
- package/invitation/useOrgInvitations.js +6 -34
- package/invitation/useOrgInvitations.js.map +1 -1
- package/library/ResourceListView.d.ts +2 -2
- package/library/ResourceListView.d.ts.map +1 -1
- package/library/ResourceListView.js +1 -1
- package/library/ResourceListView.js.map +1 -1
- package/library/useDetectSkillPackage.d.ts +1 -1
- package/library/useDetectSkillPackage.d.ts.map +1 -1
- package/mcp-server/McpServerPicker.js +1 -1
- package/mcp-server/McpServerPicker.js.map +1 -1
- package/mcp-server/useMcpServer.d.ts +2 -0
- package/mcp-server/useMcpServer.d.ts.map +1 -1
- package/mcp-server/useMcpServer.js +13 -37
- package/mcp-server/useMcpServer.js.map +1 -1
- package/mcp-server/useMcpServerCount.d.ts +1 -1
- package/mcp-server/useMcpServerCount.d.ts.map +1 -1
- package/mcp-server/useMcpServerList.d.ts +2 -2
- package/mcp-server/useMcpServerList.d.ts.map +1 -1
- package/mcp-server/useOAuthGrantStatus.d.ts +2 -0
- package/mcp-server/useOAuthGrantStatus.d.ts.map +1 -1
- package/mcp-server/useOAuthGrantStatus.js +14 -61
- package/mcp-server/useOAuthGrantStatus.js.map +1 -1
- package/mcp-server/useOrgOAuthApp.d.ts +2 -0
- package/mcp-server/useOrgOAuthApp.d.ts.map +1 -1
- package/mcp-server/useOrgOAuthApp.js +19 -43
- package/mcp-server/useOrgOAuthApp.js.map +1 -1
- package/oauth-app/useOAuthAppList.d.ts +2 -0
- package/oauth-app/useOAuthAppList.d.ts.map +1 -1
- package/oauth-app/useOAuthAppList.js +6 -34
- package/oauth-app/useOAuthAppList.js.map +1 -1
- package/organization/useOrganization.d.ts +2 -0
- package/organization/useOrganization.d.ts.map +1 -1
- package/organization/useOrganization.js +3 -33
- package/organization/useOrganization.js.map +1 -1
- package/package.json +4 -4
- package/platform-client/usePlatformClient.d.ts +2 -0
- package/platform-client/usePlatformClient.d.ts.map +1 -1
- package/platform-client/usePlatformClient.js +3 -33
- package/platform-client/usePlatformClient.js.map +1 -1
- package/platform-client/usePlatformClientList.d.ts +2 -0
- package/platform-client/usePlatformClientList.d.ts.map +1 -1
- package/platform-client/usePlatformClientList.js +6 -34
- package/platform-client/usePlatformClientList.js.map +1 -1
- package/runner/RunnerListPanel.d.ts.map +1 -1
- package/runner/RunnerListPanel.js +21 -5
- package/runner/RunnerListPanel.js.map +1 -1
- package/runner/__tests__/phase.test.d.ts +2 -0
- package/runner/__tests__/phase.test.d.ts.map +1 -0
- package/runner/__tests__/phase.test.js +33 -0
- package/runner/__tests__/phase.test.js.map +1 -0
- package/runner/__tests__/useRunnerList.test.d.ts +2 -0
- package/runner/__tests__/useRunnerList.test.d.ts.map +1 -0
- package/runner/__tests__/useRunnerList.test.js +68 -0
- package/runner/__tests__/useRunnerList.test.js.map +1 -0
- package/runner/index.d.ts +3 -1
- package/runner/index.d.ts.map +1 -1
- package/runner/index.js +2 -1
- package/runner/index.js.map +1 -1
- package/runner/phase.d.ts +13 -0
- package/runner/phase.d.ts.map +1 -1
- package/runner/phase.js +15 -0
- package/runner/phase.js.map +1 -1
- package/runner/useRunnerCredential.d.ts +66 -0
- package/runner/useRunnerCredential.d.ts.map +1 -0
- package/runner/useRunnerCredential.js +50 -0
- package/runner/useRunnerCredential.js.map +1 -0
- package/runner/useRunnerList.d.ts +21 -0
- package/runner/useRunnerList.d.ts.map +1 -1
- package/runner/useRunnerList.js +9 -36
- package/runner/useRunnerList.js.map +1 -1
- package/search/useResourceCount.d.ts +2 -1
- package/search/useResourceCount.d.ts.map +1 -1
- package/search/useResourceCount.js +13 -37
- package/search/useResourceCount.js.map +1 -1
- package/search/useResourceList.d.ts +2 -1
- package/search/useResourceList.d.ts.map +1 -1
- package/search/useResourceList.js +26 -46
- package/search/useResourceList.js.map +1 -1
- package/search/useResourceSearch.d.ts +4 -2
- package/search/useResourceSearch.d.ts.map +1 -1
- package/search/useResourceSearch.js +7 -27
- package/search/useResourceSearch.js.map +1 -1
- package/session/useNewSessionFlow.d.ts.map +1 -1
- package/session/useNewSessionFlow.js +26 -1
- package/session/useNewSessionFlow.js.map +1 -1
- package/session/useSession.d.ts +3 -1
- package/session/useSession.d.ts.map +1 -1
- package/session/useSession.js +3 -33
- package/session/useSession.js.map +1 -1
- package/session/useSessionExecutions.d.ts +3 -1
- package/session/useSessionExecutions.d.ts.map +1 -1
- package/session/useSessionExecutions.js +6 -34
- package/session/useSessionExecutions.js.map +1 -1
- package/session/useSessionList.d.ts +5 -3
- package/session/useSessionList.d.ts.map +1 -1
- package/session/useSessionList.js +9 -31
- package/session/useSessionList.js.map +1 -1
- package/skill/SkillPicker.js +1 -1
- package/skill/SkillPicker.js.map +1 -1
- package/skill/useSkill.d.ts +2 -0
- package/skill/useSkill.d.ts.map +1 -1
- package/skill/useSkill.js +13 -37
- package/skill/useSkill.js.map +1 -1
- package/skill/useSkillCount.d.ts +1 -1
- package/skill/useSkillCount.d.ts.map +1 -1
- package/skill/useSkillList.d.ts +2 -2
- package/skill/useSkillList.d.ts.map +1 -1
- package/src/agent/AgentPicker.tsx +1 -1
- package/src/agent/__tests__/useDefaultAgent.test.tsx +308 -0
- package/src/agent/useAgent.ts +19 -41
- package/src/agent/useAgentCount.ts +1 -1
- package/src/agent/useAgentList.ts +2 -2
- package/src/agent/useDefaultAgent.ts +67 -35
- package/src/agent-instance/useAgentInstance.ts +13 -37
- package/src/agent-instance/useAgentInstanceList.ts +31 -47
- package/src/api-key/useApiKeyList.ts +9 -32
- package/src/composer/ComposerToolbar.tsx +1 -22
- package/src/composer/ContextChip.tsx +2 -1
- package/src/composer/SessionComposer.tsx +206 -5
- package/src/composer/icons.tsx +27 -0
- package/src/environment/useEnvironment.ts +13 -37
- package/src/environment/useEnvironmentList.ts +31 -58
- package/src/execution/ArtifactPreviewModal.tsx +2 -2
- package/src/execution/useArtifactContent.ts +48 -65
- package/src/iam-policy/usePrincipalsCount.ts +17 -53
- package/src/iam-policy/useResourceAccess.ts +18 -55
- package/src/identity-provider/useIdentityProvider.ts +9 -39
- package/src/identity-provider/useIdentityProviderList.ts +14 -40
- package/src/index.ts +4 -0
- package/src/internal/__tests__/useFetch.test.ts +133 -0
- package/src/internal/useFetch.ts +121 -0
- package/src/invitation/useInvitationPreview.ts +14 -40
- package/src/invitation/useOrgInvitations.ts +15 -41
- package/src/library/ResourceListView.tsx +3 -3
- package/src/library/useDetectSkillPackage.ts +1 -1
- package/src/mcp-server/McpServerPicker.tsx +1 -1
- package/src/mcp-server/useMcpServer.ts +17 -42
- package/src/mcp-server/useMcpServerCount.ts +1 -1
- package/src/mcp-server/useMcpServerList.ts +2 -2
- package/src/mcp-server/useOAuthGrantStatus.ts +31 -69
- package/src/mcp-server/useOrgOAuthApp.ts +34 -51
- package/src/oauth-app/useOAuthAppList.ts +15 -41
- package/src/organization/useOrganization.ts +9 -38
- package/src/platform-client/usePlatformClient.ts +9 -39
- package/src/platform-client/usePlatformClientList.ts +14 -42
- package/src/runner/RunnerListPanel.tsx +49 -41
- package/src/runner/__tests__/phase.test.ts +35 -0
- package/src/runner/__tests__/useRunnerList.test.tsx +96 -0
- package/src/runner/index.ts +7 -0
- package/src/runner/phase.ts +16 -0
- package/src/runner/useRunnerCredential.ts +89 -0
- package/src/runner/useRunnerList.ts +36 -44
- package/src/search/useResourceCount.ts +20 -48
- package/src/search/useResourceList.ts +40 -57
- package/src/search/useResourceSearch.ts +22 -43
- package/src/session/useNewSessionFlow.ts +35 -1
- package/src/session/useSession.ts +10 -39
- package/src/session/useSessionExecutions.ts +20 -46
- package/src/session/useSessionList.ts +21 -42
- package/src/skill/SkillPicker.tsx +1 -1
- package/src/skill/useSkill.ts +17 -42
- package/src/skill/useSkillCount.ts +1 -1
- package/src/skill/useSkillList.ts +2 -2
- package/src/usage/useOrgUsageReport.ts +18 -46
- package/styles.css +1 -1
- package/usage/useOrgUsageReport.d.ts +2 -0
- package/usage/useOrgUsageReport.d.ts.map +1 -1
- package/usage/useOrgUsageReport.js +5 -35
- package/usage/useOrgUsageReport.js.map +1 -1
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import {
|
|
2
|
+
import { useRef } from "react";
|
|
3
3
|
import { create } from "@bufbuild/protobuf";
|
|
4
4
|
import { ListSessionsRequestSchema } from "@stigmer/protos/ai/stigmer/agentic/session/v1/io_pb";
|
|
5
5
|
import { useStigmer } from "../hooks";
|
|
6
|
+
import { useFetch } from "../internal/useFetch";
|
|
6
7
|
const DEFAULT_PAGE_SIZE = 50;
|
|
7
8
|
/**
|
|
8
9
|
* Data hook that fetches a paginated list of {@link Session} entries.
|
|
@@ -35,10 +36,6 @@ const DEFAULT_PAGE_SIZE = 50;
|
|
|
35
36
|
*/
|
|
36
37
|
export function useSessionList(options) {
|
|
37
38
|
const stigmer = useStigmer();
|
|
38
|
-
const [sessions, setSessions] = useState([]);
|
|
39
|
-
const [isLoading, setIsLoading] = useState(false);
|
|
40
|
-
const [error, setError] = useState(null);
|
|
41
|
-
const [fetchKey, setFetchKey] = useState(0);
|
|
42
39
|
const pageSize = options?.pageSize ?? DEFAULT_PAGE_SIZE;
|
|
43
40
|
const tagsRef = useRef(options?.tags);
|
|
44
41
|
if (options?.tags !== tagsRef.current &&
|
|
@@ -46,31 +43,12 @@ export function useSessionList(options) {
|
|
|
46
43
|
tagsRef.current = options?.tags;
|
|
47
44
|
}
|
|
48
45
|
const tags = tagsRef.current;
|
|
49
|
-
const refetch =
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
stigmer
|
|
55
|
-
|
|
56
|
-
pageSize,
|
|
57
|
-
tags: tags ?? [],
|
|
58
|
-
}))
|
|
59
|
-
.then((result) => {
|
|
60
|
-
if (cancelled.current)
|
|
61
|
-
return;
|
|
62
|
-
setSessions(result.entries);
|
|
63
|
-
setIsLoading(false);
|
|
64
|
-
}, (err) => {
|
|
65
|
-
if (cancelled.current)
|
|
66
|
-
return;
|
|
67
|
-
setError(err instanceof Error ? err.message : "Failed to load sessions");
|
|
68
|
-
setIsLoading(false);
|
|
69
|
-
});
|
|
70
|
-
return () => {
|
|
71
|
-
cancelled.current = true;
|
|
72
|
-
};
|
|
73
|
-
}, [stigmer, fetchKey, pageSize, tags]);
|
|
74
|
-
return { sessions, isLoading, error, refetch };
|
|
46
|
+
const { data: sessions, isLoading, isRefetching, error, refetch } = useFetch(() => stigmer.session
|
|
47
|
+
.list(create(ListSessionsRequestSchema, {
|
|
48
|
+
pageSize,
|
|
49
|
+
tags: tags ?? [],
|
|
50
|
+
}))
|
|
51
|
+
.then((result) => result.entries), [stigmer, pageSize, tags], []);
|
|
52
|
+
return { sessions, isLoading, isRefetching, error, refetch };
|
|
75
53
|
}
|
|
76
54
|
//# sourceMappingURL=useSessionList.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSessionList.js","sourceRoot":"","sources":["../../src/session/useSessionList.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"useSessionList.js","sourceRoot":"","sources":["../../src/session/useSessionList.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,OAAO,EAAE,yBAAyB,EAAE,MAAM,qDAAqD,CAAC;AAChG,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAwBhD,MAAM,iBAAiB,GAAG,EAAE,CAAC;AAE7B;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,MAAM,UAAU,cAAc,CAC5B,OAA+B;IAE/B,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAE7B,MAAM,QAAQ,GAAG,OAAO,EAAE,QAAQ,IAAI,iBAAiB,CAAC;IACxD,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IAEtC,IACE,OAAO,EAAE,IAAI,KAAK,OAAO,CAAC,OAAO;QACjC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,EACjE,CAAC;QACD,OAAO,CAAC,OAAO,GAAG,OAAO,EAAE,IAAI,CAAC;IAClC,CAAC;IACD,MAAM,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC;IAE7B,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,QAAQ,CAC1E,GAAG,EAAE,CACH,OAAO,CAAC,OAAO;SACZ,IAAI,CACH,MAAM,CAAC,yBAAyB,EAAE;QAChC,QAAQ;QACR,IAAI,EAAE,IAAI,IAAI,EAAE;KACjB,CAAC,CACH;SACA,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EACrC,CAAC,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,EACzB,EAAe,CAChB,CAAC;IAEF,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;AAC/D,CAAC"}
|
package/skill/SkillPicker.js
CHANGED
|
@@ -88,7 +88,7 @@ export function SkillPicker({ org, scope, value, onChange, onDisplayNameResolved
|
|
|
88
88
|
return (_jsxs("div", { className: ["space-y-2 w-72", className].filter(Boolean).join(" "), children: [value.length > 0 && (_jsxs("div", { className: "space-y-1", children: [_jsx("div", { className: "text-[0.65rem] font-medium text-muted-foreground", children: "Selected" }), _jsxs("div", { className: "relative", children: [selected_.canScrollUp && _jsx(ScrollFade, { position: "top" }), _jsx("div", { ref: selected_.scrollRef, className: "max-h-28 space-y-1 overflow-y-auto", children: value.map((ref) => {
|
|
89
89
|
const key = refKey(ref);
|
|
90
90
|
return (_jsxs("div", { className: "flex items-center gap-2 rounded-md bg-muted-faint px-2 py-1 text-xs", children: [_jsx(SkillIcon, {}), _jsx("span", { className: "min-w-0 flex-1 truncate text-foreground", children: ref.slug }), _jsx("button", { type: "button", onClick: () => handleRemove(key), disabled: disabled, className: "shrink-0 text-muted-foreground hover:text-destructive disabled:pointer-events-none", "aria-label": `Remove ${ref.slug}`, children: _jsx(XIcon, {}) })] }, key));
|
|
91
|
-
}) }), selected_.canScrollDown && _jsx(ScrollFade, { position: "bottom" })] })] })), _jsx("input", { ref: searchRef, type: "text", role: "combobox", "aria-expanded": true, "aria-controls": LIST_ID, "aria-activedescendant": focusIndex >= 0 ? `stgm-skill-${focusIndex}` : undefined, placeholder: "Search skills...", value: query, onChange: (e) => setQuery(e.target.value), onKeyDown: handleSearchKeyDown, disabled: disabled, className: "w-full rounded-md border border-input bg-background px-2.5 py-1.5 text-xs text-foreground placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50", autoFocus: true }), error && _jsx("p", { className: "text-xs text-destructive", children: error }), _jsxs("div", { className: "relative", children: [results_.canScrollUp && _jsx(ScrollFade, { position: "top" }), _jsx("div", { ref: results_.scrollRef, id: LIST_ID, role: "listbox", "aria-label": "Skills", className: "max-h-52 overflow-y-auto", children: isLoading ? (_jsx(LoadingSkeleton, {})) : availableResults.length === 0 ? (_jsx("div", { className: "py-4 text-center text-xs text-muted-foreground", children: query
|
|
91
|
+
}) }), selected_.canScrollDown && _jsx(ScrollFade, { position: "bottom" })] })] })), _jsx("input", { ref: searchRef, type: "text", role: "combobox", "aria-expanded": true, "aria-controls": LIST_ID, "aria-activedescendant": focusIndex >= 0 ? `stgm-skill-${focusIndex}` : undefined, placeholder: "Search skills...", value: query, onChange: (e) => setQuery(e.target.value), onKeyDown: handleSearchKeyDown, disabled: disabled, className: "w-full rounded-md border border-input bg-background px-2.5 py-1.5 text-xs text-foreground placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50", autoFocus: true }), error && _jsx("p", { className: "text-xs text-destructive", children: error.message }), _jsxs("div", { className: "relative", children: [results_.canScrollUp && _jsx(ScrollFade, { position: "top" }), _jsx("div", { ref: results_.scrollRef, id: LIST_ID, role: "listbox", "aria-label": "Skills", className: "max-h-52 overflow-y-auto", children: isLoading ? (_jsx(LoadingSkeleton, {})) : availableResults.length === 0 ? (_jsx("div", { className: "py-4 text-center text-xs text-muted-foreground", children: query
|
|
92
92
|
? "No skills match your search"
|
|
93
93
|
: value.length > 0
|
|
94
94
|
? "All available skills selected"
|
package/skill/SkillPicker.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SkillPicker.js","sourceRoot":"","sources":["../../src/skill/SkillPicker.tsx"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"SkillPicker.js","sourceRoot":"","sources":["../../src/skill/SkillPicker.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EACL,QAAQ,EACR,WAAW,EACX,SAAS,EACT,MAAM,EACN,OAAO,GAER,MAAM,OAAO,CAAC;AAGf,OAAO,EAAE,eAAe,EAAE,MAAM,qFAAqF,CAAC;AACtH,OAAO,EAAE,EAAE,EAAE,MAAM,gBAAgB,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AA4BpD,SAAS,MAAM,CAAC,GAAgB;IAC9B,OAAO,GAAG,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,IAAI,EAAE,CAAC;AAClC,CAAC;AAED,MAAM,OAAO,GAAG,iBAAiB,CAAC;AAElC;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,MAAM,UAAU,WAAW,CAAC,EAC1B,GAAG,EACH,KAAK,EACL,KAAK,EACL,QAAQ,EACR,qBAAqB,EACrB,QAAQ,EACR,SAAS,GACQ;IACjB,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,cAAc,CAAC,GAAG,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;IAEtF,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;IACjD,MAAM,SAAS,GAAG,MAAM,CAAmB,IAAI,CAAC,CAAC;IACjD,MAAM,QAAQ,GAAG,gBAAgB,EAAE,CAAC;IACpC,MAAM,SAAS,GAAG,gBAAgB,EAAE,CAAC;IAErC,MAAM,YAAY,GAAG,OAAO,CAC1B,GAAG,EAAE,CAAC,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAChC,CAAC,KAAK,CAAC,CACR,CAAC;IAEF,MAAM,gBAAgB,GAAG,OAAO,CAC9B,GAAG,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,EACpE,CAAC,OAAO,EAAE,YAAY,CAAC,CACxB,CAAC;IAEF,SAAS,CAAC,GAAG,EAAE;QACb,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;IACpB,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEZ,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,UAAU,IAAI,CAAC,EAAE,CAAC;YACpB,QAAQ,CAAC,SAAS,CAAC,OAAO;gBACxB,EAAE,aAAa,CAAC,cAAc,UAAU,IAAI,CAAC;gBAC7C,EAAE,cAAc,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC,EAAE,CAAC,UAAU,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC;IAErC,MAAM,YAAY,GAAG,WAAW,CAC9B,CAAC,MAAoB,EAAE,EAAE;QACvB,MAAM,GAAG,GAAgB;YACvB,GAAG,EAAE,MAAM,CAAC,GAAG;YACf,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,IAAI,EAAE,eAAe,CAAC,KAAK;SAC5B,CAAC;QACF,QAAQ,CAAC,CAAC,GAAG,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;QAC1B,qBAAqB,EAAE,CAAC,GAAG,MAAM,CAAC,GAAG,IAAI,MAAM,CAAC,IAAI,EAAE,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;IACvE,CAAC,EACD,CAAC,KAAK,EAAE,QAAQ,EAAE,qBAAqB,CAAC,CACzC,CAAC;IAEF,MAAM,YAAY,GAAG,WAAW,CAC9B,CAAC,GAAW,EAAE,EAAE;QACd,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IACnD,CAAC,EACD,CAAC,KAAK,EAAE,QAAQ,CAAC,CAClB,CAAC;IAEF,MAAM,mBAAmB,GAAG,WAAW,CACrC,CAAC,CAAkC,EAAE,EAAE;QACrC,IAAI,CAAC,CAAC,GAAG,KAAK,WAAW,EAAE,CAAC;YAC1B,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,aAAa,CAAC,CAAC,IAAI,EAAE,EAAE,CACrB,IAAI,GAAG,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CACrD,CAAC;QACJ,CAAC;aAAM,IAAI,CAAC,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAC/B,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,aAAa,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACtD,CAAC;aAAM,IACL,CAAC,CAAC,GAAG,KAAK,OAAO;YACjB,UAAU,IAAI,CAAC;YACf,UAAU,GAAG,gBAAgB,CAAC,MAAM,EACpC,CAAC;YACD,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,YAAY,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,CAAC;QAC7C,CAAC;aAAM,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;YAC7B,CAAC,CAAC,cAAc,EAAE,CAAC;QACrB,CAAC;IACH,CAAC,EACD,CAAC,gBAAgB,EAAE,UAAU,EAAE,YAAY,CAAC,CAC7C,CAAC;IAEF,OAAO,CACL,eAAK,SAAS,EAAE,CAAC,gBAAgB,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,aAEpE,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,CACnB,eAAK,SAAS,EAAC,WAAW,aACxB,cAAK,SAAS,EAAC,kDAAkD,yBAE3D,EACN,eAAK,SAAS,EAAC,UAAU,aACtB,SAAS,CAAC,WAAW,IAAI,KAAC,UAAU,IAAC,QAAQ,EAAC,KAAK,GAAG,EAEvD,cAAK,GAAG,EAAE,SAAS,CAAC,SAAS,EAAE,SAAS,EAAC,oCAAoC,YAC1E,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;oCACjB,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;oCACxB,OAAO,CACL,eAEE,SAAS,EAAC,qEAAqE,aAE/E,KAAC,SAAS,KAAG,EACb,eAAM,SAAS,EAAC,yCAAyC,YACtD,GAAG,CAAC,IAAI,GACJ,EACP,iBACE,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,EAChC,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAC,oFAAoF,gBAClF,UAAU,GAAG,CAAC,IAAI,EAAE,YAEhC,KAAC,KAAK,KAAG,GACF,KAfJ,GAAG,CAgBJ,CACP,CAAC;gCACJ,CAAC,CAAC,GACE,EAEL,SAAS,CAAC,aAAa,IAAI,KAAC,UAAU,IAAC,QAAQ,EAAC,QAAQ,GAAG,IACxD,IACF,CACP,EAGD,gBACE,GAAG,EAAE,SAAS,EACd,IAAI,EAAC,MAAM,EACX,IAAI,EAAC,UAAU,mBACA,IAAI,mBACJ,OAAO,2BAEpB,UAAU,IAAI,CAAC,CAAC,CAAC,CAAC,cAAc,UAAU,EAAE,CAAC,CAAC,CAAC,SAAS,EAE1D,WAAW,EAAC,kBAAkB,EAC9B,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EACzC,SAAS,EAAE,mBAAmB,EAC9B,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAC,sPAAsP,EAChQ,SAAS,SACT,EAED,KAAK,IAAI,YAAG,SAAS,EAAC,0BAA0B,YAAE,KAAK,CAAC,OAAO,GAAK,EAGrE,eAAK,SAAS,EAAC,UAAU,aACtB,QAAQ,CAAC,WAAW,IAAI,KAAC,UAAU,IAAC,QAAQ,EAAC,KAAK,GAAG,EAEtD,cACE,GAAG,EAAE,QAAQ,CAAC,SAAS,EACvB,EAAE,EAAE,OAAO,EACX,IAAI,EAAC,SAAS,gBACH,QAAQ,EACnB,SAAS,EAAC,0BAA0B,YAEnC,SAAS,CAAC,CAAC,CAAC,CACX,KAAC,eAAe,KAAG,CACpB,CAAC,CAAC,CAAC,gBAAgB,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAClC,cAAK,SAAS,EAAC,gDAAgD,YAC5D,KAAK;gCACJ,CAAC,CAAC,6BAA6B;gCAC/B,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;oCAChB,CAAC,CAAC,+BAA+B;oCACjC,CAAC,CAAC,iBAAiB,GACnB,CACP,CAAC,CAAC,CAAC,CACF,gBAAgB,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CACpC,kBAEE,EAAE,EAAE,cAAc,GAAG,EAAE,EACvB,IAAI,EAAC,QAAQ,cACH,GAAG,EACb,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,EACnC,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,EAAE,CACX,+FAA+F,EAC/F,kDAAkD,EAClD,GAAG,KAAK,UAAU;gCAChB,CAAC,CAAC,2BAA2B;gCAC7B,CAAC,CAAC,uCAAuC,CAC5C,EACD,IAAI,EAAC,QAAQ,mBACE,GAAG,KAAK,UAAU,aAEjC,gBAAM,SAAS,EAAC,2BAA2B,aACzC,KAAC,SAAS,KAAG,EACb,eAAM,SAAS,EAAC,sBAAsB,YACpC,KAAC,cAAc,IAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,GAAI,GAC9C,EACP,eAAM,SAAS,EAAC,sDAAsD,YACnE,MAAM,CAAC,GAAG,GACN,IACF,EACN,MAAM,CAAC,WAAW,IAAI,CACrB,eACE,SAAS,EAAE,EAAE,CACX,2CAA2C,EAC3C,GAAG,KAAK,UAAU;wCAChB,0CAA0C,CAC7C,YAEA,MAAM,CAAC,WAAW,GACd,CACR,KAnCI,MAAM,CAAC,EAAE,CAoCP,CACV,CAAC,CACH,GACG,EAEL,QAAQ,CAAC,aAAa,IAAI,KAAC,UAAU,IAAC,QAAQ,EAAC,QAAQ,GAAG,IACvD,IACF,CACP,CAAC;AACJ,CAAC;AAED,SAAS,cAAc,CAAC,EAAE,IAAI,EAAE,KAAK,EAAmC;IACtE,IAAI,CAAC,KAAK;QAAE,OAAO,4BAAG,IAAI,GAAI,CAAC;IAC/B,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC;IAC5D,IAAI,GAAG,KAAK,CAAC,CAAC;QAAE,OAAO,4BAAG,IAAI,GAAI,CAAC;IACnC,OAAO,CACL,8BACG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,EACnB,eAAM,SAAS,EAAC,eAAe,YAAE,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,GAAG,KAAK,CAAC,MAAM,CAAC,GAAQ,EAC3E,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,KAAK,CAAC,MAAM,CAAC,IAC9B,CACJ,CAAC;AACJ,CAAC;AAED,SAAS,eAAe;IACtB,OAAO,CACL,cAAK,SAAS,EAAC,gBAAgB,YAC5B,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAC9B,eAAa,SAAS,EAAC,iCAAiC,aACtD,cACE,SAAS,EAAC,oCAAoC,EAC9C,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,GAAG,EAAE,GACzB,EACF,cACE,SAAS,EAAC,2CAA2C,EACrD,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,EAAE,GAC5C,KARM,CAAC,CASL,CACP,CAAC,GACE,CACP,CAAC;AACJ,CAAC;AAED,SAAS,SAAS;IAChB,OAAO,CACL,cACE,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,MAAM,EAAC,cAAc,EACrB,WAAW,EAAC,KAAK,EACjB,aAAa,EAAC,OAAO,EACrB,cAAc,EAAC,OAAO,EACtB,SAAS,EAAC,gCAAgC,iBAC9B,MAAM,YAElB,eAAM,CAAC,EAAC,8BAA8B,GAAG,GACrC,CACP,CAAC;AACJ,CAAC;AAED,SAAS,KAAK;IACZ,OAAO,CACL,cACE,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,MAAM,EAAC,cAAc,EACrB,WAAW,EAAC,KAAK,EACjB,aAAa,EAAC,OAAO,EACrB,cAAc,EAAC,OAAO,iBACV,MAAM,YAElB,eAAM,CAAC,EAAC,sBAAsB,GAAG,GAC7B,CACP,CAAC;AACJ,CAAC"}
|
package/skill/useSkill.d.ts
CHANGED
|
@@ -5,6 +5,8 @@ export interface UseSkillReturn {
|
|
|
5
5
|
readonly skill: Skill | null;
|
|
6
6
|
/** `true` while the initial fetch or a refetch is in flight. */
|
|
7
7
|
readonly isLoading: boolean;
|
|
8
|
+
/** `true` while a background refetch is in flight. */
|
|
9
|
+
readonly isRefetching: boolean;
|
|
8
10
|
/** Error from the last failed request, or `null` when healthy. */
|
|
9
11
|
readonly error: Error | null;
|
|
10
12
|
/** Discard cached data and re-fetch the skill from the server. */
|
package/skill/useSkill.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSkill.d.ts","sourceRoot":"","sources":["../../src/skill/useSkill.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"useSkill.d.ts","sourceRoot":"","sources":["../../src/skill/useSkill.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oDAAoD,CAAC;AAKhF,wCAAwC;AACxC,MAAM,WAAW,cAAc;IAC7B,gFAAgF;IAChF,QAAQ,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IAC7B,gEAAgE;IAChE,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC;IAC5B,sDAAsD;IACtD,QAAQ,CAAC,YAAY,EAAE,OAAO,CAAC;IAC/B,kEAAkE;IAClE,QAAQ,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IAC7B,kEAAkE;IAClE,QAAQ,CAAC,OAAO,EAAE,MAAM,IAAI,CAAC;CAC9B;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCG;AACH,wBAAgB,QAAQ,CACtB,GAAG,EAAE,MAAM,GAAG,IAAI,EAClB,IAAI,EAAE,MAAM,GAAG,IAAI,EACnB,OAAO,CAAC,EAAE,MAAM,GACf,cAAc,CAmBhB"}
|
package/skill/useSkill.js
CHANGED
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import { useCallback, useEffect, useState } from "react";
|
|
3
2
|
import { isNotFound } from "@stigmer/sdk";
|
|
4
3
|
import { useStigmer } from "../hooks";
|
|
5
|
-
import {
|
|
4
|
+
import { useFetch } from "../internal/useFetch";
|
|
6
5
|
/**
|
|
7
6
|
* Data hook that fetches a single Skill by organization, slug, and
|
|
8
7
|
* optional version.
|
|
@@ -43,41 +42,18 @@ import { toError } from "../internal/toError";
|
|
|
43
42
|
*/
|
|
44
43
|
export function useSkill(org, slug, version) {
|
|
45
44
|
const stigmer = useStigmer();
|
|
46
|
-
const
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
setError(null);
|
|
56
|
-
return;
|
|
57
|
-
}
|
|
58
|
-
const cancelled = { current: false };
|
|
59
|
-
setIsLoading(true);
|
|
60
|
-
setError(null);
|
|
61
|
-
stigmer.skill.getByReference({ org, slug, version }).then((result) => {
|
|
62
|
-
if (cancelled.current)
|
|
63
|
-
return;
|
|
64
|
-
setSkill(result);
|
|
65
|
-
setIsLoading(false);
|
|
66
|
-
}, (err) => {
|
|
67
|
-
if (cancelled.current)
|
|
68
|
-
return;
|
|
69
|
-
if (isNotFound(err)) {
|
|
70
|
-
setSkill(null);
|
|
71
|
-
setIsLoading(false);
|
|
72
|
-
return;
|
|
45
|
+
const { data: skill, isLoading, isRefetching, error, refetch } = useFetch(org && slug
|
|
46
|
+
? async () => {
|
|
47
|
+
try {
|
|
48
|
+
return await stigmer.skill.getByReference({ org, slug, version });
|
|
49
|
+
}
|
|
50
|
+
catch (err) {
|
|
51
|
+
if (isNotFound(err))
|
|
52
|
+
return null;
|
|
53
|
+
throw err;
|
|
73
54
|
}
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
return () => {
|
|
78
|
-
cancelled.current = true;
|
|
79
|
-
};
|
|
80
|
-
}, [org, slug, version, stigmer, fetchKey]);
|
|
81
|
-
return { skill, isLoading, error, refetch };
|
|
55
|
+
}
|
|
56
|
+
: null, [org, slug, version, stigmer], null);
|
|
57
|
+
return { skill, isLoading, isRefetching, error, refetch };
|
|
82
58
|
}
|
|
83
59
|
//# sourceMappingURL=useSkill.js.map
|
package/skill/useSkill.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSkill.js","sourceRoot":"","sources":["../../src/skill/useSkill.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"useSkill.js","sourceRoot":"","sources":["../../src/skill/useSkill.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAGb,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAgBhD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCG;AACH,MAAM,UAAU,QAAQ,CACtB,GAAkB,EAClB,IAAmB,EACnB,OAAgB;IAEhB,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAE7B,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,QAAQ,CACvE,GAAG,IAAI,IAAI;QACT,CAAC,CAAC,KAAK,IAAI,EAAE;YACT,IAAI,CAAC;gBACH,OAAO,MAAM,OAAO,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;YACpE,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,UAAU,CAAC,GAAG,CAAC;oBAAE,OAAO,IAAI,CAAC;gBACjC,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;QACH,CAAC,CAAC,IAAI,EACR,CAAC,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,EAC7B,IAAI,CACL,CAAC;IAEF,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;AAC5D,CAAC"}
|
package/skill/useSkillCount.d.ts
CHANGED
|
@@ -23,7 +23,7 @@ export interface UseSkillCountReturn {
|
|
|
23
23
|
/** `true` while the count fetch is in flight. */
|
|
24
24
|
readonly isLoading: boolean;
|
|
25
25
|
/** Error message from the last failed request, or `null` when healthy. */
|
|
26
|
-
readonly error:
|
|
26
|
+
readonly error: Error | null;
|
|
27
27
|
/** Discard cached data and re-fetch the count from the server. */
|
|
28
28
|
readonly refetch: () => void;
|
|
29
29
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSkillCount.d.ts","sourceRoot":"","sources":["../../src/skill/useSkillCount.ts"],"names":[],"mappings":"AAIA,OAAO,EAAoB,KAAK,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAErE,yCAAyC;AACzC,MAAM,WAAW,oBAAoB;IACnC,mDAAmD;IACnD,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACxB;;;;;;;OAOG;IACH,QAAQ,CAAC,KAAK,CAAC,EAAE,iBAAiB,CAAC;CACpC;AAED,6CAA6C;AAC7C,MAAM,WAAW,mBAAmB;IAClC;;;OAGG;IACH,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,CAAC;IACnC,iDAAiD;IACjD,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC;IAC5B,0EAA0E;IAC1E,QAAQ,CAAC,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"useSkillCount.d.ts","sourceRoot":"","sources":["../../src/skill/useSkillCount.ts"],"names":[],"mappings":"AAIA,OAAO,EAAoB,KAAK,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAErE,yCAAyC;AACzC,MAAM,WAAW,oBAAoB;IACnC,mDAAmD;IACnD,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACxB;;;;;;;OAOG;IACH,QAAQ,CAAC,KAAK,CAAC,EAAE,iBAAiB,CAAC;CACpC;AAED,6CAA6C;AAC7C,MAAM,WAAW,mBAAmB;IAClC;;;OAGG;IACH,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,CAAC;IACnC,iDAAiD;IACjD,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC;IAC5B,0EAA0E;IAC1E,QAAQ,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IAC7B,kEAAkE;IAClE,QAAQ,CAAC,OAAO,EAAE,MAAM,IAAI,CAAC;CAC9B;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAgB,aAAa,CAC3B,GAAG,EAAE,MAAM,GAAG,IAAI,EAClB,OAAO,CAAC,EAAE,oBAAoB,GAC7B,mBAAmB,CAUrB"}
|
package/skill/useSkillList.d.ts
CHANGED
|
@@ -30,8 +30,8 @@ export interface UseSkillListReturn {
|
|
|
30
30
|
readonly currentPage: number;
|
|
31
31
|
/** `true` while the initial fetch or a refetch is in flight. */
|
|
32
32
|
readonly isLoading: boolean;
|
|
33
|
-
/** Error
|
|
34
|
-
readonly error:
|
|
33
|
+
/** Error from the last failed request, or `null` when healthy. */
|
|
34
|
+
readonly error: Error | null;
|
|
35
35
|
/** Discard cached data and re-fetch the current page from the server. */
|
|
36
36
|
readonly refetch: () => void;
|
|
37
37
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSkillList.d.ts","sourceRoot":"","sources":["../../src/skill/useSkillList.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAE/E,OAAO,EAAmB,KAAK,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAEpE,wCAAwC;AACxC,MAAM,WAAW,mBAAmB;IAClC,2CAA2C;IAC3C,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAC3B,0CAA0C;IAC1C,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC;IACvB,iEAAiE;IACjE,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACxB;;;;;;;OAOG;IACH,QAAQ,CAAC,KAAK,CAAC,EAAE,iBAAiB,CAAC;CACpC;AAED,4CAA4C;AAC5C,MAAM,WAAW,kBAAkB;IACjC,oDAAoD;IACpD,QAAQ,CAAC,MAAM,EAAE,SAAS,YAAY,EAAE,CAAC;IACzC,2DAA2D;IAC3D,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,sDAAsD;IACtD,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,2DAA2D;IAC3D,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,gEAAgE;IAChE,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC;IAC5B,
|
|
1
|
+
{"version":3,"file":"useSkillList.d.ts","sourceRoot":"","sources":["../../src/skill/useSkillList.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAE/E,OAAO,EAAmB,KAAK,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAEpE,wCAAwC;AACxC,MAAM,WAAW,mBAAmB;IAClC,2CAA2C;IAC3C,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAC3B,0CAA0C;IAC1C,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC;IACvB,iEAAiE;IACjE,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACxB;;;;;;;OAOG;IACH,QAAQ,CAAC,KAAK,CAAC,EAAE,iBAAiB,CAAC;CACpC;AAED,4CAA4C;AAC5C,MAAM,WAAW,kBAAkB;IACjC,oDAAoD;IACpD,QAAQ,CAAC,MAAM,EAAE,SAAS,YAAY,EAAE,CAAC;IACzC,2DAA2D;IAC3D,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,sDAAsD;IACtD,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,2DAA2D;IAC3D,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,gEAAgE;IAChE,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC;IAC5B,kEAAkE;IAClE,QAAQ,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IAC7B,yEAAyE;IACzE,QAAQ,CAAC,OAAO,EAAE,MAAM,IAAI,CAAC;CAC9B;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAgB,YAAY,CAC1B,GAAG,EAAE,MAAM,GAAG,IAAI,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,kBAAkB,CAapB"}
|
|
@@ -203,7 +203,7 @@ export function AgentPicker({
|
|
|
203
203
|
autoFocus
|
|
204
204
|
/>
|
|
205
205
|
|
|
206
|
-
{error && <p className="text-xs text-destructive">{error}</p>}
|
|
206
|
+
{error && <p className="text-xs text-destructive">{error.message}</p>}
|
|
207
207
|
|
|
208
208
|
{/* Scrollable results list */}
|
|
209
209
|
<div className="relative">
|
|
@@ -0,0 +1,308 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach, afterEach } from "vitest";
|
|
2
|
+
import { renderHook, act } from "@testing-library/react";
|
|
3
|
+
import type { ReactNode } from "react";
|
|
4
|
+
import type { Agent } from "@stigmer/protos/ai/stigmer/agentic/agent/v1/api_pb";
|
|
5
|
+
import type { Stigmer } from "@stigmer/sdk";
|
|
6
|
+
import { StigmerContext } from "../../context";
|
|
7
|
+
import { useDefaultAgent } from "../useDefaultAgent";
|
|
8
|
+
|
|
9
|
+
const STALE_THRESHOLD_MS = 30_000;
|
|
10
|
+
|
|
11
|
+
function fakeAgent(instanceId: string): Agent {
|
|
12
|
+
return {
|
|
13
|
+
status: { defaultInstanceId: instanceId },
|
|
14
|
+
} as unknown as Agent;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
function buildMockClient(overrides: {
|
|
18
|
+
getDefault?: ReturnType<typeof vi.fn>;
|
|
19
|
+
} = {}) {
|
|
20
|
+
return {
|
|
21
|
+
agent: {
|
|
22
|
+
getDefault: overrides.getDefault ?? vi.fn(),
|
|
23
|
+
},
|
|
24
|
+
} as unknown as Stigmer;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
function makeWrapper(client: Stigmer) {
|
|
28
|
+
return ({ children }: { children: ReactNode }) => (
|
|
29
|
+
<StigmerContext.Provider value={client}>
|
|
30
|
+
{children}
|
|
31
|
+
</StigmerContext.Provider>
|
|
32
|
+
);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
function fireVisibilityChange(state: DocumentVisibilityState) {
|
|
36
|
+
Object.defineProperty(document, "visibilityState", {
|
|
37
|
+
value: state,
|
|
38
|
+
writable: true,
|
|
39
|
+
configurable: true,
|
|
40
|
+
});
|
|
41
|
+
document.dispatchEvent(new Event("visibilitychange"));
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
describe("useDefaultAgent", () => {
|
|
45
|
+
let getDefaultMock: ReturnType<typeof vi.fn>;
|
|
46
|
+
let client: Stigmer;
|
|
47
|
+
|
|
48
|
+
beforeEach(() => {
|
|
49
|
+
getDefaultMock = vi.fn();
|
|
50
|
+
client = buildMockClient({ getDefault: getDefaultMock });
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
afterEach(() => {
|
|
54
|
+
vi.restoreAllMocks();
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
// -----------------------------------------------------------------------
|
|
58
|
+
// Basic fetch behavior (no fake timers needed)
|
|
59
|
+
// -----------------------------------------------------------------------
|
|
60
|
+
|
|
61
|
+
it("fetches the default agent on mount", async () => {
|
|
62
|
+
const agent = fakeAgent("inst_1");
|
|
63
|
+
getDefaultMock.mockResolvedValueOnce(agent);
|
|
64
|
+
|
|
65
|
+
const { result } = renderHook(() => useDefaultAgent("acme"), {
|
|
66
|
+
wrapper: makeWrapper(client),
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
expect(result.current.isLoading).toBe(true);
|
|
70
|
+
|
|
71
|
+
await act(async () => {});
|
|
72
|
+
|
|
73
|
+
expect(result.current.isLoading).toBe(false);
|
|
74
|
+
expect(result.current.agent).toBe(agent);
|
|
75
|
+
expect(result.current.error).toBeNull();
|
|
76
|
+
expect(getDefaultMock).toHaveBeenCalledOnce();
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
it("skips fetching when org is null", () => {
|
|
80
|
+
const { result } = renderHook(() => useDefaultAgent(null), {
|
|
81
|
+
wrapper: makeWrapper(client),
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
expect(result.current.agent).toBeNull();
|
|
85
|
+
expect(result.current.isLoading).toBe(false);
|
|
86
|
+
expect(getDefaultMock).not.toHaveBeenCalled();
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
// -----------------------------------------------------------------------
|
|
90
|
+
// Retry on transient failure
|
|
91
|
+
// -----------------------------------------------------------------------
|
|
92
|
+
|
|
93
|
+
it("retries once on transient failure then succeeds", async () => {
|
|
94
|
+
vi.useFakeTimers();
|
|
95
|
+
try {
|
|
96
|
+
const agent = fakeAgent("inst_retry");
|
|
97
|
+
getDefaultMock
|
|
98
|
+
.mockRejectedValueOnce(new Error("network timeout"))
|
|
99
|
+
.mockResolvedValueOnce(agent);
|
|
100
|
+
|
|
101
|
+
const { result } = renderHook(() => useDefaultAgent("acme"), {
|
|
102
|
+
wrapper: makeWrapper(client),
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
expect(result.current.isLoading).toBe(true);
|
|
106
|
+
|
|
107
|
+
// Flush the rejected first attempt.
|
|
108
|
+
await act(async () => {
|
|
109
|
+
await vi.advanceTimersByTimeAsync(0);
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
// Advance past the 1s retry delay.
|
|
113
|
+
await act(async () => {
|
|
114
|
+
await vi.advanceTimersByTimeAsync(1_100);
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
expect(result.current.isLoading).toBe(false);
|
|
118
|
+
expect(result.current.agent).toBe(agent);
|
|
119
|
+
expect(result.current.error).toBeNull();
|
|
120
|
+
expect(getDefaultMock).toHaveBeenCalledTimes(2);
|
|
121
|
+
} finally {
|
|
122
|
+
vi.useRealTimers();
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
it("surfaces the error after exhausting retries", async () => {
|
|
127
|
+
vi.useFakeTimers();
|
|
128
|
+
try {
|
|
129
|
+
getDefaultMock
|
|
130
|
+
.mockRejectedValueOnce(new Error("fail 1"))
|
|
131
|
+
.mockRejectedValueOnce(new Error("fail 2"));
|
|
132
|
+
|
|
133
|
+
const { result } = renderHook(() => useDefaultAgent("acme"), {
|
|
134
|
+
wrapper: makeWrapper(client),
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
// Flush first attempt + advance past retry delay + flush retry.
|
|
138
|
+
await act(async () => {
|
|
139
|
+
await vi.advanceTimersByTimeAsync(0);
|
|
140
|
+
});
|
|
141
|
+
await act(async () => {
|
|
142
|
+
await vi.advanceTimersByTimeAsync(1_100);
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
expect(result.current.isLoading).toBe(false);
|
|
146
|
+
expect(result.current.agent).toBeNull();
|
|
147
|
+
expect(result.current.error).toBeInstanceOf(Error);
|
|
148
|
+
expect(result.current.error!.message).toBe("fail 2");
|
|
149
|
+
expect(getDefaultMock).toHaveBeenCalledTimes(2);
|
|
150
|
+
} finally {
|
|
151
|
+
vi.useRealTimers();
|
|
152
|
+
}
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
// -----------------------------------------------------------------------
|
|
156
|
+
// Visibility-aware refetch
|
|
157
|
+
// -----------------------------------------------------------------------
|
|
158
|
+
|
|
159
|
+
it("refetches when document becomes visible after stale threshold", async () => {
|
|
160
|
+
vi.useFakeTimers();
|
|
161
|
+
try {
|
|
162
|
+
const agent1 = fakeAgent("inst_old");
|
|
163
|
+
const agent2 = fakeAgent("inst_new");
|
|
164
|
+
getDefaultMock
|
|
165
|
+
.mockResolvedValueOnce(agent1)
|
|
166
|
+
.mockResolvedValueOnce(agent2);
|
|
167
|
+
|
|
168
|
+
const { result } = renderHook(() => useDefaultAgent("acme"), {
|
|
169
|
+
wrapper: makeWrapper(client),
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
// Flush initial fetch.
|
|
173
|
+
await act(async () => {
|
|
174
|
+
await vi.advanceTimersByTimeAsync(0);
|
|
175
|
+
});
|
|
176
|
+
expect(result.current.agent).toBe(agent1);
|
|
177
|
+
expect(getDefaultMock).toHaveBeenCalledTimes(1);
|
|
178
|
+
|
|
179
|
+
// Simulate idle period longer than the stale threshold.
|
|
180
|
+
await act(async () => {
|
|
181
|
+
await vi.advanceTimersByTimeAsync(STALE_THRESHOLD_MS + 1_000);
|
|
182
|
+
});
|
|
183
|
+
|
|
184
|
+
// Simulate app coming back to foreground.
|
|
185
|
+
act(() => {
|
|
186
|
+
fireVisibilityChange("visible");
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
// Flush the refetch.
|
|
190
|
+
await act(async () => {
|
|
191
|
+
await vi.advanceTimersByTimeAsync(0);
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
expect(result.current.agent).toBe(agent2);
|
|
195
|
+
expect(getDefaultMock).toHaveBeenCalledTimes(2);
|
|
196
|
+
} finally {
|
|
197
|
+
vi.useRealTimers();
|
|
198
|
+
}
|
|
199
|
+
});
|
|
200
|
+
|
|
201
|
+
it("does NOT refetch when visible within the stale window", async () => {
|
|
202
|
+
vi.useFakeTimers();
|
|
203
|
+
try {
|
|
204
|
+
const agent = fakeAgent("inst_fresh");
|
|
205
|
+
getDefaultMock.mockResolvedValueOnce(agent);
|
|
206
|
+
|
|
207
|
+
const { result } = renderHook(() => useDefaultAgent("acme"), {
|
|
208
|
+
wrapper: makeWrapper(client),
|
|
209
|
+
});
|
|
210
|
+
|
|
211
|
+
// Flush initial fetch.
|
|
212
|
+
await act(async () => {
|
|
213
|
+
await vi.advanceTimersByTimeAsync(0);
|
|
214
|
+
});
|
|
215
|
+
expect(result.current.agent).toBe(agent);
|
|
216
|
+
expect(getDefaultMock).toHaveBeenCalledTimes(1);
|
|
217
|
+
|
|
218
|
+
// Only a short time passes — well within stale threshold.
|
|
219
|
+
await act(async () => {
|
|
220
|
+
await vi.advanceTimersByTimeAsync(5_000);
|
|
221
|
+
});
|
|
222
|
+
|
|
223
|
+
act(() => {
|
|
224
|
+
fireVisibilityChange("visible");
|
|
225
|
+
});
|
|
226
|
+
|
|
227
|
+
expect(getDefaultMock).toHaveBeenCalledTimes(1);
|
|
228
|
+
} finally {
|
|
229
|
+
vi.useRealTimers();
|
|
230
|
+
}
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
it("does not refetch on hidden event", async () => {
|
|
234
|
+
vi.useFakeTimers();
|
|
235
|
+
try {
|
|
236
|
+
const agent = fakeAgent("inst_1");
|
|
237
|
+
getDefaultMock.mockResolvedValueOnce(agent);
|
|
238
|
+
|
|
239
|
+
const { result } = renderHook(() => useDefaultAgent("acme"), {
|
|
240
|
+
wrapper: makeWrapper(client),
|
|
241
|
+
});
|
|
242
|
+
|
|
243
|
+
// Flush initial fetch.
|
|
244
|
+
await act(async () => {
|
|
245
|
+
await vi.advanceTimersByTimeAsync(0);
|
|
246
|
+
});
|
|
247
|
+
expect(result.current.agent).toBe(agent);
|
|
248
|
+
|
|
249
|
+
// Advance well past stale threshold.
|
|
250
|
+
await act(async () => {
|
|
251
|
+
await vi.advanceTimersByTimeAsync(STALE_THRESHOLD_MS + 1_000);
|
|
252
|
+
});
|
|
253
|
+
|
|
254
|
+
// Hidden (not visible) should not trigger refetch.
|
|
255
|
+
act(() => {
|
|
256
|
+
fireVisibilityChange("hidden");
|
|
257
|
+
});
|
|
258
|
+
|
|
259
|
+
expect(getDefaultMock).toHaveBeenCalledTimes(1);
|
|
260
|
+
} finally {
|
|
261
|
+
vi.useRealTimers();
|
|
262
|
+
}
|
|
263
|
+
});
|
|
264
|
+
|
|
265
|
+
// -----------------------------------------------------------------------
|
|
266
|
+
// Manual refetch
|
|
267
|
+
// -----------------------------------------------------------------------
|
|
268
|
+
|
|
269
|
+
it("recovers via manual refetch after initial failure", async () => {
|
|
270
|
+
vi.useFakeTimers();
|
|
271
|
+
try {
|
|
272
|
+
const agent = fakeAgent("inst_recovered");
|
|
273
|
+
getDefaultMock
|
|
274
|
+
.mockRejectedValueOnce(new Error("initial fail"))
|
|
275
|
+
.mockRejectedValueOnce(new Error("retry fail"))
|
|
276
|
+
.mockResolvedValueOnce(agent);
|
|
277
|
+
|
|
278
|
+
const { result } = renderHook(() => useDefaultAgent("acme"), {
|
|
279
|
+
wrapper: makeWrapper(client),
|
|
280
|
+
});
|
|
281
|
+
|
|
282
|
+
// Exhaust initial attempt + retry.
|
|
283
|
+
await act(async () => {
|
|
284
|
+
await vi.advanceTimersByTimeAsync(0);
|
|
285
|
+
});
|
|
286
|
+
await act(async () => {
|
|
287
|
+
await vi.advanceTimersByTimeAsync(1_100);
|
|
288
|
+
});
|
|
289
|
+
|
|
290
|
+
expect(result.current.error).not.toBeNull();
|
|
291
|
+
|
|
292
|
+
// Manual refetch triggers recovery.
|
|
293
|
+
act(() => {
|
|
294
|
+
result.current.refetch();
|
|
295
|
+
});
|
|
296
|
+
|
|
297
|
+
// Flush the refetch.
|
|
298
|
+
await act(async () => {
|
|
299
|
+
await vi.advanceTimersByTimeAsync(0);
|
|
300
|
+
});
|
|
301
|
+
|
|
302
|
+
expect(result.current.agent).toBe(agent);
|
|
303
|
+
expect(result.current.error).toBeNull();
|
|
304
|
+
} finally {
|
|
305
|
+
vi.useRealTimers();
|
|
306
|
+
}
|
|
307
|
+
});
|
|
308
|
+
});
|
package/src/agent/useAgent.ts
CHANGED
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
|
|
3
|
-
import { useCallback, useEffect, useState } from "react";
|
|
4
3
|
import type { Agent } from "@stigmer/protos/ai/stigmer/agentic/agent/v1/api_pb";
|
|
5
4
|
import { isNotFound } from "@stigmer/sdk";
|
|
6
5
|
import { useStigmer } from "../hooks";
|
|
7
|
-
import {
|
|
6
|
+
import { useFetch } from "../internal/useFetch";
|
|
8
7
|
|
|
9
8
|
/** Return value of {@link useAgent}. */
|
|
10
9
|
export interface UseAgentReturn {
|
|
@@ -12,6 +11,8 @@ export interface UseAgentReturn {
|
|
|
12
11
|
readonly agent: Agent | null;
|
|
13
12
|
/** `true` while the initial fetch or a refetch is in flight. */
|
|
14
13
|
readonly isLoading: boolean;
|
|
14
|
+
/** `true` while a background refetch is in flight and stale data is shown. */
|
|
15
|
+
readonly isRefetching: boolean;
|
|
15
16
|
/** Error from the last failed request, or `null` when healthy. */
|
|
16
17
|
readonly error: Error | null;
|
|
17
18
|
/** Discard cached data and re-fetch the agent from the server. */
|
|
@@ -60,47 +61,24 @@ export function useAgent(
|
|
|
60
61
|
slug: string | null,
|
|
61
62
|
): UseAgentReturn {
|
|
62
63
|
const stigmer = useStigmer();
|
|
63
|
-
const [agent, setAgent] = useState<Agent | null>(null);
|
|
64
|
-
const [isLoading, setIsLoading] = useState(false);
|
|
65
|
-
const [error, setError] = useState<Error | null>(null);
|
|
66
|
-
const [fetchKey, setFetchKey] = useState(0);
|
|
67
64
|
|
|
68
|
-
const
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
const cancelled = { current: false };
|
|
79
|
-
setIsLoading(true);
|
|
80
|
-
setError(null);
|
|
81
|
-
|
|
82
|
-
stigmer.agent.getByReference({ org, slug }).then(
|
|
83
|
-
(result) => {
|
|
84
|
-
if (cancelled.current) return;
|
|
85
|
-
setAgent(result);
|
|
86
|
-
setIsLoading(false);
|
|
87
|
-
},
|
|
88
|
-
(err) => {
|
|
89
|
-
if (cancelled.current) return;
|
|
90
|
-
if (isNotFound(err)) {
|
|
91
|
-
setAgent(null);
|
|
92
|
-
setIsLoading(false);
|
|
93
|
-
return;
|
|
65
|
+
const fetchFn =
|
|
66
|
+
org && slug
|
|
67
|
+
? async () => {
|
|
68
|
+
try {
|
|
69
|
+
return await stigmer.agent.getByReference({ org, slug });
|
|
70
|
+
} catch (err) {
|
|
71
|
+
if (isNotFound(err)) return null;
|
|
72
|
+
throw err;
|
|
73
|
+
}
|
|
94
74
|
}
|
|
95
|
-
|
|
96
|
-
setIsLoading(false);
|
|
97
|
-
},
|
|
98
|
-
);
|
|
75
|
+
: null;
|
|
99
76
|
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
77
|
+
const { data: agent, isLoading, isRefetching, error, refetch } = useFetch(
|
|
78
|
+
fetchFn,
|
|
79
|
+
[org, slug, stigmer],
|
|
80
|
+
null,
|
|
81
|
+
);
|
|
104
82
|
|
|
105
|
-
return { agent, isLoading, error, refetch };
|
|
83
|
+
return { agent, isLoading, isRefetching, error, refetch };
|
|
106
84
|
}
|