@sudobility/testomniac_lib 0.0.16 → 0.0.18
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/README.md +31 -21
- package/dist/business/hooks/useHistoriesManager.d.ts +2 -2
- package/dist/business/hooks/useHistoriesManager.d.ts.map +1 -1
- package/dist/business/hooks/useHistoriesManager.js +17 -17
- package/dist/business/hooks/useHistoriesManager.js.map +1 -1
- package/dist/business/stores/historiesStore.d.ts +6 -6
- package/dist/business/stores/historiesStore.d.ts.map +1 -1
- package/dist/business/stores/historiesStore.js +18 -18
- package/dist/business/stores/historiesStore.js.map +1 -1
- package/package.json +3 -3
package/README.md
CHANGED
|
@@ -1,32 +1,39 @@
|
|
|
1
|
-
# @sudobility/
|
|
1
|
+
# @sudobility/starter_lib
|
|
2
2
|
|
|
3
|
-
Business logic library with Zustand stores for the
|
|
3
|
+
Business logic library with Zustand stores for the Starter application.
|
|
4
4
|
|
|
5
5
|
## Installation
|
|
6
6
|
|
|
7
7
|
```bash
|
|
8
|
-
bun add @sudobility/
|
|
8
|
+
bun add @sudobility/starter_lib
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
Peer dependencies:
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
bun add react @tanstack/react-query zustand @sudobility/types
|
|
9
15
|
```
|
|
10
16
|
|
|
11
17
|
## Usage
|
|
12
18
|
|
|
13
|
-
```
|
|
14
|
-
import { useHistoriesManager } from "@sudobility/
|
|
19
|
+
```ts
|
|
20
|
+
import { useHistoriesManager } from "@sudobility/starter_lib";
|
|
15
21
|
|
|
22
|
+
// In a React component:
|
|
16
23
|
const {
|
|
17
24
|
histories,
|
|
18
25
|
total,
|
|
19
26
|
percentage,
|
|
20
|
-
|
|
27
|
+
isCached,
|
|
21
28
|
createHistory,
|
|
22
29
|
updateHistory,
|
|
23
30
|
deleteHistory,
|
|
24
31
|
} = useHistoriesManager({
|
|
25
|
-
baseUrl: "
|
|
32
|
+
baseUrl: "https://api.example.com",
|
|
26
33
|
networkClient,
|
|
27
34
|
userId: "firebase-uid",
|
|
28
|
-
token,
|
|
29
|
-
autoFetch: true,
|
|
35
|
+
token: firebaseIdToken,
|
|
36
|
+
autoFetch: true, // default
|
|
30
37
|
});
|
|
31
38
|
```
|
|
32
39
|
|
|
@@ -34,32 +41,35 @@ const {
|
|
|
34
41
|
|
|
35
42
|
### useHistoriesManager
|
|
36
43
|
|
|
37
|
-
Unified hook
|
|
44
|
+
Unified hook that combines starter_client hooks + Zustand store + business logic:
|
|
38
45
|
|
|
39
46
|
- Percentage calculation: `(userSum / globalTotal) * 100`
|
|
40
|
-
-
|
|
47
|
+
- Cache fallback: returns cached data while server hasn't responded
|
|
41
48
|
- Auto-fetch on mount (configurable)
|
|
42
|
-
- Token reactivity
|
|
49
|
+
- Token reactivity: resets state on token change
|
|
43
50
|
|
|
44
51
|
### useHistoriesStore
|
|
45
52
|
|
|
46
|
-
Zustand store
|
|
53
|
+
Zustand store providing per-user client-side cache with operations: `set`, `get`, `add`, `update`, `remove`. Keyed by user ID.
|
|
47
54
|
|
|
48
55
|
## Development
|
|
49
56
|
|
|
50
57
|
```bash
|
|
51
|
-
bun run build
|
|
52
|
-
bun
|
|
53
|
-
bun
|
|
58
|
+
bun run build # Build ESM
|
|
59
|
+
bun run clean # Remove dist/
|
|
60
|
+
bun test # Run Vitest tests
|
|
61
|
+
bun run typecheck # TypeScript check
|
|
62
|
+
bun run lint # ESLint
|
|
63
|
+
bun run verify # All checks + build (use before commit)
|
|
54
64
|
```
|
|
55
65
|
|
|
56
66
|
## Related Packages
|
|
57
67
|
|
|
58
|
-
-
|
|
59
|
-
-
|
|
60
|
-
-
|
|
61
|
-
-
|
|
62
|
-
-
|
|
68
|
+
- **starter_types** -- Shared type definitions (imported transitively via starter_client)
|
|
69
|
+
- **starter_client** -- API client SDK; this library wraps its hooks with business logic
|
|
70
|
+
- **starter_app** -- Web frontend that consumes `useHistoriesManager`
|
|
71
|
+
- **starter_app_rn** -- React Native app that consumes `useHistoriesManager`
|
|
72
|
+
- **starter_api** -- Backend server (communicated with indirectly through starter_client)
|
|
63
73
|
|
|
64
74
|
## License
|
|
65
75
|
|
|
@@ -3,7 +3,7 @@ import type { FirebaseIdToken } from '@sudobility/testomniac_client';
|
|
|
3
3
|
export interface UseHistoriesManagerConfig {
|
|
4
4
|
baseUrl: string;
|
|
5
5
|
networkClient: NetworkClient;
|
|
6
|
-
|
|
6
|
+
entitySlug: Optional<string>;
|
|
7
7
|
token: Optional<FirebaseIdToken>;
|
|
8
8
|
autoFetch?: boolean;
|
|
9
9
|
}
|
|
@@ -20,5 +20,5 @@ export interface UseHistoriesManagerReturn {
|
|
|
20
20
|
deleteHistory: (historyId: string) => Promise<void>;
|
|
21
21
|
refresh: () => void;
|
|
22
22
|
}
|
|
23
|
-
export declare const useHistoriesManager: ({ baseUrl, networkClient,
|
|
23
|
+
export declare const useHistoriesManager: ({ baseUrl, networkClient, entitySlug, token, autoFetch, }: UseHistoriesManagerConfig) => UseHistoriesManagerReturn;
|
|
24
24
|
//# sourceMappingURL=useHistoriesManager.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
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,
|
|
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"}
|
|
@@ -2,10 +2,10 @@ import { useCallback, useEffect, useMemo, useRef } from 'react';
|
|
|
2
2
|
import { useHistories, useHistoriesTotal } from '@sudobility/testomniac_client';
|
|
3
3
|
import { useHistoriesStore } from '../stores/historiesStore';
|
|
4
4
|
import { calculatePercentage } from '../utils/calculations';
|
|
5
|
-
export const useHistoriesManager = ({ baseUrl, networkClient,
|
|
6
|
-
const { histories: clientHistories, isLoading: historiesLoading, error: historiesError, update, createHistory: clientCreate, updateHistory: clientUpdate, deleteHistory: clientDelete, isCreating, isUpdating, isDeleting, } = useHistories(networkClient, baseUrl,
|
|
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
7
|
const { total, isLoading: totalLoading, error: totalError, } = useHistoriesTotal(networkClient, baseUrl);
|
|
8
|
-
const cacheEntry = useHistoriesStore(useCallback(state => (
|
|
8
|
+
const cacheEntry = useHistoriesStore(useCallback(state => (entitySlug ? state.cache[entitySlug] : undefined), [entitySlug]));
|
|
9
9
|
const setHistories = useHistoriesStore(state => state.setHistories);
|
|
10
10
|
const addHistoryToStore = useHistoriesStore(state => state.addHistory);
|
|
11
11
|
const updateHistoryInStore = useHistoriesStore(state => state.updateHistory);
|
|
@@ -17,53 +17,53 @@ export const useHistoriesManager = ({ baseUrl, networkClient, userId, token, aut
|
|
|
17
17
|
const prevClientHistoriesRef = useRef(clientHistories);
|
|
18
18
|
useEffect(() => {
|
|
19
19
|
if (clientHistories.length > 0 &&
|
|
20
|
-
|
|
20
|
+
entitySlug &&
|
|
21
21
|
clientHistories !== prevClientHistoriesRef.current) {
|
|
22
22
|
prevClientHistoriesRef.current = clientHistories;
|
|
23
|
-
setHistories(
|
|
23
|
+
setHistories(entitySlug, clientHistories);
|
|
24
24
|
}
|
|
25
|
-
}, [clientHistories,
|
|
25
|
+
}, [clientHistories, entitySlug, setHistories]);
|
|
26
26
|
const percentage = useMemo(() => calculatePercentage(histories, total), [histories, total]);
|
|
27
27
|
const createHistory = useCallback(async (data) => {
|
|
28
28
|
const response = await clientCreate(data);
|
|
29
|
-
if (response.success && response.data &&
|
|
30
|
-
addHistoryToStore(
|
|
29
|
+
if (response.success && response.data && entitySlug) {
|
|
30
|
+
addHistoryToStore(entitySlug, response.data);
|
|
31
31
|
}
|
|
32
32
|
if (!response.success) {
|
|
33
33
|
throw new Error(response.error || 'Failed to create history');
|
|
34
34
|
}
|
|
35
|
-
}, [clientCreate,
|
|
35
|
+
}, [clientCreate, entitySlug, addHistoryToStore]);
|
|
36
36
|
const updateHistory = useCallback(async (historyId, data) => {
|
|
37
37
|
const response = await clientUpdate(historyId, data);
|
|
38
|
-
if (response.success && response.data &&
|
|
39
|
-
updateHistoryInStore(
|
|
38
|
+
if (response.success && response.data && entitySlug) {
|
|
39
|
+
updateHistoryInStore(entitySlug, historyId, response.data);
|
|
40
40
|
}
|
|
41
41
|
if (!response.success) {
|
|
42
42
|
throw new Error(response.error || 'Failed to update history');
|
|
43
43
|
}
|
|
44
|
-
}, [clientUpdate,
|
|
44
|
+
}, [clientUpdate, entitySlug, updateHistoryInStore]);
|
|
45
45
|
const deleteHistory = useCallback(async (historyId) => {
|
|
46
46
|
const response = await clientDelete(historyId);
|
|
47
|
-
if (response.success &&
|
|
48
|
-
removeHistoryFromStore(
|
|
47
|
+
if (response.success && entitySlug) {
|
|
48
|
+
removeHistoryFromStore(entitySlug, historyId);
|
|
49
49
|
}
|
|
50
50
|
if (!response.success) {
|
|
51
51
|
throw new Error(response.error || 'Failed to delete history');
|
|
52
52
|
}
|
|
53
|
-
}, [clientDelete,
|
|
53
|
+
}, [clientDelete, entitySlug, removeHistoryFromStore]);
|
|
54
54
|
const isLoading = historiesLoading || totalLoading || isCreating || isUpdating || isDeleting;
|
|
55
55
|
const error = historiesError ?? totalError ?? null;
|
|
56
56
|
const hasAttemptedFetchRef = useRef(false);
|
|
57
57
|
useEffect(() => {
|
|
58
58
|
if (autoFetch &&
|
|
59
59
|
token &&
|
|
60
|
-
|
|
60
|
+
entitySlug &&
|
|
61
61
|
histories.length === 0 &&
|
|
62
62
|
!hasAttemptedFetchRef.current) {
|
|
63
63
|
hasAttemptedFetchRef.current = true;
|
|
64
64
|
update();
|
|
65
65
|
}
|
|
66
|
-
}, [autoFetch, token,
|
|
66
|
+
}, [autoFetch, token, entitySlug, histories.length, update]);
|
|
67
67
|
useEffect(() => {
|
|
68
68
|
hasAttemptedFetchRef.current = false;
|
|
69
69
|
}, [token]);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useHistoriesManager.js","sourceRoot":"","sources":["../../../src/business/hooks/useHistoriesManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAShE,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAChF,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"useHistoriesManager.js","sourceRoot":"","sources":["../../../src/business/hooks/useHistoriesManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,12 +6,12 @@ export interface HistoriesCacheEntry {
|
|
|
6
6
|
}
|
|
7
7
|
export interface HistoriesStoreState {
|
|
8
8
|
cache: Record<string, HistoriesCacheEntry>;
|
|
9
|
-
setHistories: (
|
|
10
|
-
getHistories: (
|
|
11
|
-
getCacheEntry: (
|
|
12
|
-
addHistory: (
|
|
13
|
-
updateHistory: (
|
|
14
|
-
removeHistory: (
|
|
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
15
|
purgeExpired: (maxAge?: number) => void;
|
|
16
16
|
clearAll: () => void;
|
|
17
17
|
}
|
|
@@ -1 +1 @@
|
|
|
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,
|
|
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"}
|
|
@@ -5,38 +5,38 @@ const isCacheExpired = (entry, maxAge) => {
|
|
|
5
5
|
};
|
|
6
6
|
export const useHistoriesStore = create((set, get) => ({
|
|
7
7
|
cache: {},
|
|
8
|
-
setHistories: (
|
|
8
|
+
setHistories: (entitySlug, histories) => set(state => ({
|
|
9
9
|
cache: {
|
|
10
10
|
...state.cache,
|
|
11
|
-
[
|
|
11
|
+
[entitySlug]: {
|
|
12
12
|
histories,
|
|
13
13
|
cachedAt: Date.now(),
|
|
14
14
|
},
|
|
15
15
|
},
|
|
16
16
|
})),
|
|
17
|
-
getHistories: (
|
|
18
|
-
const entry = get().cache[
|
|
17
|
+
getHistories: (entitySlug, maxAge = DEFAULT_CACHE_EXPIRATION_MS) => {
|
|
18
|
+
const entry = get().cache[entitySlug];
|
|
19
19
|
if (!entry)
|
|
20
20
|
return undefined;
|
|
21
21
|
if (isCacheExpired(entry, maxAge))
|
|
22
22
|
return undefined;
|
|
23
23
|
return entry.histories;
|
|
24
24
|
},
|
|
25
|
-
getCacheEntry: (
|
|
26
|
-
const entry = get().cache[
|
|
25
|
+
getCacheEntry: (entitySlug, maxAge = DEFAULT_CACHE_EXPIRATION_MS) => {
|
|
26
|
+
const entry = get().cache[entitySlug];
|
|
27
27
|
if (!entry)
|
|
28
28
|
return undefined;
|
|
29
29
|
if (isCacheExpired(entry, maxAge))
|
|
30
30
|
return undefined;
|
|
31
31
|
return entry;
|
|
32
32
|
},
|
|
33
|
-
addHistory: (
|
|
34
|
-
const existing = state.cache[
|
|
33
|
+
addHistory: (entitySlug, history) => set(state => {
|
|
34
|
+
const existing = state.cache[entitySlug];
|
|
35
35
|
if (!existing) {
|
|
36
36
|
return {
|
|
37
37
|
cache: {
|
|
38
38
|
...state.cache,
|
|
39
|
-
[
|
|
39
|
+
[entitySlug]: {
|
|
40
40
|
histories: [history],
|
|
41
41
|
cachedAt: Date.now(),
|
|
42
42
|
},
|
|
@@ -46,35 +46,35 @@ export const useHistoriesStore = create((set, get) => ({
|
|
|
46
46
|
return {
|
|
47
47
|
cache: {
|
|
48
48
|
...state.cache,
|
|
49
|
-
[
|
|
49
|
+
[entitySlug]: {
|
|
50
50
|
histories: [...existing.histories, history],
|
|
51
51
|
cachedAt: Date.now(),
|
|
52
52
|
},
|
|
53
53
|
},
|
|
54
54
|
};
|
|
55
55
|
}),
|
|
56
|
-
updateHistory: (
|
|
57
|
-
const existing = state.cache[
|
|
56
|
+
updateHistory: (entitySlug, historyId, history) => set(state => {
|
|
57
|
+
const existing = state.cache[entitySlug];
|
|
58
58
|
if (!existing)
|
|
59
59
|
return state;
|
|
60
60
|
return {
|
|
61
61
|
cache: {
|
|
62
62
|
...state.cache,
|
|
63
|
-
[
|
|
63
|
+
[entitySlug]: {
|
|
64
64
|
histories: existing.histories.map(h => h.id === historyId ? history : h),
|
|
65
65
|
cachedAt: Date.now(),
|
|
66
66
|
},
|
|
67
67
|
},
|
|
68
68
|
};
|
|
69
69
|
}),
|
|
70
|
-
removeHistory: (
|
|
71
|
-
const existing = state.cache[
|
|
70
|
+
removeHistory: (entitySlug, historyId) => set(state => {
|
|
71
|
+
const existing = state.cache[entitySlug];
|
|
72
72
|
if (!existing)
|
|
73
73
|
return state;
|
|
74
74
|
return {
|
|
75
75
|
cache: {
|
|
76
76
|
...state.cache,
|
|
77
|
-
[
|
|
77
|
+
[entitySlug]: {
|
|
78
78
|
histories: existing.histories.filter(h => h.id !== historyId),
|
|
79
79
|
cachedAt: Date.now(),
|
|
80
80
|
},
|
|
@@ -84,9 +84,9 @@ export const useHistoriesStore = create((set, get) => ({
|
|
|
84
84
|
purgeExpired: (maxAge = DEFAULT_CACHE_EXPIRATION_MS) => set(state => {
|
|
85
85
|
const now = Date.now();
|
|
86
86
|
const newCache = {};
|
|
87
|
-
for (const [
|
|
87
|
+
for (const [key, entry] of Object.entries(state.cache)) {
|
|
88
88
|
if (now - entry.cachedAt <= maxAge) {
|
|
89
|
-
newCache[
|
|
89
|
+
newCache[key] = entry;
|
|
90
90
|
}
|
|
91
91
|
}
|
|
92
92
|
return { cache: newCache };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"historiesStore.js","sourceRoot":"","sources":["../../../src/business/stores/historiesStore.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAUjC,MAAM,CAAC,MAAM,2BAA2B,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"historiesStore.js","sourceRoot":"","sources":["../../../src/business/stores/historiesStore.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sudobility/testomniac_lib",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.18",
|
|
4
4
|
"description": "Business logic library for Starter with Zustand stores",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -43,7 +43,7 @@
|
|
|
43
43
|
"devDependencies": {
|
|
44
44
|
"@eslint/js": "^9.38.0",
|
|
45
45
|
"@sudobility/testomniac_client": "^0.0.18",
|
|
46
|
-
"@sudobility/testomniac_types": "^0.0.
|
|
46
|
+
"@sudobility/testomniac_types": "^0.0.17",
|
|
47
47
|
"@sudobility/types": "^1.9.61",
|
|
48
48
|
"@tanstack/react-query": "^5.90.5",
|
|
49
49
|
"@testing-library/react": "^16.3.2",
|
|
@@ -66,6 +66,6 @@
|
|
|
66
66
|
},
|
|
67
67
|
"repository": {
|
|
68
68
|
"type": "git",
|
|
69
|
-
"url": "https://github.com/johnqh/
|
|
69
|
+
"url": "https://github.com/johnqh/entitystarter_lib.git"
|
|
70
70
|
}
|
|
71
71
|
}
|