@livestore/common 0.3.0-dev.33 → 0.3.0-dev.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/.tsbuildinfo +1 -1
- package/dist/adapter-types.d.ts +5 -9
- package/dist/adapter-types.d.ts.map +1 -1
- package/dist/adapter-types.js.map +1 -1
- package/dist/devtools/devtools-messages-client-session.d.ts +30 -29
- package/dist/devtools/devtools-messages-client-session.d.ts.map +1 -1
- package/dist/devtools/devtools-messages-client-session.js +1 -0
- package/dist/devtools/devtools-messages-client-session.js.map +1 -1
- package/dist/devtools/devtools-messages-common.d.ts +6 -6
- package/dist/devtools/devtools-messages-leader.d.ts +25 -25
- package/dist/devtools/devtools-messages-leader.js +1 -1
- package/dist/devtools/devtools-messages-leader.js.map +1 -1
- package/dist/devtools/devtools-sessioninfo.d.ts +2 -0
- package/dist/devtools/devtools-sessioninfo.d.ts.map +1 -1
- package/dist/devtools/devtools-sessioninfo.js +1 -0
- package/dist/devtools/devtools-sessioninfo.js.map +1 -1
- package/dist/index.d.ts +3 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/dist/leader-thread/LeaderSyncProcessor.d.ts +4 -4
- package/dist/leader-thread/LeaderSyncProcessor.d.ts.map +1 -1
- package/dist/leader-thread/LeaderSyncProcessor.js +21 -17
- package/dist/leader-thread/LeaderSyncProcessor.js.map +1 -1
- package/dist/leader-thread/apply-event.d.ts +4 -4
- package/dist/leader-thread/apply-event.d.ts.map +1 -1
- package/dist/leader-thread/apply-event.js +9 -9
- package/dist/leader-thread/apply-event.js.map +1 -1
- package/dist/leader-thread/eventlog.d.ts.map +1 -1
- package/dist/leader-thread/eventlog.js +11 -15
- package/dist/leader-thread/eventlog.js.map +1 -1
- package/dist/leader-thread/leader-worker-devtools.d.ts +1 -1
- package/dist/leader-thread/leader-worker-devtools.js +13 -12
- package/dist/leader-thread/leader-worker-devtools.js.map +1 -1
- package/dist/leader-thread/make-leader-thread-layer.d.ts +2 -2
- package/dist/leader-thread/make-leader-thread-layer.d.ts.map +1 -1
- package/dist/leader-thread/make-leader-thread-layer.js +11 -18
- package/dist/leader-thread/make-leader-thread-layer.js.map +1 -1
- package/dist/leader-thread/materialize-event.d.ts +16 -0
- package/dist/leader-thread/materialize-event.d.ts.map +1 -0
- package/dist/leader-thread/materialize-event.js +103 -0
- package/dist/leader-thread/materialize-event.js.map +1 -0
- package/dist/leader-thread/recreate-db.d.ts.map +1 -1
- package/dist/leader-thread/recreate-db.js +9 -17
- package/dist/leader-thread/recreate-db.js.map +1 -1
- package/dist/leader-thread/types.d.ts +5 -5
- package/dist/leader-thread/types.d.ts.map +1 -1
- package/dist/materializer-helper.d.ts.map +1 -1
- package/dist/materializer-helper.js +1 -1
- package/dist/materializer-helper.js.map +1 -1
- package/dist/query-builder/api.d.ts +4 -4
- package/dist/query-builder/api.d.ts.map +1 -1
- package/dist/query-builder/impl.d.ts +2 -2
- package/dist/query-builder/impl.test.d.ts +5 -5
- package/dist/query-builder/mod.d.ts +2 -2
- package/dist/rehydrate-from-eventlog.d.ts +1 -1
- package/dist/rehydrate-from-eventlog.d.ts.map +1 -1
- package/dist/rehydrate-from-eventlog.js +6 -7
- package/dist/rehydrate-from-eventlog.js.map +1 -1
- package/dist/rematerialize-from-eventlog.d.ts +14 -0
- package/dist/rematerialize-from-eventlog.d.ts.map +1 -0
- package/dist/rematerialize-from-eventlog.js +64 -0
- package/dist/rematerialize-from-eventlog.js.map +1 -0
- package/dist/schema/EventDef.d.ts +3 -3
- package/dist/schema/EventDef.d.ts.map +1 -1
- package/dist/schema/EventId.test.js +1 -1
- package/dist/schema/EventId.test.js.map +1 -1
- package/dist/schema/client-document-def.d.ts +2 -2
- package/dist/schema/db-schema/dsl/mod.d.ts +3 -3
- package/dist/schema/db-schema/mod.d.ts +2 -2
- package/dist/schema/mod.d.ts +4 -4
- package/dist/schema/mod.d.ts.map +1 -1
- package/dist/schema/mod.js +4 -4
- package/dist/schema/mod.js.map +1 -1
- package/dist/schema/schema-helpers.d.ts +1 -1
- package/dist/schema/schema.d.ts +25 -14
- package/dist/schema/schema.d.ts.map +1 -1
- package/dist/schema/schema.js +8 -28
- package/dist/schema/schema.js.map +1 -1
- package/dist/schema/state/mod.d.ts +3 -0
- package/dist/schema/state/mod.d.ts.map +1 -0
- package/dist/schema/state/mod.js +3 -0
- package/dist/schema/state/mod.js.map +1 -0
- package/dist/schema/state/sqlite/client-document-def.d.ts +223 -0
- package/dist/schema/state/sqlite/client-document-def.d.ts.map +1 -0
- package/dist/schema/state/sqlite/client-document-def.js +170 -0
- package/dist/schema/state/sqlite/client-document-def.js.map +1 -0
- package/dist/schema/state/sqlite/client-document-def.test.d.ts +2 -0
- package/dist/schema/state/sqlite/client-document-def.test.d.ts.map +1 -0
- package/dist/schema/state/sqlite/client-document-def.test.js +201 -0
- package/dist/schema/state/sqlite/client-document-def.test.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.d.ts +69 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.js +71 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/validate.d.ts +3 -0
- package/dist/schema/state/sqlite/db-schema/ast/validate.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/validate.js +12 -0
- package/dist/schema/state/sqlite/db-schema/ast/validate.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.d.ts +90 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.js +87 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.test.d.ts +2 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.test.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.test.js +29 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.test.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/mod.d.ts +90 -0
- package/dist/schema/state/sqlite/db-schema/dsl/mod.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/mod.js +41 -0
- package/dist/schema/state/sqlite/db-schema/dsl/mod.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/hash.d.ts +2 -0
- package/dist/schema/state/sqlite/db-schema/hash.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/hash.js +14 -0
- package/dist/schema/state/sqlite/db-schema/hash.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/mod.d.ts +3 -0
- package/dist/schema/state/sqlite/db-schema/mod.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/mod.js +3 -0
- package/dist/schema/state/sqlite/db-schema/mod.js.map +1 -0
- package/dist/schema/state/sqlite/mod.d.ts +17 -0
- package/dist/schema/state/sqlite/mod.d.ts.map +1 -0
- package/dist/schema/state/sqlite/mod.js +41 -0
- package/dist/schema/state/sqlite/mod.js.map +1 -0
- package/dist/schema/state/sqlite/query-builder/api.d.ts +293 -0
- package/dist/schema/state/sqlite/query-builder/api.d.ts.map +1 -0
- package/dist/schema/state/sqlite/query-builder/api.js +6 -0
- package/dist/schema/state/sqlite/query-builder/api.js.map +1 -0
- package/dist/schema/state/sqlite/query-builder/astToSql.d.ts +7 -0
- package/dist/schema/state/sqlite/query-builder/astToSql.d.ts.map +1 -0
- package/dist/schema/state/sqlite/query-builder/astToSql.js +190 -0
- package/dist/schema/state/sqlite/query-builder/astToSql.js.map +1 -0
- package/dist/schema/state/sqlite/query-builder/impl.d.ts +7 -0
- package/dist/schema/state/sqlite/query-builder/impl.d.ts.map +1 -0
- package/dist/schema/state/sqlite/query-builder/impl.js +286 -0
- package/dist/schema/state/sqlite/query-builder/impl.js.map +1 -0
- package/dist/schema/state/sqlite/query-builder/impl.test.d.ts +87 -0
- package/dist/schema/state/sqlite/query-builder/impl.test.d.ts.map +1 -0
- package/dist/schema/state/sqlite/query-builder/impl.test.js +554 -0
- package/dist/schema/state/sqlite/query-builder/impl.test.js.map +1 -0
- package/dist/schema/state/sqlite/query-builder/mod.d.ts +17 -0
- package/dist/schema/state/sqlite/query-builder/mod.d.ts.map +1 -0
- package/dist/schema/state/sqlite/query-builder/mod.js +17 -0
- package/dist/schema/state/sqlite/query-builder/mod.js.map +1 -0
- package/dist/schema/state/sqlite/schema-helpers.d.ts +4 -0
- package/dist/schema/state/sqlite/schema-helpers.d.ts.map +1 -0
- package/dist/schema/state/sqlite/schema-helpers.js +30 -0
- package/dist/schema/state/sqlite/schema-helpers.js.map +1 -0
- package/dist/schema/state/sqlite/sqlite-state.d.ts +12 -0
- package/dist/schema/state/sqlite/sqlite-state.d.ts.map +1 -0
- package/dist/schema/state/sqlite/sqlite-state.js +36 -0
- package/dist/schema/state/sqlite/sqlite-state.js.map +1 -0
- package/dist/schema/state/sqlite/system-tables.d.ts +574 -0
- package/dist/schema/state/sqlite/system-tables.d.ts.map +1 -0
- package/dist/schema/state/sqlite/system-tables.js +87 -0
- package/dist/schema/state/sqlite/system-tables.js.map +1 -0
- package/dist/schema/state/sqlite/table-def.d.ts +84 -0
- package/dist/schema/state/sqlite/table-def.d.ts.map +1 -0
- package/dist/schema/state/sqlite/table-def.js +36 -0
- package/dist/schema/state/sqlite/table-def.js.map +1 -0
- package/dist/schema/state/state.d.ts +3 -0
- package/dist/schema/state/state.d.ts.map +1 -0
- package/dist/schema/state/state.js +3 -0
- package/dist/schema/state/state.js.map +1 -0
- package/dist/schema/state.d.ts +3 -0
- package/dist/schema/state.d.ts.map +1 -0
- package/dist/schema/state.js +3 -0
- package/dist/schema/state.js.map +1 -0
- package/dist/schema/system-tables.d.ts +7 -433
- package/dist/schema/system-tables.d.ts.map +1 -1
- package/dist/schema/system-tables.js +1 -1
- package/dist/schema/system-tables.js.map +1 -1
- package/dist/schema/table-def.d.ts +2 -2
- package/dist/schema-management/migrations.d.ts +1 -1
- package/dist/schema-management/migrations.d.ts.map +1 -1
- package/dist/schema-management/migrations.js +14 -12
- package/dist/schema-management/migrations.js.map +1 -1
- package/dist/schema-management/validate-schema.d.ts +8 -0
- package/dist/schema-management/validate-schema.d.ts.map +1 -0
- package/dist/schema-management/validate-schema.js +39 -0
- package/dist/schema-management/validate-schema.js.map +1 -0
- package/dist/sql-queries/sql-queries.d.ts +1 -1
- package/dist/sql-queries/sql-queries.d.ts.map +1 -1
- package/dist/sql-queries/sql-query-builder.d.ts +1 -1
- package/dist/sql-queries/sql-query-builder.d.ts.map +1 -1
- package/dist/sql-queries/types.d.ts +1 -1
- package/dist/sql-queries/types.d.ts.map +1 -1
- package/dist/sync/ClientSessionSyncProcessor.d.ts +3 -3
- package/dist/sync/ClientSessionSyncProcessor.d.ts.map +1 -1
- package/dist/sync/ClientSessionSyncProcessor.js +6 -6
- package/dist/sync/ClientSessionSyncProcessor.js.map +1 -1
- package/dist/sync/next/test/event-fixtures.d.ts +7 -7
- package/dist/sync/syncstate.d.ts +4 -4
- package/dist/version.d.ts +1 -1
- package/dist/version.js +1 -1
- package/package.json +9 -3
- package/src/adapter-types.ts +4 -10
- package/src/devtools/devtools-messages-client-session.ts +1 -0
- package/src/devtools/devtools-messages-leader.ts +1 -1
- package/src/devtools/devtools-sessioninfo.ts +1 -0
- package/src/index.ts +3 -3
- package/src/leader-thread/LeaderSyncProcessor.ts +28 -30
- package/src/leader-thread/eventlog.ts +12 -17
- package/src/leader-thread/leader-worker-devtools.ts +15 -12
- package/src/leader-thread/make-leader-thread-layer.ts +15 -21
- package/src/leader-thread/{apply-event.ts → materialize-event.ts} +22 -28
- package/src/leader-thread/recreate-db.ts +9 -21
- package/src/leader-thread/types.ts +5 -5
- package/src/materializer-helper.ts +1 -1
- package/src/{rehydrate-from-eventlog.ts → rematerialize-from-eventlog.ts} +41 -38
- package/src/schema/EventDef.ts +1 -1
- package/src/schema/EventId.test.ts +1 -1
- package/src/schema/mod.ts +4 -4
- package/src/schema/schema.ts +34 -52
- package/src/schema/state/mod.ts +2 -0
- package/src/schema/{client-document-def.test.ts → state/sqlite/client-document-def.test.ts} +2 -2
- package/src/schema/{client-document-def.ts → state/sqlite/client-document-def.ts} +6 -6
- package/src/schema/{sqlite-state.ts → state/sqlite/mod.ts} +17 -6
- package/src/{query-builder → schema/state/sqlite/query-builder}/api.ts +21 -22
- package/src/{query-builder → schema/state/sqlite/query-builder}/astToSql.ts +3 -3
- package/src/{query-builder → schema/state/sqlite/query-builder}/impl.test.ts +1 -1
- package/src/{query-builder → schema/state/sqlite/query-builder}/impl.ts +3 -4
- package/src/schema/{schema-helpers.ts → state/sqlite/schema-helpers.ts} +1 -1
- package/src/schema/{system-tables.ts → state/sqlite/system-tables.ts} +6 -5
- package/src/schema/{table-def.ts → state/sqlite/table-def.ts} +2 -2
- package/src/schema-management/migrations.ts +17 -15
- package/src/sql-queries/sql-queries.ts +1 -1
- package/src/sql-queries/sql-query-builder.ts +1 -1
- package/src/sql-queries/types.ts +1 -1
- package/src/sync/ClientSessionSyncProcessor.ts +7 -7
- package/src/version.ts +1 -1
- package/src/schema/view.ts +0 -2
- package/tmp/pack.tgz +0 -0
- package/tsconfig.json +0 -12
- /package/src/schema/{db-schema → state/sqlite/db-schema}/ast/sqlite.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/ast/validate.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/dsl/__snapshots__/field-defs.test.ts.snap +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/dsl/field-defs.test.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/dsl/field-defs.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/dsl/mod.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/hash.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/mod.ts +0 -0
- /package/src/{query-builder → schema/state/sqlite/query-builder}/mod.ts +0 -0
- /package/src/schema-management/{validate-mutation-defs.ts → validate-schema.ts} +0 -0
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"field-defs.test.js","sourceRoot":"","sources":["../../../../../../src/schema/state/sqlite/db-schema/dsl/field-defs.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAA;AAE/C,OAAO,KAAK,CAAC,MAAM,iBAAiB,CAAA;AAEpC,QAAQ,CAAC,UAAU,CAAC,WAAW,EAAE,GAAG,EAAE;IACpC,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE;QAChB,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,eAAe,EAAE,CAAA;QAClC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;QACpC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;QACnE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;QACnG,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;IACnH,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE;QAChB,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,eAAe,EAAE,CAAA;QAClC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;QACnE,MAAM,CACJ,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CACrG,CAAC,eAAe,EAAE,CAAA;IACrB,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE;QACpB,MAAM,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,eAAe,EAAE,CAAA;QACtC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;QACxC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;QACvE,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,IAAI,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;IAC3E,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE;QACnB,MAAM,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,eAAe,EAAE,CAAA;QACrC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;QACvC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;IACzD,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
@@ -0,0 +1,90 @@
|
|
1
|
+
import type { Nullable } from '@livestore/utils';
|
2
|
+
import type { Option, Types } from '@livestore/utils/effect';
|
3
|
+
import { Schema } from '@livestore/utils/effect';
|
4
|
+
import type * as SqliteAst from '../ast/sqlite.js';
|
5
|
+
import type { ColumnDefinition } from './field-defs.js';
|
6
|
+
export * from './field-defs.js';
|
7
|
+
export type DbSchema = {
|
8
|
+
[key: string]: TableDefinition<string, Columns>;
|
9
|
+
};
|
10
|
+
/** Note when using the object-notation, the object keys are ignored and not used as table names */
|
11
|
+
export type DbSchemaInput = Record<string, TableDefinition<any, any>> | ReadonlyArray<TableDefinition<any, any>>;
|
12
|
+
/**
|
13
|
+
* In case of ...
|
14
|
+
* - array: we use the table name of each array item (= table definition) as the object key
|
15
|
+
* - object: we discard the keys of the input object and use the table name of each object value (= table definition) as the new object key
|
16
|
+
*/
|
17
|
+
export type DbSchemaFromInputSchema<TSchemaInput extends DbSchemaInput> = TSchemaInput extends ReadonlyArray<TableDefinition<any, any>> ? {
|
18
|
+
[K in TSchemaInput[number] as K['name']]: K;
|
19
|
+
} : TSchemaInput extends Record<string, TableDefinition<any, any>> ? {
|
20
|
+
[K in keyof TSchemaInput as TSchemaInput[K]['name']]: TSchemaInput[K];
|
21
|
+
} : never;
|
22
|
+
export declare const makeDbSchema: <TDbSchemaInput extends DbSchemaInput>(schema: TDbSchemaInput) => DbSchemaFromInputSchema<TDbSchemaInput>;
|
23
|
+
export declare const table: <TTableName extends string, TColumns extends Columns, TIndexes extends Index[]>(name: TTableName, columns: TColumns, indexes?: TIndexes) => TableDefinition<TTableName, TColumns>;
|
24
|
+
export type AnyIfConstained<In, Out> = '__constrained' extends keyof In ? any : Out;
|
25
|
+
export type EmptyObjIfConstained<In> = '__constrained' extends keyof In ? {} : In;
|
26
|
+
export type StructSchemaForColumns<TCols extends ConstraintColumns> = Schema.Schema<AnyIfConstained<TCols, FromColumns.RowDecoded<TCols>>, AnyIfConstained<TCols, FromColumns.RowEncoded<TCols>>>;
|
27
|
+
export type InsertStructSchemaForColumns<TCols extends ConstraintColumns> = Schema.Schema<AnyIfConstained<TCols, FromColumns.InsertRowDecoded<TCols>>, AnyIfConstained<TCols, FromColumns.InsertRowEncoded<TCols>>>;
|
28
|
+
export declare const structSchemaForTable: <TTableDefinition extends TableDefinition<any, any>>(tableDef: TTableDefinition) => StructSchemaForColumns<TTableDefinition["columns"]>;
|
29
|
+
export declare const insertStructSchemaForTable: <TTableDefinition extends TableDefinition<any, any>>(tableDef: TTableDefinition) => InsertStructSchemaForColumns<TTableDefinition["columns"]>;
|
30
|
+
export type TableDefinition<TName extends string, TColumns extends Columns> = {
|
31
|
+
name: TName;
|
32
|
+
columns: TColumns;
|
33
|
+
indexes?: ReadonlyArray<Index>;
|
34
|
+
ast: SqliteAst.Table;
|
35
|
+
};
|
36
|
+
export type Columns = Record<string, ColumnDefinition<any, any>>;
|
37
|
+
export type IsSingleColumn<TColumns extends Columns | ColumnDefinition<any, any>> = TColumns extends ColumnDefinition<any, any> ? true : false;
|
38
|
+
/**
|
39
|
+
* NOTE this is only needed to avoid a TS limitation where `StructSchemaForColumns` in the default case
|
40
|
+
* results in `Record<string, any>` instead of `any`. (Thanks to Andarist for the workaround)
|
41
|
+
*
|
42
|
+
* Hopefully this can be removed in the future
|
43
|
+
*/
|
44
|
+
export type ConstraintColumns = Record<string, ColumnDefinition<any, any>> & {
|
45
|
+
__constrained?: never;
|
46
|
+
};
|
47
|
+
export type Index = {
|
48
|
+
name: string;
|
49
|
+
columns: ReadonlyArray<string>;
|
50
|
+
/** @default false */
|
51
|
+
isUnique?: boolean;
|
52
|
+
};
|
53
|
+
export declare namespace FromTable {
|
54
|
+
type RowDecoded<TTableDefinition extends TableDefinition<any, any>> = Types.Simplify<Nullable<Pick<RowDecodedAll<TTableDefinition>, NullableColumnNames<TTableDefinition>>> & Omit<RowDecodedAll<TTableDefinition>, NullableColumnNames<TTableDefinition>>>;
|
55
|
+
type NullableColumnNames<TTableDefinition extends TableDefinition<any, any>> = FromColumns.NullableColumnNames<TTableDefinition['columns']>;
|
56
|
+
type Columns<TTableDefinition extends TableDefinition<any, any>> = {
|
57
|
+
[K in keyof TTableDefinition['columns']]: TTableDefinition['columns'][K]['columnType'];
|
58
|
+
};
|
59
|
+
type RowEncodeNonNullable<TTableDefinition extends TableDefinition<any, any>> = {
|
60
|
+
[K in keyof TTableDefinition['columns']]: Schema.Schema.Encoded<TTableDefinition['columns'][K]['schema']>;
|
61
|
+
};
|
62
|
+
type RowEncoded<TTableDefinition extends TableDefinition<any, any>> = Types.Simplify<Nullable<Pick<RowEncodeNonNullable<TTableDefinition>, NullableColumnNames<TTableDefinition>>> & Omit<RowEncodeNonNullable<TTableDefinition>, NullableColumnNames<TTableDefinition>>>;
|
63
|
+
type RowDecodedAll<TTableDefinition extends TableDefinition<any, any>> = {
|
64
|
+
[K in keyof TTableDefinition['columns']]: Schema.Schema.Type<TTableDefinition['columns'][K]['schema']>;
|
65
|
+
};
|
66
|
+
}
|
67
|
+
export declare namespace FromColumns {
|
68
|
+
type RowDecoded<TColumns extends Columns> = Types.Simplify<Nullable<Pick<RowDecodedAll<TColumns>, NullableColumnNames<TColumns>>> & Omit<RowDecodedAll<TColumns>, NullableColumnNames<TColumns>>>;
|
69
|
+
type RowDecodedAll<TColumns extends Columns> = {
|
70
|
+
readonly [K in keyof TColumns]: Schema.Schema.Type<TColumns[K]['schema']>;
|
71
|
+
};
|
72
|
+
type RowEncodedAll<TColumns extends Columns> = {
|
73
|
+
readonly [K in keyof TColumns]: Schema.Schema.Encoded<TColumns[K]['schema']>;
|
74
|
+
};
|
75
|
+
type RowEncoded<TColumns extends Columns> = Types.Simplify<Nullable<Pick<RowEncodeNonNullable<TColumns>, NullableColumnNames<TColumns>>> & Omit<RowEncodeNonNullable<TColumns>, NullableColumnNames<TColumns>>>;
|
76
|
+
type RowEncodeNonNullable<TColumns extends Columns> = {
|
77
|
+
readonly [K in keyof TColumns]: Schema.Schema.Encoded<TColumns[K]['schema']>;
|
78
|
+
};
|
79
|
+
type NullableColumnNames<TColumns extends Columns> = keyof {
|
80
|
+
[K in keyof TColumns as TColumns[K] extends ColumnDefinition<any, true> ? K : never]: {};
|
81
|
+
};
|
82
|
+
type RequiredInsertColumns<TColumns extends Columns> = {
|
83
|
+
[K in keyof TColumns as TColumns[K]['nullable'] extends true ? never : TColumns[K]['default'] extends Option.Some<any> ? never : K]: {};
|
84
|
+
};
|
85
|
+
type RequiredInsertColumnNames<TColumns extends Columns> = keyof RequiredInsertColumns<TColumns>;
|
86
|
+
type RequiresInsertValues<TColumns extends Columns> = RequiredInsertColumnNames<TColumns> extends never ? false : true;
|
87
|
+
type InsertRowDecoded<TColumns extends Columns> = Types.Simplify<Pick<RowDecodedAll<TColumns>, RequiredInsertColumnNames<TColumns>> & Partial<Omit<RowDecodedAll<TColumns>, RequiredInsertColumnNames<TColumns>>>>;
|
88
|
+
type InsertRowEncoded<TColumns extends Columns> = Types.Simplify<Pick<RowEncodedAll<TColumns>, RequiredInsertColumnNames<TColumns>> & Partial<Omit<RowEncodedAll<TColumns>, RequiredInsertColumnNames<TColumns>>>>;
|
89
|
+
}
|
90
|
+
//# sourceMappingURL=mod.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"mod.d.ts","sourceRoot":"","sources":["../../../../../../src/schema/state/sqlite/db-schema/dsl/mod.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AAChD,OAAO,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAA;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAEhD,OAAO,KAAK,KAAK,SAAS,MAAM,kBAAkB,CAAA;AAClD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAA;AAEvD,cAAc,iBAAiB,CAAA;AAE/B,MAAM,MAAM,QAAQ,GAAG;IACrB,CAAC,GAAG,EAAE,MAAM,GAAG,eAAe,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAChD,CAAA;AAED,mGAAmG;AACnG,MAAM,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,GAAG,aAAa,CAAC,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;AAEhH;;;;GAIG;AACH,MAAM,MAAM,uBAAuB,CAAC,YAAY,SAAS,aAAa,IACpE,YAAY,SAAS,aAAa,CAAC,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,GACzD;KAAG,CAAC,IAAI,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;CAAE,GAC/C,YAAY,SAAS,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,GAC5D;KAAG,CAAC,IAAI,MAAM,YAAY,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC;CAAE,GACzE,KAAK,CAAA;AAGb,eAAO,MAAM,YAAY,GAAI,cAAc,SAAS,aAAa,EAC/D,QAAQ,cAAc,KACrB,uBAAuB,CAAC,cAAc,CAExC,CAAA;AAED,eAAO,MAAM,KAAK,GAAI,UAAU,SAAS,MAAM,EAAE,QAAQ,SAAS,OAAO,EAAE,QAAQ,SAAS,KAAK,EAAE,EACjG,MAAM,UAAU,EAChB,SAAS,QAAQ,EACjB,UAAU,QAAQ,KACjB,eAAe,CAAC,UAAU,EAAE,QAAQ,CAStC,CAAA;AAED,MAAM,MAAM,eAAe,CAAC,EAAE,EAAE,GAAG,IAAI,eAAe,SAAS,MAAM,EAAE,GAAG,GAAG,GAAG,GAAG,CAAA;AACnF,MAAM,MAAM,oBAAoB,CAAC,EAAE,IAAI,eAAe,SAAS,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,CAAA;AAEjF,MAAM,MAAM,sBAAsB,CAAC,KAAK,SAAS,iBAAiB,IAAI,MAAM,CAAC,MAAM,CACjF,eAAe,CAAC,KAAK,EAAE,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,EACrD,eAAe,CAAC,KAAK,EAAE,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CACtD,CAAA;AAED,MAAM,MAAM,4BAA4B,CAAC,KAAK,SAAS,iBAAiB,IAAI,MAAM,CAAC,MAAM,CACvF,eAAe,CAAC,KAAK,EAAE,WAAW,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,EAC3D,eAAe,CAAC,KAAK,EAAE,WAAW,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAC5D,CAAA;AAED,eAAO,MAAM,oBAAoB,GAAI,gBAAgB,SAAS,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,EACrF,UAAU,gBAAgB,KACzB,sBAAsB,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAG1C,CAAA;AAEX,eAAO,MAAM,0BAA0B,GAAI,gBAAgB,SAAS,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,EAC3F,UAAU,gBAAgB,KACzB,4BAA4B,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAUhD,CAAA;AAwBX,MAAM,MAAM,eAAe,CAAC,KAAK,SAAS,MAAM,EAAE,QAAQ,SAAS,OAAO,IAAI;IAC5E,IAAI,EAAE,KAAK,CAAA;IACX,OAAO,EAAE,QAAQ,CAAA;IACjB,OAAO,CAAC,EAAE,aAAa,CAAC,KAAK,CAAC,CAAA;IAC9B,GAAG,EAAE,SAAS,CAAC,KAAK,CAAA;CACrB,CAAA;AAED,MAAM,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;AAEhE,MAAM,MAAM,cAAc,CAAC,QAAQ,SAAS,OAAO,GAAG,gBAAgB,CAAC,GAAG,EAAE,GAAG,CAAC,IAC9E,QAAQ,SAAS,gBAAgB,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,IAAI,GAAG,KAAK,CAAA;AAE5D;;;;;GAKG;AACH,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,GAAG;IAAE,aAAa,CAAC,EAAE,KAAK,CAAA;CAAE,CAAA;AAEtG,MAAM,MAAM,KAAK,GAAG;IAClB,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,aAAa,CAAC,MAAM,CAAC,CAAA;IAC9B,qBAAqB;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,yBAAiB,SAAS,CAAC;IAEzB,KAAY,UAAU,CAAC,gBAAgB,SAAS,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,KAAK,CAAC,QAAQ,CACzF,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,EAAE,mBAAmB,CAAC,gBAAgB,CAAC,CAAC,CAAC,GACpF,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,EAAE,mBAAmB,CAAC,gBAAgB,CAAC,CAAC,CAC/E,CAAA;IAED,KAAY,mBAAmB,CAAC,gBAAgB,SAAS,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,WAAW,CAAC,mBAAmB,CACnH,gBAAgB,CAAC,SAAS,CAAC,CAC5B,CAAA;IAED,KAAY,OAAO,CAAC,gBAAgB,SAAS,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI;SACvE,CAAC,IAAI,MAAM,gBAAgB,CAAC,SAAS,CAAC,GAAG,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;KACvF,CAAA;IAED,KAAY,oBAAoB,CAAC,gBAAgB,SAAS,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI;SACpF,CAAC,IAAI,MAAM,gBAAgB,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;KAC1G,CAAA;IAED,KAAY,UAAU,CAAC,gBAAgB,SAAS,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,KAAK,CAAC,QAAQ,CACzF,QAAQ,CAAC,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,EAAE,mBAAmB,CAAC,gBAAgB,CAAC,CAAC,CAAC,GAC3F,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,EAAE,mBAAmB,CAAC,gBAAgB,CAAC,CAAC,CACtF,CAAA;IAUD,KAAY,aAAa,CAAC,gBAAgB,SAAS,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI;SAC7E,CAAC,IAAI,MAAM,gBAAgB,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;KACvG,CAAA;CACF;AAED,yBAAiB,WAAW,CAAC;IAE3B,KAAY,UAAU,CAAC,QAAQ,SAAS,OAAO,IAAI,KAAK,CAAC,QAAQ,CAC/D,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC,GACpE,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAC/D,CAAA;IAED,KAAY,aAAa,CAAC,QAAQ,SAAS,OAAO,IAAI;QACpD,QAAQ,EAAE,CAAC,IAAI,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;KAC1E,CAAA;IAED,KAAY,aAAa,CAAC,QAAQ,SAAS,OAAO,IAAI;QACpD,QAAQ,EAAE,CAAC,IAAI,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;KAC7E,CAAA;IAED,KAAY,UAAU,CAAC,QAAQ,SAAS,OAAO,IAAI,KAAK,CAAC,QAAQ,CAC/D,QAAQ,CAAC,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,EAAE,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC,GAC3E,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,EAAE,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CACtE,CAAA;IAED,KAAY,oBAAoB,CAAC,QAAQ,SAAS,OAAO,IAAI;QAC3D,QAAQ,EAAE,CAAC,IAAI,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;KAC7E,CAAA;IAED,KAAY,mBAAmB,CAAC,QAAQ,SAAS,OAAO,IAAI,MAAM;SAE/D,CAAC,IAAI,MAAM,QAAQ,IAAI,QAAQ,CAAC,CAAC,CAAC,SAAS,gBAAgB,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,GAAG,EAAE;KACzF,CAAA;IAED,KAAY,qBAAqB,CAAC,QAAQ,SAAS,OAAO,IAAI;SAC3D,CAAC,IAAI,MAAM,QAAQ,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,IAAI,GACxD,KAAK,GACL,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,SAAS,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,GAC7C,KAAK,GACL,CAAC,GAAG,EAAE;KACb,CAAA;IAED,KAAY,yBAAyB,CAAC,QAAQ,SAAS,OAAO,IAAI,MAAM,qBAAqB,CAAC,QAAQ,CAAC,CAAA;IAEvG,KAAY,oBAAoB,CAAC,QAAQ,SAAS,OAAO,IACvD,yBAAyB,CAAC,QAAQ,CAAC,SAAS,KAAK,GAAG,KAAK,GAAG,IAAI,CAAA;IAElE,KAAY,gBAAgB,CAAC,QAAQ,SAAS,OAAO,IAAI,KAAK,CAAC,QAAQ,CACrE,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,yBAAyB,CAAC,QAAQ,CAAC,CAAC,GAChE,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,yBAAyB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAC9E,CAAA;IAED,KAAY,gBAAgB,CAAC,QAAQ,SAAS,OAAO,IAAI,KAAK,CAAC,QAAQ,CACrE,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,yBAAyB,CAAC,QAAQ,CAAC,CAAC,GAChE,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,yBAAyB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAC9E,CAAA;CACF"}
|
@@ -0,0 +1,41 @@
|
|
1
|
+
import { Schema } from '@livestore/utils/effect';
|
2
|
+
export * from './field-defs.js';
|
3
|
+
// TODO ensure via runtime check (possibly even via type-level check) that all index names are unique
|
4
|
+
export const makeDbSchema = (schema) => {
|
5
|
+
return Array.isArray(schema) ? Object.fromEntries(schema.map((_) => [_.name, _])) : schema;
|
6
|
+
};
|
7
|
+
export const table = (name, columns, indexes) => {
|
8
|
+
const ast = {
|
9
|
+
_tag: 'table',
|
10
|
+
name,
|
11
|
+
columns: columsToAst(columns),
|
12
|
+
indexes: indexesToAst(indexes ?? []),
|
13
|
+
};
|
14
|
+
return { name, columns, indexes, ast };
|
15
|
+
};
|
16
|
+
export const structSchemaForTable = (tableDef) => Schema.Struct(Object.fromEntries(tableDef.ast.columns.map((column) => [column.name, column.schema]))).annotations({
|
17
|
+
title: tableDef.name,
|
18
|
+
});
|
19
|
+
export const insertStructSchemaForTable = (tableDef) => Schema.Struct(Object.fromEntries(tableDef.ast.columns.map((column) => [
|
20
|
+
column.name,
|
21
|
+
column.nullable === true || column.default._tag === 'Some' ? Schema.optional(column.schema) : column.schema,
|
22
|
+
]))).annotations({
|
23
|
+
title: tableDef.name,
|
24
|
+
});
|
25
|
+
const columsToAst = (columns) => {
|
26
|
+
return Object.entries(columns).map(([name, column]) => {
|
27
|
+
return {
|
28
|
+
_tag: 'column',
|
29
|
+
name,
|
30
|
+
schema: column.schema,
|
31
|
+
default: column.default,
|
32
|
+
nullable: column.nullable ?? false,
|
33
|
+
primaryKey: column.primaryKey ?? false,
|
34
|
+
type: { _tag: column.columnType },
|
35
|
+
};
|
36
|
+
});
|
37
|
+
};
|
38
|
+
const indexesToAst = (indexes) => {
|
39
|
+
return indexes.map((_) => ({ _tag: 'index', columns: _.columns, name: _.name, unique: _.isUnique ?? false }));
|
40
|
+
};
|
41
|
+
//# sourceMappingURL=mod.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"mod.js","sourceRoot":"","sources":["../../../../../../src/schema/state/sqlite/db-schema/dsl/mod.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"hash.d.ts","sourceRoot":"","sources":["../../../../../src/schema/state/sqlite/db-schema/hash.ts"],"names":[],"mappings":"AACA,eAAO,MAAM,QAAQ,GAAI,KAAK,MAAM,WAYnC,CAAA"}
|
@@ -0,0 +1,14 @@
|
|
1
|
+
// Based on https://stackoverflow.com/a/7616484
|
2
|
+
export const hashCode = (str) => {
|
3
|
+
let hash = 0, i, chr;
|
4
|
+
if (str.length === 0)
|
5
|
+
return hash;
|
6
|
+
for (i = 0; i < str.length; i++) {
|
7
|
+
// eslint-disable-next-line unicorn/prefer-code-point
|
8
|
+
chr = str.charCodeAt(i);
|
9
|
+
hash = (hash << 5) - hash + chr;
|
10
|
+
hash = Math.trunc(hash); // Convert to 32bit integer
|
11
|
+
}
|
12
|
+
return hash;
|
13
|
+
};
|
14
|
+
//# sourceMappingURL=hash.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"hash.js","sourceRoot":"","sources":["../../../../../src/schema/state/sqlite/db-schema/hash.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAC/C,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,GAAW,EAAE,EAAE;IACtC,IAAI,IAAI,GAAG,CAAC,EACV,CAAC,EACD,GAAG,CAAA;IACL,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAA;IACjC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QAChC,qDAAqD;QACrD,GAAG,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;QACvB,IAAI,GAAG,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,IAAI,GAAG,GAAG,CAAA;QAC/B,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA,CAAC,2BAA2B;IACrD,CAAC;IACD,OAAO,IAAI,CAAA;AACb,CAAC,CAAA"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"mod.d.ts","sourceRoot":"","sources":["../../../../../src/schema/state/sqlite/db-schema/mod.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,cAAc,CAAA;AACzC,OAAO,KAAK,SAAS,MAAM,iBAAiB,CAAA"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"mod.js","sourceRoot":"","sources":["../../../../../src/schema/state/sqlite/db-schema/mod.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,cAAc,CAAA;AACzC,OAAO,KAAK,SAAS,MAAM,iBAAiB,CAAA"}
|
@@ -0,0 +1,17 @@
|
|
1
|
+
import type { MigrationOptions } from '../../../adapter-types.js';
|
2
|
+
import { type Materializer } from '../../EventDef.js';
|
3
|
+
import type { State } from '../../schema.js';
|
4
|
+
import { type TableDefBase } from './table-def.js';
|
5
|
+
export * from './table-def.js';
|
6
|
+
export { ClientDocumentTableDefSymbol, tableIsClientDocumentTable, clientDocument, type ClientDocumentTableDef, type ClientDocumentTableOptions, } from './client-document-def.js';
|
7
|
+
export * from '../../EventDef.js';
|
8
|
+
export declare const makeState: <TStateInput extends InputState>(inputSchema: TStateInput) => State;
|
9
|
+
export type InputState = {
|
10
|
+
readonly tables: Record<string, TableDefBase> | ReadonlyArray<TableDefBase>;
|
11
|
+
readonly materializers: Record<string, Materializer<any>>;
|
12
|
+
/**
|
13
|
+
* @default { strategy: 'auto' }
|
14
|
+
*/
|
15
|
+
readonly migrations?: MigrationOptions;
|
16
|
+
};
|
17
|
+
//# sourceMappingURL=mod.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"mod.d.ts","sourceRoot":"","sources":["../../../../src/schema/state/sqlite/mod.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAA;AACjE,OAAO,EAAE,KAAK,YAAY,EAAmC,MAAM,mBAAmB,CAAA;AACtF,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAI5C,OAAO,EAAiB,KAAK,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAEjE,cAAc,gBAAgB,CAAA;AAC9B,OAAO,EACL,4BAA4B,EAC5B,0BAA0B,EAC1B,cAAc,EACd,KAAK,sBAAsB,EAC3B,KAAK,0BAA0B,GAChC,MAAM,0BAA0B,CAAA;AACjC,cAAc,mBAAmB,CAAA;AAEjC,eAAO,MAAM,SAAS,GAAI,WAAW,SAAS,UAAU,EAAE,aAAa,WAAW,KAAG,KA2CpF,CAAA;AAED,MAAM,MAAM,UAAU,GAAG;IACvB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC,GAAG,aAAa,CAAC,YAAY,CAAC,CAAA;IAC3E,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,CAAA;IACzD;;OAEG;IACH,QAAQ,CAAC,UAAU,CAAC,EAAE,gBAAgB,CAAA;CACvC,CAAA"}
|
@@ -0,0 +1,41 @@
|
|
1
|
+
import { shouldNeverHappen } from '@livestore/utils';
|
2
|
+
import { rawSqlEvent, rawSqlMaterializer } from '../../EventDef.js';
|
3
|
+
import { ClientDocumentTableDefSymbol, tableIsClientDocumentTable } from './client-document-def.js';
|
4
|
+
import { SqliteAst } from './db-schema/mod.js';
|
5
|
+
import { stateSystemTables } from './system-tables.js';
|
6
|
+
export * from './table-def.js';
|
7
|
+
export { ClientDocumentTableDefSymbol, tableIsClientDocumentTable, clientDocument, } from './client-document-def.js';
|
8
|
+
export * from '../../EventDef.js';
|
9
|
+
export const makeState = (inputSchema) => {
|
10
|
+
const inputTables = Array.isArray(inputSchema.tables)
|
11
|
+
? inputSchema.tables
|
12
|
+
: Object.values(inputSchema.tables);
|
13
|
+
const tables = new Map();
|
14
|
+
for (const tableDef of inputTables) {
|
15
|
+
const sqliteDef = tableDef.sqliteDef;
|
16
|
+
// TODO validate tables (e.g. index names are unique)
|
17
|
+
if (tables.has(sqliteDef.ast.name)) {
|
18
|
+
shouldNeverHappen(`Duplicate table name: ${sqliteDef.ast.name}. Please use unique names for tables.`);
|
19
|
+
}
|
20
|
+
tables.set(sqliteDef.ast.name, tableDef);
|
21
|
+
}
|
22
|
+
for (const tableDef of stateSystemTables) {
|
23
|
+
tables.set(tableDef.sqliteDef.name, tableDef);
|
24
|
+
}
|
25
|
+
const materializers = new Map();
|
26
|
+
for (const [name, materializer] of Object.entries(inputSchema.materializers)) {
|
27
|
+
materializers.set(name, materializer);
|
28
|
+
}
|
29
|
+
materializers.set(rawSqlEvent.name, rawSqlMaterializer);
|
30
|
+
for (const tableDef of inputTables) {
|
31
|
+
if (tableIsClientDocumentTable(tableDef)) {
|
32
|
+
materializers.set(tableDef[ClientDocumentTableDefSymbol].derived.setEventDef.name, tableDef[ClientDocumentTableDefSymbol].derived.setMaterializer);
|
33
|
+
}
|
34
|
+
}
|
35
|
+
const hash = SqliteAst.hash({
|
36
|
+
_tag: 'dbSchema',
|
37
|
+
tables: [...tables.values()].map((_) => _.sqliteDef.ast),
|
38
|
+
});
|
39
|
+
return { sqlite: { tables, migrations: inputSchema.migrations ?? { strategy: 'auto' }, hash }, materializers };
|
40
|
+
};
|
41
|
+
//# sourceMappingURL=mod.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"mod.js","sourceRoot":"","sources":["../../../../src/schema/state/sqlite/mod.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAGpD,OAAO,EAAqB,WAAW,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAA;AAEtF,OAAO,EAAE,4BAA4B,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAA;AACnG,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAA;AAC9C,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAA;AAGtD,cAAc,gBAAgB,CAAA;AAC9B,OAAO,EACL,4BAA4B,EAC5B,0BAA0B,EAC1B,cAAc,GAGf,MAAM,0BAA0B,CAAA;AACjC,cAAc,mBAAmB,CAAA;AAEjC,MAAM,CAAC,MAAM,SAAS,GAAG,CAAiC,WAAwB,EAAS,EAAE;IAC3F,MAAM,WAAW,GAA4B,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC;QAC5E,CAAC,CAAC,WAAW,CAAC,MAAM;QACpB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,CAAA;IAErC,MAAM,MAAM,GAAG,IAAI,GAAG,EAAwB,CAAA;IAE9C,KAAK,MAAM,QAAQ,IAAI,WAAW,EAAE,CAAC;QACnC,MAAM,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAA;QACpC,qDAAqD;QACrD,IAAI,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;YACnC,iBAAiB,CAAC,yBAAyB,SAAS,CAAC,GAAG,CAAC,IAAI,uCAAuC,CAAC,CAAA;QACvG,CAAC;QACD,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;IAC1C,CAAC;IAED,KAAK,MAAM,QAAQ,IAAI,iBAAiB,EAAE,CAAC;QACzC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;IAC/C,CAAC;IAED,MAAM,aAAa,GAAG,IAAI,GAAG,EAA6B,CAAA;IAE1D,KAAK,MAAM,CAAC,IAAI,EAAE,YAAY,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,aAAa,CAAC,EAAE,CAAC;QAC7E,aAAa,CAAC,GAAG,CAAC,IAAI,EAAE,YAAY,CAAC,CAAA;IACvC,CAAC;IAED,aAAa,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,EAAE,kBAAkB,CAAC,CAAA;IAEvD,KAAK,MAAM,QAAQ,IAAI,WAAW,EAAE,CAAC;QACnC,IAAI,0BAA0B,CAAC,QAAQ,CAAC,EAAE,CAAC;YACzC,aAAa,CAAC,GAAG,CACf,QAAQ,CAAC,4BAA4B,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,EAC/D,QAAQ,CAAC,4BAA4B,CAAC,CAAC,OAAO,CAAC,eAAe,CAC/D,CAAA;QACH,CAAC;IACH,CAAC;IAED,MAAM,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;QAC1B,IAAI,EAAE,UAAU;QAChB,MAAM,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC;KACzD,CAAC,CAAA;IAEF,OAAO,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,CAAC,UAAU,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,aAAa,EAAE,CAAA;AAChH,CAAC,CAAA"}
|
@@ -0,0 +1,293 @@
|
|
1
|
+
import type { GetValForKey, SingleOrReadonlyArray } from '@livestore/utils';
|
2
|
+
import { type Option, type Schema } from '@livestore/utils/effect';
|
3
|
+
import type { SessionIdSymbol } from '../../../../adapter-types.js';
|
4
|
+
import type { SqlValue } from '../../../../util.js';
|
5
|
+
import type { ClientDocumentTableDef } from '../client-document-def.js';
|
6
|
+
import type { SqliteDsl } from '../db-schema/mod.js';
|
7
|
+
import type { TableDefBase } from '../table-def.js';
|
8
|
+
export type QueryBuilderAst = QueryBuilderAst.SelectQuery | QueryBuilderAst.CountQuery | QueryBuilderAst.RowQuery | QueryBuilderAst.InsertQuery | QueryBuilderAst.UpdateQuery | QueryBuilderAst.DeleteQuery;
|
9
|
+
export declare namespace QueryBuilderAst {
|
10
|
+
interface SelectQuery {
|
11
|
+
readonly _tag: 'SelectQuery';
|
12
|
+
readonly columns: string[];
|
13
|
+
readonly pickFirst: false | {
|
14
|
+
fallback: () => any;
|
15
|
+
} | 'no-fallback';
|
16
|
+
readonly select: {
|
17
|
+
columns: ReadonlyArray<string>;
|
18
|
+
};
|
19
|
+
readonly orderBy: ReadonlyArray<OrderBy>;
|
20
|
+
readonly offset: Option.Option<number>;
|
21
|
+
readonly limit: Option.Option<number>;
|
22
|
+
readonly tableDef: TableDefBase;
|
23
|
+
readonly where: ReadonlyArray<QueryBuilderAst.Where>;
|
24
|
+
readonly resultSchemaSingle: Schema.Schema<any>;
|
25
|
+
}
|
26
|
+
interface CountQuery {
|
27
|
+
readonly _tag: 'CountQuery';
|
28
|
+
readonly tableDef: TableDefBase;
|
29
|
+
readonly where: ReadonlyArray<QueryBuilderAst.Where>;
|
30
|
+
readonly resultSchema: Schema.Schema<number, ReadonlyArray<{
|
31
|
+
count: number;
|
32
|
+
}>>;
|
33
|
+
}
|
34
|
+
interface RowQuery {
|
35
|
+
readonly _tag: 'RowQuery';
|
36
|
+
readonly tableDef: ClientDocumentTableDef.Any;
|
37
|
+
readonly id: string | SessionIdSymbol;
|
38
|
+
readonly explicitDefaultValues: Record<string, unknown>;
|
39
|
+
}
|
40
|
+
interface InsertQuery {
|
41
|
+
readonly _tag: 'InsertQuery';
|
42
|
+
readonly tableDef: TableDefBase;
|
43
|
+
readonly values: Record<string, unknown>;
|
44
|
+
readonly onConflict: OnConflict | undefined;
|
45
|
+
readonly returning: string[] | undefined;
|
46
|
+
readonly resultSchema: Schema.Schema<any>;
|
47
|
+
}
|
48
|
+
interface OnConflict {
|
49
|
+
/** Conflicting column name */
|
50
|
+
readonly targets: string[];
|
51
|
+
readonly action: {
|
52
|
+
readonly _tag: 'ignore';
|
53
|
+
} | {
|
54
|
+
readonly _tag: 'replace';
|
55
|
+
} | {
|
56
|
+
readonly _tag: 'update';
|
57
|
+
readonly update: Record<string, unknown>;
|
58
|
+
};
|
59
|
+
}
|
60
|
+
interface UpdateQuery {
|
61
|
+
readonly _tag: 'UpdateQuery';
|
62
|
+
readonly tableDef: TableDefBase;
|
63
|
+
readonly values: Record<string, unknown>;
|
64
|
+
readonly where: ReadonlyArray<QueryBuilderAst.Where>;
|
65
|
+
readonly returning: string[] | undefined;
|
66
|
+
readonly resultSchema: Schema.Schema<any>;
|
67
|
+
}
|
68
|
+
interface DeleteQuery {
|
69
|
+
readonly _tag: 'DeleteQuery';
|
70
|
+
readonly tableDef: TableDefBase;
|
71
|
+
readonly where: ReadonlyArray<QueryBuilderAst.Where>;
|
72
|
+
readonly returning: string[] | undefined;
|
73
|
+
readonly resultSchema: Schema.Schema<any>;
|
74
|
+
}
|
75
|
+
type WriteQuery = InsertQuery | UpdateQuery | DeleteQuery;
|
76
|
+
interface Where {
|
77
|
+
readonly col: string;
|
78
|
+
readonly op: QueryBuilder.WhereOps;
|
79
|
+
readonly value: unknown;
|
80
|
+
}
|
81
|
+
interface OrderBy {
|
82
|
+
readonly col: string;
|
83
|
+
readonly direction: 'asc' | 'desc';
|
84
|
+
}
|
85
|
+
}
|
86
|
+
export declare const QueryBuilderAstSymbol: unique symbol;
|
87
|
+
export type QueryBuilderAstSymbol = typeof QueryBuilderAstSymbol;
|
88
|
+
export declare const QueryBuilderResultSymbol: unique symbol;
|
89
|
+
export type QueryBuilderResultSymbol = typeof QueryBuilderResultSymbol;
|
90
|
+
export declare const QueryBuilderTypeId: unique symbol;
|
91
|
+
export type QueryBuilderTypeId = typeof QueryBuilderTypeId;
|
92
|
+
export declare const isQueryBuilder: (value: unknown) => value is QueryBuilder<any, any, any>;
|
93
|
+
export type QueryBuilder<TResult, TTableDef extends TableDefBase,
|
94
|
+
/** Used to gradually remove features from the API based on the query context */
|
95
|
+
TWithout extends QueryBuilder.ApiFeature = never> = {
|
96
|
+
readonly [QueryBuilderTypeId]: QueryBuilderTypeId;
|
97
|
+
readonly [QueryBuilderAstSymbol]: QueryBuilderAst;
|
98
|
+
readonly ['ResultType']: TResult;
|
99
|
+
readonly asSql: () => {
|
100
|
+
query: string;
|
101
|
+
bindValues: SqlValue[];
|
102
|
+
};
|
103
|
+
readonly toString: () => string;
|
104
|
+
} & Omit<QueryBuilder.ApiFull<TResult, TTableDef, TWithout>, TWithout>;
|
105
|
+
export declare namespace QueryBuilder {
|
106
|
+
type Any = QueryBuilder<any, any, any>;
|
107
|
+
type WhereOps = WhereOps.Equality | WhereOps.Order | WhereOps.Like | WhereOps.In;
|
108
|
+
namespace WhereOps {
|
109
|
+
type Equality = '=' | '!=';
|
110
|
+
type Order = '<' | '>' | '<=' | '>=';
|
111
|
+
type Like = 'LIKE' | 'NOT LIKE' | 'ILIKE' | 'NOT ILIKE';
|
112
|
+
type In = 'IN' | 'NOT IN';
|
113
|
+
type SingleValue = Equality | Order | Like;
|
114
|
+
type MultiValue = In;
|
115
|
+
}
|
116
|
+
type ApiFeature = 'select' | 'where' | 'count' | 'orderBy' | 'offset' | 'limit' | 'first' | 'row' | 'insert' | 'update' | 'delete' | 'returning' | 'onConflict';
|
117
|
+
type WhereParams<TTableDef extends TableDefBase> = Partial<{
|
118
|
+
[K in keyof TTableDef['sqliteDef']['columns']]: TTableDef['sqliteDef']['columns'][K]['schema']['Type'] | {
|
119
|
+
op: QueryBuilder.WhereOps.SingleValue;
|
120
|
+
value: TTableDef['sqliteDef']['columns'][K]['schema']['Type'];
|
121
|
+
} | {
|
122
|
+
op: QueryBuilder.WhereOps.MultiValue;
|
123
|
+
value: ReadonlyArray<TTableDef['sqliteDef']['columns'][K]['schema']['Type']>;
|
124
|
+
} | undefined;
|
125
|
+
}>;
|
126
|
+
type OrderByParams<TTableDef extends TableDefBase> = ReadonlyArray<{
|
127
|
+
col: keyof TTableDef['sqliteDef']['columns'] & string;
|
128
|
+
direction: 'asc' | 'desc';
|
129
|
+
}>;
|
130
|
+
type ApiFull<TResult, TTableDef extends TableDefBase, TWithout extends ApiFeature> = {
|
131
|
+
/**
|
132
|
+
* `SELECT *` is the default
|
133
|
+
*
|
134
|
+
* Example:
|
135
|
+
* ```ts
|
136
|
+
* db.todos.select('id', 'text', 'completed')
|
137
|
+
* db.todos.select('id')
|
138
|
+
* ```
|
139
|
+
*/
|
140
|
+
readonly select: {
|
141
|
+
/** Selects and plucks a single column */
|
142
|
+
<TColumn extends keyof TTableDef['sqliteDef']['columns'] & string>(pluckColumn: TColumn): QueryBuilder<ReadonlyArray<TTableDef['sqliteDef']['columns'][TColumn]['schema']['Type']>, TTableDef, TWithout | 'row' | 'select' | 'returning' | 'onConflict'>;
|
143
|
+
/** Select multiple columns */
|
144
|
+
<TColumns extends keyof TTableDef['sqliteDef']['columns'] & string>(...columns: TColumns[]): QueryBuilder<ReadonlyArray<{
|
145
|
+
readonly [K in TColumns]: TTableDef['sqliteDef']['columns'][K]['schema']['Type'];
|
146
|
+
}>, TTableDef, TWithout | 'row' | 'select' | 'count' | 'returning' | 'onConflict'>;
|
147
|
+
};
|
148
|
+
/**
|
149
|
+
* Notes:
|
150
|
+
* - All where clauses are `AND`ed together by default.
|
151
|
+
* - `null` values only support `=` and `!=` which is translated to `IS NULL` and `IS NOT NULL`.
|
152
|
+
*
|
153
|
+
* Example:
|
154
|
+
* ```ts
|
155
|
+
* db.todos.where('completed', true)
|
156
|
+
* db.todos.where('completed', '!=', true)
|
157
|
+
* db.todos.where({ completed: true })
|
158
|
+
* db.todos.where({ completed: { op: '!=', value: true } })
|
159
|
+
* ```
|
160
|
+
*
|
161
|
+
* TODO: Also support `OR`
|
162
|
+
*/
|
163
|
+
readonly where: {
|
164
|
+
(params: QueryBuilder.WhereParams<TTableDef>): QueryBuilder<TResult, TTableDef, TWithout | 'row' | 'select'>;
|
165
|
+
<TColName extends keyof TTableDef['sqliteDef']['columns']>(col: TColName, value: TTableDef['sqliteDef']['columns'][TColName]['schema']['Type']): QueryBuilder<TResult, TTableDef, TWithout | 'row' | 'select'>;
|
166
|
+
<TColName extends keyof TTableDef['sqliteDef']['columns']>(col: TColName, op: QueryBuilder.WhereOps, value: TTableDef['sqliteDef']['columns'][TColName]['schema']['Type']): QueryBuilder<TResult, TTableDef, TWithout | 'row' | 'select'>;
|
167
|
+
};
|
168
|
+
/**
|
169
|
+
* Example:
|
170
|
+
* ```ts
|
171
|
+
* db.todos.count()
|
172
|
+
* db.todos.count().where('completed', true)
|
173
|
+
* ```
|
174
|
+
*/
|
175
|
+
readonly count: () => QueryBuilder<number, TTableDef, TWithout | 'row' | 'count' | 'select' | 'orderBy' | 'first' | 'offset' | 'limit' | 'returning' | 'onConflict'>;
|
176
|
+
/**
|
177
|
+
* Example:
|
178
|
+
* ```ts
|
179
|
+
* db.todos.orderBy('createdAt', 'desc')
|
180
|
+
* ```
|
181
|
+
*/
|
182
|
+
readonly orderBy: {
|
183
|
+
<TColName extends keyof TTableDef['sqliteDef']['columns'] & string>(col: TColName, direction: 'asc' | 'desc'): QueryBuilder<TResult, TTableDef, TWithout | 'returning' | 'onConflict'>;
|
184
|
+
<TParams extends QueryBuilder.OrderByParams<TTableDef>>(params: TParams): QueryBuilder<TResult, TTableDef, TWithout | 'returning' | 'onConflict'>;
|
185
|
+
};
|
186
|
+
/**
|
187
|
+
* Example:
|
188
|
+
* ```ts
|
189
|
+
* db.todos.offset(10)
|
190
|
+
* ```
|
191
|
+
*/
|
192
|
+
readonly offset: (offset: number) => QueryBuilder<TResult, TTableDef, TWithout | 'row' | 'offset' | 'orderBy' | 'returning' | 'onConflict'>;
|
193
|
+
/**
|
194
|
+
* Example:
|
195
|
+
* ```ts
|
196
|
+
* db.todos.limit(10)
|
197
|
+
* ```
|
198
|
+
*/
|
199
|
+
readonly limit: (limit: number) => QueryBuilder<TResult, TTableDef, TWithout | 'row' | 'limit' | 'offset' | 'first' | 'orderBy' | 'returning' | 'onConflict'>;
|
200
|
+
/**
|
201
|
+
* Example:
|
202
|
+
* ```ts
|
203
|
+
* db.todos.first()
|
204
|
+
* db.todos.where('id', '123').first()
|
205
|
+
* ```
|
206
|
+
*
|
207
|
+
* Query will fail if no rows are returned and no fallback is provided.
|
208
|
+
*/
|
209
|
+
readonly first: <TFallback = never>(options?: {
|
210
|
+
fallback?: () => TFallback | GetSingle<TResult>;
|
211
|
+
}) => QueryBuilder<TFallback | GetSingle<TResult>, TTableDef, TWithout | 'row' | 'first' | 'orderBy' | 'select' | 'limit' | 'offset' | 'where' | 'returning' | 'onConflict'>;
|
212
|
+
/**
|
213
|
+
* Insert a new row into the table
|
214
|
+
*
|
215
|
+
* Example:
|
216
|
+
* ```ts
|
217
|
+
* db.todos.insert({ id: '123', text: 'Buy milk', status: 'active' })
|
218
|
+
* ```
|
219
|
+
*/
|
220
|
+
readonly insert: (values: TTableDef['insertSchema']['Type']) => QueryBuilder<TResult, TTableDef, TWithout | 'row' | 'select' | 'count' | 'orderBy' | 'first' | 'offset' | 'limit' | 'where'>;
|
221
|
+
/**
|
222
|
+
* Example: If the row already exists, it will be ignored.
|
223
|
+
* ```ts
|
224
|
+
* db.todos.insert({ id: '123', text: 'Buy milk', status: 'active' }).onConflict('id', 'ignore')
|
225
|
+
* ```
|
226
|
+
*
|
227
|
+
* Example: If the row already exists, it will be replaced.
|
228
|
+
* ```ts
|
229
|
+
* db.todos.insert({ id: '123', text: 'Buy milk', status: 'active' }).onConflict('id', 'replace')
|
230
|
+
* ```
|
231
|
+
*
|
232
|
+
* Example: If the row already exists, it will be updated.
|
233
|
+
* ```ts
|
234
|
+
* db.todos.insert({ id: '123', text: 'Buy milk', status: 'active' }).onConflict('id', 'update', { text: 'Buy soy milk' })
|
235
|
+
* ```
|
236
|
+
*
|
237
|
+
* NOTE This API doesn't yet support composite primary keys.
|
238
|
+
*/
|
239
|
+
readonly onConflict: {
|
240
|
+
<TTarget extends SingleOrReadonlyArray<keyof TTableDef['sqliteDef']['columns']>>(target: TTarget, action: 'ignore' | 'replace'): QueryBuilder<TResult, TTableDef, TWithout | 'row' | 'select' | 'count' | 'orderBy' | 'first' | 'offset' | 'limit' | 'where'>;
|
241
|
+
<TTarget extends SingleOrReadonlyArray<keyof TTableDef['sqliteDef']['columns']>>(target: TTarget, action: 'update', updateValues: Partial<TTableDef['rowSchema']['Type']>): QueryBuilder<TResult, TTableDef, TWithout | 'row' | 'select' | 'count' | 'orderBy' | 'first' | 'offset' | 'limit' | 'where'>;
|
242
|
+
};
|
243
|
+
/**
|
244
|
+
* Similar to the `.select` API but for write queries (insert, update, delete).
|
245
|
+
*
|
246
|
+
* Example:
|
247
|
+
* ```ts
|
248
|
+
* db.todos.insert({ id: '123', text: 'Buy milk', status: 'active' }).returning('id')
|
249
|
+
* ```
|
250
|
+
*/
|
251
|
+
readonly returning: <TColumns extends keyof TTableDef['sqliteDef']['columns'] & string>(...columns: TColumns[]) => QueryBuilder<ReadonlyArray<{
|
252
|
+
readonly [K in TColumns]: TTableDef['sqliteDef']['columns'][K]['schema']['Type'];
|
253
|
+
}>, TTableDef>;
|
254
|
+
/**
|
255
|
+
* Update rows in the table that match the where clause
|
256
|
+
*
|
257
|
+
* Example:
|
258
|
+
* ```ts
|
259
|
+
* db.todos.update({ status: 'completed' }).where({ id: '123' })
|
260
|
+
* ```
|
261
|
+
*/
|
262
|
+
readonly update: (values: Partial<TTableDef['rowSchema']['Type']>) => QueryBuilder<TResult, TTableDef, TWithout | 'row' | 'select' | 'count' | 'orderBy' | 'first' | 'offset' | 'limit' | 'onConflict'>;
|
263
|
+
/**
|
264
|
+
* Delete rows from the table that match the where clause
|
265
|
+
*
|
266
|
+
* Example:
|
267
|
+
* ```ts
|
268
|
+
* db.todos.delete().where({ status: 'completed' })
|
269
|
+
* ```
|
270
|
+
*
|
271
|
+
* Note that it's generally recommended to do soft-deletes for synced apps.
|
272
|
+
*/
|
273
|
+
readonly delete: () => QueryBuilder<TResult, TTableDef, TWithout | 'row' | 'select' | 'count' | 'orderBy' | 'first' | 'offset' | 'limit' | 'onConflict'>;
|
274
|
+
};
|
275
|
+
}
|
276
|
+
export declare namespace RowQuery {
|
277
|
+
type GetOrCreateOptions<TTableDef extends ClientDocumentTableDef.TraitAny> = {
|
278
|
+
default: Partial<TTableDef['Value']>;
|
279
|
+
};
|
280
|
+
type RequiredColumnsOptions<TTableDef extends TableDefBase> = {
|
281
|
+
/**
|
282
|
+
* Values to be inserted into the row if it doesn't exist yet
|
283
|
+
*/
|
284
|
+
explicitDefaultValues: Pick<SqliteDsl.FromColumns.RowDecodedAll<TTableDef['sqliteDef']['columns']>, SqliteDsl.FromColumns.RequiredInsertColumnNames<Omit<TTableDef['sqliteDef']['columns'], 'id'>>>;
|
285
|
+
};
|
286
|
+
type Result<TTableDef extends TableDefBase> = SqliteDsl.FromColumns.RowDecoded<TTableDef['sqliteDef']['columns']>;
|
287
|
+
type DocumentResult<TTableDef extends ClientDocumentTableDef.Any> = GetValForKey<SqliteDsl.FromColumns.RowDecoded<TTableDef['sqliteDef']['columns']>, 'value'>;
|
288
|
+
type ResultEncoded<TTableDef extends TableDefBase> = TTableDef['options']['isClientDocumentTable'] extends true ? GetValForKey<SqliteDsl.FromColumns.RowEncoded<TTableDef['sqliteDef']['columns']>, 'value'> : SqliteDsl.FromColumns.RowEncoded<TTableDef['sqliteDef']['columns']>;
|
289
|
+
type GetIdColumnType<TTableDef extends TableDefBase> = TTableDef['sqliteDef']['columns']['id']['schema']['Type'];
|
290
|
+
}
|
291
|
+
type GetSingle<T> = T extends ReadonlyArray<infer U> ? U : never;
|
292
|
+
export {};
|
293
|
+
//# sourceMappingURL=api.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../../../../src/schema/state/sqlite/query-builder/api.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import { Predicate } from '@livestore/utils/effect';
|
2
|
+
export const QueryBuilderAstSymbol = Symbol.for('QueryBuilderAst');
|
3
|
+
export const QueryBuilderResultSymbol = Symbol.for('QueryBuilderResult');
|
4
|
+
export const QueryBuilderTypeId = Symbol.for('QueryBuilder');
|
5
|
+
export const isQueryBuilder = (value) => Predicate.hasProperty(value, QueryBuilderTypeId);
|
6
|
+
//# sourceMappingURL=api.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../../src/schema/state/sqlite/query-builder/api.ts"],"names":[],"mappings":"AACA,OAAO,EAAe,SAAS,EAAe,MAAM,yBAAyB,CAAA;AAkG7E,MAAM,CAAC,MAAM,qBAAqB,GAAG,MAAM,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAA;AAGlE,MAAM,CAAC,MAAM,wBAAwB,GAAG,MAAM,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAA;AAGxE,MAAM,CAAC,MAAM,kBAAkB,GAAG,MAAM,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA;AAG5D,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAAc,EAAwC,EAAE,CACrF,SAAS,CAAC,WAAW,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAA"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"astToSql.d.ts","sourceRoot":"","sources":["../../../../../src/schema/state/sqlite/query-builder/astToSql.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAEnD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AA6D/C,eAAO,MAAM,QAAQ,GAAI,KAAK,eAAe,KAAG;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,UAAU,EAAE,QAAQ,EAAE,CAAA;CAoKtF,CAAA"}
|