@sudobility/testomniac_lib 0.0.16 → 0.0.19
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 +4 -4
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.19",
|
|
4
4
|
"description": "Business logic library for Starter 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.20",
|
|
46
|
+
"@sudobility/testomniac_types": "^0.0.18",
|
|
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
|
}
|