-- | 'Strive.Actions.Streams'
module Strive.Options.Streams
  ( GetStreamsOptions(..)
  ) where

import Data.Default (Default, def)
import Network.HTTP.Types (QueryLike, toQuery)
import Strive.Enums (Resolution, SeriesType(Distance))

-- | 'Strive.Actions.getStreams'
data GetStreamsOptions = GetStreamsOptions
  { GetStreamsOptions -> Maybe Resolution
getStreamsOptions_resolution :: Maybe Resolution
  , GetStreamsOptions -> SeriesType
getStreamsOptions_seriesType :: SeriesType
  }
  deriving Int -> GetStreamsOptions -> ShowS
[GetStreamsOptions] -> ShowS
GetStreamsOptions -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetStreamsOptions] -> ShowS
$cshowList :: [GetStreamsOptions] -> ShowS
show :: GetStreamsOptions -> String
$cshow :: GetStreamsOptions -> String
showsPrec :: Int -> GetStreamsOptions -> ShowS
$cshowsPrec :: Int -> GetStreamsOptions -> ShowS
Show

instance Default GetStreamsOptions where
  def :: GetStreamsOptions
def = GetStreamsOptions
    { getStreamsOptions_resolution :: Maybe Resolution
getStreamsOptions_resolution = forall a. Maybe a
Nothing
    , getStreamsOptions_seriesType :: SeriesType
getStreamsOptions_seriesType = SeriesType
Distance
    }

instance QueryLike GetStreamsOptions where
  toQuery :: GetStreamsOptions -> Query
toQuery GetStreamsOptions
options = forall a. QueryLike a => a -> Query
toQuery
    [ (String
"resolution", forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap forall a. Show a => a -> String
show (GetStreamsOptions -> Maybe Resolution
getStreamsOptions_resolution GetStreamsOptions
options))
    , (String
"series_type", forall a. a -> Maybe a
Just (forall a. Show a => a -> String
show (GetStreamsOptions -> SeriesType
getStreamsOptions_seriesType GetStreamsOptions
options)))
    ]