///
/// QueryStatisticsResponse.swift
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
/// https://github.com/mrousavy/nitro
/// Copyright © Marc Rousavy @ Margelo
///

import NitroModules

/**
 * Represents an instance of `QueryStatisticsResponse`, backed by a C++ struct.
 */
public typealias QueryStatisticsResponse = margelo.nitro.healthkit.QueryStatisticsResponse

public extension QueryStatisticsResponse {
  private typealias bridge = margelo.nitro.healthkit.bridge.swift

  /**
   * Create a new instance of `QueryStatisticsResponse`.
   */
  init(averageQuantity: Quantity?, maximumQuantity: Quantity?, minimumQuantity: Quantity?, sumQuantity: Quantity?, mostRecentQuantity: Quantity?, mostRecentQuantityDateInterval: QuantityDateInterval?, duration: Quantity?, startDate: Date?, endDate: Date?, sources: [(any HybridSourceProxySpec)]) {
    self.init({ () -> bridge.std__optional_Quantity_ in
      if let __unwrappedValue = averageQuantity {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_Quantity_ in
      if let __unwrappedValue = maximumQuantity {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_Quantity_ in
      if let __unwrappedValue = minimumQuantity {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_Quantity_ in
      if let __unwrappedValue = sumQuantity {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_Quantity_ in
      if let __unwrappedValue = mostRecentQuantity {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_QuantityDateInterval_ in
      if let __unwrappedValue = mostRecentQuantityDateInterval {
        return bridge.create_std__optional_QuantityDateInterval_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_Quantity_ in
      if let __unwrappedValue = duration {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_std__chrono__system_clock__time_point_ in
      if let __unwrappedValue = startDate {
        return bridge.create_std__optional_std__chrono__system_clock__time_point_(__unwrappedValue.toCpp())
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_std__chrono__system_clock__time_point_ in
      if let __unwrappedValue = endDate {
        return bridge.create_std__optional_std__chrono__system_clock__time_point_(__unwrappedValue.toCpp())
      } else {
        return .init()
      }
    }(), { () -> bridge.std__vector_std__shared_ptr_HybridSourceProxySpec__ in
      var __vector = bridge.create_std__vector_std__shared_ptr_HybridSourceProxySpec__(sources.count)
      for __item in sources {
        __vector.push_back({ () -> bridge.std__shared_ptr_HybridSourceProxySpec_ in
          let __cxxWrapped = __item.getCxxWrapper()
          return __cxxWrapped.getCxxPart()
        }())
      }
      return __vector
    }())
  }

  @inline(__always)
  var averageQuantity: Quantity? {
    return self.__averageQuantity.value
  }
  
  @inline(__always)
  var maximumQuantity: Quantity? {
    return self.__maximumQuantity.value
  }
  
  @inline(__always)
  var minimumQuantity: Quantity? {
    return self.__minimumQuantity.value
  }
  
  @inline(__always)
  var sumQuantity: Quantity? {
    return self.__sumQuantity.value
  }
  
  @inline(__always)
  var mostRecentQuantity: Quantity? {
    return self.__mostRecentQuantity.value
  }
  
  @inline(__always)
  var mostRecentQuantityDateInterval: QuantityDateInterval? {
    return self.__mostRecentQuantityDateInterval.value
  }
  
  @inline(__always)
  var duration: Quantity? {
    return self.__duration.value
  }
  
  @inline(__always)
  var startDate: Date? {
    return { () -> Date? in
      if bridge.has_value_std__optional_std__chrono__system_clock__time_point_(self.__startDate) {
        let __unwrapped = bridge.get_std__optional_std__chrono__system_clock__time_point_(self.__startDate)
        return Date(fromChrono: __unwrapped)
      } else {
        return nil
      }
    }()
  }
  
  @inline(__always)
  var endDate: Date? {
    return { () -> Date? in
      if bridge.has_value_std__optional_std__chrono__system_clock__time_point_(self.__endDate) {
        let __unwrapped = bridge.get_std__optional_std__chrono__system_clock__time_point_(self.__endDate)
        return Date(fromChrono: __unwrapped)
      } else {
        return nil
      }
    }()
  }
  
  @inline(__always)
  var sources: [(any HybridSourceProxySpec)] {
    return self.__sources.map({ __item in { () -> any HybridSourceProxySpec in
      let __unsafePointer = bridge.get_std__shared_ptr_HybridSourceProxySpec_(__item)
      let __instance = HybridSourceProxySpec_cxx.fromUnsafe(__unsafePointer)
      return __instance.getHybridSourceProxySpec()
    }() })
  }
}
