mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-30 18:33:30 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			68 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| 'use client'
 | |
| import type { FC } from 'react'
 | |
| import React from 'react'
 | |
| import { useContext } from 'use-context-selector'
 | |
| import I18n from '@/context/i18n'
 | |
| import {
 | |
|   RiArrowRightUpLine,
 | |
|   RiBugLine,
 | |
| } from '@remixicon/react'
 | |
| import { useTranslation } from 'react-i18next'
 | |
| import KeyValueItem from '../base/key-value-item'
 | |
| import Tooltip from '@/app/components/base/tooltip'
 | |
| import Button from '@/app/components/base/button'
 | |
| import { getDocsUrl } from '@/app/components/plugins/utils'
 | |
| import { useDebugKey } from '@/service/use-plugins'
 | |
| 
 | |
| const i18nPrefix = 'plugin.debugInfo'
 | |
| 
 | |
| const DebugInfo: FC = () => {
 | |
|   const { t } = useTranslation()
 | |
|   const { locale } = useContext(I18n)
 | |
|   const { data: info, isLoading } = useDebugKey()
 | |
| 
 | |
|   // info.key likes 4580bdb7-b878-471c-a8a4-bfd760263a53 mask the middle part using *.
 | |
|   const maskedKey = info?.key?.replace(/(.{8})(.*)(.{8})/, '$1********$3')
 | |
| 
 | |
|   if (isLoading) return null
 | |
| 
 | |
|   return (
 | |
|     <Tooltip
 | |
|       triggerMethod='click'
 | |
|       disabled={!info}
 | |
|       popupContent={
 | |
|         <>
 | |
|           <div className='flex items-center gap-1 self-stretch'>
 | |
|             <span className='system-sm-semibold flex shrink-0 grow basis-0 flex-col items-start justify-center text-text-secondary'>{t(`${i18nPrefix}.title`)}</span>
 | |
|             <a href={getDocsUrl(locale, '/plugins/quick-start/debug-plugin')} target='_blank' className='flex cursor-pointer items-center gap-0.5 text-text-accent-light-mode-only'>
 | |
|               <span className='system-xs-medium'>{t(`${i18nPrefix}.viewDocs`)}</span>
 | |
|               <RiArrowRightUpLine className='h-3 w-3' />
 | |
|             </a>
 | |
|           </div>
 | |
|           <div className='space-y-0.5'>
 | |
|             <KeyValueItem
 | |
|               label={'URL'}
 | |
|               value={`${info?.host}:${info?.port}`}
 | |
|             />
 | |
|             <KeyValueItem
 | |
|               label={'Key'}
 | |
|               value={info?.key || ''}
 | |
|               maskedValue={maskedKey}
 | |
|             />
 | |
|           </div>
 | |
|         </>
 | |
|       }
 | |
|       popupClassName='flex flex-col items-start w-[256px] px-4 py-3.5 gap-1 border border-components-panel-border
 | |
|         rounded-xl bg-components-tooltip-bg shadows-shadow-lg z-50'
 | |
|       asChild={false}
 | |
|       position='bottom'
 | |
|     >
 | |
|       <Button className='h-full w-full p-2 text-components-button-secondary-text'>
 | |
|         <RiBugLine className='h-4 w-4' />
 | |
|       </Button>
 | |
|     </Tooltip>
 | |
|   )
 | |
| }
 | |
| 
 | |
| export default React.memo(DebugInfo)
 | 
