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

import NitroModules

/**
 * A class implementation that bridges HybridWorkoutProxySpec over to C++.
 * In C++, we cannot use Swift protocols - so we need to wrap it in a class to make it strongly defined.
 *
 * Also, some Swift types need to be bridged with special handling:
 * - Enums need to be wrapped in Structs, otherwise they cannot be accessed bi-directionally (Swift bug: https://github.com/swiftlang/swift/issues/75330)
 * - Other HybridObjects need to be wrapped/unwrapped from the Swift TCxx wrapper
 * - Throwing methods need to be wrapped with a Result<T, Error> type, as exceptions cannot be propagated to C++
 */
open class HybridWorkoutProxySpec_cxx {
  /**
   * The Swift <> C++ bridge's namespace (`margelo::nitro::healthkit::bridge::swift`)
   * from `ReactNativeHealthkit-Swift-Cxx-Bridge.hpp`.
   * This contains specialized C++ templates, and C++ helper functions that can be accessed from Swift.
   */
  public typealias bridge = margelo.nitro.healthkit.bridge.swift

  /**
   * Holds an instance of the `HybridWorkoutProxySpec` Swift protocol.
   */
  private var __implementation: any HybridWorkoutProxySpec

  /**
   * Holds a weak pointer to the C++ class that wraps the Swift class.
   */
  private var __cxxPart: bridge.std__weak_ptr_HybridWorkoutProxySpec_

  /**
   * Create a new `HybridWorkoutProxySpec_cxx` that wraps the given `HybridWorkoutProxySpec`.
   * All properties and methods bridge to C++ types.
   */
  public init(_ implementation: any HybridWorkoutProxySpec) {
    self.__implementation = implementation
    self.__cxxPart = .init()
    /* no base class */
  }

  /**
   * Get the actual `HybridWorkoutProxySpec` instance this class wraps.
   */
  @inline(__always)
  public func getHybridWorkoutProxySpec() -> any HybridWorkoutProxySpec {
    return __implementation
  }

  /**
   * Casts this instance to a retained unsafe raw pointer.
   * This acquires one additional strong reference on the object!
   */
  public func toUnsafe() -> UnsafeMutableRawPointer {
    return Unmanaged.passRetained(self).toOpaque()
  }

  /**
   * Casts an unsafe pointer to a `HybridWorkoutProxySpec_cxx`.
   * The pointer has to be a retained opaque `Unmanaged<HybridWorkoutProxySpec_cxx>`.
   * This removes one strong reference from the object!
   */
  public class func fromUnsafe(_ pointer: UnsafeMutableRawPointer) -> HybridWorkoutProxySpec_cxx {
    return Unmanaged<HybridWorkoutProxySpec_cxx>.fromOpaque(pointer).takeRetainedValue()
  }

  /**
   * Gets (or creates) the C++ part of this Hybrid Object.
   * The C++ part is a `std::shared_ptr<HybridWorkoutProxySpec>`.
   */
  public func getCxxPart() -> bridge.std__shared_ptr_HybridWorkoutProxySpec_ {
    let cachedCxxPart = self.__cxxPart.lock()
    if cachedCxxPart.use_count() > 0 {
      return cachedCxxPart
    } else {
      let newCxxPart = bridge.create_std__shared_ptr_HybridWorkoutProxySpec_(self.toUnsafe())
      __cxxPart = bridge.weakify_std__shared_ptr_HybridWorkoutProxySpec_(newCxxPart)
      return newCxxPart
    }
  }

  

  /**
   * Get the memory size of the Swift class (plus size of any other allocations)
   * so the JS VM can properly track it and garbage-collect the JS object if needed.
   */
  @inline(__always)
  public var memorySize: Int {
    return MemoryHelper.getSizeOf(self.__implementation) + self.__implementation.memorySize
  }

  /**
   * Compares this object with the given [other] object for reference equality.
   */
  @inline(__always)
  public func equals(other: HybridWorkoutProxySpec_cxx) -> Bool {
    return self.__implementation === other.__implementation
  }

  /**
   * Call dispose() on the Swift class.
   * This _may_ be called manually from JS.
   */
  @inline(__always)
  public func dispose() {
    self.__implementation.dispose()
  }

  /**
   * Call toString() on the Swift class.
   */
  @inline(__always)
  public func toString() -> String {
    return self.__implementation.toString()
  }

  // Properties
  public final var workoutActivityType: Int32 {
    @inline(__always)
    get {
      return self.__implementation.workoutActivityType.rawValue
    }
  }
  
  public final var duration: Quantity {
    @inline(__always)
    get {
      return self.__implementation.duration
    }
  }
  
  public final var totalEnergyBurned: bridge.std__optional_Quantity_ {
    @inline(__always)
    get {
      return { () -> bridge.std__optional_Quantity_ in
        if let __unwrappedValue = self.__implementation.totalEnergyBurned {
          return bridge.create_std__optional_Quantity_(__unwrappedValue)
        } else {
          return .init()
        }
      }()
    }
  }
  
  public final var totalDistance: bridge.std__optional_Quantity_ {
    @inline(__always)
    get {
      return { () -> bridge.std__optional_Quantity_ in
        if let __unwrappedValue = self.__implementation.totalDistance {
          return bridge.create_std__optional_Quantity_(__unwrappedValue)
        } else {
          return .init()
        }
      }()
    }
  }
  
  public final var totalSwimmingStrokeCount: bridge.std__optional_Quantity_ {
    @inline(__always)
    get {
      return { () -> bridge.std__optional_Quantity_ in
        if let __unwrappedValue = self.__implementation.totalSwimmingStrokeCount {
          return bridge.create_std__optional_Quantity_(__unwrappedValue)
        } else {
          return .init()
        }
      }()
    }
  }
  
  public final var totalFlightsClimbed: bridge.std__optional_Quantity_ {
    @inline(__always)
    get {
      return { () -> bridge.std__optional_Quantity_ in
        if let __unwrappedValue = self.__implementation.totalFlightsClimbed {
          return bridge.create_std__optional_Quantity_(__unwrappedValue)
        } else {
          return .init()
        }
      }()
    }
  }
  
  public final var events: bridge.std__optional_std__vector_WorkoutEvent__ {
    @inline(__always)
    get {
      return { () -> bridge.std__optional_std__vector_WorkoutEvent__ in
        if let __unwrappedValue = self.__implementation.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()
        }
      }()
    }
  }
  
  public final var activities: bridge.std__optional_std__vector_WorkoutActivity__ {
    @inline(__always)
    get {
      return { () -> bridge.std__optional_std__vector_WorkoutActivity__ in
        if let __unwrappedValue = self.__implementation.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()
        }
      }()
    }
  }
  
  public final var metadata: margelo.nitro.SharedAnyMap {
    @inline(__always)
    get {
      return self.__implementation.metadata.cppPart
    }
  }
  
  public final var sampleType: SampleType {
    @inline(__always)
    get {
      return self.__implementation.sampleType
    }
  }
  
  public final var startDate: margelo.nitro.chrono_time {
    @inline(__always)
    get {
      return self.__implementation.startDate.toCpp()
    }
  }
  
  public final var endDate: margelo.nitro.chrono_time {
    @inline(__always)
    get {
      return self.__implementation.endDate.toCpp()
    }
  }
  
  public final var hasUndeterminedDuration: Bool {
    @inline(__always)
    get {
      return self.__implementation.hasUndeterminedDuration
    }
  }
  
  public final var uuid: std.string {
    @inline(__always)
    get {
      return std.string(self.__implementation.uuid)
    }
  }
  
  public final var sourceRevision: SourceRevision {
    @inline(__always)
    get {
      return self.__implementation.sourceRevision
    }
  }
  
  public final var device: bridge.std__optional_Device_ {
    @inline(__always)
    get {
      return { () -> bridge.std__optional_Device_ in
        if let __unwrappedValue = self.__implementation.device {
          return bridge.create_std__optional_Device_(__unwrappedValue)
        } else {
          return .init()
        }
      }()
    }
  }

  // Methods
  @inline(__always)
  public final func toJSON(key: bridge.std__optional_std__string_) -> bridge.Result_WorkoutSample_ {
    do {
      let __result = try self.__implementation.toJSON(key: { () -> String? in
        if bridge.has_value_std__optional_std__string_(key) {
          let __unwrapped = bridge.get_std__optional_std__string_(key)
          return String(__unwrapped)
        } else {
          return nil
        }
      }())
      let __resultCpp = __result
      return bridge.create_Result_WorkoutSample_(__resultCpp)
    } catch (let __error) {
      let __exceptionPtr = __error.toCpp()
      return bridge.create_Result_WorkoutSample_(__exceptionPtr)
    }
  }
  
  @inline(__always)
  public final func saveWorkoutRoute(locations: bridge.std__vector_LocationForSaving_) -> bridge.Result_std__shared_ptr_Promise_bool___ {
    do {
      let __result = try self.__implementation.saveWorkoutRoute(locations: locations.map({ __item in __item }))
      let __resultCpp = { () -> bridge.std__shared_ptr_Promise_bool__ in
        let __promise = bridge.create_std__shared_ptr_Promise_bool__()
        let __promiseHolder = bridge.wrap_std__shared_ptr_Promise_bool__(__promise)
        __result
          .then({ __result in __promiseHolder.resolve(__result) })
          .catch({ __error in __promiseHolder.reject(__error.toCpp()) })
        return __promise
      }()
      return bridge.create_Result_std__shared_ptr_Promise_bool___(__resultCpp)
    } catch (let __error) {
      let __exceptionPtr = __error.toCpp()
      return bridge.create_Result_std__shared_ptr_Promise_bool___(__exceptionPtr)
    }
  }
  
  @inline(__always)
  public final func getWorkoutPlan() -> bridge.Result_std__shared_ptr_Promise_std__optional_WorkoutPlan____ {
    do {
      let __result = try self.__implementation.getWorkoutPlan()
      let __resultCpp = { () -> bridge.std__shared_ptr_Promise_std__optional_WorkoutPlan___ in
        let __promise = bridge.create_std__shared_ptr_Promise_std__optional_WorkoutPlan___()
        let __promiseHolder = bridge.wrap_std__shared_ptr_Promise_std__optional_WorkoutPlan___(__promise)
        __result
          .then({ __result in __promiseHolder.resolve({ () -> bridge.std__optional_WorkoutPlan_ in
              if let __unwrappedValue = __result {
                return bridge.create_std__optional_WorkoutPlan_(__unwrappedValue)
              } else {
                return .init()
              }
            }()) })
          .catch({ __error in __promiseHolder.reject(__error.toCpp()) })
        return __promise
      }()
      return bridge.create_Result_std__shared_ptr_Promise_std__optional_WorkoutPlan____(__resultCpp)
    } catch (let __error) {
      let __exceptionPtr = __error.toCpp()
      return bridge.create_Result_std__shared_ptr_Promise_std__optional_WorkoutPlan____(__exceptionPtr)
    }
  }
  
  @inline(__always)
  public final func getWorkoutRoutes() -> bridge.Result_std__shared_ptr_Promise_std__vector_WorkoutRoute____ {
    do {
      let __result = try self.__implementation.getWorkoutRoutes()
      let __resultCpp = { () -> bridge.std__shared_ptr_Promise_std__vector_WorkoutRoute___ in
        let __promise = bridge.create_std__shared_ptr_Promise_std__vector_WorkoutRoute___()
        let __promiseHolder = bridge.wrap_std__shared_ptr_Promise_std__vector_WorkoutRoute___(__promise)
        __result
          .then({ __result in __promiseHolder.resolve({ () -> bridge.std__vector_WorkoutRoute_ in
              var __vector = bridge.create_std__vector_WorkoutRoute_(__result.count)
              for __item in __result {
                __vector.push_back(__item)
              }
              return __vector
            }()) })
          .catch({ __error in __promiseHolder.reject(__error.toCpp()) })
        return __promise
      }()
      return bridge.create_Result_std__shared_ptr_Promise_std__vector_WorkoutRoute____(__resultCpp)
    } catch (let __error) {
      let __exceptionPtr = __error.toCpp()
      return bridge.create_Result_std__shared_ptr_Promise_std__vector_WorkoutRoute____(__exceptionPtr)
    }
  }
  
  @inline(__always)
  public final func getStatistic(quantityType: Int32, unitOverride: bridge.std__optional_std__string_) -> bridge.Result_std__shared_ptr_Promise_std__optional_QueryStatisticsResponse____ {
    do {
      let __result = try self.__implementation.getStatistic(quantityType: margelo.nitro.healthkit.QuantityTypeIdentifier(rawValue: quantityType)!, unitOverride: { () -> String? in
        if bridge.has_value_std__optional_std__string_(unitOverride) {
          let __unwrapped = bridge.get_std__optional_std__string_(unitOverride)
          return String(__unwrapped)
        } else {
          return nil
        }
      }())
      let __resultCpp = { () -> bridge.std__shared_ptr_Promise_std__optional_QueryStatisticsResponse___ in
        let __promise = bridge.create_std__shared_ptr_Promise_std__optional_QueryStatisticsResponse___()
        let __promiseHolder = bridge.wrap_std__shared_ptr_Promise_std__optional_QueryStatisticsResponse___(__promise)
        __result
          .then({ __result in __promiseHolder.resolve({ () -> bridge.std__optional_QueryStatisticsResponse_ in
              if let __unwrappedValue = __result {
                return bridge.create_std__optional_QueryStatisticsResponse_(__unwrappedValue)
              } else {
                return .init()
              }
            }()) })
          .catch({ __error in __promiseHolder.reject(__error.toCpp()) })
        return __promise
      }()
      return bridge.create_Result_std__shared_ptr_Promise_std__optional_QueryStatisticsResponse____(__resultCpp)
    } catch (let __error) {
      let __exceptionPtr = __error.toCpp()
      return bridge.create_Result_std__shared_ptr_Promise_std__optional_QueryStatisticsResponse____(__exceptionPtr)
    }
  }
  
  @inline(__always)
  public final func getAllStatistics() -> bridge.Result_std__shared_ptr_Promise_std__unordered_map_std__string__QueryStatisticsResponse____ {
    do {
      let __result = try self.__implementation.getAllStatistics()
      let __resultCpp = { () -> bridge.std__shared_ptr_Promise_std__unordered_map_std__string__QueryStatisticsResponse___ in
        let __promise = bridge.create_std__shared_ptr_Promise_std__unordered_map_std__string__QueryStatisticsResponse___()
        let __promiseHolder = bridge.wrap_std__shared_ptr_Promise_std__unordered_map_std__string__QueryStatisticsResponse___(__promise)
        __result
          .then({ __result in __promiseHolder.resolve({ () -> bridge.std__unordered_map_std__string__QueryStatisticsResponse_ in
              var __map = bridge.create_std__unordered_map_std__string__QueryStatisticsResponse_(__result.count)
              for (__k, __v) in __result {
                bridge.emplace_std__unordered_map_std__string__QueryStatisticsResponse_(&__map, std.string(__k), __v)
              }
              return __map
            }()) })
          .catch({ __error in __promiseHolder.reject(__error.toCpp()) })
        return __promise
      }()
      return bridge.create_Result_std__shared_ptr_Promise_std__unordered_map_std__string__QueryStatisticsResponse____(__resultCpp)
    } catch (let __error) {
      let __exceptionPtr = __error.toCpp()
      return bridge.create_Result_std__shared_ptr_Promise_std__unordered_map_std__string__QueryStatisticsResponse____(__exceptionPtr)
    }
  }
}
