wwf
2025-05-20 938c3e5a587ce950a94964ea509b9e7f8834dfae
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
'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)