| 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, langGeniusVersionInfo } = 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, langGeniusVersionInfo.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)
|