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

/**
 * Represents the JS union `HapticTypes`, backed by a C++ enum.
 */
public typealias HapticTypes = margelo.nitro.stylesheet.HapticTypes

public extension HapticTypes {
  /**
   * Get a HapticTypes for the given String value, or
   * return `nil` if the given value was invalid/unknown.
   */
  init?(fromString string: String) {
    switch string {
      case "light":
        self = .light
      case "select":
        self = .select
      case "success":
        self = .success
      case "warning":
        self = .warning
      case "error":
        self = .error
      case "medium":
        self = .medium
      case "heavy":
        self = .heavy
      case "soft":
        self = .soft
      case "rigid":
        self = .rigid
      default:
        return nil
    }
  }

  /**
   * Get the String value this HapticTypes represents.
   */
  var stringValue: String {
    switch self {
      case .light:
        return "light"
      case .select:
        return "select"
      case .success:
        return "success"
      case .warning:
        return "warning"
      case .error:
        return "error"
      case .medium:
        return "medium"
      case .heavy:
        return "heavy"
      case .soft:
        return "soft"
      case .rigid:
        return "rigid"
    }
  }
}
