///
/// QueryStatisticsResponseFromSingleSource.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 `QueryStatisticsResponseFromSingleSource`, backed by a C++ struct.
 */
public typealias QueryStatisticsResponseFromSingleSource = margelo.nitro.healthkit.QueryStatisticsResponseFromSingleSource

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

  /**
   * Create a new instance of `QueryStatisticsResponseFromSingleSource`.
   */
  init(source: (any HybridSourceProxySpec), startDate: Date?, endDate: Date?, duration: Quantity?, averageQuantity: Quantity?, maximumQuantity: Quantity?, minimumQuantity: Quantity?, sumQuantity: Quantity?, mostRecentQuantity: Quantity?, mostRecentQuantityDateInterval: QuantityDateInterval?) {
    self.init({ () -> bridge.std__shared_ptr_HybridSourceProxySpec_ in
      let __cxxWrapped = source.getCxxWrapper()
      return __cxxWrapped.getCxxPart()
    }(), { () -> 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__optional_Quantity_ in
      if let __unwrappedValue = duration {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .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()
      }
    }())
  }

  @inline(__always)
  var source: (any HybridSourceProxySpec) {
    return { () -> any HybridSourceProxySpec in
      let __unsafePointer = bridge.get_std__shared_ptr_HybridSourceProxySpec_(self.__source)
      let __instance = HybridSourceProxySpec_cxx.fromUnsafe(__unsafePointer)
      return __instance.getHybridSourceProxySpec()
    }()
  }
  
  @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 duration: Quantity? {
    return self.__duration.value
  }
  
  @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
  }
}
