Client.js
1.76 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
import { ApolloClient } from "apollo-client";
import { InMemoryCache } from "apollo-cache-inmemory";
import { HttpLink } from "apollo-link-http";
import { WebSocketLink } from "apollo-link-ws";
import { onError } from "apollo-link-error";
import { ApolloLink, split } from "apollo-link";
import { getMainDefinition } from "apollo-utilities";
import { withClientState } from "apollo-link-state";
import { setContext } from "apollo-link-context";
import { resolvers, typeDefs } from "./ClientState";
const httpLink = new HttpLink({
uri: "http://localhost:4000",
});
const wsLink = new WebSocketLink({
uri: "ws://localhost:4000",
options: {
reconnect: true,
},
});
const setAuthorizationLink = setContext((request, previousContext) => ({
headers: { Authorization: `Bearer ${localStorage.getItem("token")}` },
}));
const clientState = withClientState({
typeDefs,
resolvers,
});
const cache = new InMemoryCache();
cache.writeData({
data: {
isLoggedIn: Boolean(localStorage.getItem("token") || false),
},
});
const client = new ApolloClient({
link: ApolloLink.from([
onError(({ graphQLErrors, networkError }) => {
if (graphQLErrors)
graphQLErrors.map(({ message, locations, path }) =>
console.log(
`[GraphQL error]: Message: ${message}, Location: ${locations}, Path: ${path}`
)
);
if (networkError) console.log(`[Network error]: ${networkError}`);
}),
setAuthorizationLink,
clientState,
split(
({ query }) => {
const definition = getMainDefinition(query);
return (
definition.kind === "OperationDefinition" &&
definition.operation === "subscription"
);
},
wsLink,
httpLink
),
]),
cache,
});
export default client;