{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.Worker
(newWorker, terminate, postMessage, message, Worker(..),
gTypeWorker)
where
import Prelude ((.), (==), (>>=), return, IO, Int, Float, Double, Bool(..), Maybe, maybe, fromIntegral, round, realToFrac, fmap, Show, Read, Eq, Ord, Maybe(..))
import qualified Prelude (error)
import Data.Typeable (Typeable)
import Data.Traversable (mapM)
import Language.Javascript.JSaddle (JSM(..), JSVal(..), JSString, strictEqual, toJSVal, valToStr, valToNumber, valToBool, js, jss, jsf, jsg, function, asyncFunction, new, array, jsUndefined, (!), (!!))
import Data.Int (Int64)
import Data.Word (Word, Word64)
import JSDOM.Types
import Control.Applicative ((<$>))
import Control.Monad (void)
import Control.Lens.Operators ((^.))
import JSDOM.EventTargetClosures (EventName, unsafeEventName, unsafeEventNameAsync)
import JSDOM.Enums
newWorker ::
(MonadDOM m, ToJSString scriptUrl) => scriptUrl -> m Worker
newWorker :: forall (m :: * -> *) scriptUrl.
(MonadDOM m, ToJSString scriptUrl) =>
scriptUrl -> m Worker
newWorker scriptUrl
scriptUrl
= DOM Worker -> m Worker
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSVal -> Worker
Worker (JSVal -> Worker) -> JSM JSVal -> DOM Worker
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> JSM JSVal -> [JSM JSVal] -> JSM JSVal
forall constructor args.
(MakeObject constructor, MakeArgs args) =>
constructor -> args -> JSM JSVal
new (String -> JSM JSVal
forall a. ToJSString a => a -> JSM JSVal
jsg String
"Worker") [scriptUrl -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal scriptUrl
scriptUrl])
terminate :: (MonadDOM m) => Worker -> m ()
terminate :: forall (m :: * -> *). MonadDOM m => Worker -> m ()
terminate Worker
self = DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (Worker
self Worker -> Getting (JSM JSVal) Worker (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"terminate" ()))
postMessage ::
(MonadDOM m, ToJSVal message, IsGObject transfer) =>
Worker -> message -> [transfer] -> m ()
postMessage :: forall (m :: * -> *) message transfer.
(MonadDOM m, ToJSVal message, IsGObject transfer) =>
Worker -> message -> [transfer] -> m ()
postMessage Worker
self message
message [transfer]
transfer
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void
(Worker
self Worker -> Getting (JSM JSVal) Worker (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> [JSM JSVal] -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"postMessage"
[message -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal message
message, JSM Object -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal ([transfer] -> JSM Object
forall args. MakeArgs args => args -> JSM Object
array [transfer]
transfer)]))
message :: EventName Worker MessageEvent
message :: EventName Worker MessageEvent
message = DOMString -> EventName Worker MessageEvent
forall t e. DOMString -> EventName t e
unsafeEventNameAsync (String -> DOMString
forall a. ToJSString a => a -> DOMString
toJSString String
"message")