从useQuery传递上下文到Apollo客户端

时间:2020-06-11 19:52:07

标签: reactjs graphql next.js apollo apollo-link

我正在构建一个next.js应用程序,其中打算使用几个graphql-api。在组件中使用useQuery中的@apollo/react-hooks时,我想传递一个上下文。此刻我的客户看起来像这样:

import { ApolloClient } from '@apollo/client'
import { InMemoryCache } from 'apollo-cache-inmemory'
import { HttpLink } from 'apollo-link-http'
import { ApolloLink } from 'apollo-link'

let apolloClient

function createApolloClient() {
    return new ApolloClient({
        ssrMode: typeof window === 'undefined',
        link: new ApolloLink((operation) => {
            console.log(operation.getContext())
            return new HttpLink({
                uri: 'http://localhost:1337/graphql', // Server URL (must be absolute)
                credentials: 'same-origin', // Additional fetch() options like `credentials` or `headers`
            }).request(operation)
        }),
        cache: new InMemoryCache(),
    })
}

export function initializeApollo(initialState = null) {
    const _apolloClient = apolloClient ?? createApolloClient()

    // If your page has Next.js data fetching methods that use Apollo Client, the initial state
    // get hydrated here
    if (initialState) {
        _apolloClient.cache.restore(initialState)
    }
    // For SSG and SSR always create a new Apollo Client
    if (typeof window === 'undefined') return _apolloClient
    // Create the Apollo Client once in the client
    if (!apolloClient) apolloClient = _apolloClient

    return _apolloClient
}

export function useApollo(initialState) {
    const store = useMemo(() => initializeApollo(initialState), [initialState])
    return store
}

和我的示例组件如下所示:

import gql from 'graphql-tag'

import { useQuery } from '@apollo/react-hooks'
import { initializeApollo } from '../lib/apolloClient'

interface Props {}

export const STRAPI = gql`
    query {
        questions {
            question
        }
    }
`

const Sample = (props: Props) => {
    const {
        loading: strapiLoading,
        error: strapiError,
        data: strapiData,
    } = useQuery(STRAPI, {
        context: {
            api: 'strapi',
        },
        notifyOnNetworkStatusChange: true,
    })
    return (
        <div>
            <h1>{strapiData.questions[0].question}</h1>
        </div>
    )
}

export async function getStaticProps() {
    const apolloClient = initializeApollo()

    await apolloClient.query({
        query: STRAPI,
    })

    return {
        props: {
            initialApolloState: apolloClient.cache.extract(),
        },
        unstable_revalidate: 1,
    }
}

export default Sample

在客户端中,我尝试使用console.log(operation.getContext())打印上下文,我希望在某个地方看到'context: 'api',但是什么也没有。有人可以帮我吗?

0 个答案:

没有答案