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