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
168 lines
3.7 KiB
TypeScript
168 lines
3.7 KiB
TypeScript
import { isUndefined } from '@sniptt/guards';
|
|
|
|
import { ObjectMetadataItem } from '@/object-metadata/types/ObjectMetadataItem';
|
|
import { mapObjectMetadataToGraphQLQuery } from '@/object-metadata/utils/mapObjectMetadataToGraphQLQuery';
|
|
import {
|
|
FieldMetadataType,
|
|
RelationDefinitionType,
|
|
} from '~/generated-metadata/graphql';
|
|
|
|
import { FieldMetadataItem } from '../types/FieldMetadataItem';
|
|
|
|
// TODO: change ObjectMetadataItems mock before refactoring with relationDefinition computed field
|
|
export const mapFieldMetadataToGraphQLQuery = ({
|
|
objectMetadataItems,
|
|
field,
|
|
relationrecordFields,
|
|
computeReferences = false,
|
|
}: {
|
|
objectMetadataItems: ObjectMetadataItem[];
|
|
field: Pick<FieldMetadataItem, 'name' | 'type' | 'relationDefinition'>;
|
|
relationrecordFields?: Record<string, any>;
|
|
computeReferences?: boolean;
|
|
}): any => {
|
|
const fieldType = field.type;
|
|
|
|
const fieldIsSimpleValue = [
|
|
FieldMetadataType.UUID,
|
|
FieldMetadataType.TEXT,
|
|
FieldMetadataType.DATE_TIME,
|
|
FieldMetadataType.DATE,
|
|
FieldMetadataType.NUMBER,
|
|
FieldMetadataType.BOOLEAN,
|
|
FieldMetadataType.RATING,
|
|
FieldMetadataType.SELECT,
|
|
FieldMetadataType.MULTI_SELECT,
|
|
FieldMetadataType.POSITION,
|
|
FieldMetadataType.RAW_JSON,
|
|
FieldMetadataType.RICH_TEXT,
|
|
FieldMetadataType.ARRAY,
|
|
].includes(fieldType);
|
|
|
|
if (fieldIsSimpleValue) {
|
|
return field.name;
|
|
}
|
|
|
|
if (
|
|
fieldType === FieldMetadataType.RELATION &&
|
|
field.relationDefinition?.direction === RelationDefinitionType.MANY_TO_ONE
|
|
) {
|
|
const relationMetadataItem = objectMetadataItems.find(
|
|
(objectMetadataItem) =>
|
|
objectMetadataItem.id ===
|
|
field.relationDefinition?.targetObjectMetadata.id,
|
|
);
|
|
|
|
if (isUndefined(relationMetadataItem)) {
|
|
return '';
|
|
}
|
|
|
|
return `${field.name}
|
|
${mapObjectMetadataToGraphQLQuery({
|
|
objectMetadataItems,
|
|
objectMetadataItem: relationMetadataItem,
|
|
recordGqlFields: relationrecordFields,
|
|
computeReferences: computeReferences,
|
|
isRootLevel: false,
|
|
})}`;
|
|
}
|
|
|
|
if (
|
|
fieldType === FieldMetadataType.RELATION &&
|
|
field.relationDefinition?.direction === RelationDefinitionType.ONE_TO_MANY
|
|
) {
|
|
const relationMetadataItem = objectMetadataItems.find(
|
|
(objectMetadataItem) =>
|
|
objectMetadataItem.id ===
|
|
field.relationDefinition?.targetObjectMetadata.id,
|
|
);
|
|
|
|
if (isUndefined(relationMetadataItem)) {
|
|
return '';
|
|
}
|
|
|
|
return `${field.name}
|
|
{
|
|
edges {
|
|
node ${mapObjectMetadataToGraphQLQuery({
|
|
objectMetadataItems,
|
|
objectMetadataItem: relationMetadataItem,
|
|
recordGqlFields: relationrecordFields,
|
|
computeReferences,
|
|
isRootLevel: false,
|
|
})}
|
|
}
|
|
}`;
|
|
}
|
|
|
|
if (fieldType === FieldMetadataType.LINKS) {
|
|
return `${field.name}
|
|
{
|
|
primaryLinkUrl
|
|
primaryLinkLabel
|
|
secondaryLinks
|
|
}`;
|
|
}
|
|
|
|
if (fieldType === FieldMetadataType.CURRENCY) {
|
|
return `${field.name}
|
|
{
|
|
amountMicros
|
|
currencyCode
|
|
}
|
|
`;
|
|
}
|
|
|
|
if (fieldType === FieldMetadataType.FULL_NAME) {
|
|
return `${field.name}
|
|
{
|
|
firstName
|
|
lastName
|
|
}`;
|
|
}
|
|
|
|
if (fieldType === FieldMetadataType.ADDRESS) {
|
|
return `${field.name}
|
|
{
|
|
addressStreet1
|
|
addressStreet2
|
|
addressCity
|
|
addressState
|
|
addressCountry
|
|
addressPostcode
|
|
addressLat
|
|
addressLng
|
|
}`;
|
|
}
|
|
|
|
if (fieldType === FieldMetadataType.ACTOR) {
|
|
return `${field.name}
|
|
{
|
|
source
|
|
workspaceMemberId
|
|
name
|
|
context
|
|
}`;
|
|
}
|
|
|
|
if (fieldType === FieldMetadataType.EMAILS) {
|
|
return `${field.name}
|
|
{
|
|
primaryEmail
|
|
additionalEmails
|
|
}`;
|
|
}
|
|
|
|
if (fieldType === FieldMetadataType.PHONES) {
|
|
return `${field.name}
|
|
{
|
|
primaryPhoneNumber
|
|
primaryPhoneCountryCode
|
|
primaryPhoneCallingCode
|
|
additionalPhones
|
|
}`;
|
|
}
|
|
|
|
return '';
|
|
};
|