UNPKG

gatsby

Version:
92 lines (76 loc) 2.83 kB
import React from "react" import PropTypes from "prop-types" import { createServerOrClientContext } from "./context-utils" const StaticQueryContext = createServerOrClientContext(`StaticQuery`, {}) function StaticQueryDataRenderer({ staticQueryData, data, query, render }) { const finalData = data ? data.data : staticQueryData[query] && staticQueryData[query].data return ( <React.Fragment> {finalData && render(finalData)} {!finalData && <div>Loading (StaticQuery)</div>} </React.Fragment> ) } let warnedAboutStaticQuery = false // TODO(v6): Remove completely const StaticQuery = props => { const { data, query, render, children } = props if (process.env.NODE_ENV === `development` && !warnedAboutStaticQuery) { console.warn( `The <StaticQuery /> component is deprecated and will be removed in Gatsby v6. Use useStaticQuery instead. Refer to the migration guide for more information: https://gatsby.dev/migrating-4-to-5/#staticquery--is-deprecated` ) warnedAboutStaticQuery = true } return ( <StaticQueryContext.Consumer> {staticQueryData => ( <StaticQueryDataRenderer data={data} query={query} render={render || children} staticQueryData={staticQueryData} /> )} </StaticQueryContext.Consumer> ) } StaticQuery.propTypes = { data: PropTypes.object, query: PropTypes.string.isRequired, render: PropTypes.func, children: PropTypes.func, } const useStaticQuery = query => { if ( typeof React.useContext !== `function` && process.env.NODE_ENV === `development` ) { // TODO(v5): Remove since we require React >= 18 throw new Error( `You're likely using a version of React that doesn't support Hooks\n` + `Please update React and ReactDOM to 16.8.0 or later to use the useStaticQuery hook.` ) } const context = React.useContext(StaticQueryContext) // query is a stringified number like `3303882` when wrapped with graphql, If a user forgets // to wrap the query in a grqphql, then casting it to a Number results in `NaN` allowing us to // catch the misuse of the API and give proper direction if (isNaN(Number(query))) { throw new Error(`useStaticQuery was called with a string but expects to be called using \`graphql\`. Try this: import { useStaticQuery, graphql } from 'gatsby'; useStaticQuery(graphql\`${query}\`); `) } if (context[query]?.data) { return context[query].data } else { throw new Error( `The result of this StaticQuery could not be fetched.\n\n` + `This is likely a bug in Gatsby and if refreshing the page does not fix it, ` + `please open an issue in https://github.com/gatsbyjs/gatsby/issues` ) } } export { StaticQuery, StaticQueryContext, useStaticQuery }