mirror of
https://github.com/mountain-loop/yaak.git
synced 2026-03-18 07:23:51 +01:00
78 lines
2.1 KiB
TypeScript
78 lines
2.1 KiB
TypeScript
import type { LicenseCheckStatus } from '@yaakapp-internal/license';
|
|
import { useLicense } from '@yaakapp-internal/license';
|
|
import type { ReactNode } from 'react';
|
|
import { openSettings } from '../commands/openSettings';
|
|
import { useLicenseConfirmation } from '../hooks/useLicenseConfirmation';
|
|
import type { ButtonProps } from './core/Button';
|
|
import { Button } from './core/Button';
|
|
import { SettingsTab } from './Settings/SettingsTab';
|
|
|
|
const details: Record<
|
|
LicenseCheckStatus['type'],
|
|
{ label: ReactNode; color: ButtonProps['color'] } | null
|
|
> = {
|
|
commercial_use: null,
|
|
invalid_license: { label: 'License Error', color: 'danger' },
|
|
personal_use: { label: 'Personal Use', color: 'notice' },
|
|
trialing: { label: 'Personal Use', color: 'notice' },
|
|
};
|
|
|
|
export function LicenseBadge() {
|
|
const { check } = useLicense();
|
|
const [licenseDetails, setLicenseDetails] = useLicenseConfirmation();
|
|
|
|
if (check.error) {
|
|
return (
|
|
<LicenseBadgeButton
|
|
color="danger"
|
|
onClick={() => {
|
|
openSettings.mutate(SettingsTab.License);
|
|
}}
|
|
>
|
|
License Error
|
|
</LicenseBadgeButton>
|
|
);
|
|
}
|
|
|
|
// Hasn't loaded yet
|
|
if (licenseDetails == null || check.data == null) {
|
|
return null;
|
|
}
|
|
|
|
// User has confirmed they are using Yaak for personal use only, so hide badge
|
|
if (licenseDetails.confirmedPersonalUse) {
|
|
return null;
|
|
}
|
|
|
|
// User is trialing but has already seen the message, so hide badge
|
|
if (check.data.type === 'trialing' && licenseDetails.hasDismissedTrial) {
|
|
return null;
|
|
}
|
|
|
|
const detail = details[check.data.type];
|
|
if (detail == null) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<LicenseBadgeButton
|
|
color={detail.color}
|
|
onClick={async () => {
|
|
if (check.data.type === 'trialing') {
|
|
await setLicenseDetails((v) => ({
|
|
...v,
|
|
hasDismissedTrial: true,
|
|
}));
|
|
}
|
|
openSettings.mutate(SettingsTab.License);
|
|
}}
|
|
>
|
|
{detail.label}
|
|
</LicenseBadgeButton>
|
|
);
|
|
}
|
|
|
|
function LicenseBadgeButton({ ...props }: ButtonProps) {
|
|
return <Button size="2xs" variant="border" className="!rounded-full mx-1" {...props} />;
|
|
}
|