diff --git a/src/components/widgets/search/search.jsx b/src/components/widgets/search/search.jsx
index 414c99a6..c85a51f7 100644
--- a/src/components/widgets/search/search.jsx
+++ b/src/components/widgets/search/search.jsx
@@ -1,4 +1,4 @@
-import { useState, useEffect, useCallback, Fragment } from "react";
+import { useState, useEffect, useCallback, Fragment, useRef } from "react";
import { useTranslation } from "next-i18next";
import { FiSearch } from "react-icons/fi";
import { SiDuckduckgo, SiMicrosoftbing, SiGoogle, SiBaidu, SiBrave } from "react-icons/si";
@@ -71,6 +71,9 @@ export function getStoredProvider() {
export default function Search({ options }) {
const { t } = useTranslation();
+ const searchProviderButton = useRef();
+ const comboboxOptions = useRef();
+
const availableProviderIds = getAvailableProviderIds(options);
const [query, setQuery] = useState("");
@@ -120,11 +123,8 @@ export default function Search({ options }) {
}, [selectedProvider, options, query, searchSuggestions]);
const handleSearchKeyDown = (event) => {
- if (
- event.key === "Tab" &&
- document.getElementById("comboboxOptions")?.getAttribute("data-headlessui-state") === "open"
- ) {
- document.getElementById("searchProviderButton").focus();
+ if (event.key === "Tab" && comboboxOptions.current?.getAttribute("data-headlessui-state") === "open") {
+ searchProviderButton.current.focus();
event.preventDefault();
}
};
@@ -194,7 +194,7 @@ export default function Search({ options }) {
text-white font-medium text-sm
bg-theme-600/40 dark:bg-white/10
focus:ring-theme-500 dark:focus:ring-white/50"
- id="searchProviderButton"
+ ref={searchProviderButton}
>
{t("search.search")}
@@ -240,7 +240,7 @@ export default function Search({ options }) {
{searchSuggestions[1]?.length > 0 && (