-
-
Notifications
You must be signed in to change notification settings - Fork 2
/
codegen.ts
102 lines (99 loc) · 3.41 KB
/
codegen.ts
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
import type { CodegenConfig } from "@graphql-codegen/cli";
import {
localSchema,
sanityURL,
jsChileURL,
sanityDocuments,
apiDocuments,
} from "./graphql.config";
const noTypeCheckingPlugin = {
add: {
content: [
"/* eslint-disable */",
"/* @ts-nocheck */",
"/* prettier-ignore */",
"/* This file is automatically generated. Please do not modify it manually. */",
],
},
};
const config = {
ignoreNoDocuments: true,
generates: {
"./src/gql/": {
schema: [sanityURL],
documents: sanityDocuments,
preset: "client",
config: {
useTypeImports: true,
skipTypename: true,
avoidOptionals: true,
nonOptionalTypename: false,
// Lamentablemente, code-gen establece "any" como predeterminado, cuando no tiene un
// tipo para un "scalar". Esta opción nos obliga a definir un tipo cada vez que
// queremos usar un escalar sin tipo.
defaultScalarType: "unknown",
scalars: {
Date: "string",
DateTime: "string",
},
},
},
"./src/gql/schema.gql": {
schema: [sanityURL, localSchema],
documents: sanityDocuments,
plugins: ["schema-ast"],
},
"./src/gql/graphqlRequest.ts": {
schema: [sanityURL, localSchema],
documents: sanityDocuments,
plugins: ["typescript-graphql-request", noTypeCheckingPlugin],
config: {
documentMode: "external",
importDocumentNodeExternallyFrom: "./graphql",
importOperationTypesFrom: "Operations",
// Esto debería reducir la cantidad de enlaces de código no deseados entre archivos,
// hacer que nuestros paquetes sean más pequeños y más fáciles de dividir en código
useTypeImports: true,
// Esto nos permite reutilizar los tipos de fragmentos reales en nuestras consultas, y no copiar/insertar los fragmentos.
inlineFragmentTypes: "combine",
// Lamentablemente, code-gen establece "any" como predeterminado, cuando no tiene un
// tipo para un "scalar". Esta opción nos obliga a definir un tipo cada vez que
// queremos usar un escalar sin tipo.
defaultScalarType: "unknown",
scalars: {
Date: "string",
DateTime: "string",
},
},
},
"./src/gql/jschileAPI.ts": {
schema: [jsChileURL],
documents: apiDocuments,
plugins: [
"typescript",
"typescript-operations",
"typescript-react-apollo",
noTypeCheckingPlugin,
],
config: {
skipTypename: true,
avoidOptionals: true,
nonOptionalTypename: false,
// Esto debería reducir la cantidad de enlaces de código no deseados entre archivos,
// hacer que nuestros paquetes sean más pequeños y más fáciles de dividir en código
useTypeImports: true,
// Esto nos permite reutilizar los tipos de fragmentos reales en nuestras consultas, y no copiar/insertar los fragmentos.
inlineFragmentTypes: "combine",
// Lamentablemente, code-gen establece "any" como predeterminado, cuando no tiene un
// tipo para un "scalar". Esta opción nos obliga a definir un tipo cada vez que
// queremos usar un escalar sin tipo.
defaultScalarType: "unknown",
scalars: {
Date: "string",
DateTime: "string",
},
},
},
},
} satisfies CodegenConfig;
export default config;