@livestore/livestore 0.1.0-dev.9 → 0.2.0-dev.0
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 +3 -1
- package/dist/.tsbuildinfo +1 -1
- package/dist/global-state.d.ts +1 -1
- package/dist/global-state.d.ts.map +1 -1
- package/dist/global-state.js +1 -1
- package/dist/global-state.js.map +1 -1
- package/dist/index.d.ts +6 -6
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -5
- package/dist/index.js.map +1 -1
- package/dist/live-queries/base-class.d.ts +64 -0
- package/dist/live-queries/base-class.d.ts.map +1 -0
- package/dist/live-queries/base-class.js +31 -0
- package/dist/live-queries/base-class.js.map +1 -0
- package/dist/live-queries/computed.d.ts +26 -0
- package/dist/live-queries/computed.d.ts.map +1 -0
- package/dist/{reactiveQueries/js.js → live-queries/computed.js} +7 -26
- package/dist/live-queries/computed.js.map +1 -0
- package/dist/live-queries/db.d.ts +66 -0
- package/dist/live-queries/db.d.ts.map +1 -0
- package/dist/live-queries/db.js +199 -0
- package/dist/live-queries/db.js.map +1 -0
- package/dist/live-queries/db.test.d.ts +2 -0
- package/dist/live-queries/db.test.d.ts.map +1 -0
- package/dist/live-queries/db.test.js +117 -0
- package/dist/live-queries/db.test.js.map +1 -0
- package/dist/live-queries/graphql.d.ts +49 -0
- package/dist/live-queries/graphql.d.ts.map +1 -0
- package/dist/live-queries/graphql.js +122 -0
- package/dist/live-queries/graphql.js.map +1 -0
- package/dist/live-queries/sql.d.ts +62 -0
- package/dist/live-queries/sql.d.ts.map +1 -0
- package/dist/live-queries/sql.js +175 -0
- package/dist/live-queries/sql.js.map +1 -0
- package/dist/live-queries/sql.test.d.ts +2 -0
- package/dist/live-queries/sql.test.d.ts.map +1 -0
- package/{src/reactiveQueries/sql.test.ts → dist/live-queries/sql.test.js} +68 -91
- package/dist/live-queries/sql.test.js.map +1 -0
- package/dist/reactiveQueries/base-class.d.ts +6 -2
- package/dist/reactiveQueries/base-class.d.ts.map +1 -1
- package/dist/reactiveQueries/base-class.js +2 -0
- package/dist/reactiveQueries/base-class.js.map +1 -1
- package/dist/reactiveQueries/computed.d.ts +4 -13
- package/dist/reactiveQueries/computed.d.ts.map +1 -1
- package/dist/reactiveQueries/computed.js +2 -21
- package/dist/reactiveQueries/computed.js.map +1 -1
- package/dist/reactiveQueries/graphql.d.ts +4 -8
- package/dist/reactiveQueries/graphql.d.ts.map +1 -1
- package/dist/reactiveQueries/graphql.js +1 -15
- package/dist/reactiveQueries/graphql.js.map +1 -1
- package/dist/reactiveQueries/sql.d.ts +36 -23
- package/dist/reactiveQueries/sql.d.ts.map +1 -1
- package/dist/reactiveQueries/sql.js +100 -55
- package/dist/reactiveQueries/sql.js.map +1 -1
- package/dist/reactiveQueries/sql.test.js +12 -11
- package/dist/reactiveQueries/sql.test.js.map +1 -1
- package/dist/row-query-utils.d.ts +17 -0
- package/dist/row-query-utils.d.ts.map +1 -0
- package/dist/row-query-utils.js +30 -0
- package/dist/row-query-utils.js.map +1 -0
- package/dist/row-query.d.ts +10 -27
- package/dist/row-query.d.ts.map +1 -1
- package/dist/row-query.js +16 -66
- package/dist/row-query.js.map +1 -1
- package/dist/store/create-store.d.ts +1 -1
- package/dist/store/create-store.d.ts.map +1 -1
- package/dist/store/devtools.d.ts +1 -1
- package/dist/store/devtools.d.ts.map +1 -1
- package/dist/store/devtools.js.map +1 -1
- package/dist/store/store-types.d.ts +2 -2
- package/dist/store/store-types.d.ts.map +1 -1
- package/dist/store/store.d.ts +8 -3
- package/dist/store/store.d.ts.map +1 -1
- package/dist/store/store.js +32 -4
- package/dist/store/store.js.map +1 -1
- package/dist/utils/tests/fixture.d.ts +168 -132
- package/dist/utils/tests/fixture.d.ts.map +1 -1
- package/package.json +5 -5
- package/src/global-state.ts +1 -1
- package/src/index.ts +8 -5
- package/src/live-queries/__snapshots__/db.test.ts.snap +301 -0
- package/src/{reactiveQueries → live-queries}/base-class.ts +10 -5
- package/src/{reactiveQueries → live-queries}/computed.ts +5 -29
- package/src/live-queries/db.test.ts +153 -0
- package/src/live-queries/db.ts +350 -0
- package/src/{reactiveQueries → live-queries}/graphql.ts +6 -21
- package/src/row-query-utils.ts +65 -0
- package/src/store/create-store.ts +1 -1
- package/src/store/devtools.ts +1 -1
- package/src/store/store-types.ts +2 -2
- package/src/store/store.ts +44 -7
- package/dist/reactiveQueries/js.d.ts +0 -35
- package/dist/reactiveQueries/js.d.ts.map +0 -1
- package/dist/reactiveQueries/js.js.map +0 -1
- package/dist/store/store-context.d.ts +0 -26
- package/dist/store/store-context.d.ts.map +0 -1
- package/dist/store/store-context.js +0 -6
- package/dist/store/store-context.js.map +0 -1
- package/dist/store-context.d.ts +0 -26
- package/dist/store-context.d.ts.map +0 -1
- package/dist/store-context.js +0 -6
- package/dist/store-context.js.map +0 -1
- package/dist/store-devtools.d.ts +0 -19
- package/dist/store-devtools.d.ts.map +0 -1
- package/dist/store-devtools.js +0 -141
- package/dist/store-devtools.js.map +0 -1
- package/dist/store.d.ts +0 -175
- package/dist/store.d.ts.map +0 -1
- package/dist/store.js +0 -509
- package/dist/store.js.map +0 -1
- package/src/reactiveQueries/sql.ts +0 -226
- package/src/row-query.ts +0 -196
|
@@ -1,85 +1,130 @@
|
|
|
1
|
-
import { prepareBindValues } from '@livestore/common';
|
|
2
|
-
import { shouldNeverHappen } from '@livestore/utils';
|
|
3
|
-
import { Schema, TreeFormatter } from '@livestore/utils/effect';
|
|
1
|
+
import { getResultSchema, isQueryBuilder, prepareBindValues, QueryBuilderAstSymbol, replaceSessionIdSymbol, } from '@livestore/common';
|
|
2
|
+
import { deepEqual, shouldNeverHappen } from '@livestore/utils';
|
|
3
|
+
import { Predicate, Schema, TreeFormatter } from '@livestore/utils/effect';
|
|
4
4
|
import * as otel from '@opentelemetry/api';
|
|
5
5
|
import { globalReactivityGraph } from '../global-state.js';
|
|
6
|
-
import { NOT_REFRESHED_YET } from '../reactive.js';
|
|
6
|
+
import { isThunk, NOT_REFRESHED_YET } from '../reactive.js';
|
|
7
|
+
import { makeExecBeforeFirstRun, rowQueryLabel } from '../row-query.js';
|
|
7
8
|
import { getDurationMsFromSpan } from '../utils/otel.js';
|
|
8
9
|
import { LiveStoreQueryBase, makeGetAtomResult } from './base-class.js';
|
|
9
10
|
/**
|
|
10
|
-
* NOTE `
|
|
11
|
+
* NOTE `query` is only supposed to read data. Don't use it to insert/update/delete data but use mutations instead.
|
|
11
12
|
*/
|
|
12
|
-
export const
|
|
13
|
+
export const queryDb = (queryInput, options) => new LiveStoreSQLQuery({
|
|
14
|
+
queryInput,
|
|
13
15
|
label: options?.label,
|
|
14
|
-
genQueryString: query,
|
|
15
|
-
queriedTables: options?.queriedTables,
|
|
16
|
-
bindValues: options?.bindValues,
|
|
17
16
|
reactivityGraph: options?.reactivityGraph,
|
|
18
17
|
map: options?.map,
|
|
19
|
-
|
|
20
|
-
queryInfo: { _tag: 'None' },
|
|
18
|
+
queryInfo: Predicate.hasProperty(options, 'queryInfo') ? options.queryInfo : undefined,
|
|
21
19
|
});
|
|
22
20
|
/* An object encapsulating a reactive SQL query */
|
|
23
21
|
export class LiveStoreSQLQuery extends LiveStoreQueryBase {
|
|
24
22
|
_tag = 'sql';
|
|
25
23
|
/** A reactive thunk representing the query text */
|
|
26
|
-
|
|
24
|
+
queryInput$;
|
|
27
25
|
/** A reactive thunk representing the query results */
|
|
28
26
|
results$;
|
|
29
27
|
label;
|
|
28
|
+
// TODO
|
|
29
|
+
queryInfo;
|
|
30
30
|
reactivityGraph;
|
|
31
|
-
/** Currently only used by `rowQuery` for lazy table migrations and eager default row insertion */
|
|
32
|
-
execBeforeFirstRun;
|
|
33
31
|
mapResult;
|
|
34
|
-
|
|
35
|
-
queryInfo;
|
|
36
|
-
constructor({ genQueryString, queriedTables, bindValues, label = genQueryString.toString(), reactivityGraph, schema, map, execBeforeFirstRun, queryInfo, }) {
|
|
32
|
+
constructor({ queryInput, label: inputLabel, reactivityGraph, map, queryInfo: queryInfo_, }) {
|
|
37
33
|
super();
|
|
38
|
-
|
|
34
|
+
// TODO implement a proper toString method
|
|
35
|
+
this.label = inputLabel ? `sql(${inputLabel})` : `sql(${queryInput.toString()})`;
|
|
39
36
|
this.reactivityGraph = reactivityGraph ?? globalReactivityGraph;
|
|
40
|
-
this.execBeforeFirstRun = execBeforeFirstRun;
|
|
41
|
-
this.queryInfo = queryInfo ?? { _tag: 'None' };
|
|
42
|
-
this.schema = schema;
|
|
43
37
|
this.mapResult = map === undefined ? (rows) => rows : map;
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
38
|
+
const schemaRef = {
|
|
39
|
+
current: typeof queryInput === 'function' ? undefined : isQueryBuilder(queryInput) ? undefined : queryInput.schema,
|
|
40
|
+
};
|
|
41
|
+
const execBeforeFirstRunRef = {
|
|
42
|
+
current: undefined,
|
|
43
|
+
};
|
|
44
|
+
let queryInputRaw$OrQueryInputRaw;
|
|
45
|
+
const queryBuilderToQueryInputRaw = (qb) => {
|
|
46
|
+
const qbRes = qb.asSql();
|
|
47
|
+
const schema = getResultSchema(qb);
|
|
48
|
+
const ast = qb[QueryBuilderAstSymbol];
|
|
49
|
+
if (ast._tag === 'RowQuery') {
|
|
50
|
+
execBeforeFirstRunRef.current = makeExecBeforeFirstRun({
|
|
51
|
+
table: ast.tableDef,
|
|
52
|
+
insertValues: ast.insertValues,
|
|
53
|
+
id: ast.id,
|
|
54
|
+
});
|
|
55
|
+
this.label = rowQueryLabel(ast.tableDef, ast.id);
|
|
56
|
+
}
|
|
57
|
+
return {
|
|
58
|
+
query: qbRes.query,
|
|
59
|
+
schema,
|
|
60
|
+
bindValues: qbRes.bindValues,
|
|
61
|
+
queriedTables: new Set([ast.tableDef.sqliteDef.name]),
|
|
62
|
+
queryInfo: ast._tag === 'RowQuery' ? { _tag: 'Row', table: ast.tableDef, id: ast.id } : { _tag: 'None' },
|
|
63
|
+
};
|
|
64
|
+
};
|
|
65
|
+
if (typeof queryInput === 'function') {
|
|
66
|
+
queryInputRaw$OrQueryInputRaw = this.reactivityGraph.makeThunk((get, setDebugInfo, ctx, otelContext) => {
|
|
47
67
|
const startMs = performance.now();
|
|
48
|
-
const
|
|
68
|
+
const queryInputResult = queryInput(makeGetAtomResult(get, otelContext ?? ctx.rootOtelContext), ctx);
|
|
49
69
|
const durationMs = performance.now() - startMs;
|
|
50
|
-
|
|
51
|
-
|
|
70
|
+
const queryInputRaw = isQueryBuilder(queryInputResult)
|
|
71
|
+
? queryBuilderToQueryInputRaw(queryInputResult)
|
|
72
|
+
: queryInputResult;
|
|
73
|
+
setDebugInfo({ _tag: 'computed', label: `${this.label}:queryInput`, query: queryInputRaw.query, durationMs });
|
|
74
|
+
schemaRef.current = queryInputRaw.schema;
|
|
75
|
+
this.queryInfo = queryInputRaw.queryInfo;
|
|
76
|
+
return queryInputRaw;
|
|
52
77
|
}, {
|
|
53
|
-
label: `${label}:
|
|
54
|
-
|
|
55
|
-
|
|
78
|
+
label: `${this.label}:query`,
|
|
79
|
+
// TODO adjust to `sqlQueryInput` + adjust in devtools
|
|
80
|
+
meta: { liveStoreThunkType: 'sqlQuery' },
|
|
81
|
+
// NOTE we're not checking the schema here as we assume the query string to always change when the schema might change
|
|
82
|
+
equal: (a, b) => a.query === b.query && deepEqual(a.bindValues, b.bindValues),
|
|
56
83
|
});
|
|
57
|
-
|
|
84
|
+
// TODO come up with a better way to handle this
|
|
85
|
+
this.queryInfo = { _tag: 'None' };
|
|
58
86
|
}
|
|
59
87
|
else {
|
|
60
|
-
|
|
88
|
+
const queryInputRaw = isQueryBuilder(queryInput) ? queryBuilderToQueryInputRaw(queryInput) : queryInput;
|
|
89
|
+
schemaRef.current = queryInputRaw.schema;
|
|
90
|
+
queryInputRaw$OrQueryInputRaw = queryInputRaw;
|
|
91
|
+
// this.label = inputLabel ? this.label : `sql(${})`
|
|
92
|
+
if (inputLabel === undefined && isQueryBuilder(queryInput)) {
|
|
93
|
+
const ast = queryInput[QueryBuilderAstSymbol];
|
|
94
|
+
if (ast._tag === 'RowQuery') {
|
|
95
|
+
this.label = `sql(${rowQueryLabel(ast.tableDef, ast.id)})`;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
this.queryInfo = queryInputRaw.queryInfo;
|
|
61
99
|
}
|
|
62
|
-
|
|
63
|
-
const
|
|
64
|
-
const
|
|
100
|
+
// TODO
|
|
101
|
+
const label = this.label;
|
|
102
|
+
const queriedTablesRef = { current: undefined };
|
|
103
|
+
// const schemaEqual = Schema.equivalence(schema)
|
|
65
104
|
// TODO also support derived equality for `map` (probably will depend on having an easy way to transform a schema without an `encode` step)
|
|
66
105
|
// This would mean dropping the `map` option
|
|
67
|
-
const
|
|
68
|
-
? (a, b) => a === NOT_REFRESHED_YET || b === NOT_REFRESHED_YET ? false :
|
|
106
|
+
const resultsEqual = map === undefined
|
|
107
|
+
? (a, b) => a === NOT_REFRESHED_YET || b === NOT_REFRESHED_YET ? false : Schema.equivalence(schemaRef.current)(a, b)
|
|
69
108
|
: undefined;
|
|
70
|
-
const results$ = this.reactivityGraph.makeThunk((get, setDebugInfo,
|
|
71
|
-
{}, otelContext ?? rootOtelContext, (span) => {
|
|
109
|
+
const results$ = this.reactivityGraph.makeThunk((get, setDebugInfo, queryContext, otelContext) => queryContext.otelTracer.startActiveSpan('sql:...', // NOTE span name will be overridden further down
|
|
110
|
+
{}, otelContext ?? queryContext.rootOtelContext, (span) => {
|
|
72
111
|
const otelContext = otel.trace.setSpan(otel.context.active(), span);
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
112
|
+
const { store } = queryContext;
|
|
113
|
+
if (execBeforeFirstRunRef.current !== undefined) {
|
|
114
|
+
execBeforeFirstRunRef.current(queryContext, otelContext);
|
|
115
|
+
execBeforeFirstRunRef.current = undefined;
|
|
76
116
|
}
|
|
77
|
-
const
|
|
78
|
-
?
|
|
79
|
-
:
|
|
117
|
+
const queryInputResult = isThunk(queryInputRaw$OrQueryInputRaw)
|
|
118
|
+
? get(queryInputRaw$OrQueryInputRaw, otelContext)
|
|
119
|
+
: queryInputRaw$OrQueryInputRaw;
|
|
120
|
+
const sqlString = queryInputResult.query;
|
|
121
|
+
const bindValues = queryInputResult.bindValues;
|
|
80
122
|
if (queriedTablesRef.current === undefined) {
|
|
81
123
|
queriedTablesRef.current = store.syncDbWrapper.getTablesUsed(sqlString);
|
|
82
124
|
}
|
|
125
|
+
if (bindValues !== undefined) {
|
|
126
|
+
replaceSessionIdSymbol(bindValues, store.clientSession.coordinator.sessionId);
|
|
127
|
+
}
|
|
83
128
|
// Establish a reactive dependency on the tables used in the query
|
|
84
129
|
for (const tableName of queriedTablesRef.current) {
|
|
85
130
|
const tableRef = store.tableRefs[tableName] ?? shouldNeverHappen(`No table ref found for ${tableName}`);
|
|
@@ -87,16 +132,16 @@ export class LiveStoreSQLQuery extends LiveStoreQueryBase {
|
|
|
87
132
|
}
|
|
88
133
|
span.setAttribute('sql.query', sqlString);
|
|
89
134
|
span.updateName(`sql:${sqlString.slice(0, 50)}`);
|
|
90
|
-
const
|
|
91
|
-
queriedTables,
|
|
135
|
+
const rawDbResults = store.syncDbWrapper.select(sqlString, {
|
|
136
|
+
queriedTables: queriedTablesRef.current,
|
|
92
137
|
bindValues: bindValues ? prepareBindValues(bindValues, sqlString) : undefined,
|
|
93
138
|
otelContext,
|
|
94
139
|
});
|
|
95
|
-
span.setAttribute('sql.rowsCount',
|
|
96
|
-
const parsedResult = Schema.decodeEither(
|
|
140
|
+
span.setAttribute('sql.rowsCount', rawDbResults.length);
|
|
141
|
+
const parsedResult = Schema.decodeEither(schemaRef.current)(rawDbResults);
|
|
97
142
|
if (parsedResult._tag === 'Left') {
|
|
98
143
|
const parseErrorStr = TreeFormatter.formatErrorSync(parsedResult.left);
|
|
99
|
-
const expectedSchemaStr = String(
|
|
144
|
+
const expectedSchemaStr = String(schemaRef.current.ast);
|
|
100
145
|
const bindValuesStr = bindValues === undefined ? '' : `\nBind values: ${JSON.stringify(bindValues)}`;
|
|
101
146
|
console.error(`\
|
|
102
147
|
Error parsing SQL query result.
|
|
@@ -108,21 +153,21 @@ Expected schema: ${expectedSchemaStr}
|
|
|
108
153
|
|
|
109
154
|
Error: ${parseErrorStr}
|
|
110
155
|
|
|
111
|
-
Result:`,
|
|
156
|
+
Result:`, rawDbResults);
|
|
112
157
|
return shouldNeverHappen(`Error parsing SQL query result: ${parsedResult.left}`);
|
|
113
158
|
}
|
|
114
159
|
const result = this.mapResult(parsedResult.right);
|
|
115
160
|
span.end();
|
|
116
161
|
const durationMs = getDurationMsFromSpan(span);
|
|
117
162
|
this.executionTimes.push(durationMs);
|
|
118
|
-
setDebugInfo({ _tag: 'sql', label
|
|
163
|
+
setDebugInfo({ _tag: 'sql', label: `${label}:results`, query: sqlString, durationMs });
|
|
119
164
|
return result;
|
|
120
|
-
}), { label:
|
|
165
|
+
}), { label: `${label}:results`, meta: { liveStoreThunkType: 'sqlResult' }, equal: resultsEqual });
|
|
121
166
|
this.results$ = results$;
|
|
122
167
|
}
|
|
123
168
|
destroy = () => {
|
|
124
|
-
if (this.
|
|
125
|
-
this.reactivityGraph.destroyNode(this.
|
|
169
|
+
if (this.queryInput$ !== undefined) {
|
|
170
|
+
this.reactivityGraph.destroyNode(this.queryInput$);
|
|
126
171
|
}
|
|
127
172
|
this.reactivityGraph.destroyNode(this.results$);
|
|
128
173
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sql.js","sourceRoot":"","sources":["../../src/reactiveQueries/sql.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"sql.js","sourceRoot":"","sources":["../../src/reactiveQueries/sql.ts"],"names":[],"mappings":"AACA,OAAO,EACL,eAAe,EACf,cAAc,EACd,iBAAiB,EACjB,qBAAqB,EACrB,sBAAsB,GACvB,MAAM,mBAAmB,CAAA;AAC1B,OAAO,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAC/D,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAA;AAC1E,OAAO,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAE1C,OAAO,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAA;AAE1D,OAAO,EAAE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AAC3D,OAAO,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAEvE,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAExD,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAA;AAoBvE;;GAEG;AACH,MAAM,CAAC,MAAM,OAAO,GA4BhB,CAAC,UAAU,EAAE,OAAO,EAAE,EAAE,CAC1B,IAAI,iBAAiB,CAAC;IACpB,UAAU;IACV,KAAK,EAAE,OAAO,EAAE,KAAK;IACrB,eAAe,EAAE,OAAO,EAAE,eAAe;IACzC,GAAG,EAAE,OAAO,EAAE,GAAG;IACjB,SAAS,EAAE,SAAS,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,SAAuB,CAAC,CAAC,CAAC,SAAS;CACtG,CAAC,CAAA;AAEJ,kDAAkD;AAClD,MAAM,OAAO,iBAIX,SAAQ,kBAAuC;IAC/C,IAAI,GAAU,KAAK,CAAA;IAEnB,mDAAmD;IACnD,WAAW,CAA2G;IAEtH,sDAAsD;IACtD,QAAQ,CAA6C;IAErD,KAAK,CAAQ;IAEb,OAAO;IACP,SAAS,CAAY;IAEX,eAAe,CAAA;IAEjB,SAAS,CAAkC;IAEnD,YAAY,EACV,UAAU,EACV,KAAK,EAAE,UAAU,EACjB,eAAe,EACf,GAAG,EACH,SAAS,EAAE,UAAU,GAStB;QACC,KAAK,EAAE,CAAA;QAEP,0CAA0C;QAC1C,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,OAAO,UAAU,GAAG,CAAC,CAAC,CAAC,OAAO,UAAU,CAAC,QAAQ,EAAE,GAAG,CAAA;QAChF,IAAI,CAAC,eAAe,GAAG,eAAe,IAAI,qBAAqB,CAAA;QAE/D,IAAI,CAAC,SAAS,GAAG,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAe,CAAC,CAAC,CAAC,GAAG,CAAA;QAEzE,MAAM,SAAS,GAAqD;YAClE,OAAO,EACL,OAAO,UAAU,KAAK,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM;SAC5G,CAAA;QAED,MAAM,qBAAqB,GAAsF;YAC/G,OAAO,EAAE,SAAS;SACnB,CAAA;QAID,IAAI,6BAAkG,CAAA;QAEtG,MAAM,2BAA2B,GAAG,CAAC,EAAoB,EAAkB,EAAE;YAC3E,MAAM,KAAK,GAAG,EAAE,CAAC,KAAK,EAAE,CAAA;YACxB,MAAM,MAAM,GAAG,eAAe,CAAC,EAAE,CAAqD,CAAA;YACtF,MAAM,GAAG,GAAG,EAAE,CAAC,qBAAqB,CAAC,CAAA;YAErC,IAAI,GAAG,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;gBAC5B,qBAAqB,CAAC,OAAO,GAAG,sBAAsB,CAAC;oBACrD,KAAK,EAAE,GAAG,CAAC,QAAQ;oBACnB,YAAY,EAAE,GAAG,CAAC,YAAY;oBAC9B,EAAE,EAAE,GAAG,CAAC,EAAE;iBACX,CAAC,CAAA;gBAEF,IAAI,CAAC,KAAK,GAAG,aAAa,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC,CAAA;YAClD,CAAC;YAED,OAAO;gBACL,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,MAAM;gBACN,UAAU,EAAE,KAAK,CAAC,UAAU;gBAC5B,aAAa,EAAE,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;gBACrD,SAAS,EAAE,GAAG,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE;aACzG,CAAA;QACH,CAAC,CAAA;QAED,IAAI,OAAO,UAAU,KAAK,UAAU,EAAE,CAAC;YACrC,6BAA6B,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAC5D,CAAC,GAAG,EAAE,YAAY,EAAE,GAAG,EAAE,WAAW,EAAE,EAAE;gBACtC,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE,CAAA;gBACjC,MAAM,gBAAgB,GAAG,UAAU,CAAC,iBAAiB,CAAC,GAAG,EAAE,WAAW,IAAI,GAAG,CAAC,eAAe,CAAC,EAAE,GAAG,CAAC,CAAA;gBACpG,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE,GAAG,OAAO,CAAA;gBAC9C,MAAM,aAAa,GAAG,cAAc,CAAC,gBAAgB,CAAC;oBACpD,CAAC,CAAC,2BAA2B,CAAC,gBAAgB,CAAC;oBAC/C,CAAC,CAAC,gBAAgB,CAAA;gBAEpB,YAAY,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,KAAK,aAAa,EAAE,KAAK,EAAE,aAAa,CAAC,KAAK,EAAE,UAAU,EAAE,CAAC,CAAA;gBAE7G,SAAS,CAAC,OAAO,GAAG,aAAa,CAAC,MAAM,CAAA;gBAExC,IAAI,CAAC,SAAS,GAAG,aAAa,CAAC,SAAwB,CAAA;gBAEvD,OAAO,aAAa,CAAA;YACtB,CAAC,EACD;gBACE,KAAK,EAAE,GAAG,IAAI,CAAC,KAAK,QAAQ;gBAC5B,sDAAsD;gBACtD,IAAI,EAAE,EAAE,kBAAkB,EAAE,UAAU,EAAE;gBACxC,sHAAsH;gBACtH,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC,UAAU,CAAC;aAC9E,CACF,CAAA;YAED,gDAAgD;YAChD,IAAI,CAAC,SAAS,GAAG,EAAE,IAAI,EAAE,MAAM,EAAgB,CAAA;QACjD,CAAC;aAAM,CAAC;YACN,MAAM,aAAa,GAAG,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,2BAA2B,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,CAAA;YACvG,SAAS,CAAC,OAAO,GAAG,aAAa,CAAC,MAAM,CAAA;YACxC,6BAA6B,GAAG,aAAa,CAAA;YAE7C,oDAAoD;YACpD,IAAI,UAAU,KAAK,SAAS,IAAI,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC;gBAC3D,MAAM,GAAG,GAAG,UAAU,CAAC,qBAAqB,CAAC,CAAA;gBAC7C,IAAI,GAAG,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;oBAC5B,IAAI,CAAC,KAAK,GAAG,OAAO,aAAa,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,CAAA;gBAC5D,CAAC;YACH,CAAC;YAED,IAAI,CAAC,SAAS,GAAG,aAAa,CAAC,SAAwB,CAAA;QACzD,CAAC;QAED,OAAO;QACP,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAA;QAExB,MAAM,gBAAgB,GAAyC,EAAE,OAAO,EAAE,SAAS,EAAE,CAAA;QAErF,iDAAiD;QACjD,2IAA2I;QAC3I,4CAA4C;QAC5C,MAAM,YAAY,GAChB,GAAG,KAAK,SAAS;YACf,CAAC,CAAC,CAAC,CAAU,EAAE,CAAU,EAAE,EAAE,CACzB,CAAC,KAAK,iBAAiB,IAAI,CAAC,KAAK,iBAAiB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,OAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAC7G,CAAC,CAAC,SAAS,CAAA;QAEf,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAC7C,CAAC,GAAG,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,EAAE,CAC/C,YAAY,CAAC,UAAU,CAAC,eAAe,CACrC,SAAS,EAAE,iDAAiD;QAC5D,EAAE,EACF,WAAW,IAAI,YAAY,CAAC,eAAe,EAC3C,CAAC,IAAI,EAAE,EAAE;YACP,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC,CAAA;YACnE,MAAM,EAAE,KAAK,EAAE,GAAG,YAAY,CAAA;YAE9B,IAAI,qBAAqB,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;gBAChD,qBAAqB,CAAC,OAAO,CAAC,YAAY,EAAE,WAAW,CAAC,CAAA;gBACxD,qBAAqB,CAAC,OAAO,GAAG,SAAS,CAAA;YAC3C,CAAC;YAED,MAAM,gBAAgB,GAAG,OAAO,CAAC,6BAA6B,CAAC;gBAC7D,CAAC,CAAE,GAAG,CAAC,6BAA6B,EAAE,WAAW,CAAoB;gBACrE,CAAC,CAAE,6BAAgD,CAAA;YAErD,MAAM,SAAS,GAAG,gBAAgB,CAAC,KAAK,CAAA;YACxC,MAAM,UAAU,GAAG,gBAAgB,CAAC,UAAU,CAAA;YAE9C,IAAI,gBAAgB,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;gBAC3C,gBAAgB,CAAC,OAAO,GAAG,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAA;YACzE,CAAC;YAED,IAAI,UAAU,KAAK,SAAS,EAAE,CAAC;gBAC7B,sBAAsB,CAAC,UAAU,EAAE,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,SAAS,CAAC,CAAA;YAC/E,CAAC;YAED,kEAAkE;YAClE,KAAK,MAAM,SAAS,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBACjD,MAAM,QAAQ,GAAG,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,iBAAiB,CAAC,0BAA0B,SAAS,EAAE,CAAC,CAAA;gBACvG,GAAG,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;YAC5B,CAAC;YAED,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,SAAS,CAAC,CAAA;YACzC,IAAI,CAAC,UAAU,CAAC,OAAO,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAA;YAEhD,MAAM,YAAY,GAAG,KAAK,CAAC,aAAa,CAAC,MAAM,CAAM,SAAS,EAAE;gBAC9D,aAAa,EAAE,gBAAgB,CAAC,OAAO;gBACvC,UAAU,EAAE,UAAU,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS;gBAC7E,WAAW;aACZ,CAAC,CAAA;YAEF,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,YAAY,CAAC,MAAM,CAAC,CAAA;YAEvD,MAAM,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,OAAQ,CAAC,CAAC,YAAY,CAAC,CAAA;YAE1E,IAAI,YAAY,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;gBACjC,MAAM,aAAa,GAAG,aAAa,CAAC,eAAe,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;gBACtE,MAAM,iBAAiB,GAAG,MAAM,CAAC,SAAS,CAAC,OAAQ,CAAC,GAAG,CAAC,CAAA;gBACxD,MAAM,aAAa,GAAG,UAAU,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,kBAAkB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,CAAA;gBAEpG,OAAO,CAAC,KAAK,CACX;;;SAGP,SAAS;EAChB,aAAa;;mBAEI,iBAAiB;;SAE3B,aAAa;;QAEd,EACQ,YAAY,CACb,CAAA;gBACD,OAAO,iBAAiB,CAAC,mCAAmC,YAAY,CAAC,IAAI,EAAE,CAAC,CAAA;YAClF,CAAC;YAED,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;YAEjD,IAAI,CAAC,GAAG,EAAE,CAAA;YAEV,MAAM,UAAU,GAAG,qBAAqB,CAAC,IAAI,CAAC,CAAA;YAE9C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YAEpC,YAAY,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,KAAK,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC,CAAA;YAEtF,OAAO,MAAM,CAAA;QACf,CAAC,CACF,EACH,EAAE,KAAK,EAAE,GAAG,KAAK,UAAU,EAAE,IAAI,EAAE,EAAE,kBAAkB,EAAE,WAAW,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE,CAC9F,CAAA;QAED,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA;IAC1B,CAAC;IAED,OAAO,GAAG,GAAG,EAAE;QACb,IAAI,IAAI,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;YACnC,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;QACpD,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IACjD,CAAC,CAAA;CACF"}
|
|
@@ -2,7 +2,7 @@ import { Effect, Schema } from '@livestore/utils/effect';
|
|
|
2
2
|
import * as otel from '@opentelemetry/api';
|
|
3
3
|
import { BasicTracerProvider, InMemorySpanExporter, SimpleSpanProcessor } from '@opentelemetry/sdk-trace-base';
|
|
4
4
|
import { describe, expect, it } from 'vitest';
|
|
5
|
-
import { computed,
|
|
5
|
+
import { computed, queryDb, rawSqlMutation, sql } from '../index.js';
|
|
6
6
|
import { makeTodoMvc, tables } from '../utils/tests/fixture.js';
|
|
7
7
|
import { getSimplifiedRootSpan } from '../utils/tests/otel.js';
|
|
8
8
|
/*
|
|
@@ -34,13 +34,14 @@ describe('otel', () => {
|
|
|
34
34
|
it('otel', async () => {
|
|
35
35
|
const { exporter } = await Effect.gen(function* () {
|
|
36
36
|
const { store, exporter, span } = yield* makeQuery;
|
|
37
|
-
const query =
|
|
37
|
+
const query$ = queryDb({
|
|
38
|
+
query: `select * from todos`,
|
|
38
39
|
schema: Schema.Array(tables.todos.schema),
|
|
39
40
|
queriedTables: new Set(['todos']),
|
|
40
41
|
});
|
|
41
|
-
expect(query
|
|
42
|
+
expect(query$.run()).toMatchInlineSnapshot('[]');
|
|
42
43
|
store.mutate(rawSqlMutation({ sql: sql `INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)` }));
|
|
43
|
-
expect(query
|
|
44
|
+
expect(query$.run()).toMatchInlineSnapshot(`
|
|
44
45
|
[
|
|
45
46
|
{
|
|
46
47
|
"completed": false,
|
|
@@ -49,7 +50,7 @@ describe('otel', () => {
|
|
|
49
50
|
},
|
|
50
51
|
]
|
|
51
52
|
`);
|
|
52
|
-
query
|
|
53
|
+
query$.destroy();
|
|
53
54
|
span.end();
|
|
54
55
|
return { exporter };
|
|
55
56
|
}).pipe(Effect.scoped, Effect.tapCauseLogPretty, Effect.runPromise);
|
|
@@ -156,11 +157,11 @@ describe('otel', () => {
|
|
|
156
157
|
const { store, exporter, span } = yield* makeQuery;
|
|
157
158
|
const defaultTodo = { id: '', text: '', completed: false };
|
|
158
159
|
const filter = computed(() => `where completed = 0`, { label: 'where-filter' });
|
|
159
|
-
const query =
|
|
160
|
-
|
|
160
|
+
const query$ = queryDb((get) => ({
|
|
161
|
+
query: `select * from todos ${get(filter)}`,
|
|
161
162
|
schema: Schema.Array(tables.todos.schema).pipe(Schema.headOrElse(() => defaultTodo)),
|
|
162
|
-
});
|
|
163
|
-
expect(query
|
|
163
|
+
}), { label: 'all todos' });
|
|
164
|
+
expect(query$.run()).toMatchInlineSnapshot(`
|
|
164
165
|
{
|
|
165
166
|
"completed": false,
|
|
166
167
|
"id": "",
|
|
@@ -168,14 +169,14 @@ describe('otel', () => {
|
|
|
168
169
|
}
|
|
169
170
|
`);
|
|
170
171
|
store.mutate(rawSqlMutation({ sql: sql `INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)` }));
|
|
171
|
-
expect(query
|
|
172
|
+
expect(query$.run()).toMatchInlineSnapshot(`
|
|
172
173
|
{
|
|
173
174
|
"completed": false,
|
|
174
175
|
"id": "t1",
|
|
175
176
|
"text": "buy milk",
|
|
176
177
|
}
|
|
177
178
|
`);
|
|
178
|
-
query
|
|
179
|
+
query$.destroy();
|
|
179
180
|
span.end();
|
|
180
181
|
return { exporter };
|
|
181
182
|
}).pipe(Effect.scoped, Effect.tapCauseLogPretty, Effect.runPromise);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sql.test.js","sourceRoot":"","sources":["../../src/reactiveQueries/sql.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AACxD,OAAO,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAC1C,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAA;AAC9G,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAE7C,OAAO,EAAE,QAAQ,EAAE,
|
|
1
|
+
{"version":3,"file":"sql.test.js","sourceRoot":"","sources":["../../src/reactiveQueries/sql.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { QueryInfo } from '@livestore/common';
|
|
2
|
+
import { SessionIdSymbol } from '@livestore/common';
|
|
3
|
+
import { DbSchema } from '@livestore/common/schema';
|
|
4
|
+
import type * as otel from '@opentelemetry/api';
|
|
5
|
+
import type { LiveQuery, QueryContext } from './live-queries/base-class.js';
|
|
6
|
+
export declare const rowQueryLabel: (table: DbSchema.TableDefBase, id: string | SessionIdSymbol | undefined) => string;
|
|
7
|
+
export declare const deriveColQuery: {
|
|
8
|
+
<TQuery extends LiveQuery<any, QueryInfo.None>, TCol extends keyof TQuery['__result!'] & string>(query$: TQuery, colName: TCol): LiveQuery<TQuery['__result!'][TCol], QueryInfo.None>;
|
|
9
|
+
<TQuery extends LiveQuery<any, QueryInfo.Row>, TCol extends keyof TQuery['__result!'] & string>(query$: TQuery, colName: TCol): LiveQuery<TQuery['__result!'][TCol], QueryInfo.Col>;
|
|
10
|
+
};
|
|
11
|
+
export declare const makeExecBeforeFirstRun: ({ id, insertValues, table, otelContext: otelContext_, }: {
|
|
12
|
+
id?: string | SessionIdSymbol;
|
|
13
|
+
insertValues?: any;
|
|
14
|
+
table: DbSchema.TableDefBase;
|
|
15
|
+
otelContext: otel.Context | undefined;
|
|
16
|
+
}) => ({ store }: QueryContext) => undefined;
|
|
17
|
+
//# sourceMappingURL=row-query-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"row-query-utils.d.ts","sourceRoot":"","sources":["../src/row-query-utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAsB,SAAS,EAAE,MAAM,mBAAmB,CAAA;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AAEnD,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAE/C,OAAO,KAAK,EAAE,SAAS,EAAgB,YAAY,EAAE,MAAM,8BAA8B,CAAA;AAGzF,eAAO,MAAM,aAAa,UAAW,QAAQ,CAAC,YAAY,MAAM,MAAM,GAAG,eAAe,GAAG,SAAS,WACM,CAAA;AAE1G,eAAO,MAAM,cAAc,EAAE;IAC3B,CAAC,MAAM,SAAS,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,SAAS,MAAM,MAAM,CAAC,WAAW,CAAC,GAAG,MAAM,EAC7F,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,IAAI,GACZ,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,CAAA;IACvD,CAAC,MAAM,SAAS,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,GAAG,CAAC,EAAE,IAAI,SAAS,MAAM,MAAM,CAAC,WAAW,CAAC,GAAG,MAAM,EAC5F,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,IAAI,GACZ,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,GAAG,CAAC,CAAA;CASvD,CAAA;AAED,eAAO,MAAM,sBAAsB,4DAM9B;IACD,EAAE,CAAC,EAAE,MAAM,GAAG,eAAe,CAAA;IAC7B,YAAY,CAAC,EAAE,GAAG,CAAA;IAClB,KAAK,EAAE,QAAQ,CAAC,YAAY,CAAA;IAC5B,WAAW,EAAE,IAAI,CAAC,OAAO,GAAG,SAAS,CAAA;CACtC,iBACW,YAAY,cAqBvB,CAAA"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { SessionIdSymbol } from '@livestore/common';
|
|
2
|
+
import { DbSchema } from '@livestore/common/schema';
|
|
3
|
+
import { shouldNeverHappen } from '@livestore/utils';
|
|
4
|
+
import { computed } from './live-queries/computed.js';
|
|
5
|
+
export const rowQueryLabel = (table, id) => `row:${table.sqliteDef.name}${id === undefined ? '' : id === SessionIdSymbol ? `:sessionId` : `:${id}`}`;
|
|
6
|
+
export const deriveColQuery = (query$, colName) => {
|
|
7
|
+
return computed((get) => get(query$)[colName], {
|
|
8
|
+
label: `deriveColQuery:${query$.label}:${colName}`,
|
|
9
|
+
queryInfo: query$.queryInfo._tag === 'Row'
|
|
10
|
+
? { _tag: 'Col', table: query$.queryInfo.table, column: colName, id: query$.queryInfo.id }
|
|
11
|
+
: undefined,
|
|
12
|
+
});
|
|
13
|
+
};
|
|
14
|
+
export const makeExecBeforeFirstRun = ({ id, insertValues, table, otelContext: otelContext_, }) => ({ store }) => {
|
|
15
|
+
const otelContext = otelContext_ ?? store.otel.queriesSpanContext;
|
|
16
|
+
if (table.options.isSingleton === false) {
|
|
17
|
+
const idStr = id === SessionIdSymbol ? store.sessionId : id;
|
|
18
|
+
const rowExists = store.syncDbWrapper.select(`SELECT 1 FROM '${table.sqliteDef.name}' WHERE id = ?`, {
|
|
19
|
+
bindValues: [idStr],
|
|
20
|
+
}).length === 1;
|
|
21
|
+
if (rowExists)
|
|
22
|
+
return;
|
|
23
|
+
if (DbSchema.tableHasDerivedMutations(table) === false) {
|
|
24
|
+
return shouldNeverHappen(`Cannot insert row for table "${table.sqliteDef.name}" which does not have 'deriveMutations: true' set`);
|
|
25
|
+
}
|
|
26
|
+
// NOTE It's important that we only mutate and don't refresh here, as this function is called during a render
|
|
27
|
+
store.mutateWithoutRefresh(table.insert({ id, ...insertValues }), { otelContext, coordinatorMode: 'default' });
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=row-query-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"row-query-utils.js","sourceRoot":"","sources":["../src/row-query-utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAIpD,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAErD,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,KAA4B,EAAE,EAAwC,EAAE,EAAE,CACtG,OAAO,KAAK,CAAC,SAAS,CAAC,IAAI,GAAG,EAAE,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,eAAe,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,EAAE,CAAA;AAE1G,MAAM,CAAC,MAAM,cAAc,GASvB,CAAC,MAAoB,EAAE,OAAe,EAAE,EAAE;IAC5C,OAAO,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE;QAC7C,KAAK,EAAE,kBAAkB,MAAM,CAAC,KAAK,IAAI,OAAO,EAAE;QAClD,SAAS,EACP,MAAM,CAAC,SAAS,CAAC,IAAI,KAAK,KAAK;YAC7B,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,CAAC,SAAS,CAAC,EAAE,EAAE;YAC1F,CAAC,CAAC,SAAS;KAChB,CAAQ,CAAA;AACX,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,sBAAsB,GACjC,CAAC,EACC,EAAE,EACF,YAAY,EACZ,KAAK,EACL,WAAW,EAAE,YAAY,GAM1B,EAAE,EAAE,CACL,CAAC,EAAE,KAAK,EAAgB,EAAE,EAAE;IAC1B,MAAM,WAAW,GAAG,YAAY,IAAI,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAA;IAEjE,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,KAAK,KAAK,EAAE,CAAC;QACxC,MAAM,KAAK,GAAG,EAAE,KAAK,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAG,CAAA;QAC5D,MAAM,SAAS,GACb,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,kBAAkB,KAAK,CAAC,SAAS,CAAC,IAAI,gBAAgB,EAAE;YACjF,UAAU,EAAE,CAAC,KAAK,CAA8B;SACjD,CAAC,CAAC,MAAM,KAAK,CAAC,CAAA;QAEjB,IAAI,SAAS;YAAE,OAAM;QAErB,IAAI,QAAQ,CAAC,wBAAwB,CAAC,KAAK,CAAC,KAAK,KAAK,EAAE,CAAC;YACvD,OAAO,iBAAiB,CACtB,gCAAgC,KAAK,CAAC,SAAS,CAAC,IAAI,mDAAmD,CACxG,CAAA;QACH,CAAC;QAED,6GAA6G;QAC7G,KAAK,CAAC,oBAAoB,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,GAAG,YAAY,EAAE,CAAC,EAAE,EAAE,WAAW,EAAE,eAAe,EAAE,SAAS,EAAE,CAAC,CAAA;IAChH,CAAC;AACH,CAAC,CAAA"}
|
package/dist/row-query.d.ts
CHANGED
|
@@ -1,33 +1,16 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { QueryInfo } from '@livestore/common';
|
|
2
2
|
import { SessionIdSymbol } from '@livestore/common';
|
|
3
3
|
import { DbSchema } from '@livestore/common/schema';
|
|
4
|
-
import type { SqliteDsl } from '@livestore/db-schema';
|
|
5
|
-
import type { GetValForKey } from '@livestore/utils';
|
|
6
4
|
import type * as otel from '@opentelemetry/api';
|
|
7
|
-
import type { LiveQuery,
|
|
8
|
-
export
|
|
9
|
-
otelContext?: otel.Context;
|
|
10
|
-
skipInsertDefaultRow?: boolean;
|
|
11
|
-
reactivityGraph?: ReactivityGraph;
|
|
12
|
-
map?: (result: RowResult<TTableDef>) => TResult;
|
|
13
|
-
label?: string;
|
|
14
|
-
};
|
|
15
|
-
export type RowQueryOptionsDefaulValues<TTableDef extends DbSchema.TableDef> = {
|
|
16
|
-
defaultValues?: Partial<RowResult<TTableDef>>;
|
|
17
|
-
};
|
|
18
|
-
export type MakeRowQuery = {
|
|
19
|
-
<TTableDef extends DbSchema.TableDef<DbSchema.DefaultSqliteTableDef, boolean, DbSchema.TableOptions & {
|
|
20
|
-
isSingleton: true;
|
|
21
|
-
}>, TResult = RowResult<TTableDef>>(table: TTableDef, options?: RowQueryOptions<TTableDef, TResult>): LiveQuery<RowResult<TTableDef>, QueryInfoRow<TTableDef>>;
|
|
22
|
-
<TTableDef extends DbSchema.TableDef<DbSchema.DefaultSqliteTableDef, boolean, DbSchema.TableOptions & {
|
|
23
|
-
isSingleton: false;
|
|
24
|
-
}>, TResult = RowResult<TTableDef>>(table: TTableDef, id: string | SessionIdSymbol, options?: RowQueryOptions<TTableDef, TResult> & RowQueryOptionsDefaulValues<TTableDef>): LiveQuery<TResult, QueryInfoRow<TTableDef>>;
|
|
25
|
-
};
|
|
26
|
-
export declare const rowQuery: MakeRowQuery;
|
|
27
|
-
export type RowResult<TTableDef extends DbSchema.TableDef> = TTableDef['isSingleColumn'] extends true ? GetValForKey<SqliteDsl.FromColumns.RowDecoded<TTableDef['sqliteDef']['columns']>, 'value'> : SqliteDsl.FromColumns.RowDecoded<TTableDef['sqliteDef']['columns']>;
|
|
28
|
-
export type RowResultEncoded<TTableDef extends DbSchema.TableDef> = TTableDef['isSingleColumn'] extends true ? GetValForKey<SqliteDsl.FromColumns.RowEncoded<TTableDef['sqliteDef']['columns']>, 'value'> : SqliteDsl.FromColumns.RowEncoded<TTableDef['sqliteDef']['columns']>;
|
|
5
|
+
import type { LiveQuery, QueryContext } from './live-queries/base-class.js';
|
|
6
|
+
export declare const rowQueryLabel: (table: DbSchema.TableDefBase, id: string | SessionIdSymbol | undefined) => string;
|
|
29
7
|
export declare const deriveColQuery: {
|
|
30
|
-
<TQuery extends LiveQuery<any,
|
|
31
|
-
<TQuery extends LiveQuery<any,
|
|
8
|
+
<TQuery extends LiveQuery<any, QueryInfo.None>, TCol extends keyof TQuery['__result!'] & string>(query$: TQuery, colName: TCol): LiveQuery<TQuery['__result!'][TCol], QueryInfo.None>;
|
|
9
|
+
<TQuery extends LiveQuery<any, QueryInfo.Row>, TCol extends keyof TQuery['__result!'] & string>(query$: TQuery, colName: TCol): LiveQuery<TQuery['__result!'][TCol], QueryInfo.Col>;
|
|
32
10
|
};
|
|
11
|
+
export declare const makeExecBeforeFirstRun: ({ id, insertValues, table }: {
|
|
12
|
+
id?: string | SessionIdSymbol;
|
|
13
|
+
insertValues?: any;
|
|
14
|
+
table: DbSchema.TableDefBase;
|
|
15
|
+
}) => ({ store }: QueryContext, otelContext_: otel.Context | undefined) => undefined;
|
|
33
16
|
//# sourceMappingURL=row-query.d.ts.map
|
package/dist/row-query.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"row-query.d.ts","sourceRoot":"","sources":["../src/row-query.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"row-query.d.ts","sourceRoot":"","sources":["../src/row-query.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAsB,SAAS,EAAE,MAAM,mBAAmB,CAAA;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AAEnD,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAE/C,OAAO,KAAK,EAAE,SAAS,EAAgB,YAAY,EAAE,MAAM,8BAA8B,CAAA;AAGzF,eAAO,MAAM,aAAa,UAAW,QAAQ,CAAC,YAAY,MAAM,MAAM,GAAG,eAAe,GAAG,SAAS,WACM,CAAA;AAE1G,eAAO,MAAM,cAAc,EAAE;IAC3B,CAAC,MAAM,SAAS,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,SAAS,MAAM,MAAM,CAAC,WAAW,CAAC,GAAG,MAAM,EAC7F,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,IAAI,GACZ,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,CAAA;IACvD,CAAC,MAAM,SAAS,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,GAAG,CAAC,EAAE,IAAI,SAAS,MAAM,MAAM,CAAC,WAAW,CAAC,GAAG,MAAM,EAC5F,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,IAAI,GACZ,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,GAAG,CAAC,CAAA;CASvD,CAAA;AAED,eAAO,MAAM,sBAAsB,gCACH;IAAE,EAAE,CAAC,EAAE,MAAM,GAAG,eAAe,CAAC;IAAC,YAAY,CAAC,EAAE,GAAG,CAAC;IAAC,KAAK,EAAE,QAAQ,CAAC,YAAY,CAAA;CAAE,iBACrG,YAAY,gBAAgB,IAAI,CAAC,OAAO,GAAG,SAAS,cAqB/D,CAAA"}
|
package/dist/row-query.js
CHANGED
|
@@ -1,47 +1,8 @@
|
|
|
1
|
-
import { SessionIdSymbol
|
|
1
|
+
import { SessionIdSymbol } from '@livestore/common';
|
|
2
2
|
import { DbSchema } from '@livestore/common/schema';
|
|
3
3
|
import { shouldNeverHappen } from '@livestore/utils';
|
|
4
|
-
import {
|
|
5
|
-
|
|
6
|
-
import { LiveStoreSQLQuery } from './reactiveQueries/sql.js';
|
|
7
|
-
// TODO also allow other where clauses and multiple rows
|
|
8
|
-
export const rowQuery = (table, idOrOptions, options_) => {
|
|
9
|
-
const id = typeof idOrOptions === 'string' || idOrOptions === SessionIdSymbol ? idOrOptions : undefined;
|
|
10
|
-
const options = typeof idOrOptions === 'string' || idOrOptions === SessionIdSymbol ? options_ : idOrOptions;
|
|
11
|
-
const defaultValues = options?.defaultValues ?? {};
|
|
12
|
-
// Validate query args
|
|
13
|
-
if (table.options.isSingleton === true && id !== undefined && id !== SessionIdSymbol) {
|
|
14
|
-
shouldNeverHappen(`Cannot query state table ${table.sqliteDef.name} with id "${id}" as it is a singleton`);
|
|
15
|
-
}
|
|
16
|
-
else if (table.options.isSingleton !== true && id === undefined) {
|
|
17
|
-
shouldNeverHappen(`Cannot query state table ${table.sqliteDef.name} without id`);
|
|
18
|
-
}
|
|
19
|
-
const tableSchema = table.sqliteDef;
|
|
20
|
-
const tableName = tableSchema.name;
|
|
21
|
-
const makeQueryString = (id) => sql `select * from ${tableName} ${id === undefined ? '' : `where id = '${id}'`} limit 1`;
|
|
22
|
-
const genQueryString = id === SessionIdSymbol
|
|
23
|
-
? (_, ctx) => makeQueryString(ctx.store.sessionId)
|
|
24
|
-
: makeQueryString(id);
|
|
25
|
-
const rowSchema = table.isSingleColumn === true ? table.schema.pipe(Schema.pluck('value')) : table.schema;
|
|
26
|
-
return new LiveStoreSQLQuery({
|
|
27
|
-
label: options?.label ??
|
|
28
|
-
`rowQuery:query:${tableSchema.name}${id === undefined ? '' : id === SessionIdSymbol ? `:sessionId` : `:${id}`}`,
|
|
29
|
-
genQueryString,
|
|
30
|
-
queriedTables: new Set([tableName]),
|
|
31
|
-
reactivityGraph: options?.reactivityGraph,
|
|
32
|
-
// While this code-path is not needed for singleton tables, it's still needed for `useRow` with non-existing rows for a given ID
|
|
33
|
-
execBeforeFirstRun: makeExecBeforeFirstRun({
|
|
34
|
-
otelContext: options?.otelContext,
|
|
35
|
-
table,
|
|
36
|
-
defaultValues,
|
|
37
|
-
id,
|
|
38
|
-
skipInsertDefaultRow: options?.skipInsertDefaultRow,
|
|
39
|
-
}),
|
|
40
|
-
schema: rowSchema.pipe(Schema.Array, Schema.headOrElse()),
|
|
41
|
-
map: options?.map,
|
|
42
|
-
queryInfo: { _tag: 'Row', table, id: id ?? 'singleton' },
|
|
43
|
-
});
|
|
44
|
-
};
|
|
4
|
+
import { computed } from './live-queries/computed.js';
|
|
5
|
+
export const rowQueryLabel = (table, id) => `row:${table.sqliteDef.name}${id === undefined ? '' : id === SessionIdSymbol ? `:sessionId` : `:${id}`}`;
|
|
45
6
|
export const deriveColQuery = (query$, colName) => {
|
|
46
7
|
return computed((get) => get(query$)[colName], {
|
|
47
8
|
label: `deriveColQuery:${query$.label}:${colName}`,
|
|
@@ -50,31 +11,20 @@ export const deriveColQuery = (query$, colName) => {
|
|
|
50
11
|
: undefined,
|
|
51
12
|
});
|
|
52
13
|
};
|
|
53
|
-
const makeExecBeforeFirstRun = ({ id,
|
|
14
|
+
export const makeExecBeforeFirstRun = ({ id, insertValues, table }) => ({ store }, otelContext_) => {
|
|
54
15
|
const otelContext = otelContext_ ?? store.otel.queriesSpanContext;
|
|
55
|
-
if (
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
16
|
+
if (table.options.isSingleton === false) {
|
|
17
|
+
const idStr = id === SessionIdSymbol ? store.sessionId : id;
|
|
18
|
+
const rowExists = store.syncDbWrapper.select(`SELECT 1 FROM '${table.sqliteDef.name}' WHERE id = ?`, {
|
|
19
|
+
bindValues: [idStr],
|
|
20
|
+
}).length === 1;
|
|
21
|
+
if (rowExists)
|
|
22
|
+
return;
|
|
23
|
+
if (DbSchema.tableHasDerivedMutations(table) === false) {
|
|
24
|
+
return shouldNeverHappen(`Cannot insert row for table "${table.sqliteDef.name}" which does not have 'deriveMutations: true' set`);
|
|
25
|
+
}
|
|
26
|
+
// NOTE It's important that we only mutate and don't refresh here, as this function is called during a render
|
|
27
|
+
store.mutateWithoutRefresh(table.insert({ id, ...insertValues }), { otelContext, coordinatorMode: 'default' });
|
|
63
28
|
}
|
|
64
29
|
};
|
|
65
|
-
const insertRowWithDefaultValuesOrIgnore = ({ store, id, table, otelContext, explicitDefaultValues, }) => {
|
|
66
|
-
const idStr = id === SessionIdSymbol ? store.sessionId : id;
|
|
67
|
-
const rowExists = store.syncDbWrapper.select(`select 1 from ${table.sqliteDef.name} where id = '${idStr}'`).length === 1;
|
|
68
|
-
if (rowExists)
|
|
69
|
-
return;
|
|
70
|
-
// const mutationDef = deriveCreateMutationDef(table)
|
|
71
|
-
if (DbSchema.tableHasDerivedMutations(table) === false) {
|
|
72
|
-
return shouldNeverHappen(`Cannot insert row for table "${table.sqliteDef.name}" which does not have 'deriveMutations: true' set`);
|
|
73
|
-
}
|
|
74
|
-
// NOTE It's important that we only mutate and don't refresh here, as this function is called during a render
|
|
75
|
-
store.mutateWithoutRefresh(table.insert({ id, ...explicitDefaultValues }), {
|
|
76
|
-
otelContext,
|
|
77
|
-
coordinatorMode: 'default',
|
|
78
|
-
});
|
|
79
|
-
};
|
|
80
30
|
//# sourceMappingURL=row-query.js.map
|
package/dist/row-query.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"row-query.js","sourceRoot":"","sources":["../src/row-query.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,
|
|
1
|
+
{"version":3,"file":"row-query.js","sourceRoot":"","sources":["../src/row-query.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAIpD,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAErD,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,KAA4B,EAAE,EAAwC,EAAE,EAAE,CACtG,OAAO,KAAK,CAAC,SAAS,CAAC,IAAI,GAAG,EAAE,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,eAAe,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,EAAE,CAAA;AAE1G,MAAM,CAAC,MAAM,cAAc,GASvB,CAAC,MAAoB,EAAE,OAAe,EAAE,EAAE;IAC5C,OAAO,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE;QAC7C,KAAK,EAAE,kBAAkB,MAAM,CAAC,KAAK,IAAI,OAAO,EAAE;QAClD,SAAS,EACP,MAAM,CAAC,SAAS,CAAC,IAAI,KAAK,KAAK;YAC7B,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,CAAC,SAAS,CAAC,EAAE,EAAE;YAC1F,CAAC,CAAC,SAAS;KAChB,CAAQ,CAAA;AACX,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,sBAAsB,GACjC,CAAC,EAAE,EAAE,EAAE,YAAY,EAAE,KAAK,EAAuF,EAAE,EAAE,CACrH,CAAC,EAAE,KAAK,EAAgB,EAAE,YAAsC,EAAE,EAAE;IAClE,MAAM,WAAW,GAAG,YAAY,IAAI,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAA;IAEjE,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,KAAK,KAAK,EAAE,CAAC;QACxC,MAAM,KAAK,GAAG,EAAE,KAAK,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAG,CAAA;QAC5D,MAAM,SAAS,GACb,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,kBAAkB,KAAK,CAAC,SAAS,CAAC,IAAI,gBAAgB,EAAE;YACjF,UAAU,EAAE,CAAC,KAAK,CAA8B;SACjD,CAAC,CAAC,MAAM,KAAK,CAAC,CAAA;QAEjB,IAAI,SAAS;YAAE,OAAM;QAErB,IAAI,QAAQ,CAAC,wBAAwB,CAAC,KAAK,CAAC,KAAK,KAAK,EAAE,CAAC;YACvD,OAAO,iBAAiB,CACtB,gCAAgC,KAAK,CAAC,SAAS,CAAC,IAAI,mDAAmD,CACxG,CAAA;QACH,CAAC;QAED,6GAA6G;QAC7G,KAAK,CAAC,oBAAoB,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,GAAG,YAAY,EAAE,CAAC,EAAE,EAAE,WAAW,EAAE,eAAe,EAAE,SAAS,EAAE,CAAC,CAAA;IAChH,CAAC;AACH,CAAC,CAAA"}
|
|
@@ -3,7 +3,7 @@ import { UnexpectedError } from '@livestore/common';
|
|
|
3
3
|
import type { LiveStoreSchema } from '@livestore/common/schema';
|
|
4
4
|
import { Effect, FiberSet, Scope } from '@livestore/utils/effect';
|
|
5
5
|
import * as otel from '@opentelemetry/api';
|
|
6
|
-
import type { ReactivityGraph } from '../
|
|
6
|
+
import type { ReactivityGraph } from '../live-queries/base-class.js';
|
|
7
7
|
import { Store } from './store.js';
|
|
8
8
|
import type { BaseGraphQLContext, GraphQLOptions, OtelOptions } from './store-types.js';
|
|
9
9
|
export type CreateStoreOptions<TGraphQLContext extends BaseGraphQLContext, TSchema extends LiveStoreSchema> = {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-store.d.ts","sourceRoot":"","sources":["../../src/store/create-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,OAAO,EACP,UAAU,EAKX,MAAM,mBAAmB,CAAA;AAC1B,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,KAAK,EAAE,eAAe,EAAiB,MAAM,0BAA0B,CAAA;AAE9E,OAAO,EAIL,MAAM,EAEN,QAAQ,EAQR,KAAK,EACN,MAAM,yBAAyB,CAAA;AAChC,OAAO,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAG1C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"create-store.d.ts","sourceRoot":"","sources":["../../src/store/create-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,OAAO,EACP,UAAU,EAKX,MAAM,mBAAmB,CAAA;AAC1B,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,KAAK,EAAE,eAAe,EAAiB,MAAM,0BAA0B,CAAA;AAE9E,OAAO,EAIL,MAAM,EAEN,QAAQ,EAQR,KAAK,EACN,MAAM,yBAAyB,CAAA;AAChC,OAAO,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAG1C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAEpE,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,KAAK,EAAE,kBAAkB,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAEvF,MAAM,MAAM,kBAAkB,CAAC,eAAe,SAAS,kBAAkB,EAAE,OAAO,SAAS,eAAe,IAAI;IAC5G,MAAM,EAAE,OAAO,CAAA;IACf,OAAO,EAAE,OAAO,CAAA;IAChB,OAAO,EAAE,MAAM,CAAA;IACf,eAAe,CAAC,EAAE,eAAe,CAAA;IACjC,cAAc,CAAC,EAAE,cAAc,CAAC,eAAe,CAAC,CAAA;IAChD,WAAW,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAA;IAClC,IAAI,CAAC,EAAE,CACL,KAAK,EAAE,KAAK,CAAC,eAAe,EAAE,OAAO,CAAC,EACtC,UAAU,EAAE,IAAI,CAAC,IAAI,KAClB,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;IACrE,YAAY,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,IAAI,KAAK,IAAI,CAAA;IACxC,eAAe,CAAC,EAAE,OAAO,CAAA;IACzB,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,UAAU,KAAK,IAAI,CAAA;CAC5C,CAAA;AAED,mCAAmC;AACnC,eAAO,MAAM,kBAAkB,GAC7B,eAAe,SAAS,kBAAkB,EAC1C,OAAO,SAAS,eAAe,4CAI9B,kBAAkB,CAAC,eAAe,EAAE,OAAO,CAAC,GAAG;IAAE,MAAM,CAAC,EAAE,WAAW,CAAA;CAAE,KAAG,OAAO,CAAC,KAAK,CAAC,eAAe,EAAE,OAAO,CAAC,CAsBjH,CAAA;AAEH,eAAO,MAAM,WAAW,GACtB,eAAe,SAAS,kBAAkB,EAC1C,OAAO,SAAS,eAAe,8JAa9B,kBAAkB,CAAC,eAAe,EAAE,OAAO,CAAC,GAAG;IAAE,QAAQ,EAAE,QAAQ,CAAC,QAAQ,CAAA;CAAE,KAAG,MAAM,CAAC,MAAM,CAC/F,KAAK,CAAC,eAAe,EAAE,OAAO,CAAC,EAC/B,eAAe,EACf,KAAK,CAAC,KAAK,CAiHZ,CAAA"}
|