From c3c6a5b54ae695309c3eec1daeff3b2c4e6bf393 Mon Sep 17 00:00:00 2001 From: Jude Agboola Date: Tue, 19 Jul 2022 05:25:44 +0100 Subject: [PATCH] fix(gatsby): Wrap Head with (#36160) --- .../head-function-export/use-location.js | 13 +++++++++++++ .../shared-data/head-function-export.js | 1 + .../page-with-uselocation.js | 19 +++++++++++++++++++ .../head/head-export-handler-for-browser.js | 5 ++++- 4 files changed, 37 insertions(+), 1 deletion(-) create mode 100644 e2e-tests/production-runtime/cypress/integration/head-function-export/use-location.js create mode 100644 e2e-tests/production-runtime/src/pages/head-function-export/page-with-uselocation.js diff --git a/e2e-tests/production-runtime/cypress/integration/head-function-export/use-location.js b/e2e-tests/production-runtime/cypress/integration/head-function-export/use-location.js new file mode 100644 index 0000000000000..0bc4f7730a3a8 --- /dev/null +++ b/e2e-tests/production-runtime/cypress/integration/head-function-export/use-location.js @@ -0,0 +1,13 @@ +import headFunctionExportSharedData from "../../../shared-data/head-function-export.js" + +it(`Page with Head Export that uses useLocation works`, () => { + cy.visit(headFunctionExportSharedData.page.pageWithUseLocation).waitForRouteChange() + + cy.getTestElement(`location-pathname-in-template`) + .invoke(`text`) + .then(text => { + cy.getTestElement(`location-pathname-in-head`) + .invoke(`attr`, `content`) + .should('equal', text) + }) +}) diff --git a/e2e-tests/production-runtime/shared-data/head-function-export.js b/e2e-tests/production-runtime/shared-data/head-function-export.js index a53b7edf8ee3a..6dd60789408d8 100644 --- a/e2e-tests/production-runtime/shared-data/head-function-export.js +++ b/e2e-tests/production-runtime/shared-data/head-function-export.js @@ -12,6 +12,7 @@ const page = { invalidElements: `${path}/invalid-elements/`, fsRouteApi: `${path}/fs-route-api/`, deduplication: `${path}/deduplication/`, + pageWithUseLocation: `${path}/page-with-uselocation/`, } const data = { diff --git a/e2e-tests/production-runtime/src/pages/head-function-export/page-with-uselocation.js b/e2e-tests/production-runtime/src/pages/head-function-export/page-with-uselocation.js new file mode 100644 index 0000000000000..088e4f21afad0 --- /dev/null +++ b/e2e-tests/production-runtime/src/pages/head-function-export/page-with-uselocation.js @@ -0,0 +1,19 @@ +import * as React from "react" +import { useLocation } from '@gatsbyjs/reach-router'; + +export default function HeadFunctionExportWithUseLocation() { + const location = useLocation(); + + return ( + <> +

I test that Head export with useLocation hook works

+

{location.pathname}

+ + ) +} + +export function Head() { + const location = useLocation(); + + return +} \ No newline at end of file diff --git a/packages/gatsby/cache-dir/head/head-export-handler-for-browser.js b/packages/gatsby/cache-dir/head/head-export-handler-for-browser.js index d4113e15e7ff2..94d42f4ee7b02 100644 --- a/packages/gatsby/cache-dir/head/head-export-handler-for-browser.js +++ b/packages/gatsby/cache-dir/head/head-export-handler-for-browser.js @@ -1,6 +1,7 @@ import React from "react" import { useEffect } from "react" import { StaticQueryContext } from "gatsby" +import { LocationProvider } from "@gatsbyjs/reach-router" import { reactDOMUtils } from "../react-dom-utils" import { FireCallbackInEffect } from "./components/fire-callback-in-effect" import { VALID_NODE_NAMES } from "./constants" @@ -81,7 +82,9 @@ export function headHandlerForBrowser({ // In Prod we only call onHeadRendered in FireCallbackInEffect to render to head - + + + , hiddenRoot