From 6f6e3d8ec76c59d6f403725e9b2a22b8f6680714 Mon Sep 17 00:00:00 2001 From: Igor Pashev Date: Wed, 7 Jun 2017 16:24:05 +0300 Subject: Initial version 0.0.0 --- lib/Web/OpenWeatherMap/Types/Clouds.hs | 16 ++++++++++++ lib/Web/OpenWeatherMap/Types/Coord.hs | 17 +++++++++++++ lib/Web/OpenWeatherMap/Types/CurrentWeather.hs | 35 ++++++++++++++++++++++++++ lib/Web/OpenWeatherMap/Types/Main.hs | 23 +++++++++++++++++ lib/Web/OpenWeatherMap/Types/Sys.hs | 19 ++++++++++++++ lib/Web/OpenWeatherMap/Types/Weather.hs | 19 ++++++++++++++ lib/Web/OpenWeatherMap/Types/Wind.hs | 17 +++++++++++++ 7 files changed, 146 insertions(+) create mode 100644 lib/Web/OpenWeatherMap/Types/Clouds.hs create mode 100644 lib/Web/OpenWeatherMap/Types/Coord.hs create mode 100644 lib/Web/OpenWeatherMap/Types/CurrentWeather.hs create mode 100644 lib/Web/OpenWeatherMap/Types/Main.hs create mode 100644 lib/Web/OpenWeatherMap/Types/Sys.hs create mode 100644 lib/Web/OpenWeatherMap/Types/Weather.hs create mode 100644 lib/Web/OpenWeatherMap/Types/Wind.hs (limited to 'lib/Web/OpenWeatherMap/Types') diff --git a/lib/Web/OpenWeatherMap/Types/Clouds.hs b/lib/Web/OpenWeatherMap/Types/Clouds.hs new file mode 100644 index 0000000..78a6e97 --- /dev/null +++ b/lib/Web/OpenWeatherMap/Types/Clouds.hs @@ -0,0 +1,16 @@ +{-# LANGUAGE DeriveAnyClass #-} +{-# LANGUAGE DeriveGeneric #-} + +module Web.OpenWeatherMap.Types.Clouds ( + Clouds(..) +) where + +import GHC.Generics (Generic) + +import Data.Aeson (FromJSON) + + +data Clouds = Clouds + { all :: Double + } deriving (Show, Generic, FromJSON) + diff --git a/lib/Web/OpenWeatherMap/Types/Coord.hs b/lib/Web/OpenWeatherMap/Types/Coord.hs new file mode 100644 index 0000000..d9a9f21 --- /dev/null +++ b/lib/Web/OpenWeatherMap/Types/Coord.hs @@ -0,0 +1,17 @@ +{-# LANGUAGE DeriveAnyClass #-} +{-# LANGUAGE DeriveGeneric #-} + +module Web.OpenWeatherMap.Types.Coord ( + Coord(..) +) where + +import GHC.Generics (Generic) + +import Data.Aeson (FromJSON) + + +data Coord = Coord + { lon :: Double + , lat :: Double + } deriving (Show, Generic, FromJSON) + diff --git a/lib/Web/OpenWeatherMap/Types/CurrentWeather.hs b/lib/Web/OpenWeatherMap/Types/CurrentWeather.hs new file mode 100644 index 0000000..26572a7 --- /dev/null +++ b/lib/Web/OpenWeatherMap/Types/CurrentWeather.hs @@ -0,0 +1,35 @@ +{-# LANGUAGE DeriveAnyClass #-} +{-# LANGUAGE DeriveGeneric #-} + +module Web.OpenWeatherMap.Types.CurrentWeather ( + CurrentWeather(..) +) where + +import Prelude hiding (id) +import GHC.Generics (Generic) + +import Data.Aeson (FromJSON) + +import Web.OpenWeatherMap.Types.Clouds (Clouds) +import Web.OpenWeatherMap.Types.Coord (Coord) +import Web.OpenWeatherMap.Types.Main (Main) +import Web.OpenWeatherMap.Types.Sys (Sys) +import Web.OpenWeatherMap.Types.Weather (Weather) +import Web.OpenWeatherMap.Types.Wind (Wind) + +-- | Response to requests for current weather. +-- Refer to . +data CurrentWeather = CurrentWeather + { coord :: Coord + , weather :: [Weather] + , base :: String + , main :: Main + , wind :: Wind + , clouds :: Clouds + , dt :: Int + , sys :: Sys + , id :: Int + , name :: String + , cod :: Int + } deriving (Show, Generic, FromJSON) + diff --git a/lib/Web/OpenWeatherMap/Types/Main.hs b/lib/Web/OpenWeatherMap/Types/Main.hs new file mode 100644 index 0000000..21b1951 --- /dev/null +++ b/lib/Web/OpenWeatherMap/Types/Main.hs @@ -0,0 +1,23 @@ +{-# LANGUAGE DeriveAnyClass #-} +{-# LANGUAGE DeriveGeneric #-} + +module Web.OpenWeatherMap.Types.Main ( + Main(..) +) where + +import GHC.Generics (Generic) + +import Data.Aeson (FromJSON) + + +{-# ANN module "HLint: ignore Use camelCase" #-} +data Main = Main + { temp :: Double + , pressure :: Double + , humidity :: Double + , temp_min :: Double + , temp_max :: Double + , sea_level :: Maybe Double + , grnd_level :: Maybe Double + } deriving (Show, Generic, FromJSON) + diff --git a/lib/Web/OpenWeatherMap/Types/Sys.hs b/lib/Web/OpenWeatherMap/Types/Sys.hs new file mode 100644 index 0000000..03b223c --- /dev/null +++ b/lib/Web/OpenWeatherMap/Types/Sys.hs @@ -0,0 +1,19 @@ +{-# LANGUAGE DeriveAnyClass #-} +{-# LANGUAGE DeriveGeneric #-} + +module Web.OpenWeatherMap.Types.Sys ( + Sys(..) +) where + +import GHC.Generics (Generic) + +import Data.Aeson (FromJSON) + + +data Sys = Sys + { message :: Double + , country :: Maybe String + , sunrise :: Int + , sunset :: Int + } deriving (Show, Generic, FromJSON) + diff --git a/lib/Web/OpenWeatherMap/Types/Weather.hs b/lib/Web/OpenWeatherMap/Types/Weather.hs new file mode 100644 index 0000000..090fe0f --- /dev/null +++ b/lib/Web/OpenWeatherMap/Types/Weather.hs @@ -0,0 +1,19 @@ +{-# LANGUAGE DeriveAnyClass #-} +{-# LANGUAGE DeriveGeneric #-} + +module Web.OpenWeatherMap.Types.Weather ( + Weather(..) +) where + +import GHC.Generics (Generic) + +import Data.Aeson (FromJSON) + + +data Weather = Weather + { id :: Int + , main :: String + , description :: String + , icon :: String + } deriving (Show, Generic, FromJSON) + diff --git a/lib/Web/OpenWeatherMap/Types/Wind.hs b/lib/Web/OpenWeatherMap/Types/Wind.hs new file mode 100644 index 0000000..8481e62 --- /dev/null +++ b/lib/Web/OpenWeatherMap/Types/Wind.hs @@ -0,0 +1,17 @@ +{-# LANGUAGE DeriveAnyClass #-} +{-# LANGUAGE DeriveGeneric #-} + +module Web.OpenWeatherMap.Types.Wind ( + Wind(..) +) where + +import GHC.Generics (Generic) + +import Data.Aeson (FromJSON) + + +data Wind = Wind + { speed :: Double + , deg :: Double + } deriving (Show, Generic, FromJSON) + -- cgit v1.2.3