@sudobility/testomniac_lib 0.0.22 → 0.0.24

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.
@@ -1,2 +1,4 @@
1
- export {};
1
+ export { useScanManager } from './useScanManager';
2
+ export { useDashboardManager } from './useDashboardManager';
3
+ export { useRunManager } from './useRunManager';
2
4
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
@@ -1,2 +1,4 @@
1
- export {};
1
+ export { useScanManager } from './useScanManager';
2
+ export { useDashboardManager } from './useDashboardManager';
3
+ export { useRunManager } from './useRunManager';
2
4
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/hooks/index.ts"],"names":[],"mappings":""}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
@@ -0,0 +1,18 @@
1
+ import type { NetworkClient } from '@sudobility/types';
2
+ import type { ProjectSummaryResponse } from '@sudobility/testomniac_types';
3
+ import type { FirebaseIdToken } from '@sudobility/testomniac_client';
4
+ interface UseDashboardManagerConfig {
5
+ networkClient: NetworkClient;
6
+ baseUrl: string;
7
+ entitySlug: string;
8
+ token: FirebaseIdToken;
9
+ enabled?: boolean;
10
+ }
11
+ export declare function useDashboardManager(config: UseDashboardManagerConfig): {
12
+ projects: ProjectSummaryResponse[];
13
+ isLoading: boolean;
14
+ error: Error | null;
15
+ refetchProjects: () => Promise<void>;
16
+ };
17
+ export {};
18
+ //# sourceMappingURL=useDashboardManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDashboardManager.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/useDashboardManager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAC;AAC3E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAGrE,UAAU,yBAAyB;IACjC,aAAa,EAAE,aAAa,CAAC;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,eAAe,CAAC;IACvB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,yBAAyB;;;;;EAyCpE"}
@@ -0,0 +1,37 @@
1
+ import { useCallback, useEffect, useMemo, useState } from 'react';
2
+ import { TestomniacClient } from '@sudobility/testomniac_client';
3
+ export function useDashboardManager(config) {
4
+ const { networkClient, baseUrl, entitySlug, token, enabled = true } = config;
5
+ const [projects, setProjects] = useState([]);
6
+ const [isLoading, setIsLoading] = useState(false);
7
+ const [error, setError] = useState(null);
8
+ const client = useMemo(() => new TestomniacClient({ networkClient, baseUrl }), [networkClient, baseUrl]);
9
+ const fetchProjects = useCallback(async () => {
10
+ setIsLoading(true);
11
+ setError(null);
12
+ try {
13
+ const response = await client.getEntityProjects(entitySlug, token);
14
+ if (response.success && response.data) {
15
+ setProjects(response.data);
16
+ }
17
+ }
18
+ catch (err) {
19
+ setError(err instanceof Error ? err : new Error('Failed to fetch projects'));
20
+ }
21
+ finally {
22
+ setIsLoading(false);
23
+ }
24
+ }, [client, entitySlug, token]);
25
+ useEffect(() => {
26
+ if (enabled) {
27
+ void fetchProjects();
28
+ }
29
+ }, [enabled, fetchProjects]);
30
+ return {
31
+ projects,
32
+ isLoading,
33
+ error,
34
+ refetchProjects: fetchProjects,
35
+ };
36
+ }
37
+ //# sourceMappingURL=useDashboardManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDashboardManager.js","sourceRoot":"","sources":["../../../src/business/hooks/useDashboardManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAIlE,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAUjE,MAAM,UAAU,mBAAmB,CAAC,MAAiC;IACnE,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC;IAE7E,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAA2B,EAAE,CAAC,CAAC;IACvE,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IAEvD,MAAM,MAAM,GAAG,OAAO,CACpB,GAAG,EAAE,CAAC,IAAI,gBAAgB,CAAC,EAAE,aAAa,EAAE,OAAO,EAAE,CAAC,EACtD,CAAC,aAAa,EAAE,OAAO,CAAC,CACzB,CAAC;IAEF,MAAM,aAAa,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QAC3C,YAAY,CAAC,IAAI,CAAC,CAAC;QACnB,QAAQ,CAAC,IAAI,CAAC,CAAC;QACf,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;YACnE,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACtC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,QAAQ,CACN,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,0BAA0B,CAAC,CACnE,CAAC;QACJ,CAAC;gBAAS,CAAC;YACT,YAAY,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,EAAE,CAAC,MAAM,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC;IAEhC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,OAAO,EAAE,CAAC;YACZ,KAAK,aAAa,EAAE,CAAC;QACvB,CAAC;IACH,CAAC,EAAE,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;IAE7B,OAAO;QACL,QAAQ;QACR,SAAS;QACT,KAAK;QACL,eAAe,EAAE,aAAa;KAC/B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,31 @@
1
+ import type { NetworkClient } from '@sudobility/types';
2
+ import type { IssueResponse, PageResponse, PersonaResponse, RunDetailResponse, TestCaseResponse, TestRunResponse } from '@sudobility/testomniac_types';
3
+ import type { FirebaseIdToken } from '@sudobility/testomniac_client';
4
+ interface UseRunManagerConfig {
5
+ networkClient: NetworkClient;
6
+ baseUrl: string;
7
+ runId: number;
8
+ token: FirebaseIdToken;
9
+ enabled?: boolean;
10
+ }
11
+ export declare function useRunManager(config: UseRunManagerConfig): {
12
+ run: RunDetailResponse | null;
13
+ pages: PageResponse[];
14
+ testCases: TestCaseResponse[];
15
+ testRuns: TestRunResponse[];
16
+ issues: IssueResponse[];
17
+ personas: PersonaResponse[];
18
+ components: unknown[];
19
+ isLoading: boolean;
20
+ error: Error | null;
21
+ counts: {
22
+ pages: number;
23
+ testCases: number;
24
+ testRuns: number;
25
+ issues: number;
26
+ personas: number;
27
+ components: number;
28
+ };
29
+ };
30
+ export {};
31
+ //# sourceMappingURL=useRunManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useRunManager.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/useRunManager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,KAAK,EACV,aAAa,EACb,YAAY,EACZ,eAAe,EACf,iBAAiB,EACjB,gBAAgB,EAChB,eAAe,EAChB,MAAM,8BAA8B,CAAC;AACtC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAGrE,UAAU,mBAAmB;IAC3B,aAAa,EAAE,aAAa,CAAC;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,eAAe,CAAC;IACvB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,aAAa,CAAC,MAAM,EAAE,mBAAmB;;;;;;;;;;;;;;;;;;EAqFxD"}
@@ -0,0 +1,75 @@
1
+ import { useCallback, useEffect, useMemo, useState } from 'react';
2
+ import { TestomniacClient } from '@sudobility/testomniac_client';
3
+ export function useRunManager(config) {
4
+ const { networkClient, baseUrl, runId, token, enabled = true } = config;
5
+ const [run, setRun] = useState(null);
6
+ const [pages, setPages] = useState([]);
7
+ const [testCases, setTestCases] = useState([]);
8
+ const [testRuns, setTestRuns] = useState([]);
9
+ const [issues, setIssues] = useState([]);
10
+ const [personas, setPersonas] = useState([]);
11
+ const [components, setComponents] = useState([]);
12
+ const [isLoading, setIsLoading] = useState(false);
13
+ const [error, setError] = useState(null);
14
+ const client = useMemo(() => new TestomniacClient({ networkClient, baseUrl }), [networkClient, baseUrl]);
15
+ const fetchAll = useCallback(async () => {
16
+ setIsLoading(true);
17
+ setError(null);
18
+ try {
19
+ const [runRes, pagesRes, testCasesRes, testRunsRes, issuesRes, personasRes, componentsRes,] = await Promise.all([
20
+ client.getRun(runId, token),
21
+ client.getRunPages(runId, token),
22
+ client.getRunTestCases(runId, token),
23
+ client.getRunTestRuns(runId, token),
24
+ client.getRunIssues(runId, token),
25
+ client.getRunPersonas(runId, token),
26
+ client.getRunComponents(runId, token),
27
+ ]);
28
+ if (runRes.success && runRes.data)
29
+ setRun(runRes.data);
30
+ if (pagesRes.success && pagesRes.data)
31
+ setPages(pagesRes.data);
32
+ if (testCasesRes.success && testCasesRes.data)
33
+ setTestCases(testCasesRes.data);
34
+ if (testRunsRes.success && testRunsRes.data)
35
+ setTestRuns(testRunsRes.data);
36
+ if (issuesRes.success && issuesRes.data)
37
+ setIssues(issuesRes.data);
38
+ if (personasRes.success && personasRes.data)
39
+ setPersonas(personasRes.data);
40
+ if (componentsRes.success && componentsRes.data)
41
+ setComponents(componentsRes.data);
42
+ }
43
+ catch (err) {
44
+ setError(err instanceof Error ? err : new Error('Failed to fetch run data'));
45
+ }
46
+ finally {
47
+ setIsLoading(false);
48
+ }
49
+ }, [client, runId, token]);
50
+ useEffect(() => {
51
+ if (enabled) {
52
+ void fetchAll();
53
+ }
54
+ }, [enabled, fetchAll]);
55
+ return {
56
+ run,
57
+ pages,
58
+ testCases,
59
+ testRuns,
60
+ issues,
61
+ personas,
62
+ components,
63
+ isLoading,
64
+ error,
65
+ counts: {
66
+ pages: pages.length,
67
+ testCases: testCases.length,
68
+ testRuns: testRuns.length,
69
+ issues: issues.length,
70
+ personas: personas.length,
71
+ components: components.length,
72
+ },
73
+ };
74
+ }
75
+ //# sourceMappingURL=useRunManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useRunManager.js","sourceRoot":"","sources":["../../../src/business/hooks/useRunManager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ import type { NetworkClient } from '@sudobility/types';
2
+ import type { CreateScanRequest } from '@sudobility/testomniac_types';
3
+ interface UseScanManagerConfig {
4
+ networkClient: NetworkClient;
5
+ baseUrl: string;
6
+ }
7
+ export declare function useScanManager(config: UseScanManagerConfig): {
8
+ startScan: (data: CreateScanRequest) => Promise<import("@sudobility/types").BaseResponse<import("@sudobility/testomniac_types").CreateScanResponse>>;
9
+ isSubmitting: boolean;
10
+ submitError: Error | null;
11
+ runId: number | null;
12
+ phase: string;
13
+ pagesFound: number;
14
+ pageStatesFound: number;
15
+ actionsCompleted: number;
16
+ actionsRemaining: number;
17
+ issuesFound: number;
18
+ latestScreenshotUrl: string | null;
19
+ currentPageUrl: string | null;
20
+ events: import("@sudobility/testomniac_types").RunStreamEvent[];
21
+ isComplete: boolean;
22
+ error: string | null;
23
+ handleEvent: (event: import("@sudobility/testomniac_types").RunStreamEvent) => void;
24
+ reset: () => void;
25
+ };
26
+ export {};
27
+ //# sourceMappingURL=useScanManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useScanManager.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/useScanManager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AAItE,UAAU,oBAAoB;IAC5B,aAAa,EAAE,aAAa,CAAC;IAC7B,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,oBAAoB;sBAY1C,iBAAiB;;;;;;;;;;;;;;;;;EAyCjC"}
@@ -0,0 +1,50 @@
1
+ import { useCallback, useMemo, useState } from 'react';
2
+ import { TestomniacClient } from '@sudobility/testomniac_client';
3
+ import { useScanProgressStore } from '../stores/scanProgressStore';
4
+ export function useScanManager(config) {
5
+ const { networkClient, baseUrl } = config;
6
+ const [isSubmitting, setIsSubmitting] = useState(false);
7
+ const [submitError, setSubmitError] = useState(null);
8
+ const store = useScanProgressStore();
9
+ const client = useMemo(() => new TestomniacClient({ networkClient, baseUrl }), [networkClient, baseUrl]);
10
+ const startScan = useCallback(async (data) => {
11
+ store.reset();
12
+ setIsSubmitting(true);
13
+ setSubmitError(null);
14
+ try {
15
+ const response = await client.submitScan(data);
16
+ if (response.success && response.data?.runId) {
17
+ store.setRunId(response.data.runId);
18
+ }
19
+ return response;
20
+ }
21
+ catch (err) {
22
+ const error = err instanceof Error ? err : new Error('Failed to submit scan');
23
+ setSubmitError(error);
24
+ throw error;
25
+ }
26
+ finally {
27
+ setIsSubmitting(false);
28
+ }
29
+ }, [client, store]);
30
+ return {
31
+ startScan,
32
+ isSubmitting,
33
+ submitError,
34
+ runId: store.runId,
35
+ phase: store.phase,
36
+ pagesFound: store.pagesFound,
37
+ pageStatesFound: store.pageStatesFound,
38
+ actionsCompleted: store.actionsCompleted,
39
+ actionsRemaining: store.actionsRemaining,
40
+ issuesFound: store.issuesFound,
41
+ latestScreenshotUrl: store.latestScreenshotUrl,
42
+ currentPageUrl: store.currentPageUrl,
43
+ events: store.events,
44
+ isComplete: store.isComplete,
45
+ error: store.error,
46
+ handleEvent: store.handleEvent,
47
+ reset: store.reset,
48
+ };
49
+ }
50
+ //# sourceMappingURL=useScanManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useScanManager.js","sourceRoot":"","sources":["../../../src/business/hooks/useScanManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAGvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAOnE,MAAM,UAAU,cAAc,CAAC,MAA4B;IACzD,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,GAAG,MAAM,CAAC;IAC1C,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IACnE,MAAM,KAAK,GAAG,oBAAoB,EAAE,CAAC;IAErC,MAAM,MAAM,GAAG,OAAO,CACpB,GAAG,EAAE,CAAC,IAAI,gBAAgB,CAAC,EAAE,aAAa,EAAE,OAAO,EAAE,CAAC,EACtD,CAAC,aAAa,EAAE,OAAO,CAAC,CACzB,CAAC;IAEF,MAAM,SAAS,GAAG,WAAW,CAC3B,KAAK,EAAE,IAAuB,EAAE,EAAE;QAChC,KAAK,CAAC,KAAK,EAAE,CAAC;QACd,eAAe,CAAC,IAAI,CAAC,CAAC;QACtB,cAAc,CAAC,IAAI,CAAC,CAAC;QACrB,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAC/C,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC;gBAC7C,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACtC,CAAC;YACD,OAAO,QAAQ,CAAC;QAClB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,MAAM,KAAK,GACT,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;YAClE,cAAc,CAAC,KAAK,CAAC,CAAC;YACtB,MAAM,KAAK,CAAC;QACd,CAAC;gBAAS,CAAC;YACT,eAAe,CAAC,KAAK,CAAC,CAAC;QACzB,CAAC;IACH,CAAC,EACD,CAAC,MAAM,EAAE,KAAK,CAAC,CAChB,CAAC;IAEF,OAAO;QACL,SAAS;QACT,YAAY;QACZ,WAAW;QACX,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,eAAe,EAAE,KAAK,CAAC,eAAe;QACtC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;QACxC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;QACxC,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,mBAAmB,EAAE,KAAK,CAAC,mBAAmB;QAC9C,cAAc,EAAE,KAAK,CAAC,cAAc;QACpC,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,KAAK,EAAE,KAAK,CAAC,KAAK;KACnB,CAAC;AACJ,CAAC"}
@@ -1,2 +1,2 @@
1
- export {};
1
+ export { useScanProgressStore } from './scanProgressStore';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/business/stores/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/business/stores/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC"}
@@ -1,2 +1,2 @@
1
- export {};
1
+ export { useScanProgressStore } from './scanProgressStore';
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/stores/index.ts"],"names":[],"mappings":""}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/stores/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,22 @@
1
+ import type { RunStreamEvent } from '@sudobility/testomniac_types';
2
+ interface ScanProgressState {
3
+ runId: number | null;
4
+ phase: string;
5
+ pagesFound: number;
6
+ pageStatesFound: number;
7
+ actionsCompleted: number;
8
+ actionsRemaining: number;
9
+ issuesFound: number;
10
+ latestScreenshotUrl: string | null;
11
+ currentPageUrl: string | null;
12
+ events: RunStreamEvent[];
13
+ isComplete: boolean;
14
+ error: string | null;
15
+ setRunId: (runId: number) => void;
16
+ handleEvent: (event: RunStreamEvent) => void;
17
+ reset: () => void;
18
+ setError: (error: string | null) => void;
19
+ }
20
+ export declare const useScanProgressStore: import("zustand").UseBoundStore<import("zustand").StoreApi<ScanProgressState>>;
21
+ export {};
22
+ //# sourceMappingURL=scanProgressStore.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanProgressStore.d.ts","sourceRoot":"","sources":["../../../src/business/stores/scanProgressStore.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAEnE,UAAU,iBAAiB;IACzB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,MAAM,CAAC;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,MAAM,EAAE,cAAc,EAAE,CAAC;IACzB,UAAU,EAAE,OAAO,CAAC;IACpB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAGrB,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,WAAW,EAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,CAAC;IAC7C,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC;CAC1C;AAiBD,eAAO,MAAM,oBAAoB,gFA+D9B,CAAC"}
@@ -0,0 +1,75 @@
1
+ import { create } from 'zustand';
2
+ const initialState = {
3
+ runId: null,
4
+ phase: 'pending',
5
+ pagesFound: 0,
6
+ pageStatesFound: 0,
7
+ actionsCompleted: 0,
8
+ actionsRemaining: 0,
9
+ issuesFound: 0,
10
+ latestScreenshotUrl: null,
11
+ currentPageUrl: null,
12
+ events: [],
13
+ isComplete: false,
14
+ error: null,
15
+ };
16
+ export const useScanProgressStore = create(set => ({
17
+ ...initialState,
18
+ setRunId: runId => set({ runId }),
19
+ handleEvent: event => set(state => {
20
+ const events = [...state.events, event].slice(-100);
21
+ switch (event.type) {
22
+ case 'phase_changed':
23
+ return {
24
+ ...state,
25
+ events,
26
+ phase: event.payload.phase,
27
+ };
28
+ case 'page_discovered':
29
+ return {
30
+ ...state,
31
+ events,
32
+ pagesFound: state.pagesFound + 1,
33
+ currentPageUrl: event.payload.url,
34
+ };
35
+ case 'page_state_created':
36
+ return {
37
+ ...state,
38
+ events,
39
+ pageStatesFound: state.pageStatesFound + 1,
40
+ };
41
+ case 'action_completed':
42
+ return {
43
+ ...state,
44
+ events,
45
+ actionsCompleted: state.actionsCompleted + 1,
46
+ };
47
+ case 'issue_detected':
48
+ return {
49
+ ...state,
50
+ events,
51
+ issuesFound: state.issuesFound + 1,
52
+ };
53
+ case 'run_completed':
54
+ return {
55
+ ...state,
56
+ events,
57
+ isComplete: true,
58
+ phase: 'completed',
59
+ };
60
+ case 'run_failed':
61
+ return {
62
+ ...state,
63
+ events,
64
+ isComplete: true,
65
+ phase: 'failed',
66
+ error: event.payload.error,
67
+ };
68
+ default:
69
+ return { ...state, events };
70
+ }
71
+ }),
72
+ reset: () => set(initialState),
73
+ setError: error => set({ error }),
74
+ }));
75
+ //# sourceMappingURL=scanProgressStore.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanProgressStore.js","sourceRoot":"","sources":["../../../src/business/stores/scanProgressStore.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAwBjC,MAAM,YAAY,GAAG;IACnB,KAAK,EAAE,IAAqB;IAC5B,KAAK,EAAE,SAAS;IAChB,UAAU,EAAE,CAAC;IACb,eAAe,EAAE,CAAC;IAClB,gBAAgB,EAAE,CAAC;IACnB,gBAAgB,EAAE,CAAC;IACnB,WAAW,EAAE,CAAC;IACd,mBAAmB,EAAE,IAAqB;IAC1C,cAAc,EAAE,IAAqB;IACrC,MAAM,EAAE,EAAsB;IAC9B,UAAU,EAAE,KAAK;IACjB,KAAK,EAAE,IAAqB;CAC7B,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,MAAM,CAAoB,GAAG,CAAC,EAAE,CAAC,CAAC;IACpE,GAAG,YAAY;IAEf,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC;IAEjC,WAAW,EAAE,KAAK,CAAC,EAAE,CACnB,GAAG,CAAC,KAAK,CAAC,EAAE;QACV,MAAM,MAAM,GAAG,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;QAEpD,QAAQ,KAAK,CAAC,IAAI,EAAE,CAAC;YACnB,KAAK,eAAe;gBAClB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,KAAe;iBACrC,CAAC;YACJ,KAAK,iBAAiB;gBACpB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,UAAU,EAAE,KAAK,CAAC,UAAU,GAAG,CAAC;oBAChC,cAAc,EAAE,KAAK,CAAC,OAAO,CAAC,GAAa;iBAC5C,CAAC;YACJ,KAAK,oBAAoB;gBACvB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,eAAe,EAAE,KAAK,CAAC,eAAe,GAAG,CAAC;iBAC3C,CAAC;YACJ,KAAK,kBAAkB;gBACrB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,gBAAgB,EAAE,KAAK,CAAC,gBAAgB,GAAG,CAAC;iBAC7C,CAAC;YACJ,KAAK,gBAAgB;gBACnB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,WAAW,EAAE,KAAK,CAAC,WAAW,GAAG,CAAC;iBACnC,CAAC;YACJ,KAAK,eAAe;gBAClB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,UAAU,EAAE,IAAI;oBAChB,KAAK,EAAE,WAAW;iBACnB,CAAC;YACJ,KAAK,YAAY;gBACf,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,UAAU,EAAE,IAAI;oBAChB,KAAK,EAAE,QAAQ;oBACf,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,KAAe;iBACrC,CAAC;YACJ;gBACE,OAAO,EAAE,GAAG,KAAK,EAAE,MAAM,EAAE,CAAC;QAChC,CAAC;IACH,CAAC,CAAC;IAEJ,KAAK,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,YAAY,CAAC;IAC9B,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC;CAClC,CAAC,CAAC,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sudobility/testomniac_lib",
3
- "version": "0.0.22",
3
+ "version": "0.0.24",
4
4
  "description": "Testomniac business logic library with Zustand stores",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
@@ -42,7 +42,7 @@
42
42
  },
43
43
  "devDependencies": {
44
44
  "@eslint/js": "^9.38.0",
45
- "@sudobility/testomniac_client": "^0.0.23",
45
+ "@sudobility/testomniac_client": "^0.0.25",
46
46
  "@sudobility/testomniac_types": "^0.0.21",
47
47
  "@sudobility/types": "^1.9.61",
48
48
  "@tanstack/react-query": "^5.90.5",