# Introduction In this PR we've migrated `twenty-shared` from a `vite` app [libary-mode](https://vite.dev/guide/build#library-mode) to a [preconstruct](https://preconstruct.tools/) "atomic" application ( in the future would like to introduce preconstruct to handle of all our atomic dependencies such as `twenty-emails` `twenty-ui` etc it will be integrated at the monorepo's root directly, would be to invasive in the first, starting incremental via `twenty-shared`) For more information regarding the motivations please refer to nor: - https://github.com/twentyhq/core-team-issues/issues/587 - https://github.com/twentyhq/core-team-issues/issues/281#issuecomment-2630949682 close https://github.com/twentyhq/core-team-issues/issues/589 close https://github.com/twentyhq/core-team-issues/issues/590 ## How to test In order to ease the review this PR will ship all the codegen at the very end, the actual meaning full diff is `+2,411 −114` In order to migrate existing dependent packages to `twenty-shared` multi barrel new arch you need to run in local: ```sh yarn tsx packages/twenty-shared/scripts/migrateFromSingleToMultiBarrelImport.ts && \ npx nx run-many -t lint --fix -p twenty-front twenty-ui twenty-server twenty-emails twenty-shared twenty-zapier ``` Note that `migrateFromSingleToMultiBarrelImport` is idempotent, it's atm included in the PR but should not be merged. ( such as codegen will be added before merging this script will be removed ) ## Misc - related opened issue preconstruct https://github.com/preconstruct/preconstruct/issues/617 ## Closed related PR - https://github.com/twentyhq/twenty/pull/11028 - https://github.com/twentyhq/twenty/pull/10993 - https://github.com/twentyhq/twenty/pull/10960 ## Upcoming enhancement: ( in others dedicated PRs ) - 1/ refactor generate barrel to export atomic module instead of `*` - 2/ generate barrel own package with several files and tests - 3/ Migration twenty-ui the same way - 4/ Use `preconstruct` at monorepo global level ## Conclusion As always any suggestions are welcomed !
159 lines
4.0 KiB
TypeScript
159 lines
4.0 KiB
TypeScript
import {
|
|
Field,
|
|
HideField,
|
|
ObjectType,
|
|
registerEnumType,
|
|
} from '@nestjs/graphql';
|
|
|
|
import {
|
|
Authorize,
|
|
FilterableField,
|
|
IDField,
|
|
QueryOptions,
|
|
Relation,
|
|
} from '@ptc-org/nestjs-query-graphql';
|
|
import { Transform } from 'class-transformer';
|
|
import {
|
|
IsBoolean,
|
|
IsDateString,
|
|
IsEnum,
|
|
IsNotEmpty,
|
|
IsOptional,
|
|
IsString,
|
|
IsUUID,
|
|
Validate,
|
|
} from 'class-validator';
|
|
import { GraphQLJSON } from 'graphql-type-json';
|
|
import { FieldMetadataType } from 'twenty-shared/types';
|
|
|
|
import { FieldMetadataDefaultValue } from 'src/engine/metadata-modules/field-metadata/interfaces/field-metadata-default-value.interface';
|
|
import { FieldMetadataOptions } from 'src/engine/metadata-modules/field-metadata/interfaces/field-metadata-options.interface';
|
|
import { FieldMetadataSettings } from 'src/engine/metadata-modules/field-metadata/interfaces/field-metadata-settings.interface';
|
|
|
|
import { UUIDScalarType } from 'src/engine/api/graphql/workspace-schema-builder/graphql-types/scalars';
|
|
import { IsValidMetadataName } from 'src/engine/decorators/metadata/is-valid-metadata-name.decorator';
|
|
import { FieldMetadataDefaultOption } from 'src/engine/metadata-modules/field-metadata/dtos/options.input';
|
|
import { IsFieldMetadataDefaultValue } from 'src/engine/metadata-modules/field-metadata/validators/is-field-metadata-default-value.validator';
|
|
import { IsFieldMetadataOptions } from 'src/engine/metadata-modules/field-metadata/validators/is-field-metadata-options.validator';
|
|
import { ObjectMetadataDTO } from 'src/engine/metadata-modules/object-metadata/dtos/object-metadata.dto';
|
|
import { RelationMetadataDTO } from 'src/engine/metadata-modules/relation-metadata/dtos/relation-metadata.dto';
|
|
import { transformEnumValue } from 'src/engine/utils/transform-enum-value';
|
|
|
|
registerEnumType(FieldMetadataType, {
|
|
name: 'FieldMetadataType',
|
|
description: 'Type of the field',
|
|
});
|
|
|
|
@ObjectType('Field')
|
|
@Authorize({
|
|
authorize: (context: any) => ({
|
|
workspaceId: { eq: context?.req?.workspace?.id },
|
|
}),
|
|
})
|
|
@QueryOptions({
|
|
defaultResultSize: 10,
|
|
disableSort: true,
|
|
maxResultsSize: 1000,
|
|
})
|
|
@Relation('toRelationMetadata', () => RelationMetadataDTO, {
|
|
nullable: true,
|
|
})
|
|
@Relation('fromRelationMetadata', () => RelationMetadataDTO, {
|
|
nullable: true,
|
|
})
|
|
@Relation('object', () => ObjectMetadataDTO, {
|
|
nullable: true,
|
|
})
|
|
export class FieldMetadataDTO<T extends FieldMetadataType = FieldMetadataType> {
|
|
@IsUUID()
|
|
@IsNotEmpty()
|
|
@IDField(() => UUIDScalarType)
|
|
id: string;
|
|
|
|
@IsEnum(FieldMetadataType)
|
|
@IsNotEmpty()
|
|
@Field(() => FieldMetadataType)
|
|
type: T;
|
|
|
|
@IsString()
|
|
@IsNotEmpty()
|
|
@Field()
|
|
@IsValidMetadataName()
|
|
name: string;
|
|
|
|
@IsString()
|
|
@IsNotEmpty()
|
|
@Field()
|
|
label: string;
|
|
|
|
@IsString()
|
|
@IsOptional()
|
|
@Field({ nullable: true })
|
|
description?: string;
|
|
|
|
@IsString()
|
|
@IsOptional()
|
|
@Field({ nullable: true })
|
|
icon?: string;
|
|
|
|
@IsBoolean()
|
|
@IsOptional()
|
|
@FilterableField({ nullable: true })
|
|
isCustom?: boolean;
|
|
|
|
@IsBoolean()
|
|
@IsOptional()
|
|
@FilterableField({ nullable: true })
|
|
isActive?: boolean;
|
|
|
|
@IsBoolean()
|
|
@IsOptional()
|
|
@FilterableField({ nullable: true })
|
|
isSystem?: boolean;
|
|
|
|
@IsBoolean()
|
|
@IsOptional()
|
|
@Field({ nullable: true })
|
|
isNullable?: boolean;
|
|
|
|
@IsBoolean()
|
|
@IsOptional()
|
|
@Field({ nullable: true })
|
|
isUnique?: boolean;
|
|
|
|
@Validate(IsFieldMetadataDefaultValue)
|
|
@IsOptional()
|
|
@Field(() => GraphQLJSON, { nullable: true })
|
|
defaultValue?: FieldMetadataDefaultValue<T>;
|
|
|
|
@Transform(({ value }) =>
|
|
transformEnumValue(value as FieldMetadataDefaultOption[]),
|
|
)
|
|
@Validate(IsFieldMetadataOptions)
|
|
@IsOptional()
|
|
@Field(() => GraphQLJSON, { nullable: true })
|
|
options?: FieldMetadataOptions<T>;
|
|
|
|
@IsOptional()
|
|
@Field(() => GraphQLJSON, { nullable: true })
|
|
settings?: FieldMetadataSettings<T>;
|
|
|
|
@HideField()
|
|
workspaceId: string;
|
|
|
|
objectMetadataId: string;
|
|
|
|
@IsBoolean()
|
|
@IsOptional()
|
|
@Field({ nullable: true })
|
|
isLabelSyncedWithName?: boolean;
|
|
|
|
@IsDateString()
|
|
@Field()
|
|
createdAt: Date;
|
|
|
|
@IsDateString()
|
|
@Field()
|
|
updatedAt: Date;
|
|
}
|