/* tslint:disable */
/* eslint-disable */
/**
 * CWMS Data API
 * CWMS REST API for Data Retrieval
 *
 * The version of the OpenAPI document: 2.4.0-2026.3.16
 * 
 *
 * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
 * https://openapi-generator.tech
 * Do not edit the class manually.
 */

import { exists, mapValues } from '../runtime';
import {
    BinaryTimeSeriesRow,
    BinaryTimeSeriesRowFromJSON,
    BinaryTimeSeriesRowFromJSONTyped,
    BinaryTimeSeriesRowToJSON,
} from './BinaryTimeSeriesRow';

/**
 * 
 * @export
 * @interface BinaryTimeSeries
 */
export interface BinaryTimeSeries {
    /**
     * Owning office of object.
     * @type {string}
     * @memberof BinaryTimeSeries
     */
    officeId: string;
    /**
     * 
     * @type {string}
     * @memberof BinaryTimeSeries
     */
    name?: string;
    /**
     * 
     * @type {number}
     * @memberof BinaryTimeSeries
     */
    intervalOffset?: number;
    /**
     * 
     * @type {string}
     * @memberof BinaryTimeSeries
     */
    timeZone?: string;
    /**
     * Version type specifies the type of timeseries response to be received. Can be max aggregate or single version. Max aggregate cannot be run if version date field is specified.
     * @type {string}
     * @memberof BinaryTimeSeries
     */
    dateVersionType?: BinaryTimeSeriesDateVersionTypeEnum;
    /**
     * The version date of the time series trace
     * @type {Date}
     * @memberof BinaryTimeSeries
     */
    versionDate?: Date;
    /**
     * 
     * @type {Array<BinaryTimeSeriesRow>}
     * @memberof BinaryTimeSeries
     */
    binaryValues?: Array<BinaryTimeSeriesRow>;
}

/**
* @export
* @enum {string}
*/
export enum BinaryTimeSeriesDateVersionTypeEnum {
    MaxAggregate = 'MAX_AGGREGATE',
    SingleVersion = 'SINGLE_VERSION',
    Unversioned = 'UNVERSIONED'
}

export function BinaryTimeSeriesFromJSON(json: any): BinaryTimeSeries {
    return BinaryTimeSeriesFromJSONTyped(json, false);
}

export function BinaryTimeSeriesFromJSONTyped(json: any, ignoreDiscriminator: boolean): BinaryTimeSeries {
    if ((json === undefined) || (json === null)) {
        return json;
    }
    return {
        
        'officeId': json['office-id'],
        'name': !exists(json, 'name') ? undefined : json['name'],
        'intervalOffset': !exists(json, 'interval-offset') ? undefined : json['interval-offset'],
        'timeZone': !exists(json, 'time-zone') ? undefined : json['time-zone'],
        'dateVersionType': !exists(json, 'date-version-type') ? undefined : json['date-version-type'],
        'versionDate': !exists(json, 'version-date') ? undefined : (new Date(json['version-date'])),
        'binaryValues': !exists(json, 'binary-values') ? undefined : ((json['binary-values'] as Array<any>).map(BinaryTimeSeriesRowFromJSON)),
    };
}

export function BinaryTimeSeriesToJSON(value?: BinaryTimeSeries | null): any {
    if (value === undefined) {
        return undefined;
    }
    if (value === null) {
        return null;
    }
    return {
        
        'office-id': value.officeId,
        'name': value.name,
        'interval-offset': value.intervalOffset,
        'time-zone': value.timeZone,
        'date-version-type': value.dateVersionType,
        'version-date': value.versionDate === undefined ? undefined : (value.versionDate.toISOString()),
        'binary-values': value.binaryValues === undefined ? undefined : ((value.binaryValues as Array<any>).map(BinaryTimeSeriesRowToJSON)),
    };
}

