Erro ao chamar query de pickupPoints

Chamei algumas querys e funcionaram normalmente, mas quando vou chamar a query de pickupPoints ocorre Render Server - Error.

query:

query pickupPoints($page: int!, $perPage: int!) {
  getPickupPoints(page: $page, perPage: $perPage) {
    items{
      name,
      description,
      address {
        city,
        country,
        complement,
        state,
        street
      },
      isActive
    }
  }
}

código react:

import React from "react";
import { useQuery } from "react-apollo";
import GET_PICKUPS from './graphql/pickup-points.graphql'

const PickUpPoints = () => {
    console.log('pickuppoints')
    const getPickupPoints = useQuery(GET_PICKUPS, {
        variables: {
          page: 1,
          perPage: 10,
        },
      })

    return (
        <p>render</p>
    )
}

export default PickUpPoints

Erro: Error: Network error: Only public queries are allowed during server side rendering
Alguém sabe o que pode ser?

2 Likes

Estou tendo o mesmo tipo de problema, com outras consultas

@framework66 , veja se o seu problema diz respeito a falta de instalação da referencia ao graphl de pickupponts (se for esse que você está tentando consultar), a documentação da VTEX não orienta sobre a instalação desses endpoints, apenas informa como usar o graphql infelizmente. Acabei descobrindo pela tentativa e erro.
Para instalar por exemplo, no caso do pickuppoints,

  • você vai na pasta onde está seu manifest.json e roda o comando VTEX install VTEX.admin-pickup-points@2.13.0 , que nem aparece no seu graphlIDE lá na VTEX.
  • depois vai nas dependencias do seu manifest.json e adiciona a linha referente ao que vc instalou,por ex: “VTEX.admin-pickup-points” : “2.x”
  • em seguida, na sua pasta onde tem o react e seu package.json, você roda um VTEX setup para ele baixar os types e lincar essa api como uma referencia nas dependencias;
  • apaga o node modules
  • agora roda o VTEX link que ele vai fazer o download das dependencias necessárias
3 Likes

Estou tendo o mesmo problema com a vtex.catalog-graphql@1.102.3, mas ao que parece ele não autoriza você realizar consultas de APIs privadas em server side. Qual a razão para se usar GraphQL então se não podemos realizar queries de APIs que normalmente nos exigiriam Key e Token, seguindo a premissa de que GraphQL não expõe dados sensíveis como esses no Front-End, não podermos consultar uma simples lista de marcas, só porque a Catalog API é trancada?

1 Like

também estou tendo o mesmo problema e ainda não encontrei solução