|
'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 |
|
|