| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 | 
							- 'use client'
 - import type { FC } from 'react'
 - import React from 'react'
 - import { useTranslation } from 'react-i18next'
 - import UpgradeBtn from '../upgrade-btn'
 - import ProgressBar from '@/app/components/billing/progress-bar'
 - import Button from '@/app/components/base/button'
 - import { mailToSupport } from '@/app/components/header/utils/util'
 - import { useProviderContext } from '@/context/provider-context'
 - import { useAppContext } from '@/context/app-context'
 - import { Plan } from '@/app/components/billing/type'
 - import s from './style.module.css'
 - import cn from '@/utils/classnames'
 - 
 - const LOW = 50
 - const MIDDLE = 80
 - 
 - const AppsFull: FC<{ loc: string; className?: string; }> = ({
 -   loc,
 -   className,
 - }) => {
 -   const { t } = useTranslation()
 -   const { plan } = useProviderContext()
 -   const { userProfile, langeniusVersionInfo } = useAppContext()
 -   const isTeam = plan.type === Plan.team
 -   const usage = plan.usage.buildApps
 -   const total = plan.total.buildApps
 -   const percent = usage / total * 100
 -   const color = (() => {
 -     if (percent < LOW)
 -       return 'bg-components-progress-bar-progress-solid'
 - 
 -     if (percent < MIDDLE)
 -       return 'bg-components-progress-warning-progress'
 - 
 -     return 'bg-components-progress-error-progress'
 -   })()
 -   return (
 -     <div className={cn(
 -       'flex flex-col gap-3 rounded-xl border-[0.5px] border-components-panel-border-subtle bg-components-panel-on-panel-item-bg p-4 shadow-xs backdrop-blur-sm',
 -       className,
 -     )}>
 -       <div className='flex justify-between'>
 -         {!isTeam && (
 -           <div>
 -             <div className={cn('title-xl-semi-bold mb-1', s.textGradient)}>
 -               {t('billing.apps.fullTip1')}
 -             </div>
 -             <div className='system-xs-regular text-text-tertiary'>{t('billing.apps.fullTip1des')}</div>
 -           </div>
 -         )}
 -         {isTeam && (
 -           <div>
 -             <div className={cn('title-xl-semi-bold mb-1', s.textGradient)}>
 -               {t('billing.apps.fullTip2')}
 -             </div>
 -             <div className='system-xs-regular text-text-tertiary'>{t('billing.apps.fullTip2des')}</div>
 -           </div>
 -         )}
 -         {(plan.type === Plan.sandbox || plan.type === Plan.professional) && (
 -           <UpgradeBtn isShort loc={loc} />
 -         )}
 -         {plan.type !== Plan.sandbox && plan.type !== Plan.professional && (
 -           <Button variant='secondary-accent'>
 -             <a target='_blank' rel='noopener noreferrer' href={mailToSupport(userProfile.email, plan.type, langeniusVersionInfo.current_version)}>
 -               {t('billing.apps.contactUs')}
 -             </a>
 -           </Button>
 -         )}
 -       </div>
 -       <div className='flex flex-col gap-2'>
 -         <div className='system-xs-medium flex items-center justify-between text-text-secondary'>
 -           <div>{t('billing.usagePage.buildApps')}</div>
 -           <div>{usage}/{total}</div>
 -         </div>
 -         <ProgressBar
 -           percent={percent}
 -           color={color}
 -         />
 -       </div>
 -     </div>
 -   )
 - }
 - export default React.memo(AppsFull)
 
 
  |