1 import { type FC } from 'react';
2 import { useSelector } from 'react-redux';
4 import { c } from 'ttag';
6 import { Button } from '@proton/atoms';
7 import { usePassCore } from '@proton/pass/components/Core/PassCoreProvider';
8 import type { BaseSpotlightMessage } from '@proton/pass/components/Spotlight/SpotlightContent';
9 import { usePassConfig } from '@proton/pass/hooks/usePassConfig';
10 import { selectPlanDisplayName, selectUserPlan } from '@proton/pass/store/selectors';
11 import { pipe } from '@proton/pass/utils/fp/pipe';
12 import { epochToDate } from '@proton/pass/utils/time/format';
13 import { PASS_APP_NAME } from '@proton/shared/lib/constants';
14 import noop from '@proton/utils/noop';
16 export const UserRenewal: FC<BaseSpotlightMessage> = ({ onClose = noop }) => {
17 const { onLink } = usePassCore();
18 const { SSO_URL } = usePassConfig();
19 const plan = useSelector(selectUserPlan);
20 const planName = useSelector(selectPlanDisplayName);
22 if (!(plan && plan.SubscriptionEnd)) return;
24 const endDate = epochToDate(plan.SubscriptionEnd);
25 const title = c('Title').t`Your ${planName} subscription will end on ${endDate}`;
27 const upgrade = () => onLink(`${SSO_URL}/pass/dashboard?source=banner#your-subscriptions`);
30 <div className="flex-1">
31 <strong className="block color-invert">{title}</strong>
32 <span className="block text-sm color-invert">
34 .t`You will no longer have access to sharing, 2FA, credit card and other advanced features in ${PASS_APP_NAME}`}
36 <div className="mt-2">
42 className="text-sm px-3"
43 onClick={pipe(onClose, upgrade)}
44 style={{ backgroundColor: 'var(--interaction-norm-major-3)' }}
46 {c('Action').t`Reactivate now`}