@livestore/livestore 0.0.46-dev.4 → 0.0.46
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 +10 -0
- package/dist/.tsbuildinfo +1 -1
- package/dist/__tests__/react/fixture.d.ts +18 -2
- package/dist/__tests__/react/fixture.d.ts.map +1 -1
- package/dist/__tests__/react/fixture.js +27 -3
- package/dist/__tests__/react/fixture.js.map +1 -1
- package/dist/__tests__/react/utils/otel.d.ts +10 -0
- package/dist/__tests__/react/utils/otel.d.ts.map +1 -0
- package/dist/__tests__/react/utils/otel.js +42 -0
- package/dist/__tests__/react/utils/otel.js.map +1 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/react/LiveStoreProvider.js +39 -6
- package/dist/react/LiveStoreProvider.js.map +1 -1
- package/dist/react/LiveStoreProvider.test.d.ts +2 -0
- package/dist/react/LiveStoreProvider.test.d.ts.map +1 -0
- package/dist/react/LiveStoreProvider.test.js +51 -0
- package/dist/react/LiveStoreProvider.test.js.map +1 -0
- package/dist/react/components/DiffableList copy.d.ts +19 -0
- package/dist/react/components/DiffableList copy.d.ts.map +1 -0
- package/dist/react/components/DiffableList copy.js +62 -0
- package/dist/react/components/DiffableList copy.js.map +1 -0
- package/dist/react/components/DiffableList.d.ts +2 -9
- package/dist/react/components/DiffableList.d.ts.map +1 -1
- package/dist/react/components/DiffableList.js +10 -102
- package/dist/react/components/DiffableList.js.map +1 -1
- package/dist/react/components/DiffableList2.d.ts +20 -0
- package/dist/react/components/DiffableList2.d.ts.map +1 -0
- package/dist/react/components/DiffableList2.js +119 -0
- package/dist/react/components/DiffableList2.js.map +1 -0
- package/dist/react/components/DiffableList3.d.ts +19 -0
- package/dist/react/components/DiffableList3.d.ts.map +1 -0
- package/dist/react/components/DiffableList3.js +62 -0
- package/dist/react/components/DiffableList3.js.map +1 -0
- package/dist/react/components/LiveList.d.ts +21 -0
- package/dist/react/components/LiveList.d.ts.map +1 -0
- package/dist/react/components/LiveList.js +31 -0
- package/dist/react/components/LiveList.js.map +1 -0
- package/dist/react/index.d.ts +1 -1
- package/dist/react/index.d.ts.map +1 -1
- package/dist/react/index.js +1 -1
- package/dist/react/index.js.map +1 -1
- package/dist/react/useAtom.d.ts +1 -1
- package/dist/react/useAtom.d.ts.map +1 -1
- package/dist/react/useAtom.js.map +1 -1
- package/dist/react/useQuery.d.ts +4 -1
- package/dist/react/useQuery.d.ts.map +1 -1
- package/dist/react/useQuery.js +24 -19
- package/dist/react/useQuery.js.map +1 -1
- package/dist/react/useQuery.test.js +11 -11
- package/dist/react/useQuery.test.js.map +1 -1
- package/dist/react/useRow.d.ts.map +1 -1
- package/dist/react/useRow.js +14 -69
- package/dist/react/useRow.js.map +1 -1
- package/dist/react/useRow.test.js +440 -28
- package/dist/react/useRow.test.js.map +1 -1
- package/dist/react/useRowOld.d.ts +40 -0
- package/dist/react/useRowOld.d.ts.map +1 -0
- package/dist/react/useRowOld.js +134 -0
- package/dist/react/useRowOld.js.map +1 -0
- package/dist/react/useTemporaryQuery.d.ts +15 -3
- package/dist/react/useTemporaryQuery.d.ts.map +1 -1
- package/dist/react/useTemporaryQuery.js +60 -27
- package/dist/react/useTemporaryQuery.js.map +1 -1
- package/dist/react/useTemporaryQuery.test.js +10 -9
- package/dist/react/useTemporaryQuery.test.js.map +1 -1
- package/dist/reactive.d.ts +23 -5
- package/dist/reactive.d.ts.map +1 -1
- package/dist/reactive.js +44 -11
- package/dist/reactive.js.map +1 -1
- package/dist/reactive.test.js +1 -1
- package/dist/reactive.test.js.map +1 -1
- package/dist/reactiveQueries/base-class.d.ts +1 -1
- package/dist/reactiveQueries/base-class.d.ts.map +1 -1
- package/dist/reactiveQueries/base-class.js.map +1 -1
- package/dist/reactiveQueries/graphql.d.ts +2 -2
- package/dist/reactiveQueries/graphql.d.ts.map +1 -1
- package/dist/reactiveQueries/graphql.js +16 -10
- package/dist/reactiveQueries/graphql.js.map +1 -1
- package/dist/reactiveQueries/sql.d.ts +1 -1
- package/dist/reactiveQueries/sql.d.ts.map +1 -1
- package/dist/reactiveQueries/sql.js +15 -11
- package/dist/reactiveQueries/sql.js.map +1 -1
- package/dist/reactiveQueries/sql.test.js +1 -40
- package/dist/reactiveQueries/sql.test.js.map +1 -1
- package/dist/store.d.ts +2 -2
- package/dist/store.d.ts.map +1 -1
- package/dist/store.js +10 -7
- package/dist/store.js.map +1 -1
- package/package.json +6 -8
- package/src/__tests__/react/fixture.tsx +35 -2
- package/src/__tests__/react/utils/otel.ts +61 -0
- package/src/index.ts +12 -1
- package/src/react/LiveStoreProvider.test.tsx +82 -0
- package/src/react/LiveStoreProvider.tsx +42 -7
- package/src/react/components/LiveList.tsx +84 -0
- package/src/react/index.ts +1 -1
- package/src/react/useAtom.ts +1 -1
- package/src/react/useQuery.test.tsx +11 -11
- package/src/react/useQuery.ts +29 -22
- package/src/react/useRow.test.tsx +502 -30
- package/src/react/useRow.ts +19 -107
- package/src/react/useTemporaryQuery.test.tsx +17 -16
- package/src/react/useTemporaryQuery.ts +96 -28
- package/src/reactive.test.ts +1 -1
- package/src/reactive.ts +76 -15
- package/src/reactiveQueries/base-class.ts +2 -1
- package/src/reactiveQueries/graphql.ts +21 -15
- package/src/reactiveQueries/sql.test.ts +1 -54
- package/src/reactiveQueries/sql.ts +20 -14
- package/src/store.ts +12 -8
- package/tsconfig.json +0 -1
- package/src/react/components/DiffableList.tsx +0 -192
- package/src/react/utils/useCleanup.ts +0 -25
package/dist/react/useRow.js
CHANGED
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import { DbSchema } from '@livestore/common/schema';
|
|
2
|
-
import * as otel from '@opentelemetry/api';
|
|
3
2
|
import { mapValues } from 'lodash-es';
|
|
4
3
|
import React from 'react';
|
|
5
4
|
import { mutationForQueryInfo } from '../query-info.js';
|
|
6
5
|
import { rowQuery } from '../row-query.js';
|
|
7
6
|
import { useStore } from './LiveStoreContext.js';
|
|
8
7
|
import { useQueryRef } from './useQuery.js';
|
|
9
|
-
import {
|
|
8
|
+
import { useMakeTemporaryQuery } from './useTemporaryQuery.js';
|
|
10
9
|
/**
|
|
11
10
|
* Similar to `React.useState` but returns a tuple of `[row, setRow, query$]` for a given table where ...
|
|
12
11
|
*
|
|
@@ -22,38 +21,19 @@ export const useRow = (table, idOrOptions, options_) => {
|
|
|
22
21
|
const options = typeof idOrOptions === 'string' ? options_ : idOrOptions;
|
|
23
22
|
const { defaultValues, dbGraph } = options ?? {};
|
|
24
23
|
const { store } = useStore();
|
|
25
|
-
|
|
26
|
-
const { query$, otelContext } =
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
const query$ = DbSchema.tableIsSingleton(table)
|
|
39
|
-
? rowQuery(table, { otelContext, dbGraph })
|
|
40
|
-
: rowQuery(table, id, {
|
|
41
|
-
otelContext,
|
|
42
|
-
defaultValues: defaultValues,
|
|
43
|
-
dbGraph,
|
|
44
|
-
});
|
|
45
|
-
rcCache.set(table, id ?? 'singleton', query$, reactId, otelContext, span);
|
|
46
|
-
return { query$, otelContext };
|
|
47
|
-
}, [table, id, reactId, store, defaultValues, dbGraph]);
|
|
48
|
-
useCleanup(React.useCallback(() => {
|
|
49
|
-
const cachedItem = rcCache.get(table, id ?? 'singleton');
|
|
50
|
-
cachedItem.reactIds.delete(reactId);
|
|
51
|
-
if (cachedItem.reactIds.size === 0) {
|
|
52
|
-
rcCache.delete(cachedItem.query$);
|
|
53
|
-
cachedItem.query$.destroy();
|
|
54
|
-
cachedItem.span.end();
|
|
55
|
-
}
|
|
56
|
-
}, [table, id, reactId]));
|
|
24
|
+
// console.debug('useRow', table.sqliteDef.name, id)
|
|
25
|
+
const { query$, otelContext } = useMakeTemporaryQuery((otelContext) => DbSchema.tableIsSingleton(table)
|
|
26
|
+
? rowQuery(table, { otelContext, dbGraph })
|
|
27
|
+
: rowQuery(table, id, {
|
|
28
|
+
otelContext,
|
|
29
|
+
defaultValues: defaultValues,
|
|
30
|
+
dbGraph,
|
|
31
|
+
}), [id, table.sqliteDef.name], {
|
|
32
|
+
otel: {
|
|
33
|
+
spanName: `LiveStore:useRow:${table.sqliteDef.name}${id === undefined ? '' : `:${id}`}`,
|
|
34
|
+
attributes: { id },
|
|
35
|
+
},
|
|
36
|
+
});
|
|
57
37
|
const query$Ref = useQueryRef(query$, otelContext);
|
|
58
38
|
const setState = React.useMemo(() => {
|
|
59
39
|
if (table.isSingleColumn) {
|
|
@@ -94,39 +74,4 @@ export const useRow = (table, idOrOptions, options_) => {
|
|
|
94
74
|
}, [query$.queryInfo, query$Ref, sqliteTableDef.columns, store, table.isSingleColumn]);
|
|
95
75
|
return [query$Ref.current, setState, query$];
|
|
96
76
|
};
|
|
97
|
-
/** Reference counted cache for `query$` and otel context */
|
|
98
|
-
class RCCache {
|
|
99
|
-
cache = new Map();
|
|
100
|
-
reverseCache = new Map();
|
|
101
|
-
get = (table, id) => {
|
|
102
|
-
const queries = this.cache.get(table);
|
|
103
|
-
if (queries === undefined)
|
|
104
|
-
return undefined;
|
|
105
|
-
return queries.get(id);
|
|
106
|
-
};
|
|
107
|
-
set = (table, id, query$, reactId, otelContext, span) => {
|
|
108
|
-
let queries = this.cache.get(table);
|
|
109
|
-
if (queries === undefined) {
|
|
110
|
-
queries = new Map();
|
|
111
|
-
this.cache.set(table, queries);
|
|
112
|
-
}
|
|
113
|
-
queries.set(id, { query$, otelContext, span, reactIds: new Set([reactId]) });
|
|
114
|
-
this.reverseCache.set(query$, [table, id]);
|
|
115
|
-
};
|
|
116
|
-
delete = (query$) => {
|
|
117
|
-
const item = this.reverseCache.get(query$);
|
|
118
|
-
if (item === undefined)
|
|
119
|
-
return;
|
|
120
|
-
const [table, id] = item;
|
|
121
|
-
const queries = this.cache.get(table);
|
|
122
|
-
if (queries === undefined)
|
|
123
|
-
return;
|
|
124
|
-
queries.delete(id);
|
|
125
|
-
if (queries.size === 0) {
|
|
126
|
-
this.cache.delete(table);
|
|
127
|
-
}
|
|
128
|
-
this.reverseCache.delete(query$);
|
|
129
|
-
};
|
|
130
|
-
}
|
|
131
|
-
const rcCache = new RCCache();
|
|
132
77
|
//# sourceMappingURL=useRow.js.map
|
package/dist/react/useRow.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useRow.js","sourceRoot":"","sources":["../../src/react/useRow.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;
|
|
1
|
+
{"version":3,"file":"useRow.js","sourceRoot":"","sources":["../../src/react/useRow.ts"],"names":[],"mappings":"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"}
|