'use client' import React, { useEffect, useState } from 'react' import { Github } from '@/app/components/base/icons/src/public/common' import type { GithubRepo } from '@/models/common' const getStar = async () => { const res = await fetch('https://api.github.com/repos/langgenius/dify') if (!res.ok) throw new Error('Failed to fetch data') return res.json() } const GithubStar = () => { const [githubRepo, setGithubRepo] = useState<GithubRepo>({ stargazers_count: 6000 }) const [isFetched, setIsFetched] = useState(false) useEffect(() => { (async () => { try { if (process.env.NODE_ENV === 'development') return await setGithubRepo(await getStar()) setIsFetched(true) } catch (e) { } })() }, []) if (!isFetched) return null return ( <a href='https://github.com/langgenius/dify' target='_blank' rel='noopener noreferrer' className='flex items-center leading-[18px] border border-gray-200 rounded-md text-xs text-gray-700 font-semibold overflow-hidden'> <div className='flex items-center px-2 py-1 bg-gray-100'> <Github className='mr-1 w-[18px] h-[18px]' /> Star </div> <div className='px-2 py-1 bg-white border-l border-gray-200'>{`${githubRepo.stargazers_count}`.replace(/\B(?=(\d{3})+(?!\d))/g, ',')}</div> </a> ) } export default GithubStar