* feat: add enum type (RATING, SELECT, MULTI_SELECT) feat: wip enum type feat: try to alter enum feat: wip enum feat: wip enum feat: schema-builder can handle enum fix: return default value in field metadata response * fix: create fieldMedata with options * fix: lint issues * fix: rename abstract factory * feat: drop `PHONE` and `EMAIL` fieldMetadata types * feat: drop `VARCHAR` fieldMetadata type and rely on `TEXT` * Revert "feat: drop `PHONE` and `EMAIL` fieldMetadata types" This reverts commit 3857539f7d42f17c81f6ab92a6db950140b3c8e5.
119 lines
3.0 KiB
TypeScript
119 lines
3.0 KiB
TypeScript
import {
|
|
Entity,
|
|
Unique,
|
|
PrimaryGeneratedColumn,
|
|
Column,
|
|
ManyToOne,
|
|
JoinColumn,
|
|
OneToOne,
|
|
CreateDateColumn,
|
|
UpdateDateColumn,
|
|
} from 'typeorm';
|
|
|
|
import { FieldMetadataInterface } from 'src/metadata/field-metadata/interfaces/field-metadata.interface';
|
|
import { FieldMetadataTargetColumnMap } from 'src/metadata/field-metadata/interfaces/field-metadata-target-column-map.interface';
|
|
import { FieldMetadataDefaultValue } from 'src/metadata/field-metadata/interfaces/field-metadata-default-value.interface';
|
|
import { FieldMetadataOptions } from 'src/metadata/field-metadata/interfaces/field-metadata-options.interface';
|
|
|
|
import { ObjectMetadataEntity } from 'src/metadata/object-metadata/object-metadata.entity';
|
|
import { RelationMetadataEntity } from 'src/metadata/relation-metadata/relation-metadata.entity';
|
|
|
|
export enum FieldMetadataType {
|
|
UUID = 'UUID',
|
|
TEXT = 'TEXT',
|
|
PHONE = 'PHONE',
|
|
EMAIL = 'EMAIL',
|
|
DATE_TIME = 'DATE_TIME',
|
|
BOOLEAN = 'BOOLEAN',
|
|
NUMBER = 'NUMBER',
|
|
NUMERIC = 'NUMERIC',
|
|
PROBABILITY = 'PROBABILITY',
|
|
LINK = 'LINK',
|
|
CURRENCY = 'CURRENCY',
|
|
FULL_NAME = 'FULL_NAME',
|
|
RATING = 'RATING',
|
|
SELECT = 'SELECT',
|
|
MULTI_SELECT = 'MULTI_SELECT',
|
|
RELATION = 'RELATION',
|
|
}
|
|
|
|
@Entity('fieldMetadata')
|
|
@Unique('IndexOnNameObjectMetadataIdAndWorkspaceIdUnique', [
|
|
'name',
|
|
'objectMetadataId',
|
|
'workspaceId',
|
|
])
|
|
export class FieldMetadataEntity<
|
|
T extends FieldMetadataType | 'default' = 'default',
|
|
> implements FieldMetadataInterface<T>
|
|
{
|
|
@PrimaryGeneratedColumn('uuid')
|
|
id: string;
|
|
|
|
@Column({ nullable: false, type: 'uuid' })
|
|
objectMetadataId: string;
|
|
|
|
@ManyToOne(() => ObjectMetadataEntity, (object) => object.fields, {
|
|
onDelete: 'CASCADE',
|
|
})
|
|
@JoinColumn({ name: 'objectMetadataId' })
|
|
object: ObjectMetadataEntity;
|
|
|
|
@Column({ nullable: false })
|
|
type: FieldMetadataType;
|
|
|
|
@Column({ nullable: false })
|
|
name: string;
|
|
|
|
@Column({ nullable: false })
|
|
label: string;
|
|
|
|
@Column({ nullable: false, type: 'jsonb' })
|
|
targetColumnMap: FieldMetadataTargetColumnMap<T>;
|
|
|
|
@Column({ nullable: true, type: 'jsonb' })
|
|
defaultValue: FieldMetadataDefaultValue<T>;
|
|
|
|
@Column({ nullable: true, type: 'text' })
|
|
description: string;
|
|
|
|
@Column({ nullable: true })
|
|
icon: string;
|
|
|
|
@Column('jsonb', { nullable: true })
|
|
options: FieldMetadataOptions<T>;
|
|
|
|
@Column({ default: false })
|
|
isCustom: boolean;
|
|
|
|
@Column({ default: false })
|
|
isActive: boolean;
|
|
|
|
@Column({ default: false })
|
|
isSystem: boolean;
|
|
|
|
@Column({ nullable: true, default: true })
|
|
isNullable: boolean;
|
|
|
|
@Column({ nullable: false })
|
|
workspaceId: string;
|
|
|
|
@OneToOne(
|
|
() => RelationMetadataEntity,
|
|
(relation: RelationMetadataEntity) => relation.fromFieldMetadata,
|
|
)
|
|
fromRelationMetadata: RelationMetadataEntity;
|
|
|
|
@OneToOne(
|
|
() => RelationMetadataEntity,
|
|
(relation: RelationMetadataEntity) => relation.toFieldMetadata,
|
|
)
|
|
toRelationMetadata: RelationMetadataEntity;
|
|
|
|
@CreateDateColumn()
|
|
createdAt: Date;
|
|
|
|
@UpdateDateColumn()
|
|
updatedAt: Date;
|
|
}
|