/* tslint:disable */ /* eslint-disable */ /** * Tandoor * Tandoor API Docs * * The version of the OpenAPI document: 0.0.0 * * * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). * https://openapi-generator.tech * Do not edit the class manually. */ import { mapValues } from '../runtime'; import type { PropertyType } from './PropertyType'; import { PropertyTypeFromJSON, PropertyTypeFromJSONTyped, PropertyTypeToJSON, PropertyTypeToJSONTyped, } from './PropertyType'; /** * Moves `UniqueValidator`'s from the validation stage to the save stage. * It solves the problem with nested validation for unique fields on update. * * If you want more details, you can read related issues and articles: * https://github.com/beda-software/drf-writable-nested/issues/1 * http://www.django-rest-framework.org/api-guide/validators/#updating-nested-serializers * * Example of usage: * ``` * class Child(models.Model): * field = models.CharField(unique=True) * * * class Parent(models.Model): * child = models.ForeignKey('Child') * * * class ChildSerializer(UniqueFieldsMixin, serializers.ModelSerializer): * class Meta: * model = Child * * * class ParentSerializer(NestedUpdateMixin, serializers.ModelSerializer): * child = ChildSerializer() * * class Meta: * model = Parent * ``` * * Note: `UniqueFieldsMixin` must be applied only on the serializer * which has unique fields. * * Note: When you are using both mixins * (`UniqueFieldsMixin` and `NestedCreateMixin` or `NestedUpdateMixin`) * you should put `UniqueFieldsMixin` ahead. * @export * @interface Property */ export interface Property { /** * * @type {number} * @memberof Property */ id?: number; /** * * @type {number} * @memberof Property */ propertyAmount: number | null; /** * * @type {PropertyType} * @memberof Property */ propertyType: PropertyType; } /** * Check if a given object implements the Property interface. */ export function instanceOfProperty(value: object): value is Property { if (!('propertyAmount' in value) || value['propertyAmount'] === undefined) return false; if (!('propertyType' in value) || value['propertyType'] === undefined) return false; return true; } export function PropertyFromJSON(json: any): Property { return PropertyFromJSONTyped(json, false); } export function PropertyFromJSONTyped(json: any, ignoreDiscriminator: boolean): Property { if (json == null) { return json; } return { 'id': json['id'] == null ? undefined : json['id'], 'propertyAmount': json['property_amount'], 'propertyType': PropertyTypeFromJSON(json['property_type']), }; } export function PropertyToJSON(json: any): Property { return PropertyToJSONTyped(json, false); } export function PropertyToJSONTyped(value?: Property | null, ignoreDiscriminator: boolean = false): any { if (value == null) { return value; } return { 'id': value['id'], 'property_amount': value['propertyAmount'], 'property_type': PropertyTypeToJSON(value['propertyType']), }; }