mirror of
https://github.com/twentyhq/twenty.git
synced 2024-12-25 21:13:01 +03:00
parent
02618b3e6a
commit
1d56ace2af
@ -137,7 +137,6 @@ export type BooleanFieldComparison = {
|
||||
isNot?: InputMaybe<Scalars['Boolean']['input']>;
|
||||
};
|
||||
|
||||
/** Visibility of the calendar channel */
|
||||
export enum CalendarChannelVisibility {
|
||||
Metadata = 'METADATA',
|
||||
ShareEverything = 'SHARE_EVERYTHING'
|
||||
@ -355,6 +354,7 @@ export type FieldConnection = {
|
||||
export enum FieldMetadataType {
|
||||
Actor = 'ACTOR',
|
||||
Address = 'ADDRESS',
|
||||
Array = 'ARRAY',
|
||||
Boolean = 'BOOLEAN',
|
||||
Currency = 'CURRENCY',
|
||||
Date = 'DATE',
|
||||
@ -376,8 +376,7 @@ export enum FieldMetadataType {
|
||||
RichText = 'RICH_TEXT',
|
||||
Select = 'SELECT',
|
||||
Text = 'TEXT',
|
||||
Uuid = 'UUID',
|
||||
Array = 'ARRAY'
|
||||
Uuid = 'UUID'
|
||||
}
|
||||
|
||||
export enum FileFolder {
|
||||
@ -432,7 +431,6 @@ export type LoginToken = {
|
||||
loginToken: AuthToken;
|
||||
};
|
||||
|
||||
/** Visibility of the message channel */
|
||||
export enum MessageChannelVisibility {
|
||||
Metadata = 'METADATA',
|
||||
ShareEverything = 'SHARE_EVERYTHING',
|
||||
|
@ -130,7 +130,6 @@ export type BooleanFieldComparison = {
|
||||
isNot?: InputMaybe<Scalars['Boolean']>;
|
||||
};
|
||||
|
||||
/** Visibility of the calendar channel */
|
||||
export enum CalendarChannelVisibility {
|
||||
Metadata = 'METADATA',
|
||||
ShareEverything = 'SHARE_EVERYTHING'
|
||||
@ -330,7 +329,6 @@ export type LoginToken = {
|
||||
loginToken: AuthToken;
|
||||
};
|
||||
|
||||
/** Visibility of the message channel */
|
||||
export enum MessageChannelVisibility {
|
||||
Metadata = 'METADATA',
|
||||
ShareEverything = 'SHARE_EVERYTHING',
|
||||
|
@ -1,11 +1,39 @@
|
||||
import { CalendarChannelVisibility } from '~/generated/graphql';
|
||||
|
||||
export enum CalendarChannelSyncStatus {
|
||||
NOT_SYNCED = 'NOT_SYNCED',
|
||||
ONGOING = 'ONGOING',
|
||||
ACTIVE = 'ACTIVE',
|
||||
FAILED_INSUFFICIENT_PERMISSIONS = 'FAILED_INSUFFICIENT_PERMISSIONS',
|
||||
FAILED_UNKNOWN = 'FAILED_UNKNOWN',
|
||||
}
|
||||
|
||||
export enum CalendarChannelSyncStage {
|
||||
FULL_CALENDAR_EVENT_LIST_FETCH_PENDING = 'FULL_CALENDAR_EVENT_LIST_FETCH_PENDING',
|
||||
PARTIAL_CALENDAR_EVENT_LIST_FETCH_PENDING = 'PARTIAL_CALENDAR_EVENT_LIST_FETCH_PENDING',
|
||||
CALENDAR_EVENT_LIST_FETCH_ONGOING = 'CALENDAR_EVENT_LIST_FETCH_ONGOING',
|
||||
CALENDAR_EVENTS_IMPORT_PENDING = 'CALENDAR_EVENTS_IMPORT_PENDING',
|
||||
CALENDAR_EVENTS_IMPORT_ONGOING = 'CALENDAR_EVENTS_IMPORT_ONGOING',
|
||||
FAILED = 'FAILED',
|
||||
}
|
||||
|
||||
export enum CalendarChannelContactAutoCreationPolicy {
|
||||
AS_PARTICIPANT_AND_ORGANIZER = 'AS_PARTICIPANT_AND_ORGANIZER',
|
||||
AS_PARTICIPANT = 'AS_PARTICIPANT',
|
||||
AS_ORGANIZER = 'AS_ORGANIZER',
|
||||
NONE = 'NONE',
|
||||
}
|
||||
export type CalendarChannel = {
|
||||
id: string;
|
||||
handle: string;
|
||||
isContactAutoCreationEnabled?: boolean;
|
||||
isSyncEnabled?: boolean;
|
||||
isContactAutoCreationEnabled: boolean;
|
||||
contactAutoCreationPolicy: CalendarChannelContactAutoCreationPolicy;
|
||||
isSyncEnabled: boolean;
|
||||
visibility: CalendarChannelVisibility;
|
||||
syncStatus: string;
|
||||
syncStatus: CalendarChannelSyncStatus;
|
||||
syncStage: CalendarChannelSyncStage;
|
||||
syncCursor: string;
|
||||
syncStageStartedAt: Date;
|
||||
throttleFailureCount: number;
|
||||
__typename: 'CalendarChannel';
|
||||
};
|
||||
|
@ -6,14 +6,35 @@ export enum MessageChannelContactAutoCreationPolicy {
|
||||
NONE = 'NONE',
|
||||
}
|
||||
|
||||
export enum MessageChannelSyncStatus {
|
||||
NOT_SYNCED = 'NOT_SYNCED',
|
||||
ONGOING = 'ONGOING',
|
||||
ACTIVE = 'ACTIVE',
|
||||
FAILED_INSUFFICIENT_PERMISSIONS = 'FAILED_INSUFFICIENT_PERMISSIONS',
|
||||
FAILED_UNKNOWN = 'FAILED_UNKNOWN',
|
||||
}
|
||||
|
||||
export enum MessageChannelSyncStage {
|
||||
FULL_MESSAGE_LIST_FETCH_PENDING = 'FULL_MESSAGE_LIST_FETCH_PENDING',
|
||||
PARTIAL_MESSAGE_LIST_FETCH_PENDING = 'PARTIAL_MESSAGE_LIST_FETCH_PENDING',
|
||||
MESSAGE_LIST_FETCH_ONGOING = 'MESSAGE_LIST_FETCH_ONGOING',
|
||||
MESSAGES_IMPORT_PENDING = 'MESSAGES_IMPORT_PENDING',
|
||||
MESSAGES_IMPORT_ONGOING = 'MESSAGES_IMPORT_ONGOING',
|
||||
FAILED = 'FAILED',
|
||||
}
|
||||
|
||||
export type MessageChannel = {
|
||||
id: string;
|
||||
handle: string;
|
||||
contactAutoCreationPolicy?: MessageChannelContactAutoCreationPolicy;
|
||||
contactAutoCreationPolicy: MessageChannelContactAutoCreationPolicy;
|
||||
excludeNonProfessionalEmails: boolean;
|
||||
excludeGroupEmails: boolean;
|
||||
isSyncEnabled: boolean;
|
||||
visibility: MessageChannelVisibility;
|
||||
syncStatus: string;
|
||||
syncStatus: MessageChannelSyncStatus;
|
||||
syncStage: MessageChannelSyncStage;
|
||||
syncCursor: string;
|
||||
syncStageStartedAt: Date;
|
||||
throttleFailureCount: number;
|
||||
__typename: 'MessageChannel';
|
||||
};
|
||||
|
@ -1,8 +1,9 @@
|
||||
import { ConnectedAccount } from '@/accounts/types/ConnectedAccount';
|
||||
import { SettingsAccountsRowDropdownMenu } from '@/settings/accounts/components/SettingsAccountsRowDropdownMenu';
|
||||
import { SyncStatus } from '@/settings/accounts/constants/SyncStatus';
|
||||
import { computeSyncStatus } from '@/settings/accounts/utils/computeSyncStatus';
|
||||
import { Status } from '@/ui/display/status/components/Status';
|
||||
import styled from '@emotion/styled';
|
||||
import { useMemo } from 'react';
|
||||
|
||||
const StyledRowRightContainer = styled.div`
|
||||
align-items: center;
|
||||
@ -15,39 +16,26 @@ export const SettingsAccountsConnectedAccountsRowRightContainer = ({
|
||||
}: {
|
||||
account: ConnectedAccount;
|
||||
}) => {
|
||||
const mCSyncStatus = account.messageChannels[0]?.syncStatus;
|
||||
const cCSyncStatus = account.calendarChannels[0]?.syncStatus;
|
||||
const messageChannelSyncStatus = account.messageChannels[0]?.syncStatus;
|
||||
const calendarChannelSyncStatus = account.calendarChannels[0]?.syncStatus;
|
||||
|
||||
const status = useMemo(() => {
|
||||
if (mCSyncStatus === 'ACTIVE' && cCSyncStatus === 'ACTIVE') {
|
||||
return 'Synced';
|
||||
} else if (mCSyncStatus === 'NOT_SYNCED' && cCSyncStatus === 'NOT_SYNCED') {
|
||||
return 'Not synced';
|
||||
} else if (mCSyncStatus === 'ONGOING' || cCSyncStatus === 'ONGOING') {
|
||||
return 'Importing';
|
||||
} else if (
|
||||
mCSyncStatus === 'FAILED' ||
|
||||
mCSyncStatus === 'FAILED_INSUFFICIENT_PERMISSIONS' ||
|
||||
cCSyncStatus === 'FAILED' ||
|
||||
cCSyncStatus === 'FAILED_INSUFFICIENT_PERMISSIONS'
|
||||
) {
|
||||
return 'Failed';
|
||||
}
|
||||
return '';
|
||||
}, [mCSyncStatus, cCSyncStatus]);
|
||||
const status = computeSyncStatus(
|
||||
messageChannelSyncStatus,
|
||||
calendarChannelSyncStatus,
|
||||
);
|
||||
|
||||
return (
|
||||
<StyledRowRightContainer>
|
||||
{status === 'Failed' && (
|
||||
{status === SyncStatus.FAILED && (
|
||||
<Status color="red" text="Sync failed" weight="medium" />
|
||||
)}
|
||||
{status === 'Synced' && (
|
||||
{status === SyncStatus.SYNCED && (
|
||||
<Status color="green" text="Synced" weight="medium" />
|
||||
)}
|
||||
{status === 'Not synced' && (
|
||||
{status === SyncStatus.NOT_SYNCED && (
|
||||
<Status color="orange" text="Not synced" weight="medium" />
|
||||
)}
|
||||
{status === 'Importing' && (
|
||||
{status === SyncStatus.IMPORTING && (
|
||||
<Status
|
||||
color="turquoise"
|
||||
text="Importing"
|
||||
|
@ -0,0 +1,6 @@
|
||||
export enum SyncStatus {
|
||||
SYNCED = 'SYNCED',
|
||||
FAILED = 'FAILED',
|
||||
NOT_SYNCED = 'NOT_SYNCED',
|
||||
IMPORTING = 'IMPORTING',
|
||||
}
|
@ -0,0 +1,87 @@
|
||||
import { CalendarChannelSyncStatus } from '@/accounts/types/CalendarChannel';
|
||||
import { MessageChannelSyncStatus } from '@/accounts/types/MessageChannel';
|
||||
import { SyncStatus } from '@/settings/accounts/constants/SyncStatus';
|
||||
import { computeSyncStatus } from '../computeSyncStatus';
|
||||
|
||||
describe('computeSyncStatus', () => {
|
||||
test('should return FAILED when both sync statuses are FAILED', () => {
|
||||
expect(
|
||||
computeSyncStatus(
|
||||
MessageChannelSyncStatus.FAILED_UNKNOWN,
|
||||
CalendarChannelSyncStatus.FAILED_UNKNOWN,
|
||||
),
|
||||
).toEqual(SyncStatus.FAILED);
|
||||
});
|
||||
|
||||
test('should return FAILED when message channel sync status is FAILED_UNKNOWN', () => {
|
||||
expect(
|
||||
computeSyncStatus(
|
||||
MessageChannelSyncStatus.FAILED_UNKNOWN,
|
||||
CalendarChannelSyncStatus.ACTIVE,
|
||||
),
|
||||
).toEqual(SyncStatus.FAILED);
|
||||
});
|
||||
|
||||
test('should return FAILED when message channel sync status is FAILED_INSUFFICIENT_PERMISSIONS', () => {
|
||||
expect(
|
||||
computeSyncStatus(
|
||||
MessageChannelSyncStatus.FAILED_INSUFFICIENT_PERMISSIONS,
|
||||
CalendarChannelSyncStatus.ACTIVE,
|
||||
),
|
||||
).toEqual(SyncStatus.FAILED);
|
||||
});
|
||||
|
||||
test('should return FAILED when calendar channel sync status is FAILED_UNKNOWN', () => {
|
||||
expect(
|
||||
computeSyncStatus(
|
||||
MessageChannelSyncStatus.ACTIVE,
|
||||
CalendarChannelSyncStatus.FAILED_UNKNOWN,
|
||||
),
|
||||
).toEqual(SyncStatus.FAILED);
|
||||
});
|
||||
|
||||
test('should return FAILED when calendar channel sync status is FAILED_INSUFFICIENT_PERMISSIONS', () => {
|
||||
expect(
|
||||
computeSyncStatus(
|
||||
MessageChannelSyncStatus.ACTIVE,
|
||||
CalendarChannelSyncStatus.FAILED_INSUFFICIENT_PERMISSIONS,
|
||||
),
|
||||
).toEqual(SyncStatus.FAILED);
|
||||
});
|
||||
|
||||
test('should return IMPORTING when message channel sync status is ONGOING', () => {
|
||||
expect(
|
||||
computeSyncStatus(
|
||||
MessageChannelSyncStatus.ONGOING,
|
||||
CalendarChannelSyncStatus.ACTIVE,
|
||||
),
|
||||
).toEqual(SyncStatus.IMPORTING);
|
||||
});
|
||||
|
||||
test('should return IMPORTING when calendar channel sync status is ONGOING', () => {
|
||||
expect(
|
||||
computeSyncStatus(
|
||||
MessageChannelSyncStatus.ACTIVE,
|
||||
CalendarChannelSyncStatus.ONGOING,
|
||||
),
|
||||
).toEqual(SyncStatus.IMPORTING);
|
||||
});
|
||||
|
||||
test('should return SYNCED when one channel is ACTIVE and the other is NOT_SYNCED', () => {
|
||||
expect(
|
||||
computeSyncStatus(
|
||||
MessageChannelSyncStatus.NOT_SYNCED,
|
||||
CalendarChannelSyncStatus.ACTIVE,
|
||||
),
|
||||
).toEqual(SyncStatus.SYNCED);
|
||||
});
|
||||
|
||||
test('should return SYNCED when one channel is ACTIVE and the other is NOT_SYNCED', () => {
|
||||
expect(
|
||||
computeSyncStatus(
|
||||
MessageChannelSyncStatus.ACTIVE,
|
||||
CalendarChannelSyncStatus.NOT_SYNCED,
|
||||
),
|
||||
).toEqual(SyncStatus.SYNCED);
|
||||
});
|
||||
});
|
@ -0,0 +1,42 @@
|
||||
import { CalendarChannelSyncStatus } from '@/accounts/types/CalendarChannel';
|
||||
import { MessageChannelSyncStatus } from '@/accounts/types/MessageChannel';
|
||||
import { SyncStatus } from '@/settings/accounts/constants/SyncStatus';
|
||||
|
||||
export const computeSyncStatus = (
|
||||
messageChannelSyncStatus: MessageChannelSyncStatus,
|
||||
calendarChannelSyncStatus: CalendarChannelSyncStatus,
|
||||
) => {
|
||||
if (
|
||||
messageChannelSyncStatus === MessageChannelSyncStatus.FAILED_UNKNOWN ||
|
||||
messageChannelSyncStatus ===
|
||||
MessageChannelSyncStatus.FAILED_INSUFFICIENT_PERMISSIONS ||
|
||||
calendarChannelSyncStatus === CalendarChannelSyncStatus.FAILED_UNKNOWN ||
|
||||
calendarChannelSyncStatus ===
|
||||
CalendarChannelSyncStatus.FAILED_INSUFFICIENT_PERMISSIONS
|
||||
) {
|
||||
return SyncStatus.FAILED;
|
||||
}
|
||||
|
||||
if (
|
||||
messageChannelSyncStatus === MessageChannelSyncStatus.ONGOING ||
|
||||
calendarChannelSyncStatus === CalendarChannelSyncStatus.ONGOING
|
||||
) {
|
||||
return SyncStatus.IMPORTING;
|
||||
}
|
||||
|
||||
if (
|
||||
messageChannelSyncStatus === MessageChannelSyncStatus.NOT_SYNCED &&
|
||||
calendarChannelSyncStatus === CalendarChannelSyncStatus.NOT_SYNCED
|
||||
) {
|
||||
return SyncStatus.NOT_SYNCED;
|
||||
}
|
||||
|
||||
if (
|
||||
messageChannelSyncStatus === MessageChannelSyncStatus.ACTIVE ||
|
||||
calendarChannelSyncStatus === CalendarChannelSyncStatus.ACTIVE
|
||||
) {
|
||||
return SyncStatus.SYNCED;
|
||||
}
|
||||
|
||||
return SyncStatus.NOT_SYNCED;
|
||||
};
|
@ -1,14 +1,9 @@
|
||||
import { Field, ObjectType, registerEnumType } from '@nestjs/graphql';
|
||||
import { Field, ObjectType } from '@nestjs/graphql';
|
||||
|
||||
import { UUIDScalarType } from 'src/engine/api/graphql/workspace-schema-builder/graphql-types/scalars';
|
||||
import { TimelineCalendarEventParticipant } from 'src/engine/core-modules/calendar/dtos/timeline-calendar-event-participant.dto';
|
||||
import { CalendarChannelVisibility } from 'src/modules/calendar/common/standard-objects/calendar-channel.workspace-entity';
|
||||
|
||||
registerEnumType(CalendarChannelVisibility, {
|
||||
name: 'CalendarChannelVisibility',
|
||||
description: 'Visibility of the calendar channel',
|
||||
});
|
||||
|
||||
@ObjectType('LinkMetadata')
|
||||
class LinkMetadata {
|
||||
@Field()
|
||||
|
@ -1,14 +1,9 @@
|
||||
import { Field, ObjectType, registerEnumType } from '@nestjs/graphql';
|
||||
import { Field, ObjectType } from '@nestjs/graphql';
|
||||
|
||||
import { UUIDScalarType } from 'src/engine/api/graphql/workspace-schema-builder/graphql-types/scalars';
|
||||
import { TimelineThreadParticipant } from 'src/engine/core-modules/messaging/dtos/timeline-thread-participant.dto';
|
||||
import { MessageChannelVisibility } from 'src/modules/messaging/common/standard-objects/message-channel.workspace-entity';
|
||||
|
||||
registerEnumType(MessageChannelVisibility, {
|
||||
name: 'MessageChannelVisibility',
|
||||
description: 'Visibility of the message channel',
|
||||
});
|
||||
|
||||
@ObjectType('TimelineThread')
|
||||
export class TimelineThread {
|
||||
@Field(() => UUIDScalarType)
|
||||
|
@ -1,3 +1,5 @@
|
||||
import { registerEnumType } from '@nestjs/graphql';
|
||||
|
||||
import { Relation } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/relation.interface';
|
||||
|
||||
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
||||
@ -47,6 +49,22 @@ export enum CalendarChannelContactAutoCreationPolicy {
|
||||
NONE = 'NONE',
|
||||
}
|
||||
|
||||
registerEnumType(CalendarChannelVisibility, {
|
||||
name: 'CalendarChannelVisibility',
|
||||
});
|
||||
|
||||
registerEnumType(CalendarChannelSyncStatus, {
|
||||
name: 'CalendarChannelSyncStatus',
|
||||
});
|
||||
|
||||
registerEnumType(CalendarChannelSyncStage, {
|
||||
name: 'CalendarChannelSyncStage',
|
||||
});
|
||||
|
||||
registerEnumType(CalendarChannelContactAutoCreationPolicy, {
|
||||
name: 'CalendarChannelContactAutoCreationPolicy',
|
||||
});
|
||||
|
||||
@WorkspaceEntity({
|
||||
standardId: STANDARD_OBJECT_IDS.calendarChannel,
|
||||
namePlural: 'calendarChannels',
|
||||
|
@ -1,3 +1,5 @@
|
||||
import { registerEnumType } from '@nestjs/graphql';
|
||||
|
||||
import { Relation } from 'src/engine/workspace-manager/workspace-sync-metadata/interfaces/relation.interface';
|
||||
|
||||
import { FieldMetadataType } from 'src/engine/metadata-modules/field-metadata/field-metadata.entity';
|
||||
@ -52,6 +54,26 @@ export enum MessageChannelContactAutoCreationPolicy {
|
||||
NONE = 'NONE',
|
||||
}
|
||||
|
||||
registerEnumType(MessageChannelVisibility, {
|
||||
name: 'MessageChannelVisibility',
|
||||
});
|
||||
|
||||
registerEnumType(MessageChannelSyncStatus, {
|
||||
name: 'MessageChannelSyncStatus',
|
||||
});
|
||||
|
||||
registerEnumType(MessageChannelSyncStage, {
|
||||
name: 'MessageChannelSyncStage',
|
||||
});
|
||||
|
||||
registerEnumType(MessageChannelType, {
|
||||
name: 'MessageChannelType',
|
||||
});
|
||||
|
||||
registerEnumType(MessageChannelContactAutoCreationPolicy, {
|
||||
name: 'MessageChannelContactAutoCreationPolicy',
|
||||
});
|
||||
|
||||
@WorkspaceEntity({
|
||||
standardId: STANDARD_OBJECT_IDS.messageChannel,
|
||||
namePlural: 'messageChannels',
|
||||
|
Loading…
Reference in New Issue
Block a user