react-apollo gql, TypeError: Object (...) не является функцией

у меня есть App компонент, который я оборачиваю в поставщика apollo:

import React, { Component } from "react";
import { observer, Provider } from "mobx-react";
import { BrowserRouter as Router } from "react-router-dom";
import styled from "styled-components";
import { ThemeProvider } from "styled-components";

// graphQL
import { ApolloClient } from "apollo-client";
import { createHttpLink } from "apollo-link-http";
import { setContext } from "apollo-link-context";
import { InMemoryCache } from "apollo-cache-inmemory";

import Main from "./components/Main/Main";
import Navigation from "./components/Navigation/Navigation";

import { ApolloProvider } from "react-apollo";

const httpLink = createHttpLink({
  uri: "myUri"
});

const authLink = setContext((_, { headers }) => {
  // get the authentication token from local storage if it exists
  const token = "myToken";
  // return the headers to the context so httpLink can read them
  return {
    headers: {
      ...headers,
      authorization: token ? `Bearer ${token}` : null
    }
  };
});

const mozaikClient = new ApolloClient({
  link: authLink.concat(httpLink),
  cache: new InMemoryCache()
});

@observer
class App extends Component {
  render() {
    return (
      <ThemeProvider theme={theme}>
        <ApolloProvider client={mozaikClient}>
          <Provider {...this.props.stores}>
            <Router>
              <div className="app-container">
                <Navigation />
                <Main />
              </div>
            </Router>
          </Provider>
        </ApolloProvider>
      </ThemeProvider>
    );
  }
}

export default App;

тогда у меня есть компонент About, который я хочу использовать данные поставщика:

import React, { Component } from "react";

import { gql, graphql } from "react-apollo";
class About extends Component {
  render() {
    return <div>About component.</div>;
  }
}

const landingPageQuery = gql`
  query landingPage {
    documents(types: [LANDING]) {
      items {
        id
        ... on LandingDocument {
          landingPortrait {
            id
            url
          }
          greeting
          content
        }
      }
    }
  }
`;

export default graphql(landingPageQuery)(About);

Я получаю следующую ошибку:

о программе.js: 10 Uncaught TypeError: Object(...) не является функцией на объектах../ src / компоненты / о программе / о программе.js (About.js: 10) at webpack_require (bootstrap 9e0e85e19ef23447e3e2:669) в fn (bootstrap 9e0e85e19ef23447e3e2: 87) на объектах../ src / компоненты / основные / маршруты.js (маршруты.js: 1) at webpack_require (bootstrap 9e0e85e19ef23447e3e2:669) в fn (bootstrap 9e0e85e19ef23447e3e2: 87) на объектах../ src / компоненты / Main / Main.js (Contact.js: 4) at webpack_require (bootstrap 9e0e85e19ef23447e3e2:669) в fn (bootstrap 9e0e85e19ef23447e3e2: 87) на объектах../ src / App.js (zen-observable.js: 498) на webpack_require (bootstrap 9e0e85e19ef23447e3e2:669) в fn (bootstrap 9e0e85e19ef23447e3e2: 87) на объектах../ src / index.js (Skills.js: 4) at webpack_require (bootstrap 9e0e85e19ef23447e3e2:669) в fn (bootstrap 9e0e85e19ef23447e3e2: 87) на объектах.0 (styleVariables.js: 17) at webpack_require (bootstrap 9e0e85e19ef23447e3e2:669) при загрузке 9e0e85e19ef23447e3e2:715 на пачка.js: 719

откуда и почему эта ошибка исходит, и что это значит? Он указывает на строку, в которой я определяю свой запрос с помощью gql

1 ответов


Это похоже на известную проблему - см. здесь. Попробуйте установить graphql-tag и импорта gql из этой библиотеки.