[automated] Apply ESLint and Prettier fixes

This commit is contained in:
GitHub Action
2025-12-11 09:12:48 +00:00
parent d3afe2b292
commit c2e96eca5e

View File

@@ -7,7 +7,9 @@
> >
<div class="flex flex-col gap-6 p-8"> <div class="flex flex-col gap-6 p-8">
<div class="flex flex-row items-center gap-2"> <div class="flex flex-row items-center gap-2">
<span class="font-inter text-base font-bold leading-normal text-base-foreground"> <span
class="font-inter text-base font-bold leading-normal text-base-foreground"
>
{{ tier.name }} {{ tier.name }}
</span> </span>
<div <div
@@ -18,10 +20,14 @@
</div> </div>
</div> </div>
<div class="flex flex-row items-baseline gap-2"> <div class="flex flex-row items-baseline gap-2">
<span class="font-inter text-[32px] font-semibold leading-normal text-base-foreground"> <span
class="font-inter text-[32px] font-semibold leading-normal text-base-foreground"
>
${{ tier.price }} ${{ tier.price }}
</span> </span>
<span class="font-inter text-base font-normal leading-normal text-base-foreground"> <span
class="font-inter text-base font-normal leading-normal text-base-foreground"
>
{{ t('subscription.usdPerMonth') }} {{ t('subscription.usdPerMonth') }}
</span> </span>
</div> </div>
@@ -29,12 +35,16 @@
<div class="flex flex-col gap-4 px-8 pb-0 flex-1"> <div class="flex flex-col gap-4 px-8 pb-0 flex-1">
<div class="flex flex-row items-center justify-between"> <div class="flex flex-row items-center justify-between">
<span class="font-inter text-sm font-normal leading-normal text-muted-foreground"> <span
class="font-inter text-sm font-normal leading-normal text-muted-foreground"
>
{{ t('subscription.monthlyCreditsLabel') }} {{ t('subscription.monthlyCreditsLabel') }}
</span> </span>
<div class="flex flex-row items-center gap-1"> <div class="flex flex-row items-center gap-1">
<i class="icon-[lucide--component] text-amber-400 text-sm" /> <i class="icon-[lucide--component] text-amber-400 text-sm" />
<span class="font-inter text-sm font-bold leading-normal text-base-foreground"> <span
class="font-inter text-sm font-bold leading-normal text-base-foreground"
>
{{ tier.credits }} {{ tier.credits }}
</span> </span>
</div> </div>
@@ -44,7 +54,9 @@
<span class="text-sm font-normal text-muted-foreground"> <span class="text-sm font-normal text-muted-foreground">
{{ t('subscription.maxDurationLabel') }} {{ t('subscription.maxDurationLabel') }}
</span> </span>
<span class="font-inter text-sm font-bold leading-normal text-base-foreground"> <span
class="font-inter text-sm font-bold leading-normal text-base-foreground"
>
{{ tier.maxDuration }} {{ tier.maxDuration }}
</span> </span>
</div> </div>
@@ -78,13 +90,17 @@
{{ t('subscription.videoEstimateLabel') }} {{ t('subscription.videoEstimateLabel') }}
</span> </span>
<div class="flex flex-row items-center gap-2 opacity-50"> <div class="flex flex-row items-center gap-2 opacity-50">
<i class="pi pi-question-circle text-xs text-muted-foreground" /> <i
class="pi pi-question-circle text-xs text-muted-foreground"
/>
<span class="text-sm font-normal text-muted-foreground"> <span class="text-sm font-normal text-muted-foreground">
{{ t('subscription.videoEstimateHelp') }} {{ t('subscription.videoEstimateHelp') }}
</span> </span>
</div> </div>
</div> </div>
<span class="font-inter text-sm font-bold leading-normal text-base-foreground"> <span
class="font-inter text-sm font-bold leading-normal text-base-foreground"
>
{{ tier.videoEstimate }} {{ tier.videoEstimate }}
</span> </span>
</div> </div>
@@ -192,21 +208,26 @@ const { wrapWithErrorHandlingAsync } = useErrorHandling()
const isLoading = ref(false) const isLoading = ref(false)
const loadingTier = ref<TierKey | null>(null) const loadingTier = ref<TierKey | null>(null)
const currentTierKey = computed<TierKey | null>(() => const currentTierKey = computed<TierKey | null>(() =>
subscriptionTier.value ? TIER_TO_KEY[subscriptionTier.value] : null subscriptionTier.value ? TIER_TO_KEY[subscriptionTier.value] : null
) )
const isCurrentPlan = (tierKey: TierKey): boolean => const isCurrentPlan = (tierKey: TierKey): boolean =>
currentTierKey.value === tierKey currentTierKey.value === tierKey
const getButtonLabel = (tier: PricingTierConfig): string => { const getButtonLabel = (tier: PricingTierConfig): string => {
if (isCurrentPlan(tier.key)) return t('subscription.currentPlan') if (isCurrentPlan(tier.key)) return t('subscription.currentPlan')
if (!isActiveSubscription.value) return t('subscription.subscribeTo', { plan: tier.name }) if (!isActiveSubscription.value)
return t('subscription.subscribeTo', { plan: tier.name })
return t('subscription.changeTo', { plan: tier.name }) return t('subscription.changeTo', { plan: tier.name })
} }
const getButtonSeverity = (tier: PricingTierConfig): 'primary' | 'secondary' => const getButtonSeverity = (tier: PricingTierConfig): 'primary' | 'secondary' =>
isCurrentPlan(tier.key) ? 'secondary' : tier.key === 'creator' ? 'primary' : 'secondary' isCurrentPlan(tier.key)
? 'secondary'
: tier.key === 'creator'
? 'primary'
: 'secondary'
const initiateCheckout = async (tierKey: TierKey) => { const initiateCheckout = async (tierKey: TierKey) => {
const authHeader = await getAuthHeader() const authHeader = await getAuthHeader()
@@ -231,12 +252,13 @@ const initiateCheckout = async (tierKey: TierKey) => {
// If JSON parsing fails, try to get text response or use HTTP status // If JSON parsing fails, try to get text response or use HTTP status
try { try {
const errorText = await response.text() const errorText = await response.text()
errorMessage = errorText || `HTTP ${response.status} ${response.statusText}` errorMessage =
errorText || `HTTP ${response.status} ${response.statusText}`
} catch { } catch {
errorMessage = `HTTP ${response.status} ${response.statusText}` errorMessage = `HTTP ${response.status} ${response.statusText}`
} }
} }
throw new FirebaseAuthStoreError( throw new FirebaseAuthStoreError(
t('toastMessages.failedToInitiateSubscription', { t('toastMessages.failedToInitiateSubscription', {
error: errorMessage error: errorMessage
@@ -247,27 +269,24 @@ const initiateCheckout = async (tierKey: TierKey) => {
return await response.json() return await response.json()
} }
const handleSubscribe = wrapWithErrorHandlingAsync( const handleSubscribe = wrapWithErrorHandlingAsync(async (tierKey: TierKey) => {
async (tierKey: TierKey) => { if (!isCloud || isLoading.value || isCurrentPlan(tierKey)) return
if (!isCloud || isLoading.value || isCurrentPlan(tierKey)) return
isLoading.value = true isLoading.value = true
loadingTier.value = tierKey loadingTier.value = tierKey
try { try {
if (isActiveSubscription.value) { if (isActiveSubscription.value) {
await accessBillingPortal() await accessBillingPortal()
} else { } else {
const response = await initiateCheckout(tierKey) const response = await initiateCheckout(tierKey)
if (response.checkout_url) { if (response.checkout_url) {
window.open(response.checkout_url, '_blank') window.open(response.checkout_url, '_blank')
}
} }
} finally {
isLoading.value = false
loadingTier.value = null
} }
}, } finally {
reportError isLoading.value = false
) loadingTier.value = null
</script> }
}, reportError)
</script>