-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathcategory.subgraph.ts
104 lines (90 loc) · 2.55 KB
/
category.subgraph.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
103
104
import { shouldPunishForPoorPlans } from "../../env.js";
import { createSubgraph } from "../../subgraph.js";
import { categories, products } from "./data.js";
export default createSubgraph("category", {
typeDefs: /* GraphQL */ `
extend schema
@link(
url: "https://specs.apollo.dev/federation/v2.3"
import: ["@key", "@shareable", "@external", "@provides"]
)
type Query {
products: [Product]
@shareable
@provides(fields: "categories { id name subCategories { id name } }")
}
type Product @key(fields: "id") {
id: ID!
categories: [Category] @external
}
type Category @key(fields: "id") {
id: ID!
"""
This field is provided by Query.products
and we deliberately don't resolve it.
The test suite is about checking if @provides is used correctly.
"""
name: String
subCategories: [Category] @external
}
`,
resolvers: {
Query: {
products() {
return products.map((p) => ({
id: p.id,
categories: p.categories.map((catId) => {
const cat = categories.find((c) => c.id === catId);
if (!cat) {
return null;
}
return {
id: cat.id,
name: cat.name,
subCategories: cat.subCategories.map((subCatId) => {
const subCat = categories.find((c) => c.id === subCatId);
if (!subCat) {
return null;
}
return {
id: subCat.id,
name: subCat.name,
};
}),
};
}),
}));
},
},
Product: {
__resolveReference(key: { id: string }, context: any) {
if (shouldPunishForPoorPlans(context)) {
throw new Error("You should be using the categories subgraph!");
}
const product = products.find((p) => p.id === key.id);
if (!product) {
return null;
}
return {
id: product.id,
};
},
},
Category: {
__resolveReference(key: { id: string }, context: any) {
if (shouldPunishForPoorPlans(context)) {
throw new Error("You should be using the categories subgraph!");
}
const cat = categories.find((c) => c.id === key.id);
if (!cat) {
return null;
}
return {
id: cat.id,
// We explicitly don't resolve `name` here
// name: cat.name,
};
},
},
},
});