mirror of
https://github.com/supabase/supabase.git
synced 2026-06-16 02:26:42 +08:00
## Problem Logs settings still uses the deprecated `Modal` for: - saving queries - prompt to upgrade ## Solution - use `Dialog` instead <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit * **Refactor** * Modernized internal UI component structure for improved maintainability and consistency. <!-- review_stack_entry_start --> [](https://app.coderabbit.ai/change-stack/supabase/supabase/pull/46229?utm_source=github_walkthrough&utm_medium=github&utm_campaign=change_stack) <!-- review_stack_entry_end --> <!-- end of auto-generated comment: release notes by coderabbit.ai -->
94 lines
3.3 KiB
TypeScript
94 lines
3.3 KiB
TypeScript
import Link from 'next/link'
|
|
import {
|
|
Button,
|
|
Dialog,
|
|
DialogContent,
|
|
DialogFooter,
|
|
DialogHeader,
|
|
DialogSection,
|
|
DialogSectionSeparator,
|
|
DialogTitle,
|
|
} from 'ui'
|
|
|
|
import { TIER_QUERY_LIMITS } from './Logs.constants'
|
|
import { useSelectedOrganizationQuery } from '@/hooks/misc/useSelectedOrganization'
|
|
|
|
interface Props {
|
|
show: boolean
|
|
setShowUpgradePrompt: (value: boolean) => void
|
|
title?: string
|
|
description?: string
|
|
source?: string
|
|
}
|
|
/**
|
|
* @param show - whether to show the modal
|
|
* @param setShowUpgradePrompt - function to set the show state
|
|
* @param title - title of the modal
|
|
* @param description - description of the modal
|
|
* @param source - source of the upgrade prompt used to track the source of the upgrade prompt in the billing page
|
|
* @returns
|
|
*/
|
|
const UpgradePrompt: React.FC<Props> = ({
|
|
show,
|
|
setShowUpgradePrompt,
|
|
title = 'Log retention',
|
|
description = 'Logs can be retained up to a duration of 3 months depending on the plan that your project is on.',
|
|
source = 'logsRetentionUpgradePrompt',
|
|
}) => {
|
|
const { data: organization } = useSelectedOrganizationQuery()
|
|
|
|
return (
|
|
<Dialog open={show} onOpenChange={() => setShowUpgradePrompt(false)}>
|
|
<DialogContent size="medium">
|
|
<DialogHeader>
|
|
<DialogTitle>{title}</DialogTitle>
|
|
</DialogHeader>
|
|
<DialogSectionSeparator />
|
|
<DialogSection>
|
|
<div className="space-y-4">
|
|
<p className="text-sm">{description}</p>
|
|
<div className="border-control bg-surface-300 rounded-sm border">
|
|
<div className="flex items-center px-4 pt-2 pb-1">
|
|
<p className="text-foreground-light w-[40%] text-sm">Plan</p>
|
|
<p className="text-foreground-light w-[60%] text-sm">Retention duration</p>
|
|
</div>
|
|
<div className="py-1">
|
|
<div className="flex items-center px-4 py-1">
|
|
<p className="w-[40%] text-sm">Free</p>
|
|
<p className="w-[60%] text-sm">{TIER_QUERY_LIMITS.FREE.text}</p>
|
|
</div>
|
|
<div className="flex items-center px-4 py-1">
|
|
<p className="w-[40%] text-sm">Pro</p>
|
|
<p className="w-[60%] text-sm">{TIER_QUERY_LIMITS.PRO.text}</p>
|
|
</div>
|
|
<div className="flex items-center px-4 py-1">
|
|
<p className="w-[40%] text-sm">Team</p>
|
|
<p className="w-[60%] text-sm">{TIER_QUERY_LIMITS.TEAM.text}</p>
|
|
</div>
|
|
<div className="flex items-center px-4 py-1">
|
|
<p className="w-[40%] text-sm">Enterprise</p>
|
|
<p className="w-[60%] text-sm">{TIER_QUERY_LIMITS.ENTERPRISE.text}</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</DialogSection>
|
|
<DialogFooter className="flex justify-end gap-3">
|
|
<Button type="default" onClick={() => setShowUpgradePrompt(false)}>
|
|
Close
|
|
</Button>
|
|
<Button asChild size="tiny">
|
|
<Link
|
|
href={`/org/${organization?.slug}/billing?panel=subscriptionPlan&source=${source}`}
|
|
>
|
|
Upgrade
|
|
</Link>
|
|
</Button>
|
|
</DialogFooter>
|
|
</DialogContent>
|
|
</Dialog>
|
|
)
|
|
}
|
|
|
|
export default UpgradePrompt
|