Icon microsoft (#9907)
Implementing the Outlook icon for CreatedBy, only for emails. Not in this PR original scope : The similar feature for calendar created records. Since it was straightforward, I added it to the scope of this PR. Fix https://github.com/twentyhq/core-team-issues/issues/252
This commit is contained in:
@ -1,4 +1,6 @@
|
||||
import { FieldActorValue } from '@/object-record/record-field/types/FieldMetadata';
|
||||
import { ConnectedAccountProvider } from 'twenty-shared';
|
||||
|
||||
import { useMemo } from 'react';
|
||||
import {
|
||||
AvatarChip,
|
||||
@ -7,6 +9,10 @@ import {
|
||||
IconCalendar,
|
||||
IconCsv,
|
||||
IconGmail,
|
||||
IconGoogleCalendar,
|
||||
IconMail,
|
||||
IconMicrosoftCalendar,
|
||||
IconMicrosoftOutlook,
|
||||
IconRobot,
|
||||
IconSettingsAutomation,
|
||||
} from 'twenty-ui';
|
||||
@ -15,11 +21,25 @@ type ActorDisplayProps = Partial<FieldActorValue> & {
|
||||
avatarUrl?: string | null;
|
||||
};
|
||||
|
||||
const PROVIDORS_ICON_MAPPING = {
|
||||
EMAIL: {
|
||||
[ConnectedAccountProvider.MICROSOFT]: IconMicrosoftOutlook,
|
||||
[ConnectedAccountProvider.GOOGLE]: IconGmail,
|
||||
default: IconMail,
|
||||
},
|
||||
CALENDAR: {
|
||||
[ConnectedAccountProvider.MICROSOFT]: IconMicrosoftCalendar,
|
||||
[ConnectedAccountProvider.GOOGLE]: IconGoogleCalendar,
|
||||
default: IconCalendar,
|
||||
},
|
||||
};
|
||||
|
||||
export const ActorDisplay = ({
|
||||
name,
|
||||
source,
|
||||
workspaceMemberId,
|
||||
avatarUrl,
|
||||
context,
|
||||
}: ActorDisplayProps) => {
|
||||
const LeftIcon = useMemo(() => {
|
||||
switch (source) {
|
||||
@ -28,9 +48,9 @@ export const ActorDisplay = ({
|
||||
case 'IMPORT':
|
||||
return IconCsv;
|
||||
case 'EMAIL':
|
||||
return IconGmail;
|
||||
return PROVIDORS_ICON_MAPPING.EMAIL[context?.provider ?? 'default'];
|
||||
case 'CALENDAR':
|
||||
return IconCalendar;
|
||||
return PROVIDORS_ICON_MAPPING.CALENDAR[context?.provider ?? 'default'];
|
||||
case 'SYSTEM':
|
||||
return IconRobot;
|
||||
case 'WORKFLOW':
|
||||
@ -38,7 +58,7 @@ export const ActorDisplay = ({
|
||||
default:
|
||||
return undefined;
|
||||
}
|
||||
}, [source]);
|
||||
}, [source, context?.provider]);
|
||||
|
||||
const isIconInverted =
|
||||
source === 'API' || source === 'IMPORT' || source === 'SYSTEM';
|
||||
|
||||
Reference in New Issue
Block a user