@sap-cloud-sdk/core
Version:
SAP Cloud SDK for JavaScript core
64 lines • 4.92 kB
TypeScript
import { EdmTypeShared, OrderableEdmType } from '../edm-types';
import { Constructable, Entity } from '../entity';
import { ComplexTypeField } from './complex-type-field';
import { EdmTypeField } from './edm-type-field';
import { OrderableEdmTypeField } from './orderable-edm-type-field';
import { CollectionField, CollectionFieldType } from './collection-field';
import { ConstructorOrField } from './constructor-or-field';
import { FieldOptions } from './field';
import { EnumField } from './enum-field';
declare type ComplexTypeFieldConstructor<ComplexTypeFieldT extends ComplexTypeField<EntityT, ComplexT, NullableT, SelectableT>, EntityT extends Entity, ComplexT, NullableT extends boolean, SelectableT extends boolean> = new (fieldName: string, fieldOf: ConstructorOrField<EntityT>, fieldOptions?: FieldOptions<NullableT, SelectableT>) => ComplexTypeFieldT;
/**
* Convenience type to determine whether a field should be selectable. If the given `FieldOfT` is the type of an entity, it is selectable.
* @typeparam FieldOfT - Type of the entity or complex type field this field belongs to.
*/
export declare type IsSelectableField<FieldOfT extends ConstructorOrField<any>> = FieldOfT extends Constructable<any> ? true : false;
/**
* Convenience type to determine whether a field should be orderable. If the given `EdmT` is of type `OrderableEdmTypes`, it is orderable.
* @typeparam EdmT - EDM type of the field.
*/
export declare type IsOrderableField<EdmT extends EdmTypeShared<'any'>> = EdmT extends OrderableEdmType ? true : false;
declare type EntityTypeFromFieldOf<FieldOfT extends ConstructorOrField<any>> = FieldOfT extends ConstructorOrField<infer EntityT> ? EntityT : never;
/**
* Field builder to orchestrate the creation of the different kinds of fields.
* @typeparam FieldOfT - Type of the entity or complex type field this field belongs to.
*/
export declare class FieldBuilder<FieldOfT extends ConstructorOrField<any>> {
fieldOf: FieldOfT;
/**
* Creates an instance of `FieldBuilder`.
* @param fieldOf - Entity or complex type field, for which the field builder shall create fields.
*/
constructor(fieldOf: FieldOfT);
buildEdmTypeField<EdmT extends OrderableEdmType, NullableT extends boolean>(fieldName: string, edmType: EdmT, isNullable: NullableT): OrderableEdmTypeField<EntityTypeFromFieldOf<FieldOfT>, EdmT, NullableT, IsSelectableField<FieldOfT>>;
buildEdmTypeField<EdmT extends Exclude<EdmTypeShared<'any'>, OrderableEdmType>, NullableT extends boolean>(fieldName: string, edmType: EdmT, isNullable: NullableT): EdmTypeField<EntityTypeFromFieldOf<FieldOfT>, EdmT, NullableT, IsSelectableField<FieldOfT>>;
/**
* Build a field for a property with a complex type.
* Fields of entities are selectable; fields of complex types are not selectable.
* @param fieldName - Name of the field.
* @param complexTypeFieldCtor - Constructor of the complex type field.
* @param isNullable - Whether the field is nullable.
* @returns A complex type field of the given type.
*/
buildComplexTypeField<ComplexTypeFieldT extends ComplexTypeField<EntityTypeFromFieldOf<FieldOfT>, any, NullableT, IsSelectableField<FieldOfT>>, ComplexT, NullableT extends boolean>(fieldName: string, complexTypeFieldCtor: ComplexTypeFieldConstructor<ComplexTypeFieldT, EntityTypeFromFieldOf<FieldOfT>, ComplexT, NullableT, IsSelectableField<FieldOfT>>, isNullable: NullableT): ComplexTypeFieldT;
/**
* Build a field for a property with a collection type.
* The type of the field can either be an EDM type or a complex type.
* Fields of entities are selectable; fields of complex types are not selectable.
* @param fieldName - Name of the field.
* @param collectionFieldType - Type of the collection. Can either be an EDM type or complex type (not complex type field).
* @param isNullable - Whether the field is nullable.
* @returns A collection field with the given collection type.
*/
buildCollectionField<CollectionFieldT extends EdmTypeShared<'any'> | Record<string, any>, NullableT extends boolean>(fieldName: string, collectionFieldType: CollectionFieldType<CollectionFieldT>, isNullable: NullableT): CollectionField<EntityTypeFromFieldOf<FieldOfT>, CollectionFieldT, NullableT, IsSelectableField<FieldOfT>>;
/**
* Build a field for a property with a enum type.
* @param fieldName - Name of the field.
* @param enumType - Enum type of this field.
* @param isNullable - Whether the field is nullable.
* @returns A collection field with the given collection type.
*/
buildEnumField<EnumT extends string, NullableT extends boolean>(fieldName: string, enumType: Record<string, EnumT>, isNullable: NullableT): EnumField<EntityTypeFromFieldOf<FieldOfT>, EnumT, NullableT, IsSelectableField<FieldOfT>>;
}
export {};
//# sourceMappingURL=field-builder.d.ts.map