mirror of
https://github.com/docmost/docmost.git
synced 2026-06-22 09:21:45 +10:00
old billing grace period
This commit is contained in:
@@ -12,14 +12,18 @@ import {
|
|||||||
Badge,
|
Badge,
|
||||||
Flex,
|
Flex,
|
||||||
Switch,
|
Switch,
|
||||||
|
Alert,
|
||||||
} from "@mantine/core";
|
} from "@mantine/core";
|
||||||
import { useState } from "react";
|
import { useState } from "react";
|
||||||
import { IconCheck } from "@tabler/icons-react";
|
import { IconCheck, IconInfoCircle } from "@tabler/icons-react";
|
||||||
import { getCheckoutLink } from "@/ee/billing/services/billing-service.ts";
|
import { getCheckoutLink } from "@/ee/billing/services/billing-service.ts";
|
||||||
import { useBillingPlans } from "@/ee/billing/queries/billing-query.ts";
|
import { useBillingPlans } from "@/ee/billing/queries/billing-query.ts";
|
||||||
|
import { useAtomValue } from "jotai";
|
||||||
|
import { workspaceAtom } from "@/features/user/atoms/current-user-atom";
|
||||||
|
|
||||||
export default function BillingPlans() {
|
export default function BillingPlans() {
|
||||||
const { data: plans } = useBillingPlans();
|
const { data: plans } = useBillingPlans();
|
||||||
|
const workspace = useAtomValue(workspaceAtom);
|
||||||
const [isAnnual, setIsAnnual] = useState(true);
|
const [isAnnual, setIsAnnual] = useState(true);
|
||||||
const [selectedTierValue, setSelectedTierValue] = useState<string | null>(
|
const [selectedTierValue, setSelectedTierValue] = useState<string | null>(
|
||||||
null,
|
null,
|
||||||
@@ -36,6 +40,16 @@ export default function BillingPlans() {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// TODO: remove by July 30.
|
||||||
|
// Check if workspace was created between June 28 and July 14, 2025
|
||||||
|
const showTieredPricingNotice = (() => {
|
||||||
|
if (!workspace?.createdAt) return false;
|
||||||
|
const createdDate = new Date(workspace.createdAt);
|
||||||
|
const startDate = new Date('2025-06-20');
|
||||||
|
const endDate = new Date('2025-07-14');
|
||||||
|
return createdDate >= startDate && createdDate <= endDate;
|
||||||
|
})();
|
||||||
|
|
||||||
if (!plans || plans.length === 0) {
|
if (!plans || plans.length === 0) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@@ -68,6 +82,18 @@ export default function BillingPlans() {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<Container size="xl" py="xl">
|
<Container size="xl" py="xl">
|
||||||
|
{/* Tiered pricing notice for eligible workspaces */}
|
||||||
|
{showTieredPricingNotice && !hasTieredPlans && (
|
||||||
|
<Alert
|
||||||
|
icon={<IconInfoCircle size={16} />}
|
||||||
|
title="Want the old tiered pricing?"
|
||||||
|
color="blue"
|
||||||
|
mb="lg"
|
||||||
|
>
|
||||||
|
Contact support to switch back to our tiered pricing model.
|
||||||
|
</Alert>
|
||||||
|
)}
|
||||||
|
|
||||||
{/* Controls Section */}
|
{/* Controls Section */}
|
||||||
<Stack gap="xl" mb="md">
|
<Stack gap="xl" mb="md">
|
||||||
{/* Team Size and Billing Controls */}
|
{/* Team Size and Billing Controls */}
|
||||||
@@ -182,7 +208,7 @@ export default function BillingPlans() {
|
|||||||
|
|
||||||
{/* CTA Button */}
|
{/* CTA Button */}
|
||||||
<Button onClick={() => handleCheckout(priceId)} fullWidth>
|
<Button onClick={() => handleCheckout(priceId)} fullWidth>
|
||||||
Upgrade
|
Subscribe
|
||||||
</Button>
|
</Button>
|
||||||
|
|
||||||
{/* Features */}
|
{/* Features */}
|
||||||
|
|||||||
Reference in New Issue
Block a user