| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178 | 'use client'import type { FC } from 'react'import React, { useMemo } from 'react'import {  RiArrowRightUpLine,  RiBugLine,  RiHardDrive3Line,  RiLoginCircleLine,  RiVerifiedBadgeLine,} from '@remixicon/react'import { useTranslation } from 'react-i18next'import { usePluginPageContext } from '../plugin-page/context'import { Github } from '../../base/icons/src/public/common'import Badge from '../../base/badge'import { type PluginDetail, PluginSource, PluginType } from '../types'import CornerMark from '../card/base/corner-mark'import Description from '../card/base/description'import OrgInfo from '../card/base/org-info'import Title from '../card/base/title'import Action from './action'import cn from '@/utils/classnames'import { API_PREFIX, MARKETPLACE_URL_PREFIX } from '@/config'import { useSingleCategories } from '../hooks'import { useRenderI18nObject } from '@/hooks/use-i18n'import useRefreshPluginList from '@/app/components/plugins/install-plugin/hooks/use-refresh-plugin-list'type Props = {  className?: string  plugin: PluginDetail}const PluginItem: FC<Props> = ({  className,  plugin,}) => {  const { t } = useTranslation()  const { categoriesMap } = useSingleCategories()  const currentPluginID = usePluginPageContext(v => v.currentPluginID)  const setCurrentPluginID = usePluginPageContext(v => v.setCurrentPluginID)  const { refreshPluginList } = useRefreshPluginList()  const {    source,    tenant_id,    installation_id,    plugin_unique_identifier,    endpoints_active,    meta,    plugin_id,  } = plugin  const { category, author, name, label, description, icon, verified } = plugin.declaration  const orgName = useMemo(() => {    return [PluginSource.github, PluginSource.marketplace].includes(source) ? author : ''  }, [source, author])  const handleDelete = () => {    refreshPluginList({ category } as any)  }  const getValueFromI18nObject = useRenderI18nObject()  const title = getValueFromI18nObject(label)  const descriptionText = getValueFromI18nObject(description)  return (    <div      className={cn(        'rounded-xl border-[1.5px] border-background-section-burn p-1',        currentPluginID === plugin_id && 'border-components-option-card-option-selected-border',        source === PluginSource.debugging          ? 'bg-[repeating-linear-gradient(-45deg,rgba(16,24,40,0.04),rgba(16,24,40,0.04)_5px,rgba(0,0,0,0.02)_5px,rgba(0,0,0,0.02)_10px)]'          : 'bg-background-section-burn',      )}      onClick={() => {        setCurrentPluginID(plugin.plugin_id)      }}    >      <div className={cn('hover-bg-components-panel-on-panel-item-bg relative rounded-xl border-[0.5px] border-components-panel-border bg-components-panel-on-panel-item-bg p-4 pb-3 shadow-xs', className)}>        <CornerMark text={categoriesMap[category].label} />        {/* Header */}        <div className="flex">          <div className='flex h-10 w-10 items-center justify-center overflow-hidden rounded-xl border-[1px] border-components-panel-border-subtle'>            <img              className='h-full w-full'              src={`${API_PREFIX}/workspaces/current/plugin/icon?tenant_id=${tenant_id}&filename=${icon}`}              alt={`plugin-${plugin_unique_identifier}-logo`}            />          </div>          <div className="ml-3 w-0 grow">            <div className="flex h-5 items-center">              <Title title={title} />              {verified && <RiVerifiedBadgeLine className="ml-0.5 h-4 w-4 shrink-0 text-text-accent" />}              <Badge className='ml-1 shrink-0' text={source === PluginSource.github ? plugin.meta!.version : plugin.version} />            </div>            <div className='flex items-center justify-between'>              <Description text={descriptionText} descriptionLineRows={1}></Description>              <div onClick={e => e.stopPropagation()}>                <Action                  pluginUniqueIdentifier={plugin_unique_identifier}                  installationId={installation_id}                  author={author}                  pluginName={name}                  usedInApps={5}                  isShowFetchNewVersion={source === PluginSource.github}                  isShowInfo={source === PluginSource.github}                  isShowDelete                  meta={meta}                  onDelete={handleDelete}                  category={category}                />              </div>            </div>          </div>        </div>      </div>      <div className='mb-1 mt-1.5 flex h-4 items-center justify-between px-4'>        <div className='flex items-center'>          <OrgInfo            className="mt-0.5"            orgName={orgName}            packageName={name}            packageNameClassName='w-auto max-w-[150px]'          />          {category === PluginType.extension && (            <>              <div className='system-xs-regular mx-2 text-text-quaternary'>·</div>              <div className='system-xs-regular flex space-x-1 text-text-tertiary'>                <RiLoginCircleLine className='h-4 w-4' />                <span>{t('plugin.endpointsEnabled', { num: endpoints_active })}</span>              </div>            </>          )}        </div>        <div className='flex items-center'>          {source === PluginSource.github            && <>              <a href={`https://github.com/${meta!.repo}`} target='_blank' className='flex items-center gap-1'>                <div className='system-2xs-medium-uppercase text-text-tertiary'>{t('plugin.from')}</div>                <div className='flex items-center space-x-0.5 text-text-secondary'>                  <Github className='h-3 w-3' />                  <div className='system-2xs-semibold-uppercase'>GitHub</div>                  <RiArrowRightUpLine className='h-3 w-3' />                </div>              </a>            </>          }          {source === PluginSource.marketplace            && <>              <a href={`${MARKETPLACE_URL_PREFIX}/plugins/${author}/${name}`} target='_blank' className='flex items-center gap-0.5'>                <div className='system-2xs-medium-uppercase text-text-tertiary'>{t('plugin.from')} <span className='text-text-secondary'>marketplace</span></div>                <RiArrowRightUpLine className='h-3 w-3 text-text-tertiary' />              </a>            </>          }          {source === PluginSource.local            && <>              <div className='flex items-center gap-1'>                <RiHardDrive3Line className='h-3 w-3 text-text-tertiary' />                <div className='system-2xs-medium-uppercase text-text-tertiary'>Local Plugin</div>              </div>            </>          }          {source === PluginSource.debugging            && <>              <div className='flex items-center gap-1'>                <RiBugLine className='h-3 w-3 text-text-warning' />                <div className='system-2xs-medium-uppercase text-text-warning'>Debugging Plugin</div>              </div>            </>          }        </div>      </div>    </div>  )}export default React.memo(PluginItem)
 |