summaryrefslogtreecommitdiff
path: root/lore/Biz
diff options
context:
space:
mode:
Diffstat (limited to 'lore/Biz')
-rw-r--r--lore/Biz/Ibb/Core.hs9
-rw-r--r--lore/Biz/Ibb/Move.hs7
2 files changed, 5 insertions, 11 deletions
diff --git a/lore/Biz/Ibb/Core.hs b/lore/Biz/Ibb/Core.hs
index 4ec87e3..39f506c 100644
--- a/lore/Biz/Ibb/Core.hs
+++ b/lore/Biz/Ibb/Core.hs
@@ -6,9 +6,9 @@ module Biz.Ibb.Core where
import Alpha
import Biz.Ibb.Influencers
-import Data.Proxy
import Miso
import Miso.String
+import Network.RemoteData
import Servant.API
import Servant.Links
@@ -21,13 +21,6 @@ data Model = Model
, people :: WebData [Person]
} deriving (Show, Eq)
-data RemoteData e a
- = NotAsked
- | Loading
- | Failure e
- | Success a
- deriving (Show, Eq)
-
type WebData a = RemoteData MisoString a
init :: URI -> Model
diff --git a/lore/Biz/Ibb/Move.hs b/lore/Biz/Ibb/Move.hs
index 291e015..ea3904d 100644
--- a/lore/Biz/Ibb/Move.hs
+++ b/lore/Biz/Ibb/Move.hs
@@ -16,6 +16,7 @@ import Biz.Ibb.Core as Core
import JavaScript.Web.XMLHttpRequest (Request(..), Method(GET), RequestData(NoData), contents, xhrByteString)
import Miso
import Miso.String
+import Network.RemoteData
move :: Action -> Model -> Effect Action Model
move Nop m = noEff m
@@ -29,9 +30,9 @@ fetchPeople = do
mjson <- contents /@ xhrByteString req
case mjson of
Nothing -> pure $ Failure "could not read from server"
- Just json -> pure
- $ either (Failure . ms) Core.Success
- $ eitherDecodeStrict json
+ Just a -> pure
+ $ either (Failure . ms) Network.RemoteData.Success
+ $ eitherDecodeStrict a
where
req = Request { reqMethod = GET
, reqURI = "/api/people" -- FIXME: can replace this hardcoding with a function?