wwf
2025-05-20 938c3e5a587ce950a94964ea509b9e7f8834dfae
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
'use client'
import type { FC } from 'react'
import React from 'react'
import { useTranslation } from 'react-i18next'
import KeyValueItem from '../base/key-value-item'
import Modal from '../../base/modal'
import { convertRepoToUrl } from '../install-plugin/utils'
 
const i18nPrefix = 'plugin.pluginInfoModal'
type Props = {
  repository?: string
  release?: string
  packageName?: string
  onHide: () => void
}
 
const PlugInfo: FC<Props> = ({
  repository,
  release,
  packageName,
  onHide,
}) => {
  const { t } = useTranslation()
  const labelWidthClassName = 'w-[96px]'
  return (
    <Modal
      title={t(`${i18nPrefix}.title`)}
      className='w-[480px]'
      isShow
      onClose={onHide}
      closable
    >
      <div className='mt-5 space-y-3'>
        {repository && <KeyValueItem label={t(`${i18nPrefix}.repository`)} labelWidthClassName={labelWidthClassName} value={`${convertRepoToUrl(repository)}`} valueMaxWidthClassName='max-w-[190px]' />}
        {release && <KeyValueItem label={t(`${i18nPrefix}.release`)} labelWidthClassName={labelWidthClassName} value={release} />}
        {packageName && <KeyValueItem label={t(`${i18nPrefix}.packageName`)} labelWidthClassName={labelWidthClassName} value={packageName} />}
      </div>
    </Modal>
  )
}
export default React.memo(PlugInfo)