@squidcloud/client 1.0.86 → 1.0.87

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