|
2 | 2 |
|
3 | 3 | import { useQuery } from '@tanstack/react-query'
|
4 | 4 | import React, { memo, useDeferredValue, useEffect, useMemo } from 'react'
|
| 5 | +import clsx from 'clsx' |
5 | 6 | import { AnimatePresence, m } from 'framer-motion'
|
6 | 7 | import Image from 'next/image'
|
7 | 8 |
|
@@ -288,33 +289,31 @@ export const Activity = memo(() => {
|
288 | 289 | })
|
289 | 290 | Activity.displayName = 'Activity'
|
290 | 291 | const cMusicProps = { processName: 'cmusic' }
|
| 292 | + |
| 293 | +const ErrorFallback = `` |
291 | 294 | const TriggerComponent = memo<{
|
292 | 295 | processName: string
|
293 | 296 | icon?: string
|
294 | 297 | }>(({ processName, icon }) => {
|
295 | 298 | const isBuiltIn = !!appLabels[processName]
|
296 | 299 |
|
297 |
| - if (!isBuiltIn) { |
298 |
| - return ( |
299 |
| - <img |
300 |
| - width={32} |
301 |
| - height={32} |
302 |
| - src={icon} |
303 |
| - alt={processName} |
304 |
| - className="pointer-events-none select-none overflow-hidden rounded-md" |
305 |
| - /> |
306 |
| - ) |
307 |
| - } |
| 300 | + const src = !isBuiltIn && icon ? icon : `/apps/${appLabels[processName]}.png` |
| 301 | + |
| 302 | + const className = clsx('pointer-events-none select-none', { |
| 303 | + 'rounded-md': !isBuiltIn, |
| 304 | + }) |
| 305 | + const [error, setError] = React.useState(false) |
308 | 306 |
|
309 | 307 | return (
|
310 | 308 | <Image
|
311 | 309 | width={32}
|
312 | 310 | height={32}
|
313 |
| - src={`/apps/${appLabels[processName]}.png`} |
| 311 | + src={error ? ErrorFallback : src} |
314 | 312 | alt={processName}
|
315 | 313 | priority
|
316 | 314 | fetchPriority="low"
|
317 |
| - className="pointer-events-none select-none" |
| 315 | + className={className} |
| 316 | + onError={() => setError(true)} |
318 | 317 | />
|
319 | 318 | )
|
320 | 319 | })
|
|
0 commit comments