-- Do not manually edit this file, it was auto-generated by dillonkearns/elm-graphql -- https://github.com/dillonkearns/elm-graphql module Github.Enum.SubscriptionState exposing (SubscriptionState(..), decoder, fromString, list, toString) import Json.Decode as Decode exposing (Decoder) {-| The possible states of a subscription. - Unsubscribed - The User is only notified when particpating or @mentioned. - Subscribed - The User is notified of all conversations. - Ignored - The User is never notified. - Unavailable - Subscriptions are currently unavailable -} type SubscriptionState = Unsubscribed | Subscribed | Ignored | Unavailable list : List SubscriptionState list = [ Unsubscribed, Subscribed, Ignored, Unavailable ] decoder : Decoder SubscriptionState decoder = Decode.string |> Decode.andThen (\string -> case string of "UNSUBSCRIBED" -> Decode.succeed Unsubscribed "SUBSCRIBED" -> Decode.succeed Subscribed "IGNORED" -> Decode.succeed Ignored "UNAVAILABLE" -> Decode.succeed Unavailable _ -> Decode.fail ("Invalid SubscriptionState type, " ++ string ++ " try re-running the @dillonkearns/elm-graphql CLI ") ) {-| Convert from the union type representating the Enum to a string that the GraphQL server will recognize. -} toString : SubscriptionState -> String toString enum = case enum of Unsubscribed -> "UNSUBSCRIBED" Subscribed -> "SUBSCRIBED" Ignored -> "IGNORED" Unavailable -> "UNAVAILABLE" {-| Convert from a String representation to an elm representation enum. This is the inverse of the Enum `toString` function. So you can call `toString` and then convert back `fromString` safely. Swapi.Enum.Episode.NewHope |> Swapi.Enum.Episode.toString |> Swapi.Enum.Episode.fromString == Just NewHope This can be useful for generating Strings to use for