{
return 'plugin'
}
+
+export const updateSearchParams = (pluginsSearchParams: PluginsSearchParams) => {
+ const { query, category, tags } = pluginsSearchParams
+ const url = new URL(window.location.href)
+ const categoryChanged = url.searchParams.get('category') !== category
+ if (query)
+ url.searchParams.set('q', query)
+ else
+ url.searchParams.delete('q')
+ if (category)
+ url.searchParams.set('category', category)
+ else
+ url.searchParams.delete('category')
+ if (tags && tags.length)
+ url.searchParams.set('tags', tags.join(','))
+ else
+ url.searchParams.delete('tags')
+ history[`${categoryChanged ? 'pushState' : 'replaceState'}`]({}, '', url)
+}
diff --git a/web/app/components/plugins/plugin-page/context.tsx b/web/app/components/plugins/plugin-page/context.tsx
index cf26cd4e0..ae1ad7d05 100644
--- a/web/app/components/plugins/plugin-page/context.tsx
+++ b/web/app/components/plugins/plugin-page/context.tsx
@@ -12,9 +12,9 @@ import {
} from 'use-context-selector'
import { useSelector as useAppContextSelector } from '@/context/app-context'
import type { FilterState } from './filter-management'
-import { useTranslation } from 'react-i18next'
import { useTabSearchParams } from '@/hooks/use-tab-searchparams'
import { noop } from 'lodash-es'
+import { PLUGIN_PAGE_TABS_MAP, usePluginPageTabs } from '../hooks'
export type PluginPageContextValue = {
containerRef: React.RefObject
@@ -53,7 +53,6 @@ export function usePluginPageContext(selector: (value: PluginPageContextValue) =
export const PluginPageContextProvider = ({
children,
}: PluginPageContextProviderProps) => {
- const { t } = useTranslation()
const containerRef = useRef(null)
const [filters, setFilters] = useState({
categories: [],
@@ -63,16 +62,10 @@ export const PluginPageContextProvider = ({
const [currentPluginID, setCurrentPluginID] = useState()
const { enable_marketplace } = useAppContextSelector(s => s.systemFeatures)
+ const tabs = usePluginPageTabs()
const options = useMemo(() => {
- return [
- { value: 'plugins', text: t('common.menus.plugins') },
- ...(
- enable_marketplace
- ? [{ value: 'discover', text: t('common.menus.exploreMarketplace') }]
- : []
- ),
- ]
- }, [t, enable_marketplace])
+ return enable_marketplace ? tabs : tabs.filter(tab => tab.value !== PLUGIN_PAGE_TABS_MAP.marketplace)
+ }, [tabs, enable_marketplace])
const [activeTab, setActiveTab] = useTabSearchParams({
defaultTab: options[0].value,
})
diff --git a/web/app/components/plugins/plugin-page/index.tsx b/web/app/components/plugins/plugin-page/index.tsx
index 801eaf660..072b8ee22 100644
--- a/web/app/components/plugins/plugin-page/index.tsx
+++ b/web/app/components/plugins/plugin-page/index.tsx
@@ -40,6 +40,8 @@ import { SUPPORT_INSTALL_LOCAL_FILE_EXTENSIONS } from '@/config'
import { LanguagesSupported } from '@/i18n/language'
import I18n from '@/context/i18n'
import { noop } from 'lodash-es'
+import { PLUGIN_TYPE_SEARCH_MAP } from '../marketplace/plugin-type-switch'
+import { PLUGIN_PAGE_TABS_MAP } from '../hooks'
const PACKAGE_IDS_KEY = 'package-ids'
const BUNDLE_INFO_KEY = 'bundle-info'
@@ -136,40 +138,45 @@ const PluginPage = ({
const setActiveTab = usePluginPageContext(v => v.setActiveTab)
const { enable_marketplace } = useAppContextSelector(s => s.systemFeatures)
+ const isPluginsTab = useMemo(() => activeTab === PLUGIN_PAGE_TABS_MAP.plugins, [activeTab])
+ const isExploringMarketplace = useMemo(() => {
+ const values = Object.values(PLUGIN_TYPE_SEARCH_MAP)
+ return activeTab === PLUGIN_PAGE_TABS_MAP.marketplace || values.includes(activeTab)
+ }, [activeTab])
+
const uploaderProps = useUploader({
onFileChange: setCurrentFile,
containerRef,
- enabled: activeTab === 'plugins',
+ enabled: isPluginsTab,
})
const { dragging, fileUploader, fileChangeHandle, removeFile } = uploaderProps
-
return (
{
- activeTab === 'discover' && (
+ isExploringMarketplace && (
<>
- {activeTab === 'plugins' && (
+ {isPluginsTab && (
<>
{plugins}
{dragging && (
@@ -246,7 +253,7 @@ const PluginPage = ({
>
)}
{
- activeTab === 'discover' && enable_marketplace && marketplace
+ isExploringMarketplace && enable_marketplace && marketplace
}
{showPluginSettingModal && (