mirror of
https://github.com/facebook/docusaurus.git
synced 2025-06-06 12:52:31 +02:00
fix(v2): do not focus on skip link if page refreshed (#4797)
* fix(v2): do not focus on skip link if page refreshed * rename ref Co-authored-by: slorber <lorber.sebastien@gmail.com>
This commit is contained in:
parent
ab19070ab5
commit
0360364570
4 changed files with 32 additions and 9 deletions
|
@ -5,9 +5,10 @@
|
||||||
* LICENSE file in the root directory of this source tree.
|
* LICENSE file in the root directory of this source tree.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import React, {useRef, useEffect} from 'react';
|
import React, {useRef} from 'react';
|
||||||
import Translate from '@docusaurus/Translate';
|
import Translate from '@docusaurus/Translate';
|
||||||
import {useLocation} from '@docusaurus/router';
|
import {useChangeRoute} from '@docusaurus/theme-common';
|
||||||
|
|
||||||
import styles from './styles.module.css';
|
import styles from './styles.module.css';
|
||||||
|
|
||||||
function programmaticFocus(el: HTMLElement) {
|
function programmaticFocus(el: HTMLElement) {
|
||||||
|
@ -18,8 +19,6 @@ function programmaticFocus(el: HTMLElement) {
|
||||||
|
|
||||||
function SkipToContent(): JSX.Element {
|
function SkipToContent(): JSX.Element {
|
||||||
const containerRef = useRef<HTMLDivElement>(null);
|
const containerRef = useRef<HTMLDivElement>(null);
|
||||||
const location = useLocation();
|
|
||||||
|
|
||||||
const handleSkip = (e: React.MouseEvent<HTMLAnchorElement>) => {
|
const handleSkip = (e: React.MouseEvent<HTMLAnchorElement>) => {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
|
||||||
|
@ -32,11 +31,11 @@ function SkipToContent(): JSX.Element {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
useEffect(() => {
|
useChangeRoute(() => {
|
||||||
if (!location.hash && containerRef.current) {
|
if (containerRef.current) {
|
||||||
programmaticFocus(containerRef.current);
|
programmaticFocus(containerRef.current);
|
||||||
}
|
}
|
||||||
}, [location.pathname]);
|
});
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div ref={containerRef}>
|
<div ref={containerRef}>
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
import {useState, useCallback, useEffect, useRef} from 'react';
|
import {useState, useCallback, useEffect, useRef} from 'react';
|
||||||
import {useLocation} from '@docusaurus/router';
|
import {useLocation} from '@docusaurus/router';
|
||||||
import useScrollPosition from '@theme/hooks/useScrollPosition';
|
import useScrollPosition from '@theme/hooks/useScrollPosition';
|
||||||
|
import {useChangeRoute} from '@docusaurus/theme-common';
|
||||||
import type {useHideableNavbarReturns} from '@theme/hooks/useHideableNavbar';
|
import type {useHideableNavbarReturns} from '@theme/hooks/useHideableNavbar';
|
||||||
|
|
||||||
const useHideableNavbar = (hideOnScroll: boolean): useHideableNavbarReturns => {
|
const useHideableNavbar = (hideOnScroll: boolean): useHideableNavbarReturns => {
|
||||||
|
@ -55,13 +56,13 @@ const useHideableNavbar = (hideOnScroll: boolean): useHideableNavbarReturns => {
|
||||||
[navbarHeight, isFocusedAnchor],
|
[navbarHeight, isFocusedAnchor],
|
||||||
);
|
);
|
||||||
|
|
||||||
useEffect(() => {
|
useChangeRoute(() => {
|
||||||
if (!hideOnScroll) {
|
if (!hideOnScroll) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
setIsNavbarVisible(true);
|
setIsNavbarVisible(true);
|
||||||
}, [location.pathname]);
|
});
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!hideOnScroll) {
|
if (!hideOnScroll) {
|
||||||
|
|
|
@ -33,6 +33,8 @@ export {useTitleFormatter} from './utils/generalUtils';
|
||||||
|
|
||||||
export {usePluralForm} from './utils/usePluralForm';
|
export {usePluralForm} from './utils/usePluralForm';
|
||||||
|
|
||||||
|
export {useChangeRoute} from './utils/useChangeRoute';
|
||||||
|
|
||||||
export {
|
export {
|
||||||
useDocsPreferredVersion,
|
useDocsPreferredVersion,
|
||||||
useDocsPreferredVersionByPluginId,
|
useDocsPreferredVersionByPluginId,
|
||||||
|
|
21
packages/docusaurus-theme-common/src/utils/useChangeRoute.ts
Normal file
21
packages/docusaurus-theme-common/src/utils/useChangeRoute.ts
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the MIT license found in the
|
||||||
|
* LICENSE file in the root directory of this source tree.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import {useRef, useEffect} from 'react';
|
||||||
|
import {useLocation} from '@docusaurus/router';
|
||||||
|
|
||||||
|
export function useChangeRoute(onRouteChange: () => void): void {
|
||||||
|
const {pathname} = useLocation();
|
||||||
|
const latestPathnameRef = useRef(pathname);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (pathname !== latestPathnameRef.current) {
|
||||||
|
latestPathnameRef.current = pathname;
|
||||||
|
onRouteChange();
|
||||||
|
}
|
||||||
|
}, [pathname, latestPathnameRef, onRouteChange]);
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue