* feat: add Settings/Accounts/Emails/Inbox Settings page Closes #3013 * feat: add Settings/Accounts/Emails/Inbox Settings synchronization section Closes #3014 --------- Co-authored-by: Lucas Bordeau <bordeau.lucas@gmail.com>
58 lines
1.9 KiB
TypeScript
58 lines
1.9 KiB
TypeScript
import { useTheme } from '@emotion/react';
|
|
import styled from '@emotion/styled';
|
|
|
|
import { Account } from '@/accounts/types/Account';
|
|
import { SettingsAccountsInboxSettingsCardMedia } from '@/settings/accounts/components/SettingsAccountsInboxSettingsCardMedia';
|
|
import { IconRefresh } from '@/ui/display/icon';
|
|
import { H2Title } from '@/ui/display/typography/components/H2Title';
|
|
import { Toggle } from '@/ui/input/components/Toggle';
|
|
import { Card } from '@/ui/layout/card/components/Card';
|
|
import { CardContent } from '@/ui/layout/card/components/CardContent';
|
|
import { Section } from '@/ui/layout/section/components/Section';
|
|
|
|
const StyledCardContent = styled(CardContent)`
|
|
align-items: center;
|
|
display: flex;
|
|
gap: ${({ theme }) => theme.spacing(4)};
|
|
padding: ${({ theme }) => theme.spacing(2, 4)};
|
|
`;
|
|
|
|
const StyledTitle = styled.span`
|
|
color: ${({ theme }) => theme.font.color.primary};
|
|
font-weight: ${({ theme }) => theme.font.weight.medium};
|
|
margin-right: auto;
|
|
`;
|
|
|
|
type SettingsAccountsInboxSettingsSynchronizationSectionProps = {
|
|
account: Account;
|
|
onToggle: (value: boolean) => void;
|
|
};
|
|
|
|
export const SettingsAccountsInboxSettingsSynchronizationSection = ({
|
|
account,
|
|
onToggle,
|
|
}: SettingsAccountsInboxSettingsSynchronizationSectionProps) => {
|
|
const theme = useTheme();
|
|
|
|
return (
|
|
<Section>
|
|
<H2Title
|
|
title="Synchronization"
|
|
description="Past and future emails will automatically be synced to this workspace"
|
|
/>
|
|
<Card>
|
|
<StyledCardContent>
|
|
<SettingsAccountsInboxSettingsCardMedia>
|
|
<IconRefresh
|
|
size={theme.icon.size.sm}
|
|
stroke={theme.icon.stroke.lg}
|
|
/>
|
|
</SettingsAccountsInboxSettingsCardMedia>
|
|
<StyledTitle>Sync emails</StyledTitle>
|
|
<Toggle value={account.isSynced} onChange={onToggle} />
|
|
</StyledCardContent>
|
|
</Card>
|
|
</Section>
|
|
);
|
|
};
|