module GHCJS.DOM.JSFFI.Generated.EventTarget
(js_addEventListener, addEventListener, js_removeEventListener,
removeEventListener, js_dispatchEvent, dispatchEvent,
dispatchEvent_, EventTarget(..), gTypeEventTarget, IsEventTarget,
toEventTarget)
where
import Prelude ((.), (==), (>>=), return, IO, Int, Float, Double, Bool(..), Maybe, maybe, fromIntegral, round, fmap, Show, Read, Eq, Ord)
import qualified Prelude (error)
import Data.Typeable (Typeable)
import GHCJS.Types (JSVal(..), JSString)
import GHCJS.Foreign (jsNull)
import GHCJS.Foreign.Callback (syncCallback, asyncCallback, syncCallback1, asyncCallback1, syncCallback2, asyncCallback2, OnBlocked(..))
import GHCJS.Marshal (ToJSVal(..), FromJSVal(..))
import GHCJS.Marshal.Pure (PToJSVal(..), PFromJSVal(..))
import Control.Monad (void)
import Control.Monad.IO.Class (MonadIO(..))
import Data.Int (Int64)
import Data.Word (Word, Word64)
import Data.Maybe (fromJust)
import GHCJS.DOM.Types
import Control.Applicative ((<$>))
import GHCJS.DOM.JSFFI.Generated.Enums
foreign import javascript unsafe
"$1[\"addEventListener\"]($2, $3,\n$4)" js_addEventListener ::
EventTarget -> JSString -> Nullable EventListener -> Bool -> IO ()
addEventListener ::
(MonadIO m, IsEventTarget self, ToJSString type') =>
self -> type' -> Maybe EventListener -> Bool -> m ()
addEventListener self type' listener useCapture
= liftIO
(js_addEventListener (toEventTarget self) (toJSString type')
(maybeToNullable listener)
useCapture)
foreign import javascript unsafe
"$1[\"removeEventListener\"]($2,\n$3, $4)" js_removeEventListener
::
EventTarget -> JSString -> Nullable EventListener -> Bool -> IO ()
removeEventListener ::
(MonadIO m, IsEventTarget self, ToJSString type') =>
self -> type' -> Maybe EventListener -> Bool -> m ()
removeEventListener self type' listener useCapture
= liftIO
(js_removeEventListener (toEventTarget self) (toJSString type')
(maybeToNullable listener)
useCapture)
foreign import javascript unsafe
"($1[\"dispatchEvent\"]($2) ? 1 : 0)" js_dispatchEvent ::
EventTarget -> Nullable Event -> IO Bool
dispatchEvent ::
(MonadIO m, IsEventTarget self, IsEvent event) =>
self -> Maybe event -> m Bool
dispatchEvent self event
= liftIO
(js_dispatchEvent (toEventTarget self)
(maybeToNullable (fmap toEvent event)))
dispatchEvent_ ::
(MonadIO m, IsEventTarget self, IsEvent event) =>
self -> Maybe event -> m ()
dispatchEvent_ self event
= liftIO
(void
(js_dispatchEvent (toEventTarget self)
(maybeToNullable (fmap toEvent event))))