fix deselect in keyword picker
This commit is contained in:
		| @@ -5,7 +5,7 @@ import { Link } from "gatsby"; | ||||
| interface KeywordsPickerProps { | ||||
|   keywords: string[]; | ||||
|   value: string | null; | ||||
|   getHref: (value: string | null) => string; | ||||
|   getHref: (value: string | null, selected: boolean) => string; | ||||
|   onPick: (value: string | null) => void; | ||||
| } | ||||
| const KeywordsPicker = ({ keywords, value, getHref, onPick }: KeywordsPickerProps) => { | ||||
| @@ -28,7 +28,7 @@ const KeywordsPicker = ({ keywords, value, getHref, onPick }: KeywordsPickerProp | ||||
|                 )} | ||||
|                 onClick={() => onPick(keyword)} | ||||
|                 replace={false} | ||||
|                 to={getHref(keyword)} | ||||
|                 to={getHref(keyword, selected)} | ||||
|               > | ||||
|                 {keyword}{" "} | ||||
|               </Link> | ||||
|   | ||||
| @@ -54,8 +54,7 @@ const GalleryPage = ({ | ||||
|   const showDebug = Boolean(params.get("debug")?.length); | ||||
|   const [showPalette, setShowPalette] = React.useState(false); | ||||
|  | ||||
|   const onKeywordPick = React.useCallback( | ||||
|     (newKeyword: string | null) => { | ||||
|   const onKeywordPick = React.useCallback((newKeyword: string | null) => { | ||||
|     if (newKeyword) { | ||||
|       try { | ||||
|         window.plausible("Filter Keyword", { | ||||
| @@ -65,9 +64,7 @@ const GalleryPage = ({ | ||||
|         // do nothing | ||||
|       } | ||||
|     } | ||||
|     }, | ||||
|     [] | ||||
|   ); | ||||
|   }, []); | ||||
|  | ||||
|   const setSortKey = React.useCallback( | ||||
|     (newSortKey: string) => { | ||||
| @@ -121,7 +118,7 @@ const GalleryPage = ({ | ||||
|         console.log("⚠️failed to find hash"); | ||||
|         return; | ||||
|       } | ||||
|       console.log('scrolling into view manually') | ||||
|       console.log("scrolling into view manually"); | ||||
|       el.scrollIntoView({ | ||||
|         block: hash.startsWith("all") ? "start" : "center", | ||||
|       }); | ||||
| @@ -254,11 +251,10 @@ const GalleryPage = ({ | ||||
|         </div> | ||||
|         <div className="flex flex-col lg:flex-row lg:items-end justify-between px-4 md:px-8 sm:mx-auto"> | ||||
|           <KeywordsPicker | ||||
|             getHref={(val) => | ||||
|               getGalleryPageUrl( | ||||
|                 { keyword: val, sortKey, showDebug }, | ||||
|                 hash | ||||
|               ) | ||||
|             getHref={(val, selected) => | ||||
|               selected | ||||
|                 ? getGalleryPageUrl({ keyword: null, sortKey, showDebug }, hash) | ||||
|                 : getGalleryPageUrl({ keyword: val, sortKey, showDebug }, hash) | ||||
|             } | ||||
|             keywords={[ | ||||
|               "Boyce Thompson Arboretum", | ||||
|   | ||||
		Reference in New Issue
	
	Block a user