diff --git a/src/renderer/app.tsx b/src/renderer/app.tsx index f705cf716..0680f506f 100644 --- a/src/renderer/app.tsx +++ b/src/renderer/app.tsx @@ -73,7 +73,11 @@ export function App() { return; } - navigate(`/search/${query}`, { + const searchParams = new URLSearchParams({ + query, + }); + + navigate(`/search?${searchParams.toString()}`, { replace: location.pathname.startsWith("/search"), }); }, diff --git a/src/renderer/main.tsx b/src/renderer/main.tsx index 3bad1a79d..4839740f2 100644 --- a/src/renderer/main.tsx +++ b/src/renderer/main.tsx @@ -45,7 +45,7 @@ const router = createHashRouter([ Component: GameDetails, }, { - path: "/search/:query", + path: "/search", Component: SearchResults, }, { diff --git a/src/renderer/pages/catalogue/search-results.tsx b/src/renderer/pages/catalogue/search-results.tsx index d9d868acb..75d3e1d94 100644 --- a/src/renderer/pages/catalogue/search-results.tsx +++ b/src/renderer/pages/catalogue/search-results.tsx @@ -12,14 +12,14 @@ import { useAppDispatch } from "@renderer/hooks"; import { vars } from "@renderer/theme.css"; import { useEffect, useRef, useState } from "react"; import { useTranslation } from "react-i18next"; -import { useNavigate, useParams } from "react-router-dom"; +import { useNavigate, useSearchParams } from "react-router-dom"; import * as styles from "./catalogue.css"; export function SearchResults() { const dispatch = useAppDispatch(); const { t } = useTranslation("catalogue"); - const { query } = useParams(); + const [searchParams] = useSearchParams(); const [searchResults, setSearchResults] = useState([]); const [isLoading, setIsLoading] = useState(false); @@ -39,7 +39,7 @@ export function SearchResults() { debouncedFunc.current = debounce(() => { window.electron - .searchGames(query) + .searchGames(searchParams.get("query")) .then((results) => { setSearchResults(results); }) @@ -49,11 +49,11 @@ export function SearchResults() { }, 300); debouncedFunc.current(); - }, [query, dispatch]); + }, [searchParams, dispatch]); return ( -
+
{isLoading && Array.from({ length: 12 }).map((_, index) => ( @@ -81,7 +81,7 @@ export function SearchResults() {

{t("no_results")}

)} -
+
); }