Compatible with quicklaunch internet search

pull/899/head
shamoon 2 years ago
parent 87dbbcb1e0
commit 7a5a3a6608

@ -3,6 +3,7 @@ import { useTranslation } from "next-i18next";
import { FiSearch } from "react-icons/fi"; import { FiSearch } from "react-icons/fi";
import { SiDuckduckgo, SiMicrosoftbing, SiGoogle, SiBaidu, SiBrave } from "react-icons/si"; import { SiDuckduckgo, SiMicrosoftbing, SiGoogle, SiBaidu, SiBrave } from "react-icons/si";
import { Listbox, Transition } from "@headlessui/react"; import { Listbox, Transition } from "@headlessui/react";
import classNames from "classnames";
export const searchProviders = { export const searchProviders = {
google: { google: {
@ -37,10 +38,6 @@ export const searchProviders = {
}, },
}; };
function classNames(...classes) {
return classes.filter(Boolean).join(" ");
}
function getAvailableProviderIds(options) { function getAvailableProviderIds(options) {
if (options.provider && Array.isArray(options.provider)) { if (options.provider && Array.isArray(options.provider)) {
return Object.keys(searchProviders).filter((value) => options.provider.includes(value)); return Object.keys(searchProviders).filter((value) => options.provider.includes(value));
@ -51,26 +48,32 @@ function getAvailableProviderIds(options) {
return null; return null;
} }
const localStorageKey = "search-name";
export function getStoredProvider() {
if (typeof window !== 'undefined') {
const storedName = localStorage.getItem(localStorageKey);
if (storedName) {
return Object.values(searchProviders).find((el) => el.name === storedName);
}
}
return null;
}
export default function Search({ options }) { export default function Search({ options }) {
const { t } = useTranslation(); const { t } = useTranslation();
const availableProviderIds = getAvailableProviderIds(options); const availableProviderIds = getAvailableProviderIds(options);
const key = "search-name";
const [query, setQuery] = useState(""); const [query, setQuery] = useState("");
const [selectedProvider, setSelectedProvider] = useState(searchProviders[availableProviderIds[0] ?? searchProviders.google]); const [selectedProvider, setSelectedProvider] = useState(searchProviders[availableProviderIds[0] ?? searchProviders.google]);
useEffect(() => { useEffect(() => {
const storedName = localStorage.getItem(key); const storedProvider = getStoredProvider();
let storedProvider = null;
let storedProviderKey = null; let storedProviderKey = null;
if (storedName) { storedProviderKey = Object.keys(searchProviders).find((pkey) => searchProviders[pkey] === storedProvider);
storedProvider = Object.values(searchProviders).find((el) => el.name === storedName); if (storedProvider && availableProviderIds.includes(storedProviderKey)) {
storedProviderKey = Object.keys(searchProviders).find((pkey) => searchProviders[pkey] === storedProvider); setSelectedProvider(storedProvider);
if (storedProvider && availableProviderIds.includes(storedProviderKey)) {
setSelectedProvider(storedProvider);
}
} }
}, [availableProviderIds]); }, [availableProviderIds]);
@ -95,7 +98,7 @@ export default function Search({ options }) {
const onChangeProvider = (provider) => { const onChangeProvider = (provider) => {
setSelectedProvider(provider); setSelectedProvider(provider);
localStorage.setItem(key, provider.name); localStorage.setItem(localStorageKey, provider.name);
} }
return ( return (

@ -22,7 +22,7 @@ import { bookmarksResponse, servicesResponse, widgetsResponse } from "utils/conf
import ErrorBoundary from "components/errorboundry"; import ErrorBoundary from "components/errorboundry";
import themes from "utils/styles/themes"; import themes from "utils/styles/themes";
import QuickLaunch from "components/quicklaunch"; import QuickLaunch from "components/quicklaunch";
import { searchProviders } from "components/widgets/search/search"; import { getStoredProvider, searchProviders } from "components/widgets/search/search";
const ThemeToggle = dynamic(() => import("components/toggles/theme"), { const ThemeToggle = dynamic(() => import("components/toggles/theme"), {
ssr: false, ssr: false,
@ -197,12 +197,17 @@ function Home({ initialSettings }) {
let searchProvider = null; let searchProvider = null;
const searchWidget = Object.values(widgets).find(w => w.type === "search"); const searchWidget = Object.values(widgets).find(w => w.type === "search");
if (searchWidget) { if (searchWidget) {
if (searchWidget.options?.provider === 'custom') { if (Array.isArray(searchWidget.options?.provider)) {
searchProvider = { // if search provider is a list, try to retrieve from localstorage, fall back to the first
url: searchWidget.options.url searchProvider = getStoredProvider() ?? searchProviders[searchWidget.options.provider[0]];
}
} else { } else {
searchProvider = searchProviders[searchWidget.options?.provider]; if (searchWidget.options?.provider === 'custom') {
searchProvider = {
url: searchWidget.options.url
}
} else {
searchProvider = searchProviders[searchWidget.options?.provider];
}
} }
} }

Loading…
Cancel
Save