@constructive-io/graphql-codegen 2.20.1 → 2.22.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (96) hide show
  1. package/README.md +15 -3
  2. package/cli/codegen/barrel.d.ts +4 -1
  3. package/cli/codegen/barrel.js +18 -12
  4. package/cli/codegen/client.js +33 -0
  5. package/cli/codegen/custom-mutations.d.ts +11 -1
  6. package/cli/codegen/custom-mutations.js +49 -15
  7. package/cli/codegen/custom-queries.d.ts +8 -0
  8. package/cli/codegen/custom-queries.js +82 -47
  9. package/cli/codegen/gql-ast.js +9 -5
  10. package/cli/codegen/index.js +39 -8
  11. package/cli/codegen/mutations.d.ts +14 -4
  12. package/cli/codegen/mutations.js +114 -28
  13. package/cli/codegen/orm/barrel.js +4 -2
  14. package/cli/codegen/orm/index.js +17 -0
  15. package/cli/codegen/orm/input-types-generator.js +83 -29
  16. package/cli/codegen/orm/model-generator.js +6 -4
  17. package/cli/codegen/queries.d.ts +7 -3
  18. package/cli/codegen/queries.js +185 -158
  19. package/cli/codegen/scalars.d.ts +6 -4
  20. package/cli/codegen/scalars.js +17 -9
  21. package/cli/codegen/schema-types-generator.d.ts +26 -0
  22. package/cli/codegen/schema-types-generator.js +365 -0
  23. package/cli/codegen/ts-ast.d.ts +3 -1
  24. package/cli/codegen/ts-ast.js +2 -2
  25. package/cli/codegen/type-resolver.d.ts +52 -6
  26. package/cli/codegen/type-resolver.js +97 -19
  27. package/cli/codegen/types.d.ts +7 -4
  28. package/cli/codegen/types.js +94 -41
  29. package/cli/codegen/utils.d.ts +20 -2
  30. package/cli/codegen/utils.js +32 -7
  31. package/cli/commands/generate-orm.js +5 -5
  32. package/cli/commands/generate.d.ts +4 -1
  33. package/cli/commands/generate.js +27 -8
  34. package/cli/introspect/transform-schema.d.ts +33 -21
  35. package/cli/introspect/transform-schema.js +31 -21
  36. package/esm/cli/codegen/barrel.d.ts +4 -1
  37. package/esm/cli/codegen/barrel.js +18 -12
  38. package/esm/cli/codegen/client.js +33 -0
  39. package/esm/cli/codegen/custom-mutations.d.ts +11 -1
  40. package/esm/cli/codegen/custom-mutations.js +50 -16
  41. package/esm/cli/codegen/custom-queries.d.ts +8 -0
  42. package/esm/cli/codegen/custom-queries.js +83 -48
  43. package/esm/cli/codegen/gql-ast.js +10 -6
  44. package/esm/cli/codegen/index.js +39 -8
  45. package/esm/cli/codegen/mutations.d.ts +14 -4
  46. package/esm/cli/codegen/mutations.js +115 -29
  47. package/esm/cli/codegen/orm/barrel.js +4 -2
  48. package/esm/cli/codegen/orm/index.js +17 -0
  49. package/esm/cli/codegen/orm/input-types-generator.js +83 -29
  50. package/esm/cli/codegen/orm/model-generator.js +7 -5
  51. package/esm/cli/codegen/queries.d.ts +7 -3
  52. package/esm/cli/codegen/queries.js +186 -159
  53. package/esm/cli/codegen/scalars.d.ts +6 -4
  54. package/esm/cli/codegen/scalars.js +16 -8
  55. package/esm/cli/codegen/schema-types-generator.d.ts +26 -0
  56. package/esm/cli/codegen/schema-types-generator.js +362 -0
  57. package/esm/cli/codegen/ts-ast.d.ts +3 -1
  58. package/esm/cli/codegen/ts-ast.js +2 -2
  59. package/esm/cli/codegen/type-resolver.d.ts +52 -6
  60. package/esm/cli/codegen/type-resolver.js +97 -20
  61. package/esm/cli/codegen/types.d.ts +7 -4
  62. package/esm/cli/codegen/types.js +95 -41
  63. package/esm/cli/codegen/utils.d.ts +20 -2
  64. package/esm/cli/codegen/utils.js +31 -7
  65. package/esm/cli/commands/generate-orm.js +5 -5
  66. package/esm/cli/commands/generate.d.ts +4 -1
  67. package/esm/cli/commands/generate.js +27 -8
  68. package/esm/cli/introspect/transform-schema.d.ts +33 -21
  69. package/esm/cli/introspect/transform-schema.js +31 -21
  70. package/esm/types/config.d.ts +16 -1
  71. package/esm/types/config.js +6 -0
  72. package/esm/types/schema.d.ts +2 -0
  73. package/package.json +8 -6
  74. package/types/config.d.ts +16 -1
  75. package/types/config.js +6 -0
  76. package/types/schema.d.ts +2 -0
  77. package/__tests__/codegen/input-types-generator.test.d.ts +0 -1
  78. package/__tests__/codegen/input-types-generator.test.js +0 -635
  79. package/cli/codegen/filters.d.ts +0 -27
  80. package/cli/codegen/filters.js +0 -357
  81. package/cli/codegen/orm/input-types-generator.test.d.ts +0 -1
  82. package/cli/codegen/orm/input-types-generator.test.js +0 -75
  83. package/cli/codegen/orm/select-types.test.d.ts +0 -11
  84. package/cli/codegen/orm/select-types.test.js +0 -22
  85. package/cli/introspect/transform-schema.test.d.ts +0 -1
  86. package/cli/introspect/transform-schema.test.js +0 -67
  87. package/esm/__tests__/codegen/input-types-generator.test.d.ts +0 -1
  88. package/esm/__tests__/codegen/input-types-generator.test.js +0 -633
  89. package/esm/cli/codegen/filters.d.ts +0 -27
  90. package/esm/cli/codegen/filters.js +0 -351
  91. package/esm/cli/codegen/orm/input-types-generator.test.d.ts +0 -1
  92. package/esm/cli/codegen/orm/input-types-generator.test.js +0 -73
  93. package/esm/cli/codegen/orm/select-types.test.d.ts +0 -11
  94. package/esm/cli/codegen/orm/select-types.test.js +0 -21
  95. package/esm/cli/introspect/transform-schema.test.d.ts +0 -1
  96. package/esm/cli/introspect/transform-schema.test.js +0 -65
@@ -1,357 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.generateBaseFilterTypes = generateBaseFilterTypes;
4
- exports.generateTableFilter = generateTableFilter;
5
- exports.generateTableOrderBy = generateTableOrderBy;
6
- exports.generateInlineFilterTypes = generateInlineFilterTypes;
7
- const utils_1 = require("./utils");
8
- // ============================================================================
9
- // Base filter type definitions
10
- // ============================================================================
11
- /**
12
- * Generate all base PostGraphile filter types
13
- * These are shared across all tables
14
- */
15
- function generateBaseFilterTypes() {
16
- return `${(0, utils_1.getGeneratedFileHeader)('PostGraphile base filter types')}
17
-
18
- // ============================================================================
19
- // String filters
20
- // ============================================================================
21
-
22
- export interface StringFilter {
23
- isNull?: boolean;
24
- equalTo?: string;
25
- notEqualTo?: string;
26
- distinctFrom?: string;
27
- notDistinctFrom?: string;
28
- in?: string[];
29
- notIn?: string[];
30
- lessThan?: string;
31
- lessThanOrEqualTo?: string;
32
- greaterThan?: string;
33
- greaterThanOrEqualTo?: string;
34
- includes?: string;
35
- notIncludes?: string;
36
- includesInsensitive?: string;
37
- notIncludesInsensitive?: string;
38
- startsWith?: string;
39
- notStartsWith?: string;
40
- startsWithInsensitive?: string;
41
- notStartsWithInsensitive?: string;
42
- endsWith?: string;
43
- notEndsWith?: string;
44
- endsWithInsensitive?: string;
45
- notEndsWithInsensitive?: string;
46
- like?: string;
47
- notLike?: string;
48
- likeInsensitive?: string;
49
- notLikeInsensitive?: string;
50
- }
51
-
52
- export interface StringListFilter {
53
- isNull?: boolean;
54
- equalTo?: string[];
55
- notEqualTo?: string[];
56
- distinctFrom?: string[];
57
- notDistinctFrom?: string[];
58
- lessThan?: string[];
59
- lessThanOrEqualTo?: string[];
60
- greaterThan?: string[];
61
- greaterThanOrEqualTo?: string[];
62
- contains?: string[];
63
- containedBy?: string[];
64
- overlaps?: string[];
65
- anyEqualTo?: string;
66
- anyNotEqualTo?: string;
67
- anyLessThan?: string;
68
- anyLessThanOrEqualTo?: string;
69
- anyGreaterThan?: string;
70
- anyGreaterThanOrEqualTo?: string;
71
- }
72
-
73
- // ============================================================================
74
- // Numeric filters
75
- // ============================================================================
76
-
77
- export interface IntFilter {
78
- isNull?: boolean;
79
- equalTo?: number;
80
- notEqualTo?: number;
81
- distinctFrom?: number;
82
- notDistinctFrom?: number;
83
- in?: number[];
84
- notIn?: number[];
85
- lessThan?: number;
86
- lessThanOrEqualTo?: number;
87
- greaterThan?: number;
88
- greaterThanOrEqualTo?: number;
89
- }
90
-
91
- export interface IntListFilter {
92
- isNull?: boolean;
93
- equalTo?: number[];
94
- notEqualTo?: number[];
95
- distinctFrom?: number[];
96
- notDistinctFrom?: number[];
97
- lessThan?: number[];
98
- lessThanOrEqualTo?: number[];
99
- greaterThan?: number[];
100
- greaterThanOrEqualTo?: number[];
101
- contains?: number[];
102
- containedBy?: number[];
103
- overlaps?: number[];
104
- anyEqualTo?: number;
105
- anyNotEqualTo?: number;
106
- anyLessThan?: number;
107
- anyLessThanOrEqualTo?: number;
108
- anyGreaterThan?: number;
109
- anyGreaterThanOrEqualTo?: number;
110
- }
111
-
112
- export interface FloatFilter {
113
- isNull?: boolean;
114
- equalTo?: number;
115
- notEqualTo?: number;
116
- distinctFrom?: number;
117
- notDistinctFrom?: number;
118
- in?: number[];
119
- notIn?: number[];
120
- lessThan?: number;
121
- lessThanOrEqualTo?: number;
122
- greaterThan?: number;
123
- greaterThanOrEqualTo?: number;
124
- }
125
-
126
- export interface BigIntFilter {
127
- isNull?: boolean;
128
- equalTo?: string;
129
- notEqualTo?: string;
130
- distinctFrom?: string;
131
- notDistinctFrom?: string;
132
- in?: string[];
133
- notIn?: string[];
134
- lessThan?: string;
135
- lessThanOrEqualTo?: string;
136
- greaterThan?: string;
137
- greaterThanOrEqualTo?: string;
138
- }
139
-
140
- export interface BigFloatFilter {
141
- isNull?: boolean;
142
- equalTo?: string;
143
- notEqualTo?: string;
144
- distinctFrom?: string;
145
- notDistinctFrom?: string;
146
- in?: string[];
147
- notIn?: string[];
148
- lessThan?: string;
149
- lessThanOrEqualTo?: string;
150
- greaterThan?: string;
151
- greaterThanOrEqualTo?: string;
152
- }
153
-
154
- // ============================================================================
155
- // Boolean filter
156
- // ============================================================================
157
-
158
- export interface BooleanFilter {
159
- isNull?: boolean;
160
- equalTo?: boolean;
161
- notEqualTo?: boolean;
162
- distinctFrom?: boolean;
163
- notDistinctFrom?: boolean;
164
- in?: boolean[];
165
- notIn?: boolean[];
166
- }
167
-
168
- // ============================================================================
169
- // UUID filter
170
- // ============================================================================
171
-
172
- export interface UUIDFilter {
173
- isNull?: boolean;
174
- equalTo?: string;
175
- notEqualTo?: string;
176
- distinctFrom?: string;
177
- notDistinctFrom?: string;
178
- in?: string[];
179
- notIn?: string[];
180
- lessThan?: string;
181
- lessThanOrEqualTo?: string;
182
- greaterThan?: string;
183
- greaterThanOrEqualTo?: string;
184
- }
185
-
186
- export interface UUIDListFilter {
187
- isNull?: boolean;
188
- equalTo?: string[];
189
- notEqualTo?: string[];
190
- distinctFrom?: string[];
191
- notDistinctFrom?: string[];
192
- lessThan?: string[];
193
- lessThanOrEqualTo?: string[];
194
- greaterThan?: string[];
195
- greaterThanOrEqualTo?: string[];
196
- contains?: string[];
197
- containedBy?: string[];
198
- overlaps?: string[];
199
- anyEqualTo?: string;
200
- anyNotEqualTo?: string;
201
- anyLessThan?: string;
202
- anyLessThanOrEqualTo?: string;
203
- anyGreaterThan?: string;
204
- anyGreaterThanOrEqualTo?: string;
205
- }
206
-
207
- // ============================================================================
208
- // Date/Time filters
209
- // ============================================================================
210
-
211
- export interface DatetimeFilter {
212
- isNull?: boolean;
213
- equalTo?: string;
214
- notEqualTo?: string;
215
- distinctFrom?: string;
216
- notDistinctFrom?: string;
217
- in?: string[];
218
- notIn?: string[];
219
- lessThan?: string;
220
- lessThanOrEqualTo?: string;
221
- greaterThan?: string;
222
- greaterThanOrEqualTo?: string;
223
- }
224
-
225
- export interface DateFilter {
226
- isNull?: boolean;
227
- equalTo?: string;
228
- notEqualTo?: string;
229
- distinctFrom?: string;
230
- notDistinctFrom?: string;
231
- in?: string[];
232
- notIn?: string[];
233
- lessThan?: string;
234
- lessThanOrEqualTo?: string;
235
- greaterThan?: string;
236
- greaterThanOrEqualTo?: string;
237
- }
238
-
239
- export interface TimeFilter {
240
- isNull?: boolean;
241
- equalTo?: string;
242
- notEqualTo?: string;
243
- distinctFrom?: string;
244
- notDistinctFrom?: string;
245
- in?: string[];
246
- notIn?: string[];
247
- lessThan?: string;
248
- lessThanOrEqualTo?: string;
249
- greaterThan?: string;
250
- greaterThanOrEqualTo?: string;
251
- }
252
-
253
- // ============================================================================
254
- // JSON filter
255
- // ============================================================================
256
-
257
- export interface JSONFilter {
258
- isNull?: boolean;
259
- equalTo?: unknown;
260
- notEqualTo?: unknown;
261
- distinctFrom?: unknown;
262
- notDistinctFrom?: unknown;
263
- in?: unknown[];
264
- notIn?: unknown[];
265
- contains?: unknown;
266
- containedBy?: unknown;
267
- containsKey?: string;
268
- containsAllKeys?: string[];
269
- containsAnyKeys?: string[];
270
- }
271
- `;
272
- }
273
- // ============================================================================
274
- // Table-specific filter generators
275
- // ============================================================================
276
- /**
277
- * Generate filter interface for a specific table
278
- */
279
- function generateTableFilter(table) {
280
- const filterTypeName = (0, utils_1.getFilterTypeName)(table);
281
- const scalarFields = (0, utils_1.getScalarFields)(table);
282
- const fieldFilters = scalarFields
283
- .map((field) => {
284
- const filterType = getFieldFilterType(field);
285
- if (!filterType)
286
- return null;
287
- return ` ${field.name}?: ${filterType};`;
288
- })
289
- .filter(Boolean)
290
- .join('\n');
291
- return `export interface ${filterTypeName} {
292
- ${fieldFilters}
293
- /** Logical AND */
294
- and?: ${filterTypeName}[];
295
- /** Logical OR */
296
- or?: ${filterTypeName}[];
297
- /** Logical NOT */
298
- not?: ${filterTypeName};
299
- }`;
300
- }
301
- /**
302
- * Get the filter type for a specific field
303
- */
304
- function getFieldFilterType(field) {
305
- const { gqlType, isArray } = field.type;
306
- // Handle array types
307
- if (isArray) {
308
- const cleanType = gqlType.replace(/!/g, '');
309
- switch (cleanType) {
310
- case 'String':
311
- return 'StringListFilter';
312
- case 'Int':
313
- return 'IntListFilter';
314
- case 'UUID':
315
- return 'UUIDListFilter';
316
- default:
317
- return null;
318
- }
319
- }
320
- return (0, utils_1.getScalarFilterType)(gqlType);
321
- }
322
- // ============================================================================
323
- // OrderBy enum generators
324
- // ============================================================================
325
- /**
326
- * Generate OrderBy type for a specific table
327
- */
328
- function generateTableOrderBy(table) {
329
- const orderByTypeName = (0, utils_1.getOrderByTypeName)(table);
330
- const scalarFields = (0, utils_1.getScalarFields)(table);
331
- const fieldOrderBys = scalarFields.flatMap((field) => {
332
- const screamingName = (0, utils_1.toScreamingSnake)(field.name);
333
- return [`'${screamingName}_ASC'`, `'${screamingName}_DESC'`];
334
- });
335
- // Add standard PostGraphile order options
336
- const standardOrderBys = [
337
- "'NATURAL'",
338
- "'PRIMARY_KEY_ASC'",
339
- "'PRIMARY_KEY_DESC'",
340
- ];
341
- const allOrderBys = [...fieldOrderBys, ...standardOrderBys];
342
- return `export type ${orderByTypeName} = ${allOrderBys.join(' | ')};`;
343
- }
344
- // ============================================================================
345
- // Combined generators for hook files
346
- // ============================================================================
347
- /**
348
- * Generate inline filter and orderBy types for a query hook file
349
- * These are embedded directly in the hook file for self-containment
350
- */
351
- function generateInlineFilterTypes(table) {
352
- const filterDef = generateTableFilter(table);
353
- const orderByDef = generateTableOrderBy(table);
354
- return `${filterDef}
355
-
356
- ${orderByDef}`;
357
- }
@@ -1 +0,0 @@
1
- export {};
@@ -1,75 +0,0 @@
1
- "use strict";
2
- // Jest globals - no import needed
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- const input_types_generator_1 = require("./input-types-generator");
5
- const uuidType = { gqlType: 'UUID', isArray: false };
6
- const stringType = { gqlType: 'String', isArray: false };
7
- function createTable(table) {
8
- return {
9
- name: table.name,
10
- fields: table.fields ?? [],
11
- relations: table.relations ?? {
12
- belongsTo: [],
13
- hasOne: [],
14
- hasMany: [],
15
- manyToMany: [],
16
- },
17
- query: table.query,
18
- inflection: table.inflection,
19
- constraints: table.constraints,
20
- };
21
- }
22
- describe('input-types-generator', () => {
23
- it('emits relation helpers and select types with related names', () => {
24
- const userTable = createTable({
25
- name: 'User',
26
- fields: [
27
- { name: 'id', type: uuidType },
28
- { name: 'name', type: stringType },
29
- ],
30
- relations: {
31
- belongsTo: [],
32
- hasOne: [],
33
- hasMany: [
34
- {
35
- fieldName: 'posts',
36
- isUnique: false,
37
- referencedByTable: 'Post',
38
- type: null,
39
- keys: [],
40
- },
41
- ],
42
- manyToMany: [],
43
- },
44
- });
45
- const postTable = createTable({
46
- name: 'Post',
47
- fields: [
48
- { name: 'id', type: uuidType },
49
- { name: 'title', type: stringType },
50
- ],
51
- relations: {
52
- belongsTo: [
53
- {
54
- fieldName: 'author',
55
- isUnique: false,
56
- referencesTable: 'User',
57
- type: null,
58
- keys: [],
59
- },
60
- ],
61
- hasOne: [],
62
- hasMany: [],
63
- manyToMany: [],
64
- },
65
- });
66
- const result = (0, input_types_generator_1.generateInputTypesFile)(new Map(), new Set(), [userTable, postTable]);
67
- expect(result.content).toContain('export interface ConnectionResult<T>');
68
- expect(result.content).toContain('export interface UserRelations');
69
- expect(result.content).toContain('posts?: ConnectionResult<Post>');
70
- expect(result.content).toContain('export type UserWithRelations = User & UserRelations;');
71
- expect(result.content).toContain('posts?: boolean | {');
72
- expect(result.content).toContain('orderBy?: PostsOrderBy[];');
73
- expect(result.content).toContain('author?: boolean | { select?: UserSelect };');
74
- });
75
- });
@@ -1,11 +0,0 @@
1
- /**
2
- * Type-level tests for select-types.ts
3
- *
4
- * These tests verify the compile-time type inference behavior.
5
- * The TypeScript compiler validates these types during build.
6
- *
7
- * Note: Type-only tests using expectTypeOf have been removed as they
8
- * are not compatible with Jest. The TypeScript compiler validates
9
- * these types at compile time via the type assertions below.
10
- */
11
- export {};
@@ -1,22 +0,0 @@
1
- "use strict";
2
- /**
3
- * Type-level tests for select-types.ts
4
- *
5
- * These tests verify the compile-time type inference behavior.
6
- * The TypeScript compiler validates these types during build.
7
- *
8
- * Note: Type-only tests using expectTypeOf have been removed as they
9
- * are not compatible with Jest. The TypeScript compiler validates
10
- * these types at compile time via the type assertions below.
11
- */
12
- Object.defineProperty(exports, "__esModule", { value: true });
13
- // Compile-time type check: verify the inferred type matches expected structure
14
- const _typeCheck = {};
15
- const _excludedTypeCheck = {};
16
- // Dummy test to satisfy Jest
17
- describe('InferSelectResult', () => {
18
- it('type assertions compile correctly', () => {
19
- // If this file compiles, the type tests pass
20
- expect(true).toBe(true);
21
- });
22
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,67 +0,0 @@
1
- "use strict";
2
- // Jest globals - no import needed
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- const transform_schema_1 = require("./transform-schema");
5
- describe('transform-schema table operation filtering', () => {
6
- const dummyReturnType = { kind: 'SCALAR', name: 'String' };
7
- it('detects table operations and update/delete patterns', () => {
8
- const tableOps = (0, transform_schema_1.getTableOperationNames)([
9
- {
10
- name: 'User',
11
- query: {
12
- all: 'users',
13
- one: 'user',
14
- create: 'createUser',
15
- update: 'updateUser',
16
- delete: 'deleteUser',
17
- },
18
- inflection: { tableType: 'User' },
19
- },
20
- ]);
21
- const updateByEmail = {
22
- name: 'updateUserByEmail',
23
- kind: 'mutation',
24
- args: [],
25
- returnType: dummyReturnType,
26
- };
27
- const login = {
28
- name: 'login',
29
- kind: 'mutation',
30
- args: [],
31
- returnType: dummyReturnType,
32
- };
33
- expect((0, transform_schema_1.isTableOperation)(updateByEmail, tableOps)).toBe(true);
34
- expect((0, transform_schema_1.isTableOperation)(login, tableOps)).toBe(false);
35
- });
36
- it('filters out table operations from custom list', () => {
37
- const tableOps = (0, transform_schema_1.getTableOperationNames)([
38
- {
39
- name: 'User',
40
- query: {
41
- all: 'users',
42
- one: 'user',
43
- create: 'createUser',
44
- update: 'updateUser',
45
- delete: 'deleteUser',
46
- },
47
- inflection: { tableType: 'User' },
48
- },
49
- ]);
50
- const operations = [
51
- {
52
- name: 'users',
53
- kind: 'query',
54
- args: [],
55
- returnType: dummyReturnType,
56
- },
57
- {
58
- name: 'login',
59
- kind: 'mutation',
60
- args: [],
61
- returnType: dummyReturnType,
62
- },
63
- ];
64
- const customOps = (0, transform_schema_1.getCustomOperations)(operations, tableOps);
65
- expect(customOps.map((op) => op.name)).toEqual(['login']);
66
- });
67
- });
@@ -1 +0,0 @@
1
- export {};