Skip to content
On this page

Directus Cloud

Everything you need to start building. Provisioned in 90 seconds. Starting at $15/month.

Get Started

This is an auto-generated document to support extension builders understand the internal packages they can utilize. To find our written guides, tutorials, and API/SDK reference, check out our main docs .

Directus / @directus/sdk / rest / createField

Function: createField() ​

createField<Schema, TQuery>(collection, item, query?): RestCommand<IfAny<Schema, Record<string, any>, { [K in string | number | symbol]: Merge<MappedFunctionFields<Schema, DirectusField<Schema>> extends FF ? MapFlatFields<DirectusField<Schema>, FieldsWildcard<DirectusField<Schema>, Exclude<UnpackList<Mutable<(...)>>, PickRelationalFields<(...)> extends never ? never : AllKeys<(...)>>>, FF extends Record<string, string> ? FF<FF> : Record<string, string>> : never, PickRelationalFields<UnpackList<Mutable<TQuery["fields"]>>> extends never ? never : { [Field in string | number | symbol]: Field extends keyof DirectusField<Schema> ? Extract<(...)[(...)], ItemType<(...)>> extends RelatedCollection ? IsNullable<(...)[(...)], (...) | (...), (...) extends (...) ? (...) : (...)> : never : never }>[K] }>, Schema>

Create a new field in the given collection.

Type Parameters ​

• Schema

• TQuery extends Query<Schema, DirectusField<Schema>>

Parameters ​

• collection: keyof Schema

The collection to create a field for

• item

The field to create

• item.collection?: string

• item.field?: string

• item.meta?: NestedUnion<IfAny<Schema, object, "directus_fields" extends keyof Schema ? UnpackList<Schema[keyof Schema & "directus_fields"]> extends Item ? { [Field in string | number | symbol]: Item[Field] } & object : never : object>>

• item.schema?

• item.schema.comment?: null | string

• item.schema.data_type?: string

• item.schema.default_value?: any

• item.schema.foreign_key_column?: null | string

• item.schema.foreign_key_schema?: null | string

• item.schema.foreign_key_table?: null | string

• item.schema.generation_expression?: unknown

• item.schema.has_auto_increment?: boolean

• item.schema.is_generated?: boolean

• item.schema.is_indexed?: boolean

• item.schema.is_nullable?: boolean

• item.schema.is_primary_key?: boolean

• item.schema.is_unique?: boolean

• item.schema.max_length?: null | number

• item.schema.name?: string

• item.schema.numeric_precision?: null | number

• item.schema.numeric_scale?: null | number

• item.schema.schema?: string

• item.schema.table?: string

• item.type?: string

• query?: TQuery

Optional return data query

Returns ​

RestCommand<IfAny<Schema, Record<string, any>, { [K in string | number | symbol]: Merge<MappedFunctionFields<Schema, DirectusField<Schema>> extends FF ? MapFlatFields<DirectusField<Schema>, FieldsWildcard<DirectusField<Schema>, Exclude<UnpackList<Mutable<(...)>>, PickRelationalFields<(...)> extends never ? never : AllKeys<(...)>>>, FF extends Record<string, string> ? FF<FF> : Record<string, string>> : never, PickRelationalFields<UnpackList<Mutable<TQuery["fields"]>>> extends never ? never : { [Field in string | number | symbol]: Field extends keyof DirectusField<Schema> ? Extract<(...)[(...)], ItemType<(...)>> extends RelatedCollection ? IsNullable<(...)[(...)], (...) | (...), (...) extends (...) ? (...) : (...)> : never : never }>[K] }>, Schema>

The field object for the created field.

Defined in ​

rest/commands/create/fields.ts:21