feat(core): show expiration time in link invitation dialog (#11610)

close BS-3095
This commit is contained in:
JimmFly
2025-04-16 10:30:34 +00:00
parent 022e5f2c93
commit 1c1c5ce64b
3 changed files with 37 additions and 12 deletions

View File

@@ -111,24 +111,42 @@ export const LinkInvite = ({
});
}, [revokeInvitationLink]);
const expireTime = useMemo(() => {
return t['com.affine.payment.member.team.invite.expire-at']({
expireTime: invitationLink?.expireTime
? new Date(invitationLink.expireTime).toLocaleString()
: '',
});
}, [invitationLink, t]);
return (
<>
<div className={styles.invitationLinkContainer}>
<div className={styles.modalSubTitle}>
{t['com.affine.payment.member.team.invite.link-expiration']()}
</div>
<Menu
items={items}
contentOptions={{
style: {
width: 'var(--radix-dropdown-menu-trigger-width)',
},
}}
>
<MenuTrigger style={{ width: '100%' }}>
{currentSelectedLabel}
</MenuTrigger>
</Menu>
{invitationLink ? (
<Input
value={expireTime}
disabled
style={{
backgroundColor: cssVarV2('input/background'),
}}
/>
) : (
<Menu
items={items}
contentOptions={{
style: {
width: 'var(--radix-dropdown-menu-trigger-width)',
},
}}
>
<MenuTrigger style={{ width: '100%' }}>
{currentSelectedLabel}
</MenuTrigger>
</Menu>
)}
</div>
<div className={styles.invitationLinkContainer}>
<div className={styles.modalSubTitle}>