@sudobility/testomniac_lib 0.0.21 → 0.0.23
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/business/hooks/index.d.ts +3 -1
- package/dist/business/hooks/index.d.ts.map +1 -1
- package/dist/business/hooks/index.js +3 -1
- package/dist/business/hooks/index.js.map +1 -1
- package/dist/business/hooks/useDashboardManager.d.ts +18 -0
- package/dist/business/hooks/useDashboardManager.d.ts.map +1 -0
- package/dist/business/hooks/useDashboardManager.js +37 -0
- package/dist/business/hooks/useDashboardManager.js.map +1 -0
- package/dist/business/hooks/useRunManager.d.ts +31 -0
- package/dist/business/hooks/useRunManager.d.ts.map +1 -0
- package/dist/business/hooks/useRunManager.js +75 -0
- package/dist/business/hooks/useRunManager.js.map +1 -0
- package/dist/business/hooks/useScanManager.d.ts +27 -0
- package/dist/business/hooks/useScanManager.d.ts.map +1 -0
- package/dist/business/hooks/useScanManager.js +50 -0
- package/dist/business/hooks/useScanManager.js.map +1 -0
- package/dist/business/stores/index.d.ts +1 -1
- package/dist/business/stores/index.d.ts.map +1 -1
- package/dist/business/stores/index.js +1 -1
- package/dist/business/stores/index.js.map +1 -1
- package/dist/business/stores/scanProgressStore.d.ts +22 -0
- package/dist/business/stores/scanProgressStore.d.ts.map +1 -0
- package/dist/business/stores/scanProgressStore.js +75 -0
- package/dist/business/stores/scanProgressStore.js.map +1 -0
- package/dist/business/utils/index.d.ts +1 -1
- package/dist/business/utils/index.d.ts.map +1 -1
- package/dist/business/utils/index.js +1 -1
- package/dist/business/utils/index.js.map +1 -1
- package/package.json +3 -3
- package/dist/business/hooks/useHistoriesManager.d.ts +0 -24
- package/dist/business/hooks/useHistoriesManager.d.ts.map +0 -1
- package/dist/business/hooks/useHistoriesManager.js +0 -96
- package/dist/business/hooks/useHistoriesManager.js.map +0 -1
- package/dist/business/stores/historiesStore.d.ts +0 -19
- package/dist/business/stores/historiesStore.d.ts.map +0 -1
- package/dist/business/stores/historiesStore.js +0 -96
- package/dist/business/stores/historiesStore.js.map +0 -1
- package/dist/business/utils/calculations.d.ts +0 -4
- package/dist/business/utils/calculations.d.ts.map +0 -1
- package/dist/business/utils/calculations.js +0 -10
- package/dist/business/utils/calculations.js.map +0 -1
|
@@ -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":"AAAA,OAAO,
|
|
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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
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":"AAAA,OAAO,
|
|
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":"AAAA,OAAO,
|
|
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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/business/utils/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/business/utils/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/utils/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/utils/index.ts"],"names":[],"mappings":""}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sudobility/testomniac_lib",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.23",
|
|
4
4
|
"description": "Testomniac business logic library with Zustand stores",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -42,8 +42,8 @@
|
|
|
42
42
|
},
|
|
43
43
|
"devDependencies": {
|
|
44
44
|
"@eslint/js": "^9.38.0",
|
|
45
|
-
"@sudobility/testomniac_client": "^0.0.
|
|
46
|
-
"@sudobility/testomniac_types": "^0.0.
|
|
45
|
+
"@sudobility/testomniac_client": "^0.0.24",
|
|
46
|
+
"@sudobility/testomniac_types": "^0.0.21",
|
|
47
47
|
"@sudobility/types": "^1.9.61",
|
|
48
48
|
"@tanstack/react-query": "^5.90.5",
|
|
49
49
|
"@testing-library/react": "^16.3.2",
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import type { History, HistoryCreateRequest, HistoryUpdateRequest, NetworkClient, Optional } from '@sudobility/testomniac_types';
|
|
2
|
-
import type { FirebaseIdToken } from '@sudobility/testomniac_client';
|
|
3
|
-
export interface UseHistoriesManagerConfig {
|
|
4
|
-
baseUrl: string;
|
|
5
|
-
networkClient: NetworkClient;
|
|
6
|
-
entitySlug: Optional<string>;
|
|
7
|
-
token: Optional<FirebaseIdToken>;
|
|
8
|
-
autoFetch?: boolean;
|
|
9
|
-
}
|
|
10
|
-
export interface UseHistoriesManagerReturn {
|
|
11
|
-
histories: History[];
|
|
12
|
-
total: number;
|
|
13
|
-
percentage: number;
|
|
14
|
-
isLoading: boolean;
|
|
15
|
-
error: Optional<string>;
|
|
16
|
-
isCached: boolean;
|
|
17
|
-
cachedAt: Optional<number>;
|
|
18
|
-
createHistory: (data: HistoryCreateRequest) => Promise<void>;
|
|
19
|
-
updateHistory: (historyId: string, data: HistoryUpdateRequest) => Promise<void>;
|
|
20
|
-
deleteHistory: (historyId: string) => Promise<void>;
|
|
21
|
-
refresh: () => void;
|
|
22
|
-
}
|
|
23
|
-
export declare const useHistoriesManager: ({ baseUrl, networkClient, entitySlug, token, autoFetch, }: UseHistoriesManagerConfig) => UseHistoriesManagerReturn;
|
|
24
|
-
//# sourceMappingURL=useHistoriesManager.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useHistoriesManager.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/useHistoriesManager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,OAAO,EACP,oBAAoB,EACpB,oBAAoB,EACpB,aAAa,EACb,QAAQ,EACT,MAAM,8BAA8B,CAAC;AACtC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAmBrE,MAAM,WAAW,yBAAyB;IAExC,OAAO,EAAE,MAAM,CAAC;IAMhB,aAAa,EAAE,aAAa,CAAC;IAM7B,UAAU,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;IAO7B,KAAK,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;IAWjC,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAQD,MAAM,WAAW,yBAAyB;IAMxC,SAAS,EAAE,OAAO,EAAE,CAAC;IAMrB,KAAK,EAAE,MAAM,CAAC;IASd,UAAU,EAAE,MAAM,CAAC;IAMnB,SAAS,EAAE,OAAO,CAAC;IAUnB,KAAK,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;IASxB,QAAQ,EAAE,OAAO,CAAC;IAMlB,QAAQ,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;IAS3B,aAAa,EAAE,CAAC,IAAI,EAAE,oBAAoB,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAU7D,aAAa,EAAE,CACb,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,oBAAoB,KACvB,OAAO,CAAC,IAAI,CAAC,CAAC;IASnB,aAAa,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAMpD,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAmDD,eAAO,MAAM,mBAAmB,GAAI,2DAMjC,yBAAyB,KAAG,yBA2J9B,CAAC"}
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
import { useCallback, useEffect, useMemo, useRef } from 'react';
|
|
2
|
-
import { useHistories, useHistoriesTotal } from '@sudobility/testomniac_client';
|
|
3
|
-
import { useHistoriesStore } from '../stores/historiesStore';
|
|
4
|
-
import { calculatePercentage } from '../utils/calculations';
|
|
5
|
-
export const useHistoriesManager = ({ baseUrl, networkClient, entitySlug, token, autoFetch = true, }) => {
|
|
6
|
-
const { histories: clientHistories, isLoading: historiesLoading, error: historiesError, update, createHistory: clientCreate, updateHistory: clientUpdate, deleteHistory: clientDelete, isCreating, isUpdating, isDeleting, } = useHistories(networkClient, baseUrl, entitySlug ?? null, token ?? null);
|
|
7
|
-
const { total, isLoading: totalLoading, error: totalError, } = useHistoriesTotal(networkClient, baseUrl);
|
|
8
|
-
const cacheEntry = useHistoriesStore(useCallback(state => (entitySlug ? state.cache[entitySlug] : undefined), [entitySlug]));
|
|
9
|
-
const setHistories = useHistoriesStore(state => state.setHistories);
|
|
10
|
-
const addHistoryToStore = useHistoriesStore(state => state.addHistory);
|
|
11
|
-
const updateHistoryInStore = useHistoriesStore(state => state.updateHistory);
|
|
12
|
-
const removeHistoryFromStore = useHistoriesStore(state => state.removeHistory);
|
|
13
|
-
const cachedHistories = cacheEntry?.histories;
|
|
14
|
-
const cachedAt = cacheEntry?.cachedAt;
|
|
15
|
-
const histories = useMemo(() => clientHistories.length > 0 ? clientHistories : (cachedHistories ?? []), [clientHistories, cachedHistories]);
|
|
16
|
-
const isCached = clientHistories.length === 0 && (cachedHistories?.length ?? 0) > 0;
|
|
17
|
-
const prevClientHistoriesRef = useRef(clientHistories);
|
|
18
|
-
useEffect(() => {
|
|
19
|
-
if (clientHistories.length > 0 &&
|
|
20
|
-
entitySlug &&
|
|
21
|
-
clientHistories !== prevClientHistoriesRef.current) {
|
|
22
|
-
prevClientHistoriesRef.current = clientHistories;
|
|
23
|
-
setHistories(entitySlug, clientHistories);
|
|
24
|
-
}
|
|
25
|
-
}, [clientHistories, entitySlug, setHistories]);
|
|
26
|
-
const percentage = useMemo(() => calculatePercentage(histories, total), [histories, total]);
|
|
27
|
-
const createHistory = useCallback(async (data) => {
|
|
28
|
-
const response = await clientCreate(data);
|
|
29
|
-
if (response.success && response.data && entitySlug) {
|
|
30
|
-
addHistoryToStore(entitySlug, response.data);
|
|
31
|
-
}
|
|
32
|
-
if (!response.success) {
|
|
33
|
-
throw new Error(response.error || 'Failed to create history');
|
|
34
|
-
}
|
|
35
|
-
}, [clientCreate, entitySlug, addHistoryToStore]);
|
|
36
|
-
const updateHistory = useCallback(async (historyId, data) => {
|
|
37
|
-
const response = await clientUpdate(historyId, data);
|
|
38
|
-
if (response.success && response.data && entitySlug) {
|
|
39
|
-
updateHistoryInStore(entitySlug, historyId, response.data);
|
|
40
|
-
}
|
|
41
|
-
if (!response.success) {
|
|
42
|
-
throw new Error(response.error || 'Failed to update history');
|
|
43
|
-
}
|
|
44
|
-
}, [clientUpdate, entitySlug, updateHistoryInStore]);
|
|
45
|
-
const deleteHistory = useCallback(async (historyId) => {
|
|
46
|
-
const response = await clientDelete(historyId);
|
|
47
|
-
if (response.success && entitySlug) {
|
|
48
|
-
removeHistoryFromStore(entitySlug, historyId);
|
|
49
|
-
}
|
|
50
|
-
if (!response.success) {
|
|
51
|
-
throw new Error(response.error || 'Failed to delete history');
|
|
52
|
-
}
|
|
53
|
-
}, [clientDelete, entitySlug, removeHistoryFromStore]);
|
|
54
|
-
const isLoading = historiesLoading || totalLoading || isCreating || isUpdating || isDeleting;
|
|
55
|
-
const error = historiesError ?? totalError ?? null;
|
|
56
|
-
const hasAttemptedFetchRef = useRef(false);
|
|
57
|
-
useEffect(() => {
|
|
58
|
-
if (autoFetch &&
|
|
59
|
-
token &&
|
|
60
|
-
entitySlug &&
|
|
61
|
-
histories.length === 0 &&
|
|
62
|
-
!hasAttemptedFetchRef.current) {
|
|
63
|
-
hasAttemptedFetchRef.current = true;
|
|
64
|
-
update();
|
|
65
|
-
}
|
|
66
|
-
}, [autoFetch, token, entitySlug, histories.length, update]);
|
|
67
|
-
useEffect(() => {
|
|
68
|
-
hasAttemptedFetchRef.current = false;
|
|
69
|
-
}, [token]);
|
|
70
|
-
return useMemo(() => ({
|
|
71
|
-
histories,
|
|
72
|
-
total,
|
|
73
|
-
percentage,
|
|
74
|
-
isLoading,
|
|
75
|
-
error,
|
|
76
|
-
isCached,
|
|
77
|
-
cachedAt: cachedAt ?? null,
|
|
78
|
-
createHistory,
|
|
79
|
-
updateHistory,
|
|
80
|
-
deleteHistory,
|
|
81
|
-
refresh: update,
|
|
82
|
-
}), [
|
|
83
|
-
histories,
|
|
84
|
-
total,
|
|
85
|
-
percentage,
|
|
86
|
-
isLoading,
|
|
87
|
-
error,
|
|
88
|
-
isCached,
|
|
89
|
-
cachedAt,
|
|
90
|
-
createHistory,
|
|
91
|
-
updateHistory,
|
|
92
|
-
deleteHistory,
|
|
93
|
-
update,
|
|
94
|
-
]);
|
|
95
|
-
};
|
|
96
|
-
//# sourceMappingURL=useHistoriesManager.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useHistoriesManager.js","sourceRoot":"","sources":["../../../src/business/hooks/useHistoriesManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import type { History } from '@sudobility/testomniac_types';
|
|
2
|
-
export declare const DEFAULT_CACHE_EXPIRATION_MS: number;
|
|
3
|
-
export interface HistoriesCacheEntry {
|
|
4
|
-
histories: History[];
|
|
5
|
-
cachedAt: number;
|
|
6
|
-
}
|
|
7
|
-
export interface HistoriesStoreState {
|
|
8
|
-
cache: Record<string, HistoriesCacheEntry>;
|
|
9
|
-
setHistories: (entitySlug: string, histories: History[]) => void;
|
|
10
|
-
getHistories: (entitySlug: string, maxAge?: number) => History[] | undefined;
|
|
11
|
-
getCacheEntry: (entitySlug: string, maxAge?: number) => HistoriesCacheEntry | undefined;
|
|
12
|
-
addHistory: (entitySlug: string, history: History) => void;
|
|
13
|
-
updateHistory: (entitySlug: string, historyId: string, history: History) => void;
|
|
14
|
-
removeHistory: (entitySlug: string, historyId: string) => void;
|
|
15
|
-
purgeExpired: (maxAge?: number) => void;
|
|
16
|
-
clearAll: () => void;
|
|
17
|
-
}
|
|
18
|
-
export declare const useHistoriesStore: import("zustand").UseBoundStore<import("zustand").StoreApi<HistoriesStoreState>>;
|
|
19
|
-
//# sourceMappingURL=historiesStore.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"historiesStore.d.ts","sourceRoot":"","sources":["../../../src/business/stores/historiesStore.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAC;AAS5D,eAAO,MAAM,2BAA2B,QAAiB,CAAC;AAQ1D,MAAM,WAAW,mBAAmB;IAElC,SAAS,EAAE,OAAO,EAAE,CAAC;IAErB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAqBD,MAAM,WAAW,mBAAmB;IAElC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;IAS3C,YAAY,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IAUjE,YAAY,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,KAAK,OAAO,EAAE,GAAG,SAAS,CAAC;IAU7E,aAAa,EAAE,CACb,UAAU,EAAE,MAAM,EAClB,MAAM,CAAC,EAAE,MAAM,KACZ,mBAAmB,GAAG,SAAS,CAAC;IASrC,UAAU,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;IAU3D,aAAa,EAAE,CACb,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,OAAO,KACb,IAAI,CAAC;IASV,aAAa,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IAO/D,YAAY,EAAE,CAAC,MAAM,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;IAKxC,QAAQ,EAAE,MAAM,IAAI,CAAC;CACtB;AAqCD,eAAO,MAAM,iBAAiB,kFAwG3B,CAAC"}
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
import { create } from 'zustand';
|
|
2
|
-
export const DEFAULT_CACHE_EXPIRATION_MS = 10 * 60 * 1000;
|
|
3
|
-
const isCacheExpired = (entry, maxAge) => {
|
|
4
|
-
return Date.now() - entry.cachedAt > maxAge;
|
|
5
|
-
};
|
|
6
|
-
export const useHistoriesStore = create((set, get) => ({
|
|
7
|
-
cache: {},
|
|
8
|
-
setHistories: (entitySlug, histories) => set(state => ({
|
|
9
|
-
cache: {
|
|
10
|
-
...state.cache,
|
|
11
|
-
[entitySlug]: {
|
|
12
|
-
histories,
|
|
13
|
-
cachedAt: Date.now(),
|
|
14
|
-
},
|
|
15
|
-
},
|
|
16
|
-
})),
|
|
17
|
-
getHistories: (entitySlug, maxAge = DEFAULT_CACHE_EXPIRATION_MS) => {
|
|
18
|
-
const entry = get().cache[entitySlug];
|
|
19
|
-
if (!entry)
|
|
20
|
-
return undefined;
|
|
21
|
-
if (isCacheExpired(entry, maxAge))
|
|
22
|
-
return undefined;
|
|
23
|
-
return entry.histories;
|
|
24
|
-
},
|
|
25
|
-
getCacheEntry: (entitySlug, maxAge = DEFAULT_CACHE_EXPIRATION_MS) => {
|
|
26
|
-
const entry = get().cache[entitySlug];
|
|
27
|
-
if (!entry)
|
|
28
|
-
return undefined;
|
|
29
|
-
if (isCacheExpired(entry, maxAge))
|
|
30
|
-
return undefined;
|
|
31
|
-
return entry;
|
|
32
|
-
},
|
|
33
|
-
addHistory: (entitySlug, history) => set(state => {
|
|
34
|
-
const existing = state.cache[entitySlug];
|
|
35
|
-
if (!existing) {
|
|
36
|
-
return {
|
|
37
|
-
cache: {
|
|
38
|
-
...state.cache,
|
|
39
|
-
[entitySlug]: {
|
|
40
|
-
histories: [history],
|
|
41
|
-
cachedAt: Date.now(),
|
|
42
|
-
},
|
|
43
|
-
},
|
|
44
|
-
};
|
|
45
|
-
}
|
|
46
|
-
return {
|
|
47
|
-
cache: {
|
|
48
|
-
...state.cache,
|
|
49
|
-
[entitySlug]: {
|
|
50
|
-
histories: [...existing.histories, history],
|
|
51
|
-
cachedAt: Date.now(),
|
|
52
|
-
},
|
|
53
|
-
},
|
|
54
|
-
};
|
|
55
|
-
}),
|
|
56
|
-
updateHistory: (entitySlug, historyId, history) => set(state => {
|
|
57
|
-
const existing = state.cache[entitySlug];
|
|
58
|
-
if (!existing)
|
|
59
|
-
return state;
|
|
60
|
-
return {
|
|
61
|
-
cache: {
|
|
62
|
-
...state.cache,
|
|
63
|
-
[entitySlug]: {
|
|
64
|
-
histories: existing.histories.map(h => h.id === historyId ? history : h),
|
|
65
|
-
cachedAt: Date.now(),
|
|
66
|
-
},
|
|
67
|
-
},
|
|
68
|
-
};
|
|
69
|
-
}),
|
|
70
|
-
removeHistory: (entitySlug, historyId) => set(state => {
|
|
71
|
-
const existing = state.cache[entitySlug];
|
|
72
|
-
if (!existing)
|
|
73
|
-
return state;
|
|
74
|
-
return {
|
|
75
|
-
cache: {
|
|
76
|
-
...state.cache,
|
|
77
|
-
[entitySlug]: {
|
|
78
|
-
histories: existing.histories.filter(h => h.id !== historyId),
|
|
79
|
-
cachedAt: Date.now(),
|
|
80
|
-
},
|
|
81
|
-
},
|
|
82
|
-
};
|
|
83
|
-
}),
|
|
84
|
-
purgeExpired: (maxAge = DEFAULT_CACHE_EXPIRATION_MS) => set(state => {
|
|
85
|
-
const now = Date.now();
|
|
86
|
-
const newCache = {};
|
|
87
|
-
for (const [key, entry] of Object.entries(state.cache)) {
|
|
88
|
-
if (now - entry.cachedAt <= maxAge) {
|
|
89
|
-
newCache[key] = entry;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
return { cache: newCache };
|
|
93
|
-
}),
|
|
94
|
-
clearAll: () => set({ cache: {} }),
|
|
95
|
-
}));
|
|
96
|
-
//# sourceMappingURL=historiesStore.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"historiesStore.js","sourceRoot":"","sources":["../../../src/business/stores/historiesStore.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import type { History } from '@sudobility/testomniac_types';
|
|
2
|
-
export declare const calculateSum: (histories: History[]) => number;
|
|
3
|
-
export declare const calculatePercentage: (histories: History[], globalTotal: number) => number;
|
|
4
|
-
//# sourceMappingURL=calculations.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"calculations.d.ts","sourceRoot":"","sources":["../../../src/business/utils/calculations.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAC;AAiB5D,eAAO,MAAM,YAAY,GAAI,WAAW,OAAO,EAAE,KAAG,MAEnD,CAAC;AA2BF,eAAO,MAAM,mBAAmB,GAC9B,WAAW,OAAO,EAAE,EACpB,aAAa,MAAM,KAClB,MAIF,CAAC"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
export const calculateSum = (histories) => {
|
|
2
|
-
return histories.reduce((sum, h) => sum + h.value, 0);
|
|
3
|
-
};
|
|
4
|
-
export const calculatePercentage = (histories, globalTotal) => {
|
|
5
|
-
if (globalTotal <= 0)
|
|
6
|
-
return 0;
|
|
7
|
-
const userSum = calculateSum(histories);
|
|
8
|
-
return (userSum / globalTotal) * 100;
|
|
9
|
-
};
|
|
10
|
-
//# sourceMappingURL=calculations.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"calculations.js","sourceRoot":"","sources":["../../../src/business/utils/calculations.ts"],"names":[],"mappings":"AAiBA,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,SAAoB,EAAU,EAAE;IAC3D,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;AACxD,CAAC,CAAC;AA2BF,MAAM,CAAC,MAAM,mBAAmB,GAAG,CACjC,SAAoB,EACpB,WAAmB,EACX,EAAE;IACV,IAAI,WAAW,IAAI,CAAC;QAAE,OAAO,CAAC,CAAC;IAC/B,MAAM,OAAO,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;IACxC,OAAO,CAAC,OAAO,GAAG,WAAW,CAAC,GAAG,GAAG,CAAC;AACvC,CAAC,CAAC"}
|