fix(web): distinct extension-format icons (plugin/mcp/skill)

The format filter used Wrench/AudioWaveform/Book for plugin/mcp/skill,
which collided with the plugin-component icons (Tool/EventListener/
KnowledgeEngine) shown right below. Switch formats to Puzzle/Server/
Sparkles — matching the canonical getTypeIcon used by the detail badges
— across the market filter, installed filter, install-queue map and
install-progress dialog.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
Junyan Qin
2026-06-04 21:34:23 +08:00
parent c967a2aa82
commit 3b4c455813
4 changed files with 23 additions and 17 deletions

View File

@@ -11,7 +11,7 @@ import {
Download,
Package,
Server,
BookOpen,
Sparkles,
CheckCircle2,
XCircle,
Loader2,
@@ -176,7 +176,7 @@ function TaskProgressContent({ task }: { task: PluginInstallTask }) {
// MCP / Skill don't have the plugin's download + dependency-install stages;
// show a single "installing → done/failed" row instead of plugin steps.
const isPlugin = task.extensionType === 'plugin';
const simpleIcon = task.extensionType === 'mcp' ? Server : BookOpen;
const simpleIcon = task.extensionType === 'mcp' ? Server : Sparkles;
const simpleInstallingLabel =
task.extensionType === 'mcp'
? t('addExtension.installStage.mcpInstalling')

View File

@@ -9,9 +9,9 @@ import {
Loader2,
X,
ListTodo,
Wrench,
AudioWaveform,
Book,
Puzzle,
Server,
Sparkles,
} from 'lucide-react';
import { Button } from '@/components/ui/button';
import {
@@ -35,9 +35,9 @@ const STAGE_ICONS: Record<string, React.ElementType> = {
};
const EXTENSION_TYPE_ICONS: Record<string, React.ElementType> = {
plugin: Wrench,
mcp: AudioWaveform,
skill: Book,
plugin: Puzzle,
mcp: Server,
skill: Sparkles,
};
function TaskQueueItem({
@@ -54,7 +54,7 @@ function TaskQueueItem({
const isError = task.stage === InstallStage.ERROR;
const isRunning = !isDone && !isError;
const StageIcon = STAGE_ICONS[task.stage] || Download;
const TypeIcon = EXTENSION_TYPE_ICONS[task.extensionType] || Wrench;
const TypeIcon = EXTENSION_TYPE_ICONS[task.extensionType] || Puzzle;
const getTypeBadgeClass = () => {
switch (task.extensionType) {

View File

@@ -21,8 +21,7 @@ import { extractI18nObject } from '@/i18n/I18nProvider';
import { toast } from 'sonner';
import { useAsyncTask, AsyncTaskStatus } from '@/hooks/useAsyncTask';
import { useSidebarData } from '@/app/home/components/home-sidebar/SidebarDataContext';
import { Loader2, Puzzle } from 'lucide-react';
import { Wrench, AudioWaveform, Book } from 'lucide-react';
import { Loader2, Puzzle, Server, Sparkles } from 'lucide-react';
export interface PluginInstalledComponentRef {
refreshPluginList: () => void;
@@ -44,14 +43,18 @@ export const FilterOptions = [
{
value: 'plugin' as FilterType,
labelKey: 'market.typePlugin',
icon: Wrench,
icon: Puzzle,
},
{
value: 'mcp' as FilterType,
labelKey: 'market.typeMCP',
icon: AudioWaveform,
icon: Server,
},
{
value: 'skill' as FilterType,
labelKey: 'market.typeSkill',
icon: Sparkles,
},
{ value: 'skill' as FilterType, labelKey: 'market.typeSkill', icon: Book },
];
interface PluginInstalledComponentProps {

View File

@@ -17,6 +17,9 @@ import { Separator } from '@/components/ui/separator';
import { ToggleGroup, ToggleGroupItem } from '@/components/ui/toggle-group';
import {
Search,
Puzzle,
Server,
Sparkles,
Wrench,
AudioWaveform,
Hash,
@@ -88,9 +91,9 @@ function MarketPageContent({
const extensionTypeOptions = [
{ value: 'all', label: t('market.filters.allFormats'), icon: null },
{ value: 'plugin', label: t('market.typePlugin'), icon: Wrench },
{ value: 'mcp', label: t('market.typeMCP'), icon: AudioWaveform },
{ value: 'skill', label: t('market.typeSkill'), icon: Book },
{ value: 'plugin', label: t('market.typePlugin'), icon: Puzzle },
{ value: 'mcp', label: t('market.typeMCP'), icon: Server },
{ value: 'skill', label: t('market.typeSkill'), icon: Sparkles },
];
const [searchQuery, setSearchQuery] = useState('');