@contember/client 1.2.5 → 1.3.0-alpha.10
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/development/content/formatContentApiRelativeUrl.cjs +5 -0
- package/dist/development/content/formatContentApiRelativeUrl.cjs.map +1 -0
- package/dist/development/content/formatContentApiRelativeUrl.js.map +1 -1
- package/dist/development/content/params/whereToFilter.cjs +17 -0
- package/dist/development/content/params/whereToFilter.cjs.map +1 -0
- package/dist/development/content/replaceGraphQlLiteral.cjs +15 -0
- package/dist/development/content/replaceGraphQlLiteral.cjs.map +1 -0
- package/dist/development/content/replaceGraphQlLiteral.js +15 -0
- package/dist/development/content/replaceGraphQlLiteral.js.map +1 -0
- package/dist/development/content/upload/FileUploadError.cjs +10 -0
- package/dist/development/content/upload/FileUploadError.cjs.map +1 -0
- package/dist/development/content/upload/GenerateUploadUrlMutationBuilder.cjs +64 -0
- package/dist/development/content/upload/GenerateUploadUrlMutationBuilder.cjs.map +1 -0
- package/dist/development/content/upload/GenerateUploadUrlMutationBuilder.js +49 -20
- package/dist/development/content/upload/GenerateUploadUrlMutationBuilder.js.map +1 -1
- package/dist/development/content/upload/S3FileUploader.cjs +107 -0
- package/dist/development/content/upload/S3FileUploader.cjs.map +1 -0
- package/dist/development/content/upload/S3FileUploader.js +2 -3
- package/dist/development/content/upload/S3FileUploader.js.map +1 -1
- package/dist/development/graphQlBuilder/GraphQlLiteral.cjs +15 -0
- package/dist/development/graphQlBuilder/GraphQlLiteral.cjs.map +1 -0
- package/dist/development/graphQlBuilder/GraphQlLiteral.js +3 -0
- package/dist/development/graphQlBuilder/GraphQlLiteral.js.map +1 -1
- package/dist/development/graphQlClient/GraphQlClient.cjs +26 -0
- package/dist/development/graphQlClient/GraphQlClient.cjs.map +1 -0
- package/dist/development/graphQlClient/GraphQlClient.js +9 -16
- package/dist/development/graphQlClient/GraphQlClient.js.map +1 -1
- package/dist/development/index.cjs +46 -0
- package/dist/development/index.cjs.map +1 -0
- package/dist/development/index.js +5 -26
- package/dist/development/index.js.map +1 -1
- package/dist/development/system/formatSystemApiRelativeUrl.cjs +5 -0
- package/dist/development/system/formatSystemApiRelativeUrl.cjs.map +1 -0
- package/dist/development/system/formatSystemApiRelativeUrl.js.map +1 -1
- package/dist/development/tenant/loginMutation.cjs +34 -0
- package/dist/development/tenant/loginMutation.cjs.map +1 -0
- package/dist/development/tenant/tenantApiRelativeUrl.cjs +5 -0
- package/dist/development/tenant/tenantApiRelativeUrl.cjs.map +1 -0
- package/dist/development/tenant/tenantErrorMessages.cjs +18 -0
- package/dist/development/tenant/tenantErrorMessages.cjs.map +1 -0
- package/dist/development/tenant/tenantErrorMessages.js.map +1 -1
- package/dist/development/utils/readFileAsArrayBuffer.cjs +15 -0
- package/dist/development/utils/readFileAsArrayBuffer.cjs.map +1 -0
- package/dist/production/content/formatContentApiRelativeUrl.cjs +5 -0
- package/dist/production/content/formatContentApiRelativeUrl.cjs.map +1 -0
- package/dist/production/content/formatContentApiRelativeUrl.js.map +1 -1
- package/dist/production/content/params/whereToFilter.cjs +17 -0
- package/dist/production/content/params/whereToFilter.cjs.map +1 -0
- package/dist/production/content/replaceGraphQlLiteral.cjs +15 -0
- package/dist/production/content/replaceGraphQlLiteral.cjs.map +1 -0
- package/dist/production/content/replaceGraphQlLiteral.js +15 -0
- package/dist/production/content/replaceGraphQlLiteral.js.map +1 -0
- package/dist/production/content/upload/FileUploadError.cjs +10 -0
- package/dist/production/content/upload/FileUploadError.cjs.map +1 -0
- package/dist/production/content/upload/GenerateUploadUrlMutationBuilder.cjs +64 -0
- package/dist/production/content/upload/GenerateUploadUrlMutationBuilder.cjs.map +1 -0
- package/dist/production/content/upload/GenerateUploadUrlMutationBuilder.js +49 -20
- package/dist/production/content/upload/GenerateUploadUrlMutationBuilder.js.map +1 -1
- package/dist/production/content/upload/S3FileUploader.cjs +107 -0
- package/dist/production/content/upload/S3FileUploader.cjs.map +1 -0
- package/dist/production/content/upload/S3FileUploader.js +2 -3
- package/dist/production/content/upload/S3FileUploader.js.map +1 -1
- package/dist/production/graphQlBuilder/GraphQlLiteral.cjs +12 -0
- package/dist/production/graphQlBuilder/GraphQlLiteral.cjs.map +1 -0
- package/dist/production/graphQlBuilder/GraphQlLiteral.js.map +1 -1
- package/dist/production/graphQlClient/GraphQlClient.cjs +26 -0
- package/dist/production/graphQlClient/GraphQlClient.cjs.map +1 -0
- package/dist/production/graphQlClient/GraphQlClient.js +9 -16
- package/dist/production/graphQlClient/GraphQlClient.js.map +1 -1
- package/dist/production/index.cjs +46 -0
- package/dist/production/index.cjs.map +1 -0
- package/dist/production/index.js +5 -26
- package/dist/production/index.js.map +1 -1
- package/dist/production/system/formatSystemApiRelativeUrl.cjs +5 -0
- package/dist/production/system/formatSystemApiRelativeUrl.cjs.map +1 -0
- package/dist/production/system/formatSystemApiRelativeUrl.js.map +1 -1
- package/dist/production/tenant/loginMutation.cjs +34 -0
- package/dist/production/tenant/loginMutation.cjs.map +1 -0
- package/dist/production/tenant/tenantApiRelativeUrl.cjs +5 -0
- package/dist/production/tenant/tenantApiRelativeUrl.cjs.map +1 -0
- package/dist/production/tenant/tenantErrorMessages.cjs +18 -0
- package/dist/production/tenant/tenantErrorMessages.cjs.map +1 -0
- package/dist/production/tenant/tenantErrorMessages.js.map +1 -1
- package/dist/production/utils/readFileAsArrayBuffer.cjs +15 -0
- package/dist/production/utils/readFileAsArrayBuffer.cjs.map +1 -0
- package/dist/types/content/index.d.ts +1 -0
- package/dist/types/content/index.d.ts.map +1 -1
- package/dist/types/content/replaceGraphQlLiteral.d.ts +6 -0
- package/dist/types/content/replaceGraphQlLiteral.d.ts.map +1 -0
- package/dist/types/content/upload/GenerateUploadUrlMutationBuilder.d.ts +8 -4
- package/dist/types/content/upload/GenerateUploadUrlMutationBuilder.d.ts.map +1 -1
- package/dist/types/content/upload/S3FileUploader.d.ts.map +1 -1
- package/dist/types/crudQueryBuilder/index.d.ts +0 -6
- package/dist/types/crudQueryBuilder/index.d.ts.map +1 -1
- package/dist/types/crudQueryBuilder/types.d.ts +2 -43
- package/dist/types/crudQueryBuilder/types.d.ts.map +1 -1
- package/dist/types/graphQlBuilder/GraphQlLiteral.d.ts +3 -0
- package/dist/types/graphQlBuilder/GraphQlLiteral.d.ts.map +1 -1
- package/dist/types/graphQlBuilder/QueryBuilder.d.ts +2 -8
- package/dist/types/graphQlBuilder/QueryBuilder.d.ts.map +1 -1
- package/dist/types/graphQlBuilder/index.d.ts +0 -3
- package/dist/types/graphQlBuilder/index.d.ts.map +1 -1
- package/dist/types/graphQlClient/GraphQlClient.d.ts +10 -12
- package/dist/types/graphQlClient/GraphQlClient.d.ts.map +1 -1
- package/dist/types/graphQlClient/index.d.ts +2 -0
- package/dist/types/graphQlClient/index.d.ts.map +1 -1
- package/dist/types/index.d.ts +1 -29
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +19 -4
- package/src/content/index.ts +1 -1
- package/src/content/replaceGraphQlLiteral.ts +22 -0
- package/src/content/upload/GenerateUploadUrlMutationBuilder.ts +56 -33
- package/src/content/upload/S3FileUploader.ts +1 -2
- package/src/crudQueryBuilder/index.ts +0 -6
- package/src/crudQueryBuilder/types.ts +5 -70
- package/src/graphQlBuilder/GraphQlLiteral.ts +8 -1
- package/src/graphQlBuilder/QueryBuilder.ts +2 -23
- package/src/graphQlBuilder/index.ts +0 -3
- package/src/graphQlClient/GraphQlClient.ts +15 -28
- package/src/graphQlClient/index.ts +7 -0
- package/src/index.ts +5 -31
- package/src/tsconfig.json +12 -1
- package/dist/development/crudQueryBuilder/CrudQueryBuilder.js +0 -104
- package/dist/development/crudQueryBuilder/CrudQueryBuilder.js.map +0 -1
- package/dist/development/crudQueryBuilder/CrudQueryBuilderError.js +0 -6
- package/dist/development/crudQueryBuilder/CrudQueryBuilderError.js.map +0 -1
- package/dist/development/crudQueryBuilder/ErrorsRelationBuilder.js +0 -15
- package/dist/development/crudQueryBuilder/ErrorsRelationBuilder.js.map +0 -1
- package/dist/development/crudQueryBuilder/ReadBuilder.js +0 -70
- package/dist/development/crudQueryBuilder/ReadBuilder.js.map +0 -1
- package/dist/development/crudQueryBuilder/ValidationRelationBuilder.js +0 -18
- package/dist/development/crudQueryBuilder/ValidationRelationBuilder.js.map +0 -1
- package/dist/development/crudQueryBuilder/WriteBuilder.js +0 -54
- package/dist/development/crudQueryBuilder/WriteBuilder.js.map +0 -1
- package/dist/development/crudQueryBuilder/WriteDataBuilder.js +0 -110
- package/dist/development/crudQueryBuilder/WriteDataBuilder.js.map +0 -1
- package/dist/development/crudQueryBuilder/WriteManyRelationBuilder.js +0 -77
- package/dist/development/crudQueryBuilder/WriteManyRelationBuilder.js.map +0 -1
- package/dist/development/crudQueryBuilder/WriteOneRelationBuilder.js +0 -51
- package/dist/development/crudQueryBuilder/WriteOneRelationBuilder.js.map +0 -1
- package/dist/development/crudQueryBuilder/types.js +0 -40
- package/dist/development/crudQueryBuilder/types.js.map +0 -1
- package/dist/development/graphQlBuilder/GraphQlBuilderError.js +0 -6
- package/dist/development/graphQlBuilder/GraphQlBuilderError.js.map +0 -1
- package/dist/development/graphQlBuilder/ObjectBuilder.js +0 -80
- package/dist/development/graphQlBuilder/ObjectBuilder.js.map +0 -1
- package/dist/development/graphQlBuilder/QueryBuilder.js +0 -22
- package/dist/development/graphQlBuilder/QueryBuilder.js.map +0 -1
- package/dist/development/graphQlBuilder/QueryCompiler.js +0 -101
- package/dist/development/graphQlBuilder/QueryCompiler.js.map +0 -1
- package/dist/development/graphQlBuilder/RootObjectBuilder.js +0 -31
- package/dist/development/graphQlBuilder/RootObjectBuilder.js.map +0 -1
- package/dist/development/utils/isEmptyObject.js +0 -12
- package/dist/development/utils/isEmptyObject.js.map +0 -1
- package/dist/production/crudQueryBuilder/CrudQueryBuilder.js +0 -104
- package/dist/production/crudQueryBuilder/CrudQueryBuilder.js.map +0 -1
- package/dist/production/crudQueryBuilder/CrudQueryBuilderError.js +0 -6
- package/dist/production/crudQueryBuilder/CrudQueryBuilderError.js.map +0 -1
- package/dist/production/crudQueryBuilder/ErrorsRelationBuilder.js +0 -15
- package/dist/production/crudQueryBuilder/ErrorsRelationBuilder.js.map +0 -1
- package/dist/production/crudQueryBuilder/ReadBuilder.js +0 -70
- package/dist/production/crudQueryBuilder/ReadBuilder.js.map +0 -1
- package/dist/production/crudQueryBuilder/ValidationRelationBuilder.js +0 -18
- package/dist/production/crudQueryBuilder/ValidationRelationBuilder.js.map +0 -1
- package/dist/production/crudQueryBuilder/WriteBuilder.js +0 -54
- package/dist/production/crudQueryBuilder/WriteBuilder.js.map +0 -1
- package/dist/production/crudQueryBuilder/WriteDataBuilder.js +0 -110
- package/dist/production/crudQueryBuilder/WriteDataBuilder.js.map +0 -1
- package/dist/production/crudQueryBuilder/WriteManyRelationBuilder.js +0 -77
- package/dist/production/crudQueryBuilder/WriteManyRelationBuilder.js.map +0 -1
- package/dist/production/crudQueryBuilder/WriteOneRelationBuilder.js +0 -51
- package/dist/production/crudQueryBuilder/WriteOneRelationBuilder.js.map +0 -1
- package/dist/production/crudQueryBuilder/types.js +0 -40
- package/dist/production/crudQueryBuilder/types.js.map +0 -1
- package/dist/production/graphQlBuilder/GraphQlBuilderError.js +0 -6
- package/dist/production/graphQlBuilder/GraphQlBuilderError.js.map +0 -1
- package/dist/production/graphQlBuilder/ObjectBuilder.js +0 -80
- package/dist/production/graphQlBuilder/ObjectBuilder.js.map +0 -1
- package/dist/production/graphQlBuilder/QueryBuilder.js +0 -22
- package/dist/production/graphQlBuilder/QueryBuilder.js.map +0 -1
- package/dist/production/graphQlBuilder/QueryCompiler.js +0 -101
- package/dist/production/graphQlBuilder/QueryCompiler.js.map +0 -1
- package/dist/production/graphQlBuilder/RootObjectBuilder.js +0 -31
- package/dist/production/graphQlBuilder/RootObjectBuilder.js.map +0 -1
- package/dist/production/utils/isEmptyObject.js +0 -12
- package/dist/production/utils/isEmptyObject.js.map +0 -1
- package/dist/types/crudQueryBuilder/CrudQueryBuilder.d.ts +0 -21
- package/dist/types/crudQueryBuilder/CrudQueryBuilder.d.ts.map +0 -1
- package/dist/types/crudQueryBuilder/CrudQueryBuilderError.d.ts +0 -3
- package/dist/types/crudQueryBuilder/CrudQueryBuilderError.d.ts.map +0 -1
- package/dist/types/crudQueryBuilder/ErrorsRelationBuilder.d.ts +0 -5
- package/dist/types/crudQueryBuilder/ErrorsRelationBuilder.d.ts.map +0 -1
- package/dist/types/crudQueryBuilder/ReadBuilder.d.ts +0 -31
- package/dist/types/crudQueryBuilder/ReadBuilder.d.ts.map +0 -1
- package/dist/types/crudQueryBuilder/ValidationRelationBuilder.d.ts +0 -5
- package/dist/types/crudQueryBuilder/ValidationRelationBuilder.d.ts.map +0 -1
- package/dist/types/crudQueryBuilder/WriteBuilder.d.ts +0 -24
- package/dist/types/crudQueryBuilder/WriteBuilder.d.ts.map +0 -1
- package/dist/types/crudQueryBuilder/WriteDataBuilder.d.ts +0 -24
- package/dist/types/crudQueryBuilder/WriteDataBuilder.d.ts.map +0 -1
- package/dist/types/crudQueryBuilder/WriteManyRelationBuilder.d.ts +0 -27
- package/dist/types/crudQueryBuilder/WriteManyRelationBuilder.d.ts.map +0 -1
- package/dist/types/crudQueryBuilder/WriteOneRelationBuilder.d.ts +0 -28
- package/dist/types/crudQueryBuilder/WriteOneRelationBuilder.d.ts.map +0 -1
- package/dist/types/graphQlBuilder/GraphQlBuilderError.d.ts +0 -3
- package/dist/types/graphQlBuilder/GraphQlBuilderError.d.ts.map +0 -1
- package/dist/types/graphQlBuilder/ObjectBuilder.d.ts +0 -28
- package/dist/types/graphQlBuilder/ObjectBuilder.d.ts.map +0 -1
- package/dist/types/graphQlBuilder/QueryCompiler.d.ts +0 -13
- package/dist/types/graphQlBuilder/QueryCompiler.d.ts.map +0 -1
- package/dist/types/graphQlBuilder/RootObjectBuilder.d.ts +0 -17
- package/dist/types/graphQlBuilder/RootObjectBuilder.d.ts.map +0 -1
- package/src/crudQueryBuilder/CrudQueryBuilder.ts +0 -168
- package/src/crudQueryBuilder/CrudQueryBuilderError.ts +0 -1
- package/src/crudQueryBuilder/ErrorsRelationBuilder.ts +0 -16
- package/src/crudQueryBuilder/ReadBuilder.ts +0 -106
- package/src/crudQueryBuilder/ValidationRelationBuilder.ts +0 -17
- package/src/crudQueryBuilder/WriteBuilder.ts +0 -79
- package/src/crudQueryBuilder/WriteDataBuilder.ts +0 -153
- package/src/crudQueryBuilder/WriteManyRelationBuilder.ts +0 -141
- package/src/crudQueryBuilder/WriteOneRelationBuilder.ts +0 -101
- package/src/graphQlBuilder/GraphQlBuilderError.ts +0 -1
- package/src/graphQlBuilder/ObjectBuilder.ts +0 -87
- package/src/graphQlBuilder/QueryCompiler.ts +0 -115
- package/src/graphQlBuilder/RootObjectBuilder.ts +0 -36
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
var __defProp = Object.defineProperty;
|
|
2
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
|
-
var __publicField = (obj, key, value) => {
|
|
4
|
-
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
5
|
-
return value;
|
|
6
|
-
};
|
|
7
|
-
import { CrudQueryBuilderError } from "./CrudQueryBuilderError.js";
|
|
8
|
-
import { WriteManyRelationBuilder } from "./WriteManyRelationBuilder.js";
|
|
9
|
-
import { WriteOneRelationBuilder } from "./WriteOneRelationBuilder.js";
|
|
10
|
-
import { GraphQlLiteral } from "../graphQlBuilder/GraphQlLiteral.js";
|
|
11
|
-
import { isEmptyObject } from "../utils/isEmptyObject.js";
|
|
12
|
-
class WriteDataBuilder {
|
|
13
|
-
constructor(data) {
|
|
14
|
-
__publicField(this, "data");
|
|
15
|
-
this.data = data || {};
|
|
16
|
-
}
|
|
17
|
-
static resolveData(dataLike) {
|
|
18
|
-
let resolvedData;
|
|
19
|
-
if (dataLike instanceof WriteDataBuilder) {
|
|
20
|
-
resolvedData = dataLike.data;
|
|
21
|
-
} else if (typeof dataLike === "function") {
|
|
22
|
-
resolvedData = dataLike(new WriteDataBuilder()).data;
|
|
23
|
-
} else {
|
|
24
|
-
resolvedData = dataLike;
|
|
25
|
-
}
|
|
26
|
-
if (isEmptyObject(resolvedData)) {
|
|
27
|
-
return void 0;
|
|
28
|
-
}
|
|
29
|
-
return resolvedData;
|
|
30
|
-
}
|
|
31
|
-
set(fieldName, value) {
|
|
32
|
-
return new WriteDataBuilder({ ...this.data, [fieldName]: value });
|
|
33
|
-
}
|
|
34
|
-
many(fieldName, data) {
|
|
35
|
-
const resolvedData = WriteManyRelationBuilder.instantiateFromFactory(data).data;
|
|
36
|
-
return resolvedData === void 0 || resolvedData.length === 0 ? this : new WriteDataBuilder(this.mergeInFreshData(this.data, fieldName, resolvedData));
|
|
37
|
-
}
|
|
38
|
-
one(fieldName, data) {
|
|
39
|
-
const resolvedData = WriteOneRelationBuilder.instantiateFromFactory(data).data;
|
|
40
|
-
return resolvedData === void 0 || isEmptyObject(resolvedData) ? this : new WriteDataBuilder(this.mergeInFreshData(this.data, fieldName, resolvedData));
|
|
41
|
-
}
|
|
42
|
-
mergeInFreshData(original, fieldName, fresh) {
|
|
43
|
-
if (fieldName in original) {
|
|
44
|
-
const existingValue = original[fieldName];
|
|
45
|
-
if (Array.isArray(existingValue)) {
|
|
46
|
-
if (Array.isArray(fresh)) {
|
|
47
|
-
return { ...original, [fieldName]: [...existingValue, ...fresh] };
|
|
48
|
-
}
|
|
49
|
-
throw new CrudQueryBuilderError(`Inconsistent data.`);
|
|
50
|
-
}
|
|
51
|
-
if (Array.isArray(fresh)) {
|
|
52
|
-
throw new CrudQueryBuilderError(`Inconsistent data.`);
|
|
53
|
-
}
|
|
54
|
-
return { ...original, [fieldName]: this.mergeUpdateOne(existingValue, fresh) };
|
|
55
|
-
}
|
|
56
|
-
return { ...original, [fieldName]: fresh };
|
|
57
|
-
}
|
|
58
|
-
mergeUpdateOne(original, fresh) {
|
|
59
|
-
if (original instanceof GraphQlLiteral) {
|
|
60
|
-
if (fresh instanceof GraphQlLiteral) {
|
|
61
|
-
if (original.value === fresh.value) {
|
|
62
|
-
return original;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
throw new CrudQueryBuilderError(`Inconsistent data.`);
|
|
66
|
-
}
|
|
67
|
-
if (fresh instanceof GraphQlLiteral) {
|
|
68
|
-
throw new CrudQueryBuilderError(`Inconsistent data.`);
|
|
69
|
-
}
|
|
70
|
-
if (Array.isArray(original)) {
|
|
71
|
-
if (Array.isArray(fresh)) {
|
|
72
|
-
return [...original, ...fresh];
|
|
73
|
-
}
|
|
74
|
-
throw new CrudQueryBuilderError(`Inconsistent data.`);
|
|
75
|
-
}
|
|
76
|
-
if (Array.isArray(fresh)) {
|
|
77
|
-
throw new CrudQueryBuilderError(`Inconsistent data.`);
|
|
78
|
-
}
|
|
79
|
-
if (original === null) {
|
|
80
|
-
if (fresh === null) {
|
|
81
|
-
return original;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
if (fresh === null) {
|
|
85
|
-
throw new CrudQueryBuilderError(`Inconsistent data.`);
|
|
86
|
-
}
|
|
87
|
-
if (typeof original === "object") {
|
|
88
|
-
if (typeof fresh === "object") {
|
|
89
|
-
const composite = { ...original };
|
|
90
|
-
for (const field in fresh) {
|
|
91
|
-
const fromFresh = fresh[field];
|
|
92
|
-
composite[field] = field in composite ? this.mergeUpdateOne(composite[field], fromFresh) : fromFresh;
|
|
93
|
-
}
|
|
94
|
-
return composite;
|
|
95
|
-
}
|
|
96
|
-
throw new CrudQueryBuilderError(`Inconsistent data.`);
|
|
97
|
-
}
|
|
98
|
-
if (typeof fresh === "object") {
|
|
99
|
-
throw new CrudQueryBuilderError(`Inconsistent data.`);
|
|
100
|
-
}
|
|
101
|
-
if (original === fresh) {
|
|
102
|
-
return original;
|
|
103
|
-
}
|
|
104
|
-
throw new CrudQueryBuilderError(`Inconsistent data.`);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
export {
|
|
108
|
-
WriteDataBuilder
|
|
109
|
-
};
|
|
110
|
-
//# sourceMappingURL=WriteDataBuilder.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"WriteDataBuilder.js","sources":["../../../src/crudQueryBuilder/WriteDataBuilder.ts"],"sourcesContent":["import type { Input, Value } from '@contember/schema'\nimport { GraphQlLiteral } from '../graphQlBuilder'\nimport { isEmptyObject } from '../utils'\nimport { CrudQueryBuilderError } from './CrudQueryBuilderError'\nimport type { WriteOperation } from './types'\nimport { WriteManyRelationBuilder } from './WriteManyRelationBuilder'\nimport { WriteOneRelationBuilder } from './WriteOneRelationBuilder'\n\nclass WriteDataBuilder<Op extends WriteOperation.ContentfulOperation> {\n\tpublic readonly data: WriteDataBuilder.DataFormat[Op['op']]\n\n\tpublic constructor(data?: WriteDataBuilder.DataFormat[Op['op']]) {\n\t\tthis.data = data || {}\n\t}\n\n\tpublic static resolveData<Op extends WriteOperation.ContentfulOperation>(\n\t\tdataLike: WriteDataBuilder.DataLike<Op>,\n\t): WriteDataBuilder.DataFormat[Op['op']] | undefined {\n\t\tlet resolvedData: WriteDataBuilder.DataFormat[Op['op']]\n\n\t\tif (dataLike instanceof WriteDataBuilder) {\n\t\t\tresolvedData = dataLike.data\n\t\t} else if (typeof dataLike === 'function') {\n\t\t\tresolvedData = dataLike(new WriteDataBuilder()).data\n\t\t} else {\n\t\t\tresolvedData = dataLike\n\t\t}\n\n\t\tif (isEmptyObject(resolvedData)) {\n\t\t\treturn undefined\n\t\t}\n\t\treturn resolvedData\n\t}\n\n\tpublic set(fieldName: string, value: Input.ColumnValue<GraphQlLiteral>) {\n\t\treturn new WriteDataBuilder<Op>({ ...this.data, [fieldName]: value })\n\t}\n\n\tpublic many(fieldName: string, data: WriteManyRelationBuilder.BuilderFactory<Op>): WriteDataBuilder<Op> {\n\t\tconst resolvedData = WriteManyRelationBuilder.instantiateFromFactory(data).data\n\t\treturn resolvedData === undefined || resolvedData.length === 0\n\t\t\t? this\n\t\t\t: new WriteDataBuilder<Op>(this.mergeInFreshData(this.data, fieldName, resolvedData))\n\t}\n\n\tpublic one(fieldName: string, data: WriteOneRelationBuilder.BuilderFactory<Op>): WriteDataBuilder<Op> {\n\t\tconst resolvedData = WriteOneRelationBuilder.instantiateFromFactory(data).data\n\t\treturn resolvedData === undefined || isEmptyObject(resolvedData)\n\t\t\t? this\n\t\t\t: new WriteDataBuilder<Op>(this.mergeInFreshData(this.data, fieldName, resolvedData))\n\t}\n\n\tprivate mergeInFreshData(\n\t\toriginal: WriteDataBuilder.DataFormat[Op['op']],\n\t\tfieldName: string,\n\t\tfresh: WriteManyRelationBuilder.DataFormat[Op['op']] | WriteOneRelationBuilder.DataFormat[Op['op']],\n\t): WriteDataBuilder.DataFormat[Op['op']] {\n\t\tif (fieldName in original) {\n\t\t\tconst existingValue = original[fieldName]\n\t\t\tif (Array.isArray(existingValue)) {\n\t\t\t\tif (Array.isArray(fresh)) {\n\t\t\t\t\treturn { ...original, [fieldName]: [...existingValue, ...fresh] }\n\t\t\t\t}\n\t\t\t\tthrow new CrudQueryBuilderError(`Inconsistent data.`)\n\t\t\t}\n\t\t\tif (Array.isArray(fresh)) {\n\t\t\t\tthrow new CrudQueryBuilderError(`Inconsistent data.`)\n\t\t\t}\n\t\t\treturn { ...original, [fieldName]: this.mergeUpdateOne(existingValue, fresh) }\n\t\t}\n\t\treturn { ...original, [fieldName]: fresh }\n\t}\n\n\tprivate mergeUpdateOne(\n\t\toriginal:\n\t\t\t| Value.FieldValue<GraphQlLiteral>\n\t\t\t| Input.CreateOneRelationInput<GraphQlLiteral>\n\t\t\t| Input.UpdateOneRelationInput<GraphQlLiteral>,\n\t\tfresh:\n\t\t\t| Value.FieldValue<GraphQlLiteral>\n\t\t\t| Input.CreateOneRelationInput<GraphQlLiteral>\n\t\t\t| Input.UpdateOneRelationInput<GraphQlLiteral>,\n\t):\n\t\t| Value.FieldValue<GraphQlLiteral>\n\t\t| Input.CreateOneRelationInput<GraphQlLiteral>\n\t\t| Input.UpdateOneRelationInput<GraphQlLiteral> {\n\t\t// TODO This implementation pretty bad but it will have to do for now.\n\t\tif (original instanceof GraphQlLiteral) {\n\t\t\tif (fresh instanceof GraphQlLiteral) {\n\t\t\t\tif (original.value === fresh.value) {\n\t\t\t\t\treturn original\n\t\t\t\t}\n\t\t\t}\n\t\t\tthrow new CrudQueryBuilderError(`Inconsistent data.`)\n\t\t}\n\t\tif (fresh instanceof GraphQlLiteral) {\n\t\t\tthrow new CrudQueryBuilderError(`Inconsistent data.`)\n\t\t}\n\n\t\tif (Array.isArray(original)) {\n\t\t\tif (Array.isArray(fresh)) {\n\t\t\t\treturn [...original, ...fresh]\n\t\t\t}\n\t\t\tthrow new CrudQueryBuilderError(`Inconsistent data.`)\n\t\t}\n\t\tif (Array.isArray(fresh)) {\n\t\t\tthrow new CrudQueryBuilderError(`Inconsistent data.`)\n\t\t}\n\n\t\tif (original === null) {\n\t\t\tif (fresh === null) {\n\t\t\t\treturn original\n\t\t\t}\n\t\t}\n\t\tif (fresh === null) {\n\t\t\tthrow new CrudQueryBuilderError(`Inconsistent data.`)\n\t\t}\n\n\t\tif (typeof original === 'object') {\n\t\t\tif (typeof fresh === 'object') {\n\t\t\t\tconst composite: any = { ...original }\n\t\t\t\tfor (const field in fresh) {\n\t\t\t\t\tconst fromFresh = (fresh as any)[field]\n\t\t\t\t\tcomposite[field] = field in composite ? this.mergeUpdateOne(composite[field], fromFresh) : fromFresh\n\t\t\t\t}\n\t\t\t\treturn composite\n\t\t\t}\n\t\t\tthrow new CrudQueryBuilderError(`Inconsistent data.`)\n\t\t}\n\t\tif (typeof fresh === 'object') {\n\t\t\tthrow new CrudQueryBuilderError(`Inconsistent data.`)\n\t\t}\n\n\t\tif (original === fresh) {\n\t\t\treturn original\n\t\t}\n\t\tthrow new CrudQueryBuilderError(`Inconsistent data.`)\n\t}\n}\n\nnamespace WriteDataBuilder {\n\texport interface DataFormat {\n\t\tcreate: Input.CreateDataInput<GraphQlLiteral>\n\t\tupdate: Input.UpdateDataInput<GraphQlLiteral>\n\t}\n\n\texport type DataLike<Op extends WriteOperation.ContentfulOperation> =\n\t\t| DataFormat[Op['op']]\n\t\t| WriteDataBuilder<Op>\n\t\t| ((builder: WriteDataBuilder<Op>) => WriteDataBuilder<Op>)\n}\n\nexport { WriteDataBuilder }\n"],"names":[],"mappings":"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"}
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
import { WriteDataBuilder } from "./WriteDataBuilder.js";
|
|
2
|
-
class WriteManyRelationBuilder {
|
|
3
|
-
constructor(data = []) {
|
|
4
|
-
this.data = data;
|
|
5
|
-
}
|
|
6
|
-
static instantiate(data = []) {
|
|
7
|
-
return new WriteManyRelationBuilder(data);
|
|
8
|
-
}
|
|
9
|
-
static instantiateFromFactory(builder) {
|
|
10
|
-
if (typeof builder === "function") {
|
|
11
|
-
return builder(WriteManyRelationBuilder.instantiate());
|
|
12
|
-
}
|
|
13
|
-
if ("data" in builder) {
|
|
14
|
-
return WriteManyRelationBuilder.instantiate(builder.data);
|
|
15
|
-
}
|
|
16
|
-
return WriteManyRelationBuilder.instantiate(builder);
|
|
17
|
-
}
|
|
18
|
-
create(data, alias) {
|
|
19
|
-
const resolvedData = WriteDataBuilder.resolveData(data);
|
|
20
|
-
return resolvedData === void 0 ? this : WriteManyRelationBuilder.instantiate([
|
|
21
|
-
...this.data,
|
|
22
|
-
this.withAlias({ create: resolvedData }, alias)
|
|
23
|
-
]);
|
|
24
|
-
}
|
|
25
|
-
connect(where, alias) {
|
|
26
|
-
return WriteManyRelationBuilder.instantiate([
|
|
27
|
-
...this.data,
|
|
28
|
-
this.withAlias({ connect: where }, alias)
|
|
29
|
-
]);
|
|
30
|
-
}
|
|
31
|
-
delete(where, alias) {
|
|
32
|
-
return WriteManyRelationBuilder.instantiate([
|
|
33
|
-
...this.data,
|
|
34
|
-
this.withAlias({ delete: where }, alias)
|
|
35
|
-
]);
|
|
36
|
-
}
|
|
37
|
-
disconnect(where, alias) {
|
|
38
|
-
return WriteManyRelationBuilder.instantiate([
|
|
39
|
-
...this.data,
|
|
40
|
-
this.withAlias({ disconnect: where }, alias)
|
|
41
|
-
]);
|
|
42
|
-
}
|
|
43
|
-
update(where, data, alias) {
|
|
44
|
-
const resolvedData = WriteDataBuilder.resolveData(data);
|
|
45
|
-
return resolvedData === void 0 ? this : WriteManyRelationBuilder.instantiate([
|
|
46
|
-
...this.data,
|
|
47
|
-
this.withAlias({ update: { by: where, data: resolvedData } }, alias)
|
|
48
|
-
]);
|
|
49
|
-
}
|
|
50
|
-
upsert(where, update, create, alias) {
|
|
51
|
-
const resolvedUpdate = WriteDataBuilder.resolveData(update);
|
|
52
|
-
const resolvedCreate = WriteDataBuilder.resolveData(create);
|
|
53
|
-
return resolvedUpdate === void 0 && resolvedCreate === void 0 ? this : WriteManyRelationBuilder.instantiate([
|
|
54
|
-
...this.data,
|
|
55
|
-
this.withAlias(
|
|
56
|
-
{
|
|
57
|
-
upsert: {
|
|
58
|
-
by: where,
|
|
59
|
-
update: resolvedUpdate || {},
|
|
60
|
-
create: resolvedCreate || {}
|
|
61
|
-
}
|
|
62
|
-
},
|
|
63
|
-
alias
|
|
64
|
-
)
|
|
65
|
-
]);
|
|
66
|
-
}
|
|
67
|
-
withAlias(data, alias) {
|
|
68
|
-
if (alias !== void 0) {
|
|
69
|
-
data.alias = alias;
|
|
70
|
-
}
|
|
71
|
-
return data;
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
export {
|
|
75
|
-
WriteManyRelationBuilder
|
|
76
|
-
};
|
|
77
|
-
//# sourceMappingURL=WriteManyRelationBuilder.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"WriteManyRelationBuilder.js","sources":["../../../src/crudQueryBuilder/WriteManyRelationBuilder.ts"],"sourcesContent":["import type { Input } from '@contember/schema'\nimport type { GraphQlLiteral } from '../graphQlBuilder'\nimport type { WriteOperation, WriteRelationOps } from './types'\nimport { WriteDataBuilder } from './WriteDataBuilder'\n\nclass WriteManyRelationBuilder<\n\tOp extends WriteOperation.ContentfulOperation,\n\tAllowed extends WriteRelationOps[Op['op']],\n> {\n\tprivate constructor(public readonly data: WriteManyRelationBuilder.DataFormat[Op['op']] = []) {}\n\n\tpublic static instantiate<\n\t\tOp extends WriteOperation.ContentfulOperation,\n\t\tAllowed extends WriteRelationOps[Op['op']] = WriteRelationOps[Op['op']],\n\t>(data: WriteManyRelationBuilder.DataFormat[Op['op']] = []): WriteManyRelationBuilder.Builder<Op, Allowed> {\n\t\treturn new WriteManyRelationBuilder<Op, Allowed>(data)\n\t}\n\n\tpublic static instantiateFromFactory<\n\t\tOp extends WriteOperation.ContentfulOperation,\n\t\tAllowed extends WriteRelationOps[Op['op']],\n\t>(builder: WriteManyRelationBuilder.BuilderFactory<Op, Allowed>): WriteManyRelationBuilder.Builder<Op, never> {\n\t\tif (typeof builder === 'function') {\n\t\t\treturn builder(WriteManyRelationBuilder.instantiate())\n\t\t}\n\t\tif ('data' in builder) {\n\t\t\treturn WriteManyRelationBuilder.instantiate(builder.data)\n\t\t}\n\t\treturn WriteManyRelationBuilder.instantiate(builder)\n\t}\n\n\tpublic create(\n\t\tdata: WriteDataBuilder.DataLike<WriteOperation.Create>,\n\t\talias?: string,\n\t): WriteManyRelationBuilder.Builder<Op> {\n\t\tconst resolvedData = WriteDataBuilder.resolveData(data)\n\t\treturn (\n\t\t\tresolvedData === undefined\n\t\t\t\t? this\n\t\t\t\t: WriteManyRelationBuilder.instantiate<Op>([\n\t\t\t\t\t\t...this.data,\n\t\t\t\t\t\tthis.withAlias({ create: resolvedData }, alias),\n\t\t\t\t ] as WriteManyRelationBuilder.DataFormat[WriteOperation.Create['op']])\n\t\t) as WriteManyRelationBuilder.Builder<Op>\n\t}\n\n\tpublic connect(where: Input.UniqueWhere<GraphQlLiteral>, alias?: string) {\n\t\treturn WriteManyRelationBuilder.instantiate<Op>([\n\t\t\t...this.data,\n\t\t\tthis.withAlias({ connect: where }, alias),\n\t\t] as WriteManyRelationBuilder.DataFormat[Op['op']])\n\t}\n\n\tpublic delete(where: Input.UniqueWhere<GraphQlLiteral>, alias?: string) {\n\t\treturn WriteManyRelationBuilder.instantiate<WriteOperation.Update>([\n\t\t\t...this.data,\n\t\t\tthis.withAlias({ delete: where }, alias),\n\t\t])\n\t}\n\n\tpublic disconnect(where: Input.UniqueWhere<GraphQlLiteral>, alias?: string) {\n\t\treturn WriteManyRelationBuilder.instantiate<WriteOperation.Update>([\n\t\t\t...this.data,\n\t\t\tthis.withAlias({ disconnect: where }, alias),\n\t\t])\n\t}\n\n\tpublic update(\n\t\twhere: Input.UniqueWhere<GraphQlLiteral>,\n\t\tdata: WriteDataBuilder.DataLike<WriteOperation.Update>,\n\t\talias?: string,\n\t): WriteManyRelationBuilder.Builder<WriteOperation.Update> {\n\t\tconst resolvedData = WriteDataBuilder.resolveData(data)\n\t\treturn (\n\t\t\tresolvedData === undefined\n\t\t\t\t? this\n\t\t\t\t: WriteManyRelationBuilder.instantiate<WriteOperation.Update>([\n\t\t\t\t\t\t...this.data,\n\t\t\t\t\t\tthis.withAlias({ update: { by: where, data: resolvedData } }, alias),\n\t\t\t\t ])\n\t\t) as WriteManyRelationBuilder.Builder<WriteOperation.Update>\n\t}\n\n\tpublic upsert(\n\t\twhere: Input.UniqueWhere<GraphQlLiteral>,\n\t\tupdate: WriteDataBuilder.DataLike<WriteOperation.Update>,\n\t\tcreate: WriteDataBuilder.DataLike<WriteOperation.Create>,\n\t\talias?: string,\n\t): WriteManyRelationBuilder.Builder<WriteOperation.Update> {\n\t\tconst resolvedUpdate = WriteDataBuilder.resolveData(update)\n\t\tconst resolvedCreate = WriteDataBuilder.resolveData(create)\n\t\treturn (\n\t\t\tresolvedUpdate === undefined && resolvedCreate === undefined\n\t\t\t\t? this\n\t\t\t\t: WriteManyRelationBuilder.instantiate<WriteOperation.Update>([\n\t\t\t\t\t\t...this.data,\n\t\t\t\t\t\tthis.withAlias(\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tupsert: {\n\t\t\t\t\t\t\t\t\tby: where,\n\t\t\t\t\t\t\t\t\tupdate: resolvedUpdate || {},\n\t\t\t\t\t\t\t\t\tcreate: resolvedCreate || {},\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\talias,\n\t\t\t\t\t\t),\n\t\t\t\t ])\n\t\t) as WriteManyRelationBuilder.Builder<WriteOperation.Update>\n\t}\n\n\tprivate withAlias<\n\t\tD extends Input.CreateOneRelationInput<GraphQlLiteral> | Input.UpdateManyRelationInputItem<GraphQlLiteral>,\n\t>(data: D, alias?: string): D {\n\t\tif (alias !== undefined) {\n\t\t\tdata.alias = alias\n\t\t}\n\t\treturn data\n\t}\n}\n\nnamespace WriteManyRelationBuilder {\n\texport interface DataFormat {\n\t\tcreate: Input.CreateManyRelationInput<GraphQlLiteral>\n\t\tupdate: Input.UpdateManyRelationInput<GraphQlLiteral>\n\t}\n\n\texport type Builder<\n\t\tOp extends WriteOperation.ContentfulOperation,\n\t\tAllowed extends WriteRelationOps[Op['op']] = WriteRelationOps[Op['op']],\n\t> = Omit<\n\t\tWriteManyRelationBuilder<Op, Allowed>,\n\t\tExclude<WriteRelationOps[WriteOperation.ContentfulOperation['op']], Allowed>\n\t>\n\n\texport type BuilderFactory<\n\t\tOp extends WriteOperation.ContentfulOperation,\n\t\tAllowed extends WriteRelationOps[Op['op']] = WriteRelationOps[Op['op']],\n\t> = DataFormat[Op['op']] | Builder<Op, never> | ((builder: Builder<Op, Allowed>) => Builder<Op, never>)\n}\n\nexport { WriteManyRelationBuilder }\n"],"names":[],"mappings":";AAKA,MAAM,yBAGJ;AAAA,EACO,YAA4B,OAAsD,IAAI;AAA1D,SAAA,OAAA;AAAA,EAA2D;AAAA,EAE/F,OAAc,YAGZ,OAAsD,IAAmD;AACnG,WAAA,IAAI,yBAAsC,IAAI;AAAA,EACtD;AAAA,EAEA,OAAc,uBAGZ,SAA4G;AACzG,QAAA,OAAO,YAAY,YAAY;AAC3B,aAAA,QAAQ,yBAAyB,YAAA,CAAa;AAAA,IACtD;AACA,QAAI,UAAU,SAAS;AACf,aAAA,yBAAyB,YAAY,QAAQ,IAAI;AAAA,IACzD;AACO,WAAA,yBAAyB,YAAY,OAAO;AAAA,EACpD;AAAA,EAEO,OACN,MACA,OACuC;AACjC,UAAA,eAAe,iBAAiB,YAAY,IAAI;AACtD,WACC,iBAAiB,SACd,OACA,yBAAyB,YAAgB;AAAA,MACzC,GAAG,KAAK;AAAA,MACR,KAAK,UAAU,EAAE,QAAQ,aAAA,GAAgB,KAAK;AAAA,IAAA,CACuB;AAAA,EAE1E;AAAA,EAEO,QAAQ,OAA0C,OAAgB;AACxE,WAAO,yBAAyB,YAAgB;AAAA,MAC/C,GAAG,KAAK;AAAA,MACR,KAAK,UAAU,EAAE,SAAS,MAAA,GAAS,KAAK;AAAA,IAAA,CACS;AAAA,EACnD;AAAA,EAEO,OAAO,OAA0C,OAAgB;AACvE,WAAO,yBAAyB,YAAmC;AAAA,MAClE,GAAG,KAAK;AAAA,MACR,KAAK,UAAU,EAAE,QAAQ,MAAA,GAAS,KAAK;AAAA,IAAA,CACvC;AAAA,EACF;AAAA,EAEO,WAAW,OAA0C,OAAgB;AAC3E,WAAO,yBAAyB,YAAmC;AAAA,MAClE,GAAG,KAAK;AAAA,MACR,KAAK,UAAU,EAAE,YAAY,MAAA,GAAS,KAAK;AAAA,IAAA,CAC3C;AAAA,EACF;AAAA,EAEO,OACN,OACA,MACA,OAC0D;AACpD,UAAA,eAAe,iBAAiB,YAAY,IAAI;AACtD,WACC,iBAAiB,SACd,OACA,yBAAyB,YAAmC;AAAA,MAC5D,GAAG,KAAK;AAAA,MACR,KAAK,UAAU,EAAE,QAAQ,EAAE,IAAI,OAAO,MAAM,eAAe,GAAG,KAAK;AAAA,IAAA,CAClE;AAAA,EAEN;AAAA,EAEO,OACN,OACA,QACA,QACA,OAC0D;AACpD,UAAA,iBAAiB,iBAAiB,YAAY,MAAM;AACpD,UAAA,iBAAiB,iBAAiB,YAAY,MAAM;AAC1D,WACC,mBAAmB,UAAa,mBAAmB,SAChD,OACA,yBAAyB,YAAmC;AAAA,MAC5D,GAAG,KAAK;AAAA,MACR,KAAK;AAAA,QACJ;AAAA,UACC,QAAQ;AAAA,YACP,IAAI;AAAA,YACJ,QAAQ,kBAAkB,CAAC;AAAA,YAC3B,QAAQ,kBAAkB,CAAC;AAAA,UAC5B;AAAA,QACD;AAAA,QACA;AAAA,MACD;AAAA,IAAA,CACC;AAAA,EAEN;AAAA,EAEQ,UAEN,MAAS,OAAmB;AAC7B,QAAI,UAAU,QAAW;AACxB,WAAK,QAAQ;AAAA,IACd;AACO,WAAA;AAAA,EACR;AACD;"}
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { WriteDataBuilder } from "./WriteDataBuilder.js";
|
|
2
|
-
class WriteOneRelationBuilder {
|
|
3
|
-
constructor(data = void 0) {
|
|
4
|
-
this.data = data;
|
|
5
|
-
}
|
|
6
|
-
static instantiate(data = void 0) {
|
|
7
|
-
return new WriteOneRelationBuilder(data);
|
|
8
|
-
}
|
|
9
|
-
static instantiateFromFactory(builder) {
|
|
10
|
-
if (typeof builder === "function") {
|
|
11
|
-
return builder(WriteOneRelationBuilder.instantiate());
|
|
12
|
-
}
|
|
13
|
-
if (builder && "data" in builder) {
|
|
14
|
-
return WriteOneRelationBuilder.instantiate(builder.data);
|
|
15
|
-
}
|
|
16
|
-
return WriteOneRelationBuilder.instantiate(builder);
|
|
17
|
-
}
|
|
18
|
-
create(data) {
|
|
19
|
-
const resolvedData = WriteDataBuilder.resolveData(data);
|
|
20
|
-
return resolvedData === void 0 ? this : WriteOneRelationBuilder.instantiate({
|
|
21
|
-
create: resolvedData
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
connect(where) {
|
|
25
|
-
return WriteOneRelationBuilder.instantiate({ connect: where });
|
|
26
|
-
}
|
|
27
|
-
delete() {
|
|
28
|
-
return WriteOneRelationBuilder.instantiate({ delete: true });
|
|
29
|
-
}
|
|
30
|
-
disconnect() {
|
|
31
|
-
return WriteOneRelationBuilder.instantiate({ disconnect: true });
|
|
32
|
-
}
|
|
33
|
-
update(data) {
|
|
34
|
-
const resolvedData = WriteDataBuilder.resolveData(data);
|
|
35
|
-
return resolvedData === void 0 ? this : new WriteOneRelationBuilder({ update: resolvedData });
|
|
36
|
-
}
|
|
37
|
-
upsert(update, create) {
|
|
38
|
-
const resolvedCreate = WriteDataBuilder.resolveData(create);
|
|
39
|
-
const resolvedUpdate = WriteDataBuilder.resolveData(update);
|
|
40
|
-
return resolvedUpdate === void 0 && resolvedCreate === void 0 ? this : WriteOneRelationBuilder.instantiate({
|
|
41
|
-
upsert: {
|
|
42
|
-
update: resolvedUpdate || {},
|
|
43
|
-
create: resolvedCreate || {}
|
|
44
|
-
}
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
export {
|
|
49
|
-
WriteOneRelationBuilder
|
|
50
|
-
};
|
|
51
|
-
//# sourceMappingURL=WriteOneRelationBuilder.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"WriteOneRelationBuilder.js","sources":["../../../src/crudQueryBuilder/WriteOneRelationBuilder.ts"],"sourcesContent":["import type { Input } from '@contember/schema'\nimport type { GraphQlLiteral } from '../graphQlBuilder'\nimport type { WriteOperation, WriteRelationOps } from './types'\nimport { WriteDataBuilder } from './WriteDataBuilder'\n\nclass WriteOneRelationBuilder<\n\tOp extends WriteOperation.ContentfulOperation,\n\tAllowed extends WriteRelationOps[Op['op']] = WriteRelationOps[Op['op']],\n\tD extends WriteOneRelationBuilder.DataFormat[Op['op']] | undefined = WriteOneRelationBuilder.DataFormat[Op['op']],\n> {\n\tprotected constructor(public readonly data: D = undefined as D) {}\n\n\tpublic static instantiate<\n\t\tOp extends WriteOperation.ContentfulOperation,\n\t\tAllowed extends WriteRelationOps[Op['op']] = WriteRelationOps[Op['op']],\n\t\tD extends WriteOneRelationBuilder.DataFormat[Op['op']] | undefined = WriteOneRelationBuilder.DataFormat[Op['op']],\n\t>(data: D = undefined as D): WriteOneRelationBuilder.Builder<Op, Allowed, D> {\n\t\treturn new WriteOneRelationBuilder<Op, Allowed, D>(data)\n\t}\n\n\tpublic static instantiateFromFactory<\n\t\tOp extends WriteOperation.ContentfulOperation,\n\t\tAllowed extends WriteRelationOps[Op['op']] = WriteRelationOps[Op['op']],\n\t\tD extends WriteOneRelationBuilder.DataFormat[Op['op']] | undefined = WriteOneRelationBuilder.DataFormat[Op['op']],\n\t>(builder: WriteOneRelationBuilder.BuilderFactory<Op, Allowed, D>): WriteOneRelationBuilder.Builder<Op, never, D> {\n\t\tif (typeof builder === 'function') {\n\t\t\treturn builder(WriteOneRelationBuilder.instantiate())\n\t\t}\n\t\tif (builder && 'data' in builder!) {\n\t\t\treturn WriteOneRelationBuilder.instantiate(builder.data)\n\t\t}\n\t\treturn WriteOneRelationBuilder.instantiate(builder)\n\t}\n\n\tpublic create(data: WriteDataBuilder.DataLike<WriteOperation.Create>) {\n\t\tconst resolvedData = WriteDataBuilder.resolveData(data)\n\t\treturn resolvedData === undefined\n\t\t\t? this\n\t\t\t: WriteOneRelationBuilder.instantiate<Op, never>({\n\t\t\t\t\tcreate: resolvedData,\n\t\t\t })\n\t}\n\n\tpublic connect(where: Input.UniqueWhere<GraphQlLiteral>) {\n\t\treturn WriteOneRelationBuilder.instantiate<Op, never>({ connect: where })\n\t}\n\n\tpublic delete() {\n\t\treturn WriteOneRelationBuilder.instantiate<WriteOperation.Update, never>({ delete: true })\n\t}\n\n\tpublic disconnect() {\n\t\treturn WriteOneRelationBuilder.instantiate<WriteOperation.Update, never>({ disconnect: true })\n\t}\n\n\tpublic update(data: WriteDataBuilder.DataLike<WriteOperation.Update>) {\n\t\tconst resolvedData = WriteDataBuilder.resolveData(data)\n\t\treturn resolvedData === undefined ? this : new WriteOneRelationBuilder({ update: resolvedData })\n\t}\n\n\tpublic upsert(\n\t\tupdate: WriteDataBuilder.DataLike<WriteOperation.Update>,\n\t\tcreate: WriteDataBuilder.DataLike<WriteOperation.Create>,\n\t) {\n\t\tconst resolvedCreate = WriteDataBuilder.resolveData(create)\n\t\tconst resolvedUpdate = WriteDataBuilder.resolveData(update)\n\n\t\treturn resolvedUpdate === undefined && resolvedCreate === undefined\n\t\t\t? this\n\t\t\t: WriteOneRelationBuilder.instantiate<WriteOperation.Update, never>({\n\t\t\t\t\tupsert: {\n\t\t\t\t\t\tupdate: resolvedUpdate || {},\n\t\t\t\t\t\tcreate: resolvedCreate || {},\n\t\t\t\t\t},\n\t\t\t })\n\t}\n}\n\nnamespace WriteOneRelationBuilder {\n\texport interface DataFormat {\n\t\tcreate: Input.CreateOneRelationInput<GraphQlLiteral>\n\t\tupdate: Input.UpdateOneRelationInput<GraphQlLiteral>\n\t}\n\n\texport type Builder<\n\t\tOp extends WriteOperation.ContentfulOperation,\n\t\tAllowed extends WriteRelationOps[Op['op']] = WriteRelationOps[Op['op']],\n\t\tD extends WriteOneRelationBuilder.DataFormat[Op['op']] | undefined = WriteOneRelationBuilder.DataFormat[Op['op']],\n\t> = Omit<\n\t\tWriteOneRelationBuilder<Op, Allowed, D>,\n\t\tExclude<WriteRelationOps[WriteOperation.ContentfulOperation['op']], Allowed>\n\t>\n\n\texport type BuilderFactory<\n\t\tOp extends WriteOperation.ContentfulOperation,\n\t\tAllowed extends WriteRelationOps[Op['op']] = WriteRelationOps[Op['op']],\n\t\tD extends WriteOneRelationBuilder.DataFormat[Op['op']] | undefined = WriteOneRelationBuilder.DataFormat[Op['op']],\n\t> = D | Builder<Op, never, D> | ((builder: Builder<Op, Allowed, D>) => Builder<Op, never, D>)\n}\n\nexport { WriteOneRelationBuilder }\n"],"names":[],"mappings":";AAKA,MAAM,wBAIJ;AAAA,EACS,YAA4B,OAAU,QAAgB;AAA1B,SAAA,OAAA;AAAA,EAA2B;AAAA,EAEjE,OAAc,YAIZ,OAAU,QAAiE;AACrE,WAAA,IAAI,wBAAwC,IAAI;AAAA,EACxD;AAAA,EAEA,OAAc,uBAIZ,SAAgH;AAC7G,QAAA,OAAO,YAAY,YAAY;AAC3B,aAAA,QAAQ,wBAAwB,YAAA,CAAa;AAAA,IACrD;AACI,QAAA,WAAW,UAAU,SAAU;AAC3B,aAAA,wBAAwB,YAAY,QAAQ,IAAI;AAAA,IACxD;AACO,WAAA,wBAAwB,YAAY,OAAO;AAAA,EACnD;AAAA,EAEO,OAAO,MAAwD;AAC/D,UAAA,eAAe,iBAAiB,YAAY,IAAI;AACtD,WAAO,iBAAiB,SACrB,OACA,wBAAwB,YAAuB;AAAA,MAC/C,QAAQ;AAAA,IAAA,CACP;AAAA,EACL;AAAA,EAEO,QAAQ,OAA0C;AACxD,WAAO,wBAAwB,YAAuB,EAAE,SAAS,MAAO,CAAA;AAAA,EACzE;AAAA,EAEO,SAAS;AACf,WAAO,wBAAwB,YAA0C,EAAE,QAAQ,KAAM,CAAA;AAAA,EAC1F;AAAA,EAEO,aAAa;AACnB,WAAO,wBAAwB,YAA0C,EAAE,YAAY,KAAM,CAAA;AAAA,EAC9F;AAAA,EAEO,OAAO,MAAwD;AAC/D,UAAA,eAAe,iBAAiB,YAAY,IAAI;AAC/C,WAAA,iBAAiB,SAAY,OAAO,IAAI,wBAAwB,EAAE,QAAQ,cAAc;AAAA,EAChG;AAAA,EAEO,OACN,QACA,QACC;AACK,UAAA,iBAAiB,iBAAiB,YAAY,MAAM;AACpD,UAAA,iBAAiB,iBAAiB,YAAY,MAAM;AAE1D,WAAO,mBAAmB,UAAa,mBAAmB,SACvD,OACA,wBAAwB,YAA0C;AAAA,MAClE,QAAQ;AAAA,QACP,QAAQ,kBAAkB,CAAC;AAAA,QAC3B,QAAQ,kBAAkB,CAAC;AAAA,MAC5B;AAAA,IAAA,CACC;AAAA,EACL;AACD;"}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
var __defProp = Object.defineProperty;
|
|
2
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
|
-
var __publicField = (obj, key, value) => {
|
|
4
|
-
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
5
|
-
return value;
|
|
6
|
-
};
|
|
7
|
-
var WriteOperation;
|
|
8
|
-
((WriteOperation2) => {
|
|
9
|
-
class Operation {
|
|
10
|
-
}
|
|
11
|
-
WriteOperation2.Operation = Operation;
|
|
12
|
-
class ContentfulOperation extends Operation {
|
|
13
|
-
}
|
|
14
|
-
WriteOperation2.ContentfulOperation = ContentfulOperation;
|
|
15
|
-
class Update extends ContentfulOperation {
|
|
16
|
-
constructor() {
|
|
17
|
-
super(...arguments);
|
|
18
|
-
__publicField(this, "op", "update");
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
WriteOperation2.Update = Update;
|
|
22
|
-
class Create extends ContentfulOperation {
|
|
23
|
-
constructor() {
|
|
24
|
-
super(...arguments);
|
|
25
|
-
__publicField(this, "op", "create");
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
WriteOperation2.Create = Create;
|
|
29
|
-
class Delete extends Operation {
|
|
30
|
-
constructor() {
|
|
31
|
-
super(...arguments);
|
|
32
|
-
__publicField(this, "op", "delete");
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
WriteOperation2.Delete = Delete;
|
|
36
|
-
})(WriteOperation || (WriteOperation = {}));
|
|
37
|
-
export {
|
|
38
|
-
WriteOperation
|
|
39
|
-
};
|
|
40
|
-
//# sourceMappingURL=types.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sources":["../../../src/crudQueryBuilder/types.ts"],"sourcesContent":["import { GraphQlLiteral } from '../graphQlBuilder'\n\nexport type Mutations = 'create' | 'update' | 'delete'\n\nexport type Queries = 'get' | 'list' | 'paginate'\n\nexport type GetQueryArguments = 'by'\n\nexport type ListQueryArguments = 'filter' | 'orderBy' | 'offset' | 'limit'\n\nexport type PaginateQueryArguments = 'filter' | 'orderBy' | 'skip' | 'first'\n\nexport type CreateMutationArguments = 'data'\n\nexport type UpdateMutationArguments = 'data' | 'by'\n\nexport type DeleteMutationArguments = 'by'\n\nexport type ReductionArguments = 'filter' | 'by'\n\nexport type HasOneArguments = 'filter'\n\nexport type HasManyArguments = 'filter' | 'orderBy' | 'offset' | 'limit'\n\nexport type UpdateMutationFields = 'ok' | 'validation' | 'errors' | 'errorMessage' | 'node'\n\nexport type CreateMutationFields = 'ok' | 'validation' | 'errors' | 'errorMessage' | 'node'\n\nexport type DeleteMutationFields = 'ok' | 'node' | 'errors' | 'errorMessage'\n\nexport type WriteArguments = CreateMutationArguments | UpdateMutationArguments | DeleteMutationArguments\n\nexport type WriteFields = UpdateMutationFields | CreateMutationFields\n\nexport type ReadArguments =\n\t| GetQueryArguments\n\t| ListQueryArguments\n\t| PaginateQueryArguments\n\t| HasOneArguments\n\t| HasManyArguments\n\nexport interface WriteRelationOps {\n\tcreate: 'create' | 'connect'\n\tupdate: 'create' | 'connect' | 'delete' | 'disconnect' | 'update' | 'upsert'\n}\n\nexport type OrderDirection = GraphQlLiteral<'asc'> | GraphQlLiteral<'desc'>\n\n// TODO Silly enums because TS does not support enum extension 🙄\n// https://github.com/Microsoft/TypeScript/issues/17592\nexport namespace WriteOperation {\n\texport interface Operation {\n\t\top: 'create' | 'update' | 'delete'\n\t}\n\texport abstract class Operation implements Operation {}\n\n\texport interface ContentfulOperation {\n\t\top: 'create' | 'update'\n\t}\n\texport abstract class ContentfulOperation extends Operation implements ContentfulOperation {}\n\n\texport class Update extends ContentfulOperation {\n\t\toverride readonly op = 'update' as const\n\t}\n\n\texport class Create extends ContentfulOperation {\n\t\toverride readonly op = 'create' as const\n\t}\n\n\texport class Delete extends Operation {\n\t\toverride readonly op = 'delete' as const\n\t}\n}\n"],"names":["WriteOperation"],"mappings":";;;;;;AAkDiB,IAAA;AAAA,CAAV,CAAUA,oBAAV;AAIC,QAAe,UAA+B;AAAA,EAAC;AAA/CA,kBAAe,YAAA;AAKf,QAAe,4BAA4B,UAAyC;AAAA,EAAC;AAArFA,kBAAe,sBAAA;AAEf,QAAM,eAAe,oBAAoB;AAAA,IAAzC;AAAA;AACY,gCAAK;AAAA;AAAA,EACxB;AAFOA,kBAAM,SAAA;AAIN,QAAM,eAAe,oBAAoB;AAAA,IAAzC;AAAA;AACY,gCAAK;AAAA;AAAA,EACxB;AAFOA,kBAAM,SAAA;AAIN,QAAM,eAAe,UAAU;AAAA,IAA/B;AAAA;AACY,gCAAK;AAAA;AAAA,EACxB;AAFOA,kBAAM,SAAA;AAAA,GAnBG,mBAAA,iBAAA,CAAA,EAAA;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"GraphQlBuilderError.js","sources":["../../../src/graphQlBuilder/GraphQlBuilderError.ts"],"sourcesContent":["export class GraphQlBuilderError extends Error {}\n"],"names":[],"mappings":"AAAO,MAAM,4BAA4B,MAAM;AAAC;"}
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
class ObjectBuilder {
|
|
2
|
-
constructor(fields = [], objects = {}, args = {}, fragmentApplications = [], inlineFragments = {}, objectName) {
|
|
3
|
-
this.fields = fields;
|
|
4
|
-
this.objects = objects;
|
|
5
|
-
this.args = args;
|
|
6
|
-
this.fragmentApplications = fragmentApplications;
|
|
7
|
-
this.inlineFragments = inlineFragments;
|
|
8
|
-
this.objectName = objectName;
|
|
9
|
-
}
|
|
10
|
-
argument(name, value) {
|
|
11
|
-
return new ObjectBuilder(
|
|
12
|
-
this.fields,
|
|
13
|
-
this.objects,
|
|
14
|
-
{ ...this.args, [name]: value },
|
|
15
|
-
this.fragmentApplications,
|
|
16
|
-
this.inlineFragments,
|
|
17
|
-
this.objectName
|
|
18
|
-
);
|
|
19
|
-
}
|
|
20
|
-
name(name) {
|
|
21
|
-
return new ObjectBuilder(
|
|
22
|
-
this.fields,
|
|
23
|
-
this.objects,
|
|
24
|
-
this.args,
|
|
25
|
-
this.fragmentApplications,
|
|
26
|
-
this.inlineFragments,
|
|
27
|
-
name
|
|
28
|
-
);
|
|
29
|
-
}
|
|
30
|
-
field(name) {
|
|
31
|
-
return new ObjectBuilder(
|
|
32
|
-
[...this.fields, name],
|
|
33
|
-
this.objects,
|
|
34
|
-
this.args,
|
|
35
|
-
this.fragmentApplications,
|
|
36
|
-
this.inlineFragments,
|
|
37
|
-
this.objectName
|
|
38
|
-
);
|
|
39
|
-
}
|
|
40
|
-
object(name, builder) {
|
|
41
|
-
if (!(builder instanceof ObjectBuilder)) {
|
|
42
|
-
builder = builder(new ObjectBuilder());
|
|
43
|
-
}
|
|
44
|
-
return new ObjectBuilder(
|
|
45
|
-
this.fields,
|
|
46
|
-
{ ...this.objects, [name]: builder },
|
|
47
|
-
this.args,
|
|
48
|
-
this.fragmentApplications,
|
|
49
|
-
this.inlineFragments,
|
|
50
|
-
this.objectName
|
|
51
|
-
);
|
|
52
|
-
}
|
|
53
|
-
inlineFragment(typeName, builder) {
|
|
54
|
-
if (!(builder instanceof ObjectBuilder)) {
|
|
55
|
-
builder = builder(new ObjectBuilder());
|
|
56
|
-
}
|
|
57
|
-
return new ObjectBuilder(
|
|
58
|
-
this.fields,
|
|
59
|
-
this.objects,
|
|
60
|
-
this.args,
|
|
61
|
-
this.fragmentApplications,
|
|
62
|
-
{ ...this.inlineFragments, [typeName]: builder },
|
|
63
|
-
this.objectName
|
|
64
|
-
);
|
|
65
|
-
}
|
|
66
|
-
applyFragment(fragmentName) {
|
|
67
|
-
return new ObjectBuilder(
|
|
68
|
-
this.fields,
|
|
69
|
-
this.objects,
|
|
70
|
-
this.args,
|
|
71
|
-
[...this.fragmentApplications, fragmentName],
|
|
72
|
-
this.inlineFragments,
|
|
73
|
-
this.objectName
|
|
74
|
-
);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
export {
|
|
78
|
-
ObjectBuilder
|
|
79
|
-
};
|
|
80
|
-
//# sourceMappingURL=ObjectBuilder.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ObjectBuilder.js","sources":["../../../src/graphQlBuilder/ObjectBuilder.ts"],"sourcesContent":["export class ObjectBuilder {\n\tconstructor(\n\t\tpublic readonly fields: string[] = [],\n\t\tpublic readonly objects: { [name: string]: ObjectBuilder } = {},\n\t\tpublic readonly args: { [name: string]: any } = {},\n\t\tpublic readonly fragmentApplications: string[] = [],\n\t\tpublic readonly inlineFragments: { [typeName: string]: ObjectBuilder } = {},\n\t\tpublic readonly objectName?: string,\n\t) {}\n\n\tpublic argument(name: string, value: any): ObjectBuilder {\n\t\treturn new ObjectBuilder(\n\t\t\tthis.fields,\n\t\t\tthis.objects,\n\t\t\t{ ...this.args, [name]: value },\n\t\t\tthis.fragmentApplications,\n\t\t\tthis.inlineFragments,\n\t\t\tthis.objectName,\n\t\t)\n\t}\n\n\tpublic name(name: string): ObjectBuilder {\n\t\treturn new ObjectBuilder(\n\t\t\tthis.fields,\n\t\t\tthis.objects,\n\t\t\tthis.args,\n\t\t\tthis.fragmentApplications,\n\t\t\tthis.inlineFragments,\n\t\t\tname,\n\t\t)\n\t}\n\n\tpublic field(name: string): ObjectBuilder {\n\t\treturn new ObjectBuilder(\n\t\t\t[...this.fields, name],\n\t\t\tthis.objects,\n\t\t\tthis.args,\n\t\t\tthis.fragmentApplications,\n\t\t\tthis.inlineFragments,\n\t\t\tthis.objectName,\n\t\t)\n\t}\n\n\tpublic object(name: string, builder: ((builder: ObjectBuilder) => ObjectBuilder) | ObjectBuilder): ObjectBuilder {\n\t\tif (!(builder instanceof ObjectBuilder)) {\n\t\t\tbuilder = builder(new ObjectBuilder())\n\t\t}\n\n\t\treturn new ObjectBuilder(\n\t\t\tthis.fields,\n\t\t\t{ ...this.objects, [name]: builder },\n\t\t\tthis.args,\n\t\t\tthis.fragmentApplications,\n\t\t\tthis.inlineFragments,\n\t\t\tthis.objectName,\n\t\t)\n\t}\n\n\tpublic inlineFragment(\n\t\ttypeName: string,\n\t\tbuilder: ((builder: ObjectBuilder) => ObjectBuilder) | ObjectBuilder,\n\t): ObjectBuilder {\n\t\tif (!(builder instanceof ObjectBuilder)) {\n\t\t\tbuilder = builder(new ObjectBuilder())\n\t\t}\n\n\t\treturn new ObjectBuilder(\n\t\t\tthis.fields,\n\t\t\tthis.objects,\n\t\t\tthis.args,\n\t\t\tthis.fragmentApplications,\n\t\t\t{ ...this.inlineFragments, [typeName]: builder },\n\t\t\tthis.objectName,\n\t\t)\n\t}\n\n\tpublic applyFragment(fragmentName: string): ObjectBuilder {\n\t\treturn new ObjectBuilder(\n\t\t\tthis.fields,\n\t\t\tthis.objects,\n\t\t\tthis.args,\n\t\t\t[...this.fragmentApplications, fragmentName],\n\t\t\tthis.inlineFragments,\n\t\t\tthis.objectName,\n\t\t)\n\t}\n}\n"],"names":[],"mappings":"AAAO,MAAM,cAAc;AAAA,EAC1B,YACiB,SAAmB,IACnB,UAA6C,CAAA,GAC7C,OAAgC,CAAC,GACjC,uBAAiC,CAAC,GAClC,kBAAyD,CAAA,GACzD,YACf;AANe,SAAA,SAAA;AACA,SAAA,UAAA;AACA,SAAA,OAAA;AACA,SAAA,uBAAA;AACA,SAAA,kBAAA;AACA,SAAA,aAAA;AAAA,EACd;AAAA,EAEI,SAAS,MAAc,OAA2B;AACxD,WAAO,IAAI;AAAA,MACV,KAAK;AAAA,MACL,KAAK;AAAA,MACL,EAAE,GAAG,KAAK,MAAM,CAAC,IAAI,GAAG,MAAM;AAAA,MAC9B,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,IAAA;AAAA,EAEP;AAAA,EAEO,KAAK,MAA6B;AACxC,WAAO,IAAI;AAAA,MACV,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL;AAAA,IAAA;AAAA,EAEF;AAAA,EAEO,MAAM,MAA6B;AACzC,WAAO,IAAI;AAAA,MACV,CAAC,GAAG,KAAK,QAAQ,IAAI;AAAA,MACrB,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,IAAA;AAAA,EAEP;AAAA,EAEO,OAAO,MAAc,SAAqF;AAC5G,QAAA,EAAE,mBAAmB,gBAAgB;AAC9B,gBAAA,QAAQ,IAAI,cAAA,CAAe;AAAA,IACtC;AAEA,WAAO,IAAI;AAAA,MACV,KAAK;AAAA,MACL,EAAE,GAAG,KAAK,SAAS,CAAC,IAAI,GAAG,QAAQ;AAAA,MACnC,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,IAAA;AAAA,EAEP;AAAA,EAEO,eACN,UACA,SACgB;AACZ,QAAA,EAAE,mBAAmB,gBAAgB;AAC9B,gBAAA,QAAQ,IAAI,cAAA,CAAe;AAAA,IACtC;AAEA,WAAO,IAAI;AAAA,MACV,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,EAAE,GAAG,KAAK,iBAAiB,CAAC,QAAQ,GAAG,QAAQ;AAAA,MAC/C,KAAK;AAAA,IAAA;AAAA,EAEP;AAAA,EAEO,cAAc,cAAqC;AACzD,WAAO,IAAI;AAAA,MACV,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,CAAC,GAAG,KAAK,sBAAsB,YAAY;AAAA,MAC3C,KAAK;AAAA,MACL,KAAK;AAAA,IAAA;AAAA,EAEP;AACD;"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { QueryCompiler } from "./QueryCompiler.js";
|
|
2
|
-
import { RootObjectBuilder } from "./RootObjectBuilder.js";
|
|
3
|
-
class QueryBuilder {
|
|
4
|
-
query(builder) {
|
|
5
|
-
if (!(builder instanceof RootObjectBuilder)) {
|
|
6
|
-
builder = builder(new RootObjectBuilder());
|
|
7
|
-
}
|
|
8
|
-
const compiler = new QueryCompiler("query", builder);
|
|
9
|
-
return compiler.create();
|
|
10
|
-
}
|
|
11
|
-
mutation(builder) {
|
|
12
|
-
if (!(builder instanceof RootObjectBuilder)) {
|
|
13
|
-
builder = builder(new RootObjectBuilder());
|
|
14
|
-
}
|
|
15
|
-
const compiler = new QueryCompiler("mutation", builder);
|
|
16
|
-
return compiler.create();
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
export {
|
|
20
|
-
QueryBuilder
|
|
21
|
-
};
|
|
22
|
-
//# sourceMappingURL=QueryBuilder.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"QueryBuilder.js","sources":["../../../src/graphQlBuilder/QueryBuilder.ts"],"sourcesContent":["import type { GraphQlLiteral } from './GraphQlLiteral'\nimport { QueryCompiler } from './QueryCompiler'\nimport { RootObjectBuilder } from './RootObjectBuilder'\n\nclass QueryBuilder {\n\tquery(builder: ((builder: RootObjectBuilder) => RootObjectBuilder) | RootObjectBuilder): string {\n\t\tif (!(builder instanceof RootObjectBuilder)) {\n\t\t\tbuilder = builder(new RootObjectBuilder())\n\t\t}\n\t\tconst compiler = new QueryCompiler('query', builder)\n\t\treturn compiler.create()\n\t}\n\n\tmutation(builder: ((builder: RootObjectBuilder) => RootObjectBuilder) | RootObjectBuilder): string {\n\t\tif (!(builder instanceof RootObjectBuilder)) {\n\t\t\tbuilder = builder(new RootObjectBuilder())\n\t\t}\n\t\tconst compiler = new QueryCompiler('mutation', builder)\n\t\treturn compiler.create()\n\t}\n}\n\nnamespace QueryBuilder {\n\texport interface Object {\n\t\t[key: string]: Value\n\t}\n\n\texport interface List extends Array<Value> {}\n\n\texport type AtomicValue = string | null | number | boolean | GraphQlLiteral\n\texport type Value = AtomicValue | QueryBuilder.Object | List\n}\n\nexport { QueryBuilder }\n"],"names":[],"mappings":";;AAIA,MAAM,aAAa;AAAA,EAClB,MAAM,SAA0F;AAC3F,QAAA,EAAE,mBAAmB,oBAAoB;AAClC,gBAAA,QAAQ,IAAI,kBAAA,CAAmB;AAAA,IAC1C;AACA,UAAM,WAAW,IAAI,cAAc,SAAS,OAAO;AACnD,WAAO,SAAS;EACjB;AAAA,EAEA,SAAS,SAA0F;AAC9F,QAAA,EAAE,mBAAmB,oBAAoB;AAClC,gBAAA,QAAQ,IAAI,kBAAA,CAAmB;AAAA,IAC1C;AACA,UAAM,WAAW,IAAI,cAAc,YAAY,OAAO;AACtD,WAAO,SAAS;EACjB;AACD;"}
|
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
import { GraphQlLiteral } from "./GraphQlLiteral.js";
|
|
2
|
-
class QueryCompiler {
|
|
3
|
-
constructor(operation, builder) {
|
|
4
|
-
this.operation = operation;
|
|
5
|
-
this.builder = builder;
|
|
6
|
-
}
|
|
7
|
-
create() {
|
|
8
|
-
const rootObjects = this.formatRootObjects(this.builder.objects);
|
|
9
|
-
const fragmentDefinitions = this.formatFragmentDefinitions(this.builder.fragmentDefinitions);
|
|
10
|
-
return `${this.operation} {
|
|
11
|
-
${rootObjects}
|
|
12
|
-
}${fragmentDefinitions ? `
|
|
13
|
-
${fragmentDefinitions}` : ""}`;
|
|
14
|
-
}
|
|
15
|
-
formatFragmentDefinitions(fragments) {
|
|
16
|
-
const lines = [];
|
|
17
|
-
for (const name in fragments) {
|
|
18
|
-
const object = fragments[name];
|
|
19
|
-
lines.push(`fragment ${name} on ${object.objectName} {`);
|
|
20
|
-
lines.push(...this.formatObjectBody(object));
|
|
21
|
-
lines.push("}");
|
|
22
|
-
}
|
|
23
|
-
return lines.join("\n");
|
|
24
|
-
}
|
|
25
|
-
formatRootObjects(objects) {
|
|
26
|
-
const lines = [];
|
|
27
|
-
for (const alias in objects) {
|
|
28
|
-
lines.push(...this.formatObject(alias, objects[alias]).map((val) => ` ${val}`));
|
|
29
|
-
}
|
|
30
|
-
return lines.join("\n");
|
|
31
|
-
}
|
|
32
|
-
formatObject(alias, builder) {
|
|
33
|
-
const result = [];
|
|
34
|
-
result.push(`${alias}${builder.objectName ? `: ${builder.objectName}` : ""}${this.formatArgs(builder.args, 0)} {`);
|
|
35
|
-
result.push(...this.formatObjectBody(builder));
|
|
36
|
-
result.push("}");
|
|
37
|
-
return result;
|
|
38
|
-
}
|
|
39
|
-
formatObjectBody(builder) {
|
|
40
|
-
const result = ["__typename"];
|
|
41
|
-
for (const fieldName of builder.fields) {
|
|
42
|
-
result.push(fieldName);
|
|
43
|
-
}
|
|
44
|
-
for (const fragmentName of builder.fragmentApplications) {
|
|
45
|
-
result.push(`... ${fragmentName}`);
|
|
46
|
-
}
|
|
47
|
-
for (const typeName in builder.inlineFragments) {
|
|
48
|
-
const fragment = builder.inlineFragments[typeName];
|
|
49
|
-
result.push(`... on ${typeName} {`, ...this.formatObjectBody(fragment), "}");
|
|
50
|
-
}
|
|
51
|
-
for (const alias in builder.objects) {
|
|
52
|
-
result.push(...this.formatObject(alias, builder.objects[alias]));
|
|
53
|
-
}
|
|
54
|
-
return result.map((val) => ` ${val}`);
|
|
55
|
-
}
|
|
56
|
-
formatArgs(args, level) {
|
|
57
|
-
if (args === null) {
|
|
58
|
-
return "null";
|
|
59
|
-
}
|
|
60
|
-
if (typeof args === "number") {
|
|
61
|
-
return args.toString();
|
|
62
|
-
}
|
|
63
|
-
if (typeof args === "boolean") {
|
|
64
|
-
return args ? "true" : "false";
|
|
65
|
-
}
|
|
66
|
-
if (typeof args === "string") {
|
|
67
|
-
return JSON.stringify(args);
|
|
68
|
-
}
|
|
69
|
-
if (Array.isArray(args)) {
|
|
70
|
-
const vals = args.map((val) => this.formatArgs(val, level + 1));
|
|
71
|
-
return `[${vals.join(", ")}]`;
|
|
72
|
-
}
|
|
73
|
-
if (args instanceof GraphQlLiteral) {
|
|
74
|
-
return args.value;
|
|
75
|
-
}
|
|
76
|
-
if (typeof args === "object") {
|
|
77
|
-
let result = "";
|
|
78
|
-
for (let key in args) {
|
|
79
|
-
const argValue = args[key];
|
|
80
|
-
if (argValue === void 0) {
|
|
81
|
-
continue;
|
|
82
|
-
}
|
|
83
|
-
result += `${key}: ${this.formatArgs(argValue, level + 1)}, `;
|
|
84
|
-
}
|
|
85
|
-
if (result.length > 0) {
|
|
86
|
-
result = result.substring(0, result.length - 2);
|
|
87
|
-
}
|
|
88
|
-
if (level > 0) {
|
|
89
|
-
return `{${result}}`;
|
|
90
|
-
} else if (result.length > 0) {
|
|
91
|
-
return `(${result})`;
|
|
92
|
-
}
|
|
93
|
-
return "";
|
|
94
|
-
}
|
|
95
|
-
throw new Error(typeof args);
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
export {
|
|
99
|
-
QueryCompiler
|
|
100
|
-
};
|
|
101
|
-
//# sourceMappingURL=QueryCompiler.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"QueryCompiler.js","sources":["../../../src/graphQlBuilder/QueryCompiler.ts"],"sourcesContent":["import { GraphQlLiteral } from './GraphQlLiteral'\nimport type { ObjectBuilder } from './ObjectBuilder'\nimport type { RootObjectBuilder } from './RootObjectBuilder'\n\nexport class QueryCompiler {\n\tconstructor(private operation: 'query' | 'mutation', private builder: RootObjectBuilder) {}\n\n\tpublic create(): string {\n\t\tconst rootObjects = this.formatRootObjects(this.builder.objects)\n\t\tconst fragmentDefinitions = this.formatFragmentDefinitions(this.builder.fragmentDefinitions)\n\n\t\treturn `${this.operation} {\\n${rootObjects}\\n}${fragmentDefinitions ? `\\n${fragmentDefinitions}` : ''}`\n\t}\n\n\tprivate formatFragmentDefinitions(fragments: RootObjectBuilder['fragmentDefinitions']): string {\n\t\tconst lines: string[] = []\n\n\t\tfor (const name in fragments) {\n\t\t\tconst object = fragments[name]\n\n\t\t\tlines.push(`fragment ${name} on ${object.objectName!} {`)\n\t\t\tlines.push(...this.formatObjectBody(object))\n\t\t\tlines.push('}')\n\t\t}\n\n\t\treturn lines.join('\\n')\n\t}\n\n\tprivate formatRootObjects(objects: RootObjectBuilder['objects']): string {\n\t\tconst lines: string[] = []\n\n\t\tfor (const alias in objects) {\n\t\t\tlines.push(...this.formatObject(alias, objects[alias]).map(val => `\\t${val}`))\n\t\t}\n\n\t\treturn lines.join('\\n')\n\t}\n\n\tprivate formatObject(alias: string, builder: ObjectBuilder): string[] {\n\t\tconst result = []\n\n\t\tresult.push(`${alias}${builder.objectName ? `: ${builder.objectName}` : ''}${this.formatArgs(builder.args, 0)} {`)\n\n\t\tresult.push(...this.formatObjectBody(builder))\n\n\t\tresult.push('}')\n\n\t\treturn result\n\t}\n\n\tprivate formatObjectBody(builder: ObjectBuilder): string[] {\n\t\tconst result = ['__typename']\n\t\tfor (const fieldName of builder.fields) {\n\t\t\tresult.push(fieldName)\n\t\t}\n\t\tfor (const fragmentName of builder.fragmentApplications) {\n\t\t\tresult.push(`... ${fragmentName}`)\n\t\t}\n\t\tfor (const typeName in builder.inlineFragments) {\n\t\t\tconst fragment = builder.inlineFragments[typeName]\n\t\t\tresult.push(`... on ${typeName} {`, ...this.formatObjectBody(fragment), '}')\n\t\t}\n\t\tfor (const alias in builder.objects) {\n\t\t\tresult.push(...this.formatObject(alias, builder.objects[alias]))\n\t\t}\n\t\treturn result.map(val => `\\t${val}`)\n\t}\n\n\tprivate formatArgs(args: any, level: number): string {\n\t\tif (args === null) {\n\t\t\treturn 'null'\n\t\t}\n\n\t\tif (typeof args === 'number') {\n\t\t\treturn args.toString()\n\t\t}\n\n\t\tif (typeof args === 'boolean') {\n\t\t\treturn args ? 'true' : 'false'\n\t\t}\n\t\tif (typeof args === 'string') {\n\t\t\treturn JSON.stringify(args)\n\t\t}\n\n\t\tif (Array.isArray(args)) {\n\t\t\tconst vals = args.map(val => this.formatArgs(val, level + 1))\n\t\t\treturn `[${vals.join(', ')}]`\n\t\t}\n\t\tif (args instanceof GraphQlLiteral) {\n\t\t\treturn args.value\n\t\t}\n\n\t\tif (typeof args === 'object') {\n\t\t\tlet result = ''\n\t\t\tfor (let key in args) {\n\t\t\t\tconst argValue = args[key]\n\t\t\t\tif (argValue === undefined) {\n\t\t\t\t\tcontinue\n\t\t\t\t}\n\t\t\t\tresult += `${key}: ${this.formatArgs(argValue, level + 1)}, `\n\t\t\t}\n\t\t\tif (result.length > 0) {\n\t\t\t\tresult = result.substring(0, result.length - 2)\n\t\t\t}\n\t\t\tif (level > 0) {\n\t\t\t\treturn `{${result}}`\n\t\t\t} else if (result.length > 0) {\n\t\t\t\treturn `(${result})`\n\t\t\t}\n\t\t\treturn ''\n\t\t}\n\n\t\tthrow new Error(typeof args)\n\t}\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import { GraphQlBuilderError } from "./GraphQlBuilderError.js";
|
|
2
|
-
import { ObjectBuilder } from "./ObjectBuilder.js";
|
|
3
|
-
import { isEmptyObject } from "../utils/isEmptyObject.js";
|
|
4
|
-
class RootObjectBuilder {
|
|
5
|
-
constructor(objects = {}, fragmentDefinitions = {}) {
|
|
6
|
-
this.objects = objects;
|
|
7
|
-
this.fragmentDefinitions = fragmentDefinitions;
|
|
8
|
-
}
|
|
9
|
-
fragment(name, builder) {
|
|
10
|
-
if (!(builder instanceof ObjectBuilder)) {
|
|
11
|
-
builder = builder(new ObjectBuilder());
|
|
12
|
-
}
|
|
13
|
-
if (!isEmptyObject(builder.args)) {
|
|
14
|
-
throw new GraphQlBuilderError(`Cannot supply args to Graph QL fragments!`);
|
|
15
|
-
}
|
|
16
|
-
if (!builder.objectName) {
|
|
17
|
-
throw new GraphQlBuilderError(`Object names are mandatory for Graph QL fragments!`);
|
|
18
|
-
}
|
|
19
|
-
return new RootObjectBuilder(this.objects, { ...this.fragmentDefinitions, [name]: builder });
|
|
20
|
-
}
|
|
21
|
-
object(name, builder) {
|
|
22
|
-
if (!(builder instanceof ObjectBuilder)) {
|
|
23
|
-
builder = builder(new ObjectBuilder());
|
|
24
|
-
}
|
|
25
|
-
return new RootObjectBuilder({ ...this.objects, [name]: builder }, this.fragmentDefinitions);
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
export {
|
|
29
|
-
RootObjectBuilder
|
|
30
|
-
};
|
|
31
|
-
//# sourceMappingURL=RootObjectBuilder.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RootObjectBuilder.js","sources":["../../../src/graphQlBuilder/RootObjectBuilder.ts"],"sourcesContent":["import { isEmptyObject } from '../utils'\nimport { GraphQlBuilderError } from './GraphQlBuilderError'\nimport { ObjectBuilder } from './ObjectBuilder'\n\nexport class RootObjectBuilder {\n\tconstructor(\n\t\tpublic readonly objects: { [name: string]: ObjectBuilder } = {},\n\t\tpublic readonly fragmentDefinitions: { [name: string]: ObjectBuilder } = {},\n\t) {}\n\n\tpublic fragment(\n\t\tname: string,\n\t\tbuilder: ((builder: ObjectBuilder) => ObjectBuilder) | ObjectBuilder,\n\t): RootObjectBuilder {\n\t\tif (!(builder instanceof ObjectBuilder)) {\n\t\t\tbuilder = builder(new ObjectBuilder())\n\t\t}\n\n\t\tif (!isEmptyObject(builder.args)) {\n\t\t\tthrow new GraphQlBuilderError(`Cannot supply args to Graph QL fragments!`)\n\t\t}\n\t\tif (!builder.objectName) {\n\t\t\tthrow new GraphQlBuilderError(`Object names are mandatory for Graph QL fragments!`)\n\t\t}\n\n\t\treturn new RootObjectBuilder(this.objects, { ...this.fragmentDefinitions, [name]: builder })\n\t}\n\n\tpublic object(name: string, builder: ((builder: ObjectBuilder) => ObjectBuilder) | ObjectBuilder): RootObjectBuilder {\n\t\tif (!(builder instanceof ObjectBuilder)) {\n\t\t\tbuilder = builder(new ObjectBuilder())\n\t\t}\n\n\t\treturn new RootObjectBuilder({ ...this.objects, [name]: builder }, this.fragmentDefinitions)\n\t}\n}\n"],"names":[],"mappings":";;;AAIO,MAAM,kBAAkB;AAAA,EAC9B,YACiB,UAA6C,IAC7C,sBAAyD,CAAA,GACxE;AAFe,SAAA,UAAA;AACA,SAAA,sBAAA;AAAA,EACd;AAAA,EAEI,SACN,MACA,SACoB;AAChB,QAAA,EAAE,mBAAmB,gBAAgB;AAC9B,gBAAA,QAAQ,IAAI,cAAA,CAAe;AAAA,IACtC;AAEA,QAAI,CAAC,cAAc,QAAQ,IAAI,GAAG;AAC3B,YAAA,IAAI,oBAAoB,2CAA2C;AAAA,IAC1E;AACI,QAAA,CAAC,QAAQ,YAAY;AAClB,YAAA,IAAI,oBAAoB,oDAAoD;AAAA,IACnF;AAEA,WAAO,IAAI,kBAAkB,KAAK,SAAS,EAAE,GAAG,KAAK,qBAAqB,CAAC,IAAI,GAAG,QAAA,CAAS;AAAA,EAC5F;AAAA,EAEO,OAAO,MAAc,SAAyF;AAChH,QAAA,EAAE,mBAAmB,gBAAgB;AAC9B,gBAAA,QAAQ,IAAI,cAAA,CAAe;AAAA,IACtC;AAEA,WAAO,IAAI,kBAAkB,EAAE,GAAG,KAAK,SAAS,CAAC,IAAI,GAAG,QAAW,GAAA,KAAK,mBAAmB;AAAA,EAC5F;AACD;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"isEmptyObject.js","sources":["../../../src/utils/isEmptyObject.ts"],"sourcesContent":["export const isEmptyObject = (arg: object): boolean => {\n\t// This is faster than Object.keys(arg).length === 0 && arg.constructor === Object\n\tfor (const key in arg) {\n\t\tif (arg.hasOwnProperty(key)) {\n\t\t\treturn false\n\t\t}\n\t}\n\treturn true\n}\n"],"names":[],"mappings":"AAAa,MAAA,gBAAgB,CAAC,QAAyB;AAEtD,aAAW,OAAO,KAAK;AAClB,QAAA,IAAI,eAAe,GAAG,GAAG;AACrB,aAAA;AAAA,IACR;AAAA,EACD;AACO,SAAA;AACR;"}
|