module Web.Hyperbole.Effect.Client where
import Data.Aeson
import Data.Text (Text)
import Effectful
import Effectful.Dispatch.Dynamic
import Effectful.Reader.Dynamic
import Web.Hyperbole.Effect.Hyperbole
import Web.Hyperbole.HyperView
import Web.Hyperbole.Types.Client (clientSetPageTitle)
import Web.Hyperbole.Types.Event
trigger :: (HyperView id es, HyperViewHandled id view, Hyperbole :> es) => id -> Action id -> Eff (Reader view : es) ()
trigger :: forall id (es :: [Effect]) view.
(HyperView id es, HyperViewHandled id view, Hyperbole :> es) =>
id -> Action id -> Eff (Reader view : es) ()
trigger id
vid Action id
act = do
Hyperbole (Eff (Reader view : es)) () -> Eff (Reader view : es) ()
forall (e :: Effect) (es :: [Effect]) a.
(HasCallStack, DispatchOf e ~ 'Dynamic, e :> es) =>
e (Eff es) a -> Eff es a
send (Hyperbole (Eff (Reader view : es)) ()
-> Eff (Reader view : es) ())
-> Hyperbole (Eff (Reader view : es)) ()
-> Eff (Reader view : es) ()
forall a b. (a -> b) -> a -> b
$ TargetViewId -> Encoded -> Hyperbole (Eff (Reader view : es)) ()
forall (a :: * -> *). TargetViewId -> Encoded -> Hyperbole a ()
TriggerAction (Text -> TargetViewId
TargetViewId (Text -> TargetViewId) -> Text -> TargetViewId
forall a b. (a -> b) -> a -> b
$ id -> Text
forall id. ViewId id => id -> Text
encodeViewId id
vid) (Action id -> Encoded
forall a. ViewAction a => a -> Encoded
toAction Action id
act)
pushEvent :: (ToJSON a, Hyperbole :> es) => Text -> a -> Eff es ()
pushEvent :: forall a (es :: [Effect]).
(ToJSON a, Hyperbole :> es) =>
Text -> a -> Eff es ()
pushEvent Text
nm a
a = do
Hyperbole (Eff es) () -> Eff es ()
forall (e :: Effect) (es :: [Effect]) a.
(HasCallStack, DispatchOf e ~ 'Dynamic, e :> es) =>
e (Eff es) a -> Eff es a
send (Hyperbole (Eff es) () -> Eff es ())
-> Hyperbole (Eff es) () -> Eff es ()
forall a b. (a -> b) -> a -> b
$ Text -> Value -> Hyperbole (Eff es) ()
forall (a :: * -> *). Text -> Value -> Hyperbole a ()
TriggerEvent Text
nm (a -> Value
forall a. ToJSON a => a -> Value
toJSON a
a)
pageTitle :: (Hyperbole :> es) => Text -> Eff es ()
pageTitle :: forall (es :: [Effect]). (Hyperbole :> es) => Text -> Eff es ()
pageTitle Text
t = do
Hyperbole (Eff es) () -> Eff es ()
forall (e :: Effect) (es :: [Effect]) a.
(HasCallStack, DispatchOf e ~ 'Dynamic, e :> es) =>
e (Eff es) a -> Eff es a
send (Hyperbole (Eff es) () -> Eff es ())
-> Hyperbole (Eff es) () -> Eff es ()
forall a b. (a -> b) -> a -> b
$ (Client -> Client) -> Hyperbole (Eff es) ()
forall (a :: * -> *). (Client -> Client) -> Hyperbole a ()
ModClient ((Client -> Client) -> Hyperbole (Eff es) ())
-> (Client -> Client) -> Hyperbole (Eff es) ()
forall a b. (a -> b) -> a -> b
$ Text -> Client -> Client
clientSetPageTitle Text
t