@squidcloud/client 1.0.89 → 1.0.91

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.
Files changed (103) hide show
  1. package/dist/cjs/index.js +5 -5
  2. package/dist/common/src/ai-assistant.context.d.ts +12 -12
  3. package/dist/common/src/ai-assistant.schemas.d.ts +1 -1
  4. package/dist/common/src/ai-assistant.types.d.ts +12 -12
  5. package/dist/common/src/api-call.context.d.ts +13 -13
  6. package/dist/common/src/api.types.d.ts +4 -4
  7. package/dist/common/src/application.schemas.d.ts +1 -1
  8. package/dist/common/src/application.types.d.ts +184 -184
  9. package/dist/common/src/backend-function.schemas.d.ts +1 -1
  10. package/dist/common/src/backend-function.types.d.ts +1 -1
  11. package/dist/common/src/backend-run.types.d.ts +2 -2
  12. package/dist/common/src/bundle-api.types.d.ts +36 -35
  13. package/dist/common/src/bundle-data.types.d.ts +4 -4
  14. package/dist/common/src/communication.types.d.ts +12 -12
  15. package/dist/common/src/context.types.d.ts +40 -40
  16. package/dist/common/src/distributed-lock.context.d.ts +5 -5
  17. package/dist/common/src/document.types.d.ts +22 -22
  18. package/dist/common/src/graphql.context.d.ts +7 -7
  19. package/dist/common/src/graphql.types.d.ts +9 -9
  20. package/dist/common/src/heartbeat.types.d.ts +1 -1
  21. package/dist/common/src/http-status.enum.d.ts +50 -50
  22. package/dist/common/src/index.d.ts +53 -53
  23. package/dist/common/src/integrations/ai_assistant.types.d.ts +30 -30
  24. package/dist/common/src/integrations/api.types.d.ts +80 -80
  25. package/dist/common/src/integrations/auth.types.d.ts +39 -39
  26. package/dist/common/src/integrations/database.types.d.ts +236 -236
  27. package/dist/common/src/integrations/index.d.ts +101 -101
  28. package/dist/common/src/integrations/observability.types.d.ts +23 -23
  29. package/dist/common/src/logger.types.d.ts +21 -21
  30. package/dist/common/src/metrics.types.d.ts +1 -1
  31. package/dist/common/src/mutation.context.d.ts +14 -14
  32. package/dist/common/src/mutation.schemas.d.ts +1 -1
  33. package/dist/common/src/mutation.types.d.ts +53 -53
  34. package/dist/common/src/named-query.context.d.ts +4 -4
  35. package/dist/common/src/named-query.schemas.d.ts +1 -1
  36. package/dist/common/src/named-query.types.d.ts +1 -1
  37. package/dist/common/src/query/base-query-builder.d.ts +188 -188
  38. package/dist/common/src/query/index.d.ts +3 -3
  39. package/dist/common/src/query/query-context.d.ts +137 -137
  40. package/dist/common/src/query/serialized-query.types.d.ts +24 -24
  41. package/dist/common/src/query.types.d.ts +59 -59
  42. package/dist/common/src/regions.d.ts +1 -1
  43. package/dist/common/src/schema/schema.types.d.ts +54 -54
  44. package/dist/common/src/secret.schemas.d.ts +1 -1
  45. package/dist/common/src/secret.types.d.ts +8 -8
  46. package/dist/common/src/security.types.d.ts +1 -1
  47. package/dist/common/src/socket.schemas.d.ts +1 -1
  48. package/dist/common/src/socket.types.d.ts +1 -1
  49. package/dist/common/src/time-units.d.ts +1 -1
  50. package/dist/common/src/trigger.types.d.ts +1 -1
  51. package/dist/common/src/types.d.ts +14 -14
  52. package/dist/common/src/utils/array.d.ts +1 -1
  53. package/dist/common/src/utils/assert.d.ts +1 -1
  54. package/dist/common/src/utils/error.d.ts +4 -4
  55. package/dist/common/src/utils/http.d.ts +2 -2
  56. package/dist/common/src/utils/id.d.ts +2 -2
  57. package/dist/common/src/utils/lock.manager.d.ts +14 -14
  58. package/dist/common/src/utils/nullish.d.ts +2 -2
  59. package/dist/common/src/utils/object.d.ts +5 -6
  60. package/dist/common/src/utils/serialization.d.ts +6 -6
  61. package/dist/common/src/utils/transforms.d.ts +18 -18
  62. package/dist/common/src/utils/url.d.ts +1 -1
  63. package/dist/common/src/utils/validation.d.ts +30 -30
  64. package/dist/common/src/webhook-response.d.ts +1 -1
  65. package/dist/esm/index.js +5 -5
  66. package/dist/node_modules/json-schema-typed/draft-2020-12.d.ts +1239 -1239
  67. package/dist/typescript-client/src/ai-assistant-client.d.ts +167 -167
  68. package/dist/typescript-client/src/ai-client.factory.d.ts +11 -11
  69. package/dist/typescript-client/src/api.manager.d.ts +15 -15
  70. package/dist/typescript-client/src/auth.manager.d.ts +23 -23
  71. package/dist/typescript-client/src/backend-function.manager.d.ts +13 -13
  72. package/dist/typescript-client/src/client-id.service.d.ts +25 -25
  73. package/dist/typescript-client/src/collection-reference.d.ts +81 -81
  74. package/dist/typescript-client/src/collection-reference.factory.d.ts +13 -13
  75. package/dist/typescript-client/src/connection-details.d.ts +23 -23
  76. package/dist/typescript-client/src/data.manager.d.ts +172 -172
  77. package/dist/typescript-client/src/destruct.manager.d.ts +12 -12
  78. package/dist/typescript-client/src/distributed-lock.manager.d.ts +19 -19
  79. package/dist/typescript-client/src/document-identity.service.d.ts +12 -12
  80. package/dist/typescript-client/src/document-reference.d.ts +134 -134
  81. package/dist/typescript-client/src/document-reference.factory.d.ts +13 -12
  82. package/dist/typescript-client/src/document-store.d.ts +11 -11
  83. package/dist/typescript-client/src/graphql-client.d.ts +14 -12
  84. package/dist/typescript-client/src/graphql-client.factory.d.ts +11 -9
  85. package/dist/typescript-client/src/index.d.ts +8 -8
  86. package/dist/typescript-client/src/mutation/mutation-sender.d.ts +10 -10
  87. package/dist/typescript-client/src/named-query.manager.d.ts +12 -12
  88. package/dist/typescript-client/src/query/deserializer.d.ts +3 -3
  89. package/dist/typescript-client/src/query/join-query-builder.factory.d.ts +149 -149
  90. package/dist/typescript-client/src/query/local-query-manager.d.ts +9 -0
  91. package/dist/typescript-client/src/query/query-builder.factory.d.ts +80 -71
  92. package/dist/typescript-client/src/query/query-subscription.manager.d.ts +170 -134
  93. package/dist/typescript-client/src/rpc.manager.d.ts +29 -28
  94. package/dist/typescript-client/src/socket.manager.d.ts +33 -32
  95. package/dist/typescript-client/src/squid.d.ts +218 -217
  96. package/dist/typescript-client/src/state/action.applier.d.ts +7 -7
  97. package/dist/typescript-client/src/state/actions.d.ts +29 -29
  98. package/dist/typescript-client/src/state/path_trie.d.ts +27 -27
  99. package/dist/typescript-client/src/state/state.service.d.ts +22 -22
  100. package/dist/typescript-client/src/state/state.service.spec.d.ts +1 -1
  101. package/dist/typescript-client/src/testing/setup-tests.d.ts +1 -1
  102. package/dist/typescript-client/src/types.d.ts +2 -2
  103. package/package.json +1 -1
@@ -1,149 +1,149 @@
1
- import { Alias, BaseQueryBuilder, DocumentData, FieldName, FieldSort, HasDereference, Operator, Pagination, PaginationOptions, PrimitiveFieldType, SerializedJoinQuery, SimpleCondition, SnapshotEmitter } from '@squidcloud/common';
2
- import { Observable } from 'rxjs';
3
- import { DocumentReference } from '../document-reference';
4
- import { QueryBuilder } from './query-builder.factory';
5
- type WithDocumentReferences<T extends Record<any, DocumentData>> = {
6
- [k in keyof T]: DocumentReference<Required<T>[k]>;
7
- };
8
- type Grouped<Aliases extends Record<Alias, Alias[]>, ReturnType extends Record<Alias, any>, RootAlias extends Alias> = Aliases[RootAlias] extends [] ? Required<ReturnType>[RootAlias] : Record<RootAlias, Required<ReturnType>[RootAlias]> & OtherGroups<Aliases, ReturnType, Aliases[RootAlias]>;
9
- type OtherGroups<Aliases extends Record<Alias, Alias[]>, ReturnType extends Record<Alias, any>, ManyRootAliases extends Alias[]> = ManyRootAliases extends [infer First extends Alias, ...infer Rest extends Alias[]] ? Record<First, Array<Grouped<Aliases, ReturnType, First>>> & OtherGroups<Aliases, ReturnType, Rest> : Record<Alias, never>;
10
- interface HasGrouped {
11
- /**
12
- * Transforms this join query result to a nested data structure. For example, a join between teachers and students
13
- * normally returns a result of the form:
14
- * [
15
- * { teacher: {name: 'Mr. Smith'}, student: {name: 'John Doe'} },
16
- * { teacher: {name: 'Mr. Smith'}, student: {name: 'Jane Smith'} },
17
- * { teacher: {name: 'Mr. EmptyClass'}, student: undefined },
18
- * ]
19
- * into a result of the form:
20
- * [
21
- * { teacher: {name: 'Mr. Smith'}, students: [
22
- * { name: 'John Doe' },
23
- * { name: 'Jane Smith' },
24
- * ]},
25
- * { teacher: {name: 'Mr. EmptyClass'}, students: [] },
26
- * ]
27
- */
28
- grouped(): any;
29
- }
30
- /**
31
- * A query builder that can participate in a join.
32
- * To learn more about join queries, see
33
- * {@link https://docs.squid.cloud/docs/client-sdk/queries#joining-data-across-collections-and-integrations}.
34
- */
35
- export declare class JoinQueryBuilder<Aliases extends Record<Alias, Alias[]>, ReturnType extends Record<Alias, DocumentData>, LatestAlias extends Alias, RootAlias extends Alias> extends BaseQueryBuilder<ReturnType> implements SnapshotEmitter<WithDocumentReferences<ReturnType>>, HasGrouped, HasDereference {
36
- private readonly collectionName;
37
- private readonly integrationId;
38
- private readonly querySubscriptionManager;
39
- private readonly documentReferenceFactory;
40
- private readonly queryBuilderFactory;
41
- private readonly latestAlias;
42
- private readonly joins;
43
- private readonly joinConditions;
44
- private readonly queryBuilder;
45
- /**
46
- * Adds a condition to the query.
47
- *
48
- * @param fieldName The name of the field to query
49
- * @param operator The operator to use
50
- * @param value The value to compare against
51
- * @returns The query builder
52
- */
53
- where(fieldName: (keyof ReturnType[LatestAlias] & FieldName) | string, operator: Operator | 'in' | 'not in', value: PrimitiveFieldType | Array<PrimitiveFieldType>): this;
54
- /**
55
- * Sets a limit to the number of results returned by the query. The maximum limit is 20,000 and the default is 1,000
56
- * if none is provided.
57
- *
58
- * @param limit The maximum number of results to return
59
- * @returns The query builder
60
- */
61
- limit(limit: number): this;
62
- getLimit(): number;
63
- /**
64
- * Adds a sort order to the query. You can add multiple sort orders to the query. The order in which you add them
65
- * determines the order in which they are applied.
66
- * @param fieldName The name of the field to sort by
67
- * @param asc Whether to sort in ascending order. Defaults to true.
68
- * @returns The query builder
69
- */
70
- sortBy(fieldName: keyof ReturnType[RootAlias] & FieldName, asc?: boolean): this;
71
- /**
72
- * Joins this query with another join query and return a new query builder that can be used to query the joined
73
- * documents.
74
- * @param queryBuilder The query builder to join with
75
- * @param alias TODO
76
- * @param joinFields TODO
77
- * @param options TODO
78
- * @returns A new query builder that can be used to query the joined documents
79
- */
80
- join<NewAlias extends string, NewReturnType extends DocumentData, LeftAlias extends Extract<keyof ReturnType, Alias>, IsInner extends boolean = false>(queryBuilder: QueryBuilder<NewReturnType>, alias: Exclude<NewAlias, keyof ReturnType>, joinFields: {
81
- left: keyof Required<ReturnType>[LeftAlias] & FieldName;
82
- right: keyof NewReturnType & FieldName;
83
- }, options: {
84
- leftAlias: LeftAlias;
85
- isInner?: IsInner;
86
- }): JoinQueryBuilder<Omit<Aliases, LeftAlias> & Record<LeftAlias, [...Aliases[LeftAlias], NewAlias]> & Record<NewAlias, []>, ReturnType & (IsInner extends true ? Record<NewAlias, NewReturnType> : Partial<Record<NewAlias, NewReturnType>>), NewAlias, RootAlias>;
87
- join<NewAlias extends string, NewReturnType extends DocumentData, IsInner extends boolean = false>(queryBuilder: QueryBuilder<NewReturnType>, alias: Exclude<NewAlias, keyof ReturnType>, joinFields: {
88
- left: keyof Required<ReturnType>[LatestAlias] & FieldName;
89
- right: keyof NewReturnType & FieldName;
90
- }, options?: {
91
- isInner?: IsInner;
92
- }): JoinQueryBuilder<Omit<Aliases, LatestAlias> & Record<LatestAlias, [...Aliases[LatestAlias], NewAlias]> & Record<NewAlias, []>, ReturnType & (IsInner extends true ? Record<NewAlias, NewReturnType> : Partial<Record<NewAlias, NewReturnType>>), NewAlias, RootAlias>;
93
- /** @inheritDoc */
94
- snapshot(): Promise<Array<WithDocumentReferences<ReturnType>>>;
95
- /** @inheritDoc */
96
- snapshots(subscribe?: boolean): Observable<Array<WithDocumentReferences<ReturnType>>>;
97
- /** @inheritDoc */
98
- grouped(): GroupedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
99
- /** @inheritDoc */
100
- dereference(): DereferencedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
101
- getSortOrders(): Array<FieldSort<any>>;
102
- clone(): JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>;
103
- addCompositeCondition(conditions: Array<SimpleCondition>): JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>;
104
- flipSortOrder(): JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>;
105
- extractData(data: WithDocumentReferences<ReturnType>): any;
106
- serialize(): SerializedJoinQuery;
107
- paginate(options?: Partial<PaginationOptions>): Pagination<WithDocumentReferences<ReturnType>>;
108
- }
109
- declare class DereferencedJoin<Aliases extends Record<Alias, Alias[]>, ReturnType extends Record<Alias, DocumentData>, RootAlias extends Alias, LatestAlias extends Alias> implements SnapshotEmitter<ReturnType>, HasGrouped {
110
- private readonly joinQueryBuilder;
111
- constructor(joinQueryBuilder: JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>);
112
- /** @inheritDoc */
113
- grouped(): SnapshotEmitter<Grouped<Aliases, ReturnType, RootAlias>>;
114
- /** @inheritDoc */
115
- snapshot(): Promise<Array<ReturnType>>;
116
- /** @inheritDoc */
117
- snapshots(subscribe?: boolean): Observable<Array<ReturnType>>;
118
- getSortOrders(): Array<FieldSort<any>>;
119
- clone(): DereferencedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
120
- addCompositeCondition(conditions: Array<SimpleCondition>): DereferencedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
121
- flipSortOrder(): DereferencedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
122
- limit(limit: number): DereferencedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
123
- extractData(data: ReturnType): any;
124
- paginate(options?: Partial<PaginationOptions>): Pagination<ReturnType>;
125
- serialize(): SerializedJoinQuery;
126
- getLimit(): number;
127
- }
128
- declare class GroupedJoin<Aliases extends Record<Alias, Alias[]>, ReturnType extends Record<Alias, DocumentData>, RootAlias extends Alias, LatestAlias extends Alias> implements SnapshotEmitter<Grouped<Aliases, WithDocumentReferences<ReturnType>, RootAlias>>, HasDereference {
129
- readonly joinQueryBuilder: JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>;
130
- /** internal */
131
- constructor(joinQueryBuilder: JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>);
132
- /** @inheritDoc */
133
- snapshot(): Promise<Array<Grouped<Aliases, WithDocumentReferences<ReturnType>, RootAlias>>>;
134
- /** @inheritDoc */
135
- snapshots(subscribe?: boolean): Observable<Array<Grouped<Aliases, WithDocumentReferences<ReturnType>, RootAlias>>>;
136
- /** @inheritDoc */
137
- dereference(): SnapshotEmitter<Grouped<Aliases, ReturnType, RootAlias>>;
138
- private groupData;
139
- getSortOrders(): Array<FieldSort<any>>;
140
- clone(): GroupedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
141
- addCompositeCondition(conditions: Array<SimpleCondition>): GroupedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
142
- flipSortOrder(): GroupedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
143
- limit(limit: number): GroupedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
144
- getLimit(): number;
145
- extractData(data: Grouped<Aliases, WithDocumentReferences<ReturnType>, RootAlias>): any;
146
- serialize(): SerializedJoinQuery;
147
- paginate(options?: Partial<PaginationOptions>): Pagination<Grouped<Aliases, WithDocumentReferences<ReturnType>, RootAlias>>;
148
- }
149
- export {};
1
+ import { Alias, BaseQueryBuilder, DocumentData, FieldName, FieldSort, HasDereference, Operator, Pagination, PaginationOptions, PrimitiveFieldType, SerializedJoinQuery, SimpleCondition, SnapshotEmitter } from '@squidcloud/common';
2
+ import { Observable } from 'rxjs';
3
+ import { DocumentReference } from '../document-reference';
4
+ import { QueryBuilder } from './query-builder.factory';
5
+ type WithDocumentReferences<T extends Record<any, DocumentData>> = {
6
+ [k in keyof T]: DocumentReference<Required<T>[k]>;
7
+ };
8
+ type Grouped<Aliases extends Record<Alias, Alias[]>, ReturnType extends Record<Alias, any>, RootAlias extends Alias> = Aliases[RootAlias] extends [] ? Required<ReturnType>[RootAlias] : Record<RootAlias, Required<ReturnType>[RootAlias]> & OtherGroups<Aliases, ReturnType, Aliases[RootAlias]>;
9
+ type OtherGroups<Aliases extends Record<Alias, Alias[]>, ReturnType extends Record<Alias, any>, ManyRootAliases extends Alias[]> = ManyRootAliases extends [infer First extends Alias, ...infer Rest extends Alias[]] ? Record<First, Array<Grouped<Aliases, ReturnType, First>>> & OtherGroups<Aliases, ReturnType, Rest> : Record<Alias, never>;
10
+ interface HasGrouped {
11
+ /**
12
+ * Transforms this join query result to a nested data structure. For example, a join between teachers and students
13
+ * normally returns a result of the form:
14
+ * [
15
+ * { teacher: {name: 'Mr. Smith'}, student: {name: 'John Doe'} },
16
+ * { teacher: {name: 'Mr. Smith'}, student: {name: 'Jane Smith'} },
17
+ * { teacher: {name: 'Mr. EmptyClass'}, student: undefined },
18
+ * ]
19
+ * into a result of the form:
20
+ * [
21
+ * { teacher: {name: 'Mr. Smith'}, students: [
22
+ * { name: 'John Doe' },
23
+ * { name: 'Jane Smith' },
24
+ * ]},
25
+ * { teacher: {name: 'Mr. EmptyClass'}, students: [] },
26
+ * ]
27
+ */
28
+ grouped(): any;
29
+ }
30
+ /**
31
+ * A query builder that can participate in a join.
32
+ * To learn more about join queries, see
33
+ * {@link https://docs.squid.cloud/docs/client-sdk/queries#joining-data-across-collections-and-integrations}.
34
+ */
35
+ export declare class JoinQueryBuilder<Aliases extends Record<Alias, Alias[]>, ReturnType extends Record<Alias, DocumentData>, LatestAlias extends Alias, RootAlias extends Alias> extends BaseQueryBuilder<ReturnType> implements SnapshotEmitter<WithDocumentReferences<ReturnType>>, HasGrouped, HasDereference {
36
+ private readonly collectionName;
37
+ private readonly integrationId;
38
+ private readonly querySubscriptionManager;
39
+ private readonly documentReferenceFactory;
40
+ private readonly queryBuilderFactory;
41
+ private readonly latestAlias;
42
+ private readonly joins;
43
+ private readonly joinConditions;
44
+ private readonly queryBuilder;
45
+ /**
46
+ * Adds a condition to the query.
47
+ *
48
+ * @param fieldName The name of the field to query
49
+ * @param operator The operator to use
50
+ * @param value The value to compare against
51
+ * @returns The query builder
52
+ */
53
+ where(fieldName: (keyof ReturnType[LatestAlias] & FieldName) | string, operator: Operator | 'in' | 'not in', value: PrimitiveFieldType | Array<PrimitiveFieldType>): this;
54
+ /**
55
+ * Sets a limit to the number of results returned by the query. The maximum limit is 20,000 and the default is 1,000
56
+ * if none is provided.
57
+ *
58
+ * @param limit The maximum number of results to return
59
+ * @returns The query builder
60
+ */
61
+ limit(limit: number): this;
62
+ getLimit(): number;
63
+ /**
64
+ * Adds a sort order to the query. You can add multiple sort orders to the query. The order in which you add them
65
+ * determines the order in which they are applied.
66
+ * @param fieldName The name of the field to sort by
67
+ * @param asc Whether to sort in ascending order. Defaults to true.
68
+ * @returns The query builder
69
+ */
70
+ sortBy(fieldName: keyof ReturnType[RootAlias] & FieldName, asc?: boolean): this;
71
+ /**
72
+ * Joins this query with another join query and return a new query builder that can be used to query the joined
73
+ * documents.
74
+ * @param queryBuilder The query builder to join with
75
+ * @param alias TODO
76
+ * @param joinFields TODO
77
+ * @param options TODO
78
+ * @returns A new query builder that can be used to query the joined documents
79
+ */
80
+ join<NewAlias extends string, NewReturnType extends DocumentData, LeftAlias extends Extract<keyof ReturnType, Alias>, IsInner extends boolean = false>(queryBuilder: QueryBuilder<NewReturnType>, alias: Exclude<NewAlias, keyof ReturnType>, joinFields: {
81
+ left: keyof Required<ReturnType>[LeftAlias] & FieldName;
82
+ right: keyof NewReturnType & FieldName;
83
+ }, options: {
84
+ leftAlias: LeftAlias;
85
+ isInner?: IsInner;
86
+ }): JoinQueryBuilder<Omit<Aliases, LeftAlias> & Record<LeftAlias, [...Aliases[LeftAlias], NewAlias]> & Record<NewAlias, []>, ReturnType & (IsInner extends true ? Record<NewAlias, NewReturnType> : Partial<Record<NewAlias, NewReturnType>>), NewAlias, RootAlias>;
87
+ join<NewAlias extends string, NewReturnType extends DocumentData, IsInner extends boolean = false>(queryBuilder: QueryBuilder<NewReturnType>, alias: Exclude<NewAlias, keyof ReturnType>, joinFields: {
88
+ left: keyof Required<ReturnType>[LatestAlias] & FieldName;
89
+ right: keyof NewReturnType & FieldName;
90
+ }, options?: {
91
+ isInner?: IsInner;
92
+ }): JoinQueryBuilder<Omit<Aliases, LatestAlias> & Record<LatestAlias, [...Aliases[LatestAlias], NewAlias]> & Record<NewAlias, []>, ReturnType & (IsInner extends true ? Record<NewAlias, NewReturnType> : Partial<Record<NewAlias, NewReturnType>>), NewAlias, RootAlias>;
93
+ /** @inheritDoc */
94
+ snapshot(): Promise<Array<WithDocumentReferences<ReturnType>>>;
95
+ /** @inheritDoc */
96
+ snapshots(subscribe?: boolean): Observable<Array<WithDocumentReferences<ReturnType>>>;
97
+ /** @inheritDoc */
98
+ grouped(): GroupedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
99
+ /** @inheritDoc */
100
+ dereference(): DereferencedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
101
+ getSortOrders(): Array<FieldSort<any>>;
102
+ clone(): JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>;
103
+ addCompositeCondition(conditions: Array<SimpleCondition>): JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>;
104
+ flipSortOrder(): JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>;
105
+ extractData(data: WithDocumentReferences<ReturnType>): any;
106
+ serialize(): SerializedJoinQuery;
107
+ paginate(options?: Partial<PaginationOptions>): Pagination<WithDocumentReferences<ReturnType>>;
108
+ }
109
+ declare class DereferencedJoin<Aliases extends Record<Alias, Alias[]>, ReturnType extends Record<Alias, DocumentData>, RootAlias extends Alias, LatestAlias extends Alias> implements SnapshotEmitter<ReturnType>, HasGrouped {
110
+ private readonly joinQueryBuilder;
111
+ constructor(joinQueryBuilder: JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>);
112
+ /** @inheritDoc */
113
+ grouped(): SnapshotEmitter<Grouped<Aliases, ReturnType, RootAlias>>;
114
+ /** @inheritDoc */
115
+ snapshot(): Promise<Array<ReturnType>>;
116
+ /** @inheritDoc */
117
+ snapshots(subscribe?: boolean): Observable<Array<ReturnType>>;
118
+ getSortOrders(): Array<FieldSort<any>>;
119
+ clone(): DereferencedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
120
+ addCompositeCondition(conditions: Array<SimpleCondition>): DereferencedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
121
+ flipSortOrder(): DereferencedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
122
+ limit(limit: number): DereferencedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
123
+ extractData(data: ReturnType): any;
124
+ paginate(options?: Partial<PaginationOptions>): Pagination<ReturnType>;
125
+ serialize(): SerializedJoinQuery;
126
+ getLimit(): number;
127
+ }
128
+ declare class GroupedJoin<Aliases extends Record<Alias, Alias[]>, ReturnType extends Record<Alias, DocumentData>, RootAlias extends Alias, LatestAlias extends Alias> implements SnapshotEmitter<Grouped<Aliases, WithDocumentReferences<ReturnType>, RootAlias>>, HasDereference {
129
+ readonly joinQueryBuilder: JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>;
130
+ /** internal */
131
+ constructor(joinQueryBuilder: JoinQueryBuilder<Aliases, ReturnType, LatestAlias, RootAlias>);
132
+ /** @inheritDoc */
133
+ snapshot(): Promise<Array<Grouped<Aliases, WithDocumentReferences<ReturnType>, RootAlias>>>;
134
+ /** @inheritDoc */
135
+ snapshots(subscribe?: boolean): Observable<Array<Grouped<Aliases, WithDocumentReferences<ReturnType>, RootAlias>>>;
136
+ /** @inheritDoc */
137
+ dereference(): SnapshotEmitter<Grouped<Aliases, ReturnType, RootAlias>>;
138
+ private groupData;
139
+ getSortOrders(): Array<FieldSort<any>>;
140
+ clone(): GroupedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
141
+ addCompositeCondition(conditions: Array<SimpleCondition>): GroupedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
142
+ flipSortOrder(): GroupedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
143
+ limit(limit: number): GroupedJoin<Aliases, ReturnType, RootAlias, LatestAlias>;
144
+ getLimit(): number;
145
+ extractData(data: Grouped<Aliases, WithDocumentReferences<ReturnType>, RootAlias>): any;
146
+ serialize(): SerializedJoinQuery;
147
+ paginate(options?: Partial<PaginationOptions>): Pagination<Grouped<Aliases, WithDocumentReferences<ReturnType>, RootAlias>>;
148
+ }
149
+ export {};
@@ -0,0 +1,9 @@
1
+ import { DocumentReferenceFactory } from '../document-reference.factory';
2
+ import { DocumentStore } from '../document-store';
3
+ import { QuerySubscriptionManager } from './query-subscription.manager';
4
+ export declare class LocalQueryManager {
5
+ private readonly documentStore;
6
+ private readonly documentReferenceFactory;
7
+ private readonly querySubscriptionManager;
8
+ constructor(documentStore: DocumentStore, documentReferenceFactory: DocumentReferenceFactory, querySubscriptionManager: QuerySubscriptionManager);
9
+ }
@@ -1,71 +1,80 @@
1
- import { BaseQueryBuilder, DocumentData, FieldName, FieldSort, HasDereference, Operator, Pagination, PaginationOptions, PrimitiveFieldType, SerializedSimpleQuery, SimpleCondition, SnapshotEmitter } from '@squidcloud/common';
2
- import { Observable } from 'rxjs';
3
- import { DocumentReference } from '../document-reference';
4
- /** A query builder that can be used to build a query that returns a list of documents. */
5
- export declare class QueryBuilder<DocumentType extends DocumentData> extends BaseQueryBuilder<DocumentType> implements SnapshotEmitter<DocumentReference<DocumentType>>, HasDereference {
6
- private readonly collectionName;
7
- private readonly integrationId;
8
- private readonly querySubscriptionManager;
9
- private readonly documentReferenceFactory;
10
- private readonly queryBuilderFactory;
11
- private readonly documentIdentityService;
12
- private forceFetchFromServer;
13
- /** @inheritDoc */
14
- where(fieldName: (keyof DocumentType & FieldName) | string, operator: Operator | 'in' | 'not in', value: PrimitiveFieldType | Array<PrimitiveFieldType>): this;
15
- /** @inheritDoc */
16
- limit(limit: number): this;
17
- getLimit(): number;
18
- /** @inheritDoc */
19
- sortBy(fieldName: keyof DocumentType & FieldName, asc?: boolean): this;
20
- private mergeConditions;
21
- getSortOrder(): FieldSort<DocumentType>[];
22
- /**
23
- * @inheritDoc
24
- */
25
- snapshot(): Promise<Array<DocumentReference<DocumentType>>>;
26
- /**
27
- * Forces the query to return data from the server even if there is a query that already returned the requested
28
- * result.
29
- */
30
- setForceFetchFromServer(): this;
31
- /**
32
- * @inheritDoc
33
- */
34
- snapshots(subscribe?: boolean): Observable<Array<DocumentReference<DocumentType>>>;
35
- /**
36
- * @inheritDoc
37
- */
38
- changes(): Observable<Changes<DocumentType>>;
39
- /**
40
- * A unique hash for the query. Identical queries should return the same hash
41
- * value.
42
- *
43
- * @returns The query's hash string.
44
- */
45
- get hash(): string;
46
- /** @inheritDoc */
47
- dereference(): SnapshotEmitter<DocumentType>;
48
- getSortOrders(): Array<FieldSort<any>>;
49
- clone(): QueryBuilder<DocumentType>;
50
- addCompositeCondition(conditions: Array<SimpleCondition>): QueryBuilder<DocumentType>;
51
- flipSortOrder(): QueryBuilder<DocumentType>;
52
- serialize(): SerializedSimpleQuery;
53
- extractData(data: DocumentReference<DocumentType>): DocumentType;
54
- paginate(options?: Partial<PaginationOptions>): Pagination<DocumentReference<DocumentType>>;
55
- }
56
- /** Describes the changes to a query result. */
57
- export declare class Changes<DocumentType extends DocumentData> {
58
- /** The newly inserted documents to the query result */
59
- readonly inserts: Array<DocumentReference<DocumentType>>;
60
- /** The documents that were updated in the query result */
61
- readonly updates: Array<DocumentReference<DocumentType>>;
62
- /** The actual document data that was deleted from the query result */
63
- readonly deletes: Array<DocumentType>;
64
- constructor(
65
- /** The newly inserted documents to the query result */
66
- inserts: Array<DocumentReference<DocumentType>>,
67
- /** The documents that were updated in the query result */
68
- updates: Array<DocumentReference<DocumentType>>,
69
- /** The actual document data that was deleted from the query result */
70
- deletes: Array<DocumentType>);
71
- }
1
+ import { BaseQueryBuilder, DocumentData, FieldName, FieldSort, HasDereference, Operator, Pagination, PaginationOptions, PrimitiveFieldType, SerializedSimpleQuery, SimpleCondition, SnapshotEmitter } from '@squidcloud/common';
2
+ import { Observable } from 'rxjs';
3
+ import { DocumentReference } from '../document-reference';
4
+ /** A query builder that can be used to build a query that returns a list of documents. */
5
+ export declare class QueryBuilder<DocumentType extends DocumentData> extends BaseQueryBuilder<DocumentType> implements SnapshotEmitter<DocumentReference<DocumentType>>, HasDereference {
6
+ private readonly collectionName;
7
+ private readonly integrationId;
8
+ private readonly querySubscriptionManager;
9
+ private readonly localQueryManager;
10
+ private readonly documentReferenceFactory;
11
+ private readonly queryBuilderFactory;
12
+ private readonly documentIdentityService;
13
+ private forceFetchFromServer;
14
+ /** @inheritDoc */
15
+ where(fieldName: (keyof DocumentType & FieldName) | string, operator: Operator | 'in' | 'not in', value: PrimitiveFieldType | Array<PrimitiveFieldType>): this;
16
+ /** @inheritDoc */
17
+ limit(limit: number): this;
18
+ getLimit(): number;
19
+ /** @inheritDoc */
20
+ sortBy(fieldName: keyof DocumentType & FieldName, asc?: boolean): this;
21
+ private mergeConditions;
22
+ getSortOrder(): FieldSort<DocumentType>[];
23
+ /**
24
+ * @inheritDoc
25
+ */
26
+ snapshot(): Promise<Array<DocumentReference<DocumentType>>>;
27
+ /**
28
+ * Forces the query to return data from the server even if there is a query that already returned the requested
29
+ * result.
30
+ */
31
+ setForceFetchFromServer(): this;
32
+ /**
33
+ * Returns the results of the query based on the data that is currently available on the client. This method is useful
34
+ * for synchronously accessing data that has already been fetched by another query. The method will return an empty
35
+ * array if data has not yet been populated.
36
+ *
37
+ * @returns An array of query results.
38
+ */
39
+ peek(): Array<DocumentReference<DocumentType>>;
40
+ /**
41
+ * @inheritDoc
42
+ */
43
+ snapshots(subscribe?: boolean): Observable<Array<DocumentReference<DocumentType>>>;
44
+ /**
45
+ * @inheritDoc
46
+ */
47
+ changes(): Observable<Changes<DocumentType>>;
48
+ /**
49
+ * A unique hash for the query. Identical queries should return the same hash
50
+ * value.
51
+ *
52
+ * @returns The query's hash string.
53
+ */
54
+ get hash(): string;
55
+ /** @inheritDoc */
56
+ dereference(): SnapshotEmitter<DocumentType>;
57
+ getSortOrders(): Array<FieldSort<any>>;
58
+ clone(): QueryBuilder<DocumentType>;
59
+ addCompositeCondition(conditions: Array<SimpleCondition>): QueryBuilder<DocumentType>;
60
+ flipSortOrder(): QueryBuilder<DocumentType>;
61
+ serialize(): SerializedSimpleQuery;
62
+ extractData(data: DocumentReference<DocumentType>): DocumentType;
63
+ paginate(options?: Partial<PaginationOptions>): Pagination<DocumentReference<DocumentType>>;
64
+ }
65
+ /** Describes the changes to a query result. */
66
+ export declare class Changes<DocumentType extends DocumentData> {
67
+ /** The newly inserted documents to the query result */
68
+ readonly inserts: Array<DocumentReference<DocumentType>>;
69
+ /** The documents that were updated in the query result */
70
+ readonly updates: Array<DocumentReference<DocumentType>>;
71
+ /** The actual document data that was deleted from the query result */
72
+ readonly deletes: Array<DocumentType>;
73
+ constructor(
74
+ /** The newly inserted documents to the query result */
75
+ inserts: Array<DocumentReference<DocumentType>>,
76
+ /** The documents that were updated in the query result */
77
+ updates: Array<DocumentReference<DocumentType>>,
78
+ /** The actual document data that was deleted from the query result */
79
+ deletes: Array<DocumentType>);
80
+ }