| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | 'use client' | 
					
						
							|  |  |  | import { useState } from 'react' | 
					
						
							|  |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							| 
									
										
										
										
											2025-02-07 18:56:43 +08:00
										 |  |  | import { RiKey2Line } from '@remixicon/react' | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | import Button from '@/app/components/base/button' | 
					
						
							|  |  |  | import SecretKeyModal from '@/app/components/develop/secret-key/secret-key-modal' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type ISecretKeyButtonProps = { | 
					
						
							|  |  |  |   className?: string | 
					
						
							| 
									
										
										
										
											2023-09-27 16:06:49 +08:00
										 |  |  |   appId?: string | 
					
						
							| 
									
										
										
										
											2023-08-16 10:31:08 +08:00
										 |  |  |   textCls?: string | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-07 18:56:43 +08:00
										 |  |  | const SecretKeyButton = ({ className, appId, textCls }: ISecretKeyButtonProps) => { | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   const [isVisible, setVisible] = useState(false) | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <> | 
					
						
							| 
									
										
										
										
											2025-02-07 18:56:43 +08:00
										 |  |  |       <Button | 
					
						
							|  |  |  |         className={`px-3 ${className}`} | 
					
						
							|  |  |  |         onClick={() => setVisible(true)} | 
					
						
							|  |  |  |         size='small' | 
					
						
							|  |  |  |         variant='ghost' | 
					
						
							|  |  |  |       > | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |         <div className={'flex h-3.5 w-3.5 items-center justify-center'}> | 
					
						
							|  |  |  |           <RiKey2Line className='h-3.5 w-3.5 text-text-tertiary' /> | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |         <div className={`system-xs-medium px-[3px] text-text-tertiary ${textCls}`}>{t('appApi.apiKey')}</div> | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |       </Button> | 
					
						
							|  |  |  |       <SecretKeyModal isShow={isVisible} onClose={() => setVisible(false)} appId={appId} /> | 
					
						
							|  |  |  |     </> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default SecretKeyButton |