堆栈:React / Gatsby + Prismic集成+ Netlify托管
问题:
gatsby-source-graphql-universal
和gatsby-source-prismic-graphql
出现了问题,但我能够解决这些问题并使网站正常运行。Localhost browser when running develop
我尝试过的事情
<LayoutContainer className="div">
<Global styles={[globalStyles, typeStyles]} />
<div className="Layout">
<Header />
<main className="Layout__content">
{children}
</main>
<Footer />
</div>
</LayoutContainer>
)
export const query = graphql`
query SiteTitleQuery {
site {
siteMetadata {
title
}
}
}
`
3:52:38 PM: error "gatsby-source-prismic-graphql" threw an error while running the sourceNodes lifecycle:
3:52:38 PM: Cannot use GraphQLDirective "@include" from another module or realm.
3:52:38 PM: Ensure that there is only one instance of "graphql" in the node_modules
3:52:38 PM: directory. If different versions of "graphql" are the dependencies of other
3:52:38 PM: relied on modules, use "resolutions" to ensure only one version is installed.
3:52:38 PM: https://yarnpkg.com/en/docs/selective-version-resolutions
3:52:38 PM: Duplicate "graphql" modules cannot be used at the same time since different
3:52:38 PM: versions may have different capabilities and behavior. The data from one
3:52:38 PM: version used in the function from another could produce confusing and
3:52:38 PM: spurious results.
3:52:38 PM: 74 | if (!sdl) {
3:52:38 PM: 75 | introspectionSchema = await introspectSchema(link);
3:52:38 PM: > 76 | sdl = printSchema(introspectionSchema);
3:52:38 PM: | ^
3:52:38 PM: 77 | } else {
3:52:38 PM: 78 | introspectionSchema = buildSchema(sdl);
3:52:38 PM: 79 | }
3:52:38 PM:
3:52:38 PM:
3:52:38 PM: Error: Cannot use GraphQLDirective "@include" from another module or realm.
3:52:38 PM: Ensure that there is only one instance of "graphql" in the node_modules
3:52:38 PM: directory. If different versions of "graphql" are the dependencies of other
3:52:38 PM: relied on modules, use "resolutions" to ensure only one version is installed.
3:52:38 PM: https://yarnpkg.com/en/docs/selective-version-resolutions
3:52:38 PM: Duplicate "graphql" modules cannot be used at the same time since different
3:52:38 PM: versions may have different capabilities and behavior. The data from one
3:52:38 PM: version used in the function from another could produce confusing and
3:52:38 PM: spurious results.
3:52:38 PM:
3:52:38 PM: - Array.filter
3:52:38 PM:
3:52:38 PM: - gatsby-node.js:76 exports.sourceNodes
3:52:38 PM: [repo]/[gatsby-source-prismic-graphql]/[gatsby-source-graphql-universal]/[ga tsby-source-graphql]/gatsby-node.js:76:13
3:52:38 PM:
3:52:38 PM: - task_queues.js:97 processTicksAndRejections
3:52:38 PM: internal/process/task_queues.js:97:5
3:52:38 PM:
3:52:38 PM: - api-runner-node.js:299 async runAPI
3:52:38 PM: [repo]/[gatsby]/dist/utils/api-runner-node.js:299:16
3:52:38 PM:
3:52:38 PM:
3:52:38 PM: not finished source and transform nodes - 0.526s
3:52:38 PM:
3:52:38 PM: ┌─────────────────────────────┐
3:52:38 PM: │ "build.command" failed │
3:52:38 PM: └─────────────────────────────┘
代码:
import React from "react";
import PropTypes from "prop-types";
import { graphql } from "gatsby";
import styled from "@emotion/styled";
import { Global } from "@emotion/core";
import globalStyles from 'styles/global';
import typeStyles from 'styles/typography';
import dimensions from "styles/dimensions";
import Footer from "components/Footer";
import Header from "components/Header";
import 'styles/fonts.scss';
const LayoutContainer = styled.div`
max-width: ${dimensions.maxwidthDesktop}px;
padding-left: ${dimensions.paddingHorizontalDesktop}em;
padding-right: ${dimensions.paddingHorizontalDesktop}em;
margin: 0 auto;
@media(max-width: ${dimensions.maxwidthTablet}px) {
padding-left: ${dimensions.paddingHorizontalTablet}em;
padding-right: ${dimensions.paddingHorizontalTablet}em;
}
@media(max-width: ${dimensions.maxwidthMobile}px) {
padding-left: ${dimensions.paddingHorizontalMobile}em;
padding-right: ${dimensions.paddingHorizontalMobile}em;
}
.Layout__content {
padding-bottom: 5em;
}
`;
const Layout = ({ children }) => (
<LayoutContainer className="div">
<Global styles={[globalStyles, typeStyles]} />
<div className="Layout">
<Header />
<main className="Layout__content">
{children}
</main>
<Footer />
</div>
</LayoutContainer>
)
export const query = graphql`
query SiteTitleQuery {
site {
siteMetadata {
title
}
}
}
`
Layout.propTypes = {
children: PropTypes.node.isRequired,
}
export default Layout;
非常感谢您的帮助
答案 0 :(得分:0)
我在部署Prist Gatsby启动程序时也遇到了类似的问题。用Prismic分支替换gatsby-source-prismic-graphql
程序包后,它开始工作了:
npm install --save @prismicio/gatsby-source-prismic-graphql
或
yarn add @prismicio/gatsby-source-prismic-graphql
...,并按照此处Phil的指示更新gatsby-config.js
中的引用:
https://community.prismic.io/t/error-with-module-gatsby-source-prismic-graphql/779/12