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

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

  /**
   * Create a new instance of `WorkoutSample`.
   */
  init(workoutActivityType: WorkoutActivityType, duration: Quantity, totalEnergyBurned: Quantity?, totalDistance: Quantity?, totalSwimmingStrokeCount: Quantity?, totalFlightsClimbed: Quantity?, events: [WorkoutEvent]?, activities: [WorkoutActivity]?, metadata: AnyMap, sampleType: SampleType, startDate: Date, endDate: Date, hasUndeterminedDuration: Bool, uuid: String, sourceRevision: SourceRevision, device: Device?) {
    self.init(workoutActivityType, duration, { () -> bridge.std__optional_Quantity_ in
      if let __unwrappedValue = totalEnergyBurned {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_Quantity_ in
      if let __unwrappedValue = totalDistance {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_Quantity_ in
      if let __unwrappedValue = totalSwimmingStrokeCount {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_Quantity_ in
      if let __unwrappedValue = totalFlightsClimbed {
        return bridge.create_std__optional_Quantity_(__unwrappedValue)
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_std__vector_WorkoutEvent__ in
      if let __unwrappedValue = events {
        return bridge.create_std__optional_std__vector_WorkoutEvent__({ () -> bridge.std__vector_WorkoutEvent_ in
          var __vector = bridge.create_std__vector_WorkoutEvent_(__unwrappedValue.count)
          for __item in __unwrappedValue {
            __vector.push_back(__item)
          }
          return __vector
        }())
      } else {
        return .init()
      }
    }(), { () -> bridge.std__optional_std__vector_WorkoutActivity__ in
      if let __unwrappedValue = activities {
        return bridge.create_std__optional_std__vector_WorkoutActivity__({ () -> bridge.std__vector_WorkoutActivity_ in
          var __vector = bridge.create_std__vector_WorkoutActivity_(__unwrappedValue.count)
          for __item in __unwrappedValue {
            __vector.push_back(__item)
          }
          return __vector
        }())
      } else {
        return .init()
      }
    }(), metadata.cppPart, sampleType, startDate.toCpp(), endDate.toCpp(), hasUndeterminedDuration, std.string(uuid), sourceRevision, { () -> bridge.std__optional_Device_ in
      if let __unwrappedValue = device {
        return bridge.create_std__optional_Device_(__unwrappedValue)
      } else {
        return .init()
      }
    }())
  }

  @inline(__always)
  var workoutActivityType: WorkoutActivityType {
    return self.__workoutActivityType
  }
  
  @inline(__always)
  var duration: Quantity {
    return self.__duration
  }
  
  @inline(__always)
  var totalEnergyBurned: Quantity? {
    return self.__totalEnergyBurned.value
  }
  
  @inline(__always)
  var totalDistance: Quantity? {
    return self.__totalDistance.value
  }
  
  @inline(__always)
  var totalSwimmingStrokeCount: Quantity? {
    return self.__totalSwimmingStrokeCount.value
  }
  
  @inline(__always)
  var totalFlightsClimbed: Quantity? {
    return self.__totalFlightsClimbed.value
  }
  
  @inline(__always)
  var events: [WorkoutEvent]? {
    return { () -> [WorkoutEvent]? in
      if bridge.has_value_std__optional_std__vector_WorkoutEvent__(self.__events) {
        let __unwrapped = bridge.get_std__optional_std__vector_WorkoutEvent__(self.__events)
        return __unwrapped.map({ __item in __item })
      } else {
        return nil
      }
    }()
  }
  
  @inline(__always)
  var activities: [WorkoutActivity]? {
    return { () -> [WorkoutActivity]? in
      if bridge.has_value_std__optional_std__vector_WorkoutActivity__(self.__activities) {
        let __unwrapped = bridge.get_std__optional_std__vector_WorkoutActivity__(self.__activities)
        return __unwrapped.map({ __item in __item })
      } else {
        return nil
      }
    }()
  }
  
  @inline(__always)
  var metadata: AnyMap {
    return AnyMap(withCppPart: self.__metadata)
  }
  
  @inline(__always)
  var sampleType: SampleType {
    return self.__sampleType
  }
  
  @inline(__always)
  var startDate: Date {
    return Date(fromChrono: self.__startDate)
  }
  
  @inline(__always)
  var endDate: Date {
    return Date(fromChrono: self.__endDate)
  }
  
  @inline(__always)
  var hasUndeterminedDuration: Bool {
    return self.__hasUndeterminedDuration
  }
  
  @inline(__always)
  var uuid: String {
    return String(self.__uuid)
  }
  
  @inline(__always)
  var sourceRevision: SourceRevision {
    return self.__sourceRevision
  }
  
  @inline(__always)
  var device: Device? {
    return self.__device.value
  }
}
