Skip to content
This repository has been archived by the owner on Jun 11, 2021. It is now read-only.

Commit

Permalink
feat(docsearch): introduce initialScrollY option
Browse files Browse the repository at this point in the history
  • Loading branch information
francoischalifour committed Jun 11, 2020
1 parent 512f586 commit 2d5b216
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 16 deletions.
32 changes: 18 additions & 14 deletions packages/docsearch-react/src/DocSearch.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
import React from 'react';
import { createPortal } from 'react-dom';
import { PublicAutocompleteOptions } from '@francoischalifour/autocomplete-core';
import {
PublicAutocompleteOptions,
AutocompleteState,
} from '@francoischalifour/autocomplete-core';

import { DocSearchHit, InternalDocSearchHit } from './types';
import { DocSearchButton } from './DocSearchButton';
Expand All @@ -19,24 +22,21 @@ export interface DocSearchProps
hit: DocSearchHit;
children: React.ReactNode;
}): JSX.Element;
resultsFooterComponent?(props: {
state: AutocompleteState<InternalDocSearchHit>;
}): JSX.Element | null;
}

export function DocSearch(props: DocSearchProps) {
const [isOpen, setIsOpen] = React.useState(false);

const onOpen = React.useCallback(
function onOpen() {
setIsOpen(true);
},
[setIsOpen]
);
const onOpen = React.useCallback(() => {
setIsOpen(true);
}, [setIsOpen]);

const onClose = React.useCallback(
function onClose() {
setIsOpen(false);
},
[setIsOpen]
);
const onClose = React.useCallback(() => {
setIsOpen(false);
}, [setIsOpen]);

useDocSearchKeyboardEvents({ isOpen, onOpen, onClose });

Expand All @@ -46,7 +46,11 @@ export function DocSearch(props: DocSearchProps) {

{isOpen &&
createPortal(
<DocSearchModal {...props} onClose={onClose} />,
<DocSearchModal
{...props}
initialScrollY={window.scrollY}
onClose={onClose}
/>,
document.body
)}
</>
Expand Down
8 changes: 6 additions & 2 deletions packages/docsearch-react/src/DocSearchModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ import { ScreenState } from './ScreenState';
import { Footer } from './Footer';

interface DocSearchModalProps extends DocSearchProps {
initialScrollY: number;
onClose?(): void;
}

Expand All @@ -37,6 +38,7 @@ export function DocSearchModal({
hitComponent = Hit,
resultsFooterComponent = () => null,
navigator,
initialScrollY = 0,
}: DocSearchModalProps) {
const [state, setState] = React.useState<
AutocompleteState<InternalDocSearchHit>
Expand Down Expand Up @@ -275,14 +277,16 @@ export function DocSearchModal({

React.useEffect(() => {
document.body.classList.add('DocSearch--active');
scrollY.current = window.scrollY;

return () => {
document.body.classList.remove('DocSearch--active');

// IE11 doesn't support `scrollTo` so we check that the method exists
// first.
window.scrollTo?.(0, scrollY.current);
window.scrollTo?.(0, initialScrollY);
};

// eslint-disable-next-line react-hooks/exhaustive-deps
}, []);

React.useEffect(() => {
Expand Down
1 change: 1 addition & 0 deletions packages/website/src/theme/SearchBar/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ function DocSearch({ indexName, appId, apiKey, searchParameters }) {
apiKey={apiKey}
indexName={indexName}
searchParameters={searchParameters}
initialScrollY={window.scrollY}
onClose={onClose}
navigator={{
navigate({ suggestionUrl }) {
Expand Down

0 comments on commit 2d5b216

Please sign in to comment.