@ranger-theme/contentful-render
TypeScript icon, indicating that this package has built-in type declarations

0.1.1Β β€’Β PublicΒ β€’Β Published

@ranger-theme/contentful-render

πŸŽ‰ Introduce

coreζ ΈεΏƒζžΆζž„

πŸ“š Documentation

πŸ“¦ Install

$ npm install --save-dev @ranger-theme/contentful-render
# or
$ yarn add --save-dev @ranger-theme/contentful-render
# or
$ pnpm add --save-dev @ranger-theme/contentful-render

πŸ”¨ Usage

const createApolloClient = ({ cookies, reduxState }) => {
  const magentoLink = createMagentoLink({ cookies, reduxState })
  const contentfulLink = createContentfulLink()

  return new ApolloClient({
    // Routes the query to the proper client
    link: ApolloLink.split(
      (operation) => operation.getContext().clientName === 'contentful',
      contentfulLink,
      magentoLink
    ),
    cache: new InMemoryCache({
      addTypename: false,
      typePolicies
    }).restore({}),
    connectToDevTools: process.browser,
    ssrMode: !process.browser,
    defaultOptions: {
      query: {
        fetchPolicy: 'cache-first'
      }
    }
  })
}

Send api to query data

import { useAwaitQuery } from '@ranger-theme/hooks'

export const useContentfulPage = (url) => {
  const getLandingPage = useAwaitQuery(GET_LANDING_PAGE)
  const [isLoading, setIsLoading] = useState(false)
  const [page, setPage] = useState(null)

  useEffect(() => {
    const fetchLandingPage = async () => {
      try {
        setIsLoading(true)

        const { data } = await getLandingPage({
          context: {
            clientName: 'contentful'
          },
          variables: {
            where: {
              url
            }
          }
        })
        const result = data?.pageCollection?.items?.[0] ?? null
        setPage(result)
        setIsLoading(false)
      } catch (error) {
        setIsLoading(false)
      }
    }

    fetchLandingPage()
  }, [getLandingPage, url])

  return {
    isLoading,
    page
  }
}

Readme

Keywords

none

Package Sidebar

Install

npm i @ranger-theme/contentful-render

Weekly Downloads

0

Version

0.1.1

License

MIT

Unpacked Size

10.1 kB

Total Files

7

Last publish

Collaborators

  • jdream