-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcodegen.ts
More file actions
73 lines (71 loc) · 1.94 KB
/
codegen.ts
File metadata and controls
73 lines (71 loc) · 1.94 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
import type { CodegenConfig } from "@graphql-codegen/cli";
import { addTypenameSelectionDocumentTransform } from "@graphql-codegen/client-preset";
const noTypeCheckingPlugin = {
add: {
content: [
"/* eslint-disable @typescript-eslint/ban-ts-comment */",
"// @ts-nocheck",
"/* eslint-disable */",
"/* prettier-ignore */",
"/* This file is automatically generated. Please do not modify it manually. */",
],
},
};
const config: CodegenConfig = {
schema: "http://localhost:4000/graphql",
documents: ["./src/**/*.graphql", "src/**/*.{ts,tsx}"],
generates: {
"./src/gql/": {
preset: "client",
config: {
avoidOptionals: {
inputValue: false,
},
enumsAsTypes: true,
futureProofEnums: false, // For now, we don't need to future proof enums
strictScalars: true,
dedupeFragments: true,
useTypeImports: true,
scalars: {
JSON: "null | boolean | number | string | Record<string, unknown> | unknown[]",
Date: {
input: "Date",
output: "Date",
},
ObjectID: {
input: "string",
output: "string",
},
BigNumber: {
input: "string",
output: "bignumber.js#BigNumber",
},
_Any: "unknown",
},
},
plugins: [noTypeCheckingPlugin],
presetConfig: {
fragmentMasking: { unmaskFunctionName: "getFragmentData" },
},
documentTransforms: [addTypenameSelectionDocumentTransform],
},
"./src/gql/enums.ts": {
config: {
typesPrefix: "Gql",
enumsAsConst: true,
onlyEnums: true,
namingConvention: {
enumValues: "keep",
},
},
plugins: ["typescript"],
},
"./src/gql/introspection.json": {
plugins: ["introspection"],
config: {
minify: true,
},
},
},
};
export default config;