{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.UIEvent
(newUIEvent, initUIEvent, getView, getDetail, getLayerX, getLayerY,
getPageX, getPageY, getWhich, UIEvent(..), gTypeUIEvent, IsUIEvent,
toUIEvent)
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.Enums
newUIEvent ::
(MonadDOM m, ToJSString type', IsUIEventInit eventInitDict) =>
type' -> Maybe eventInitDict -> m UIEvent
newUIEvent type' eventInitDict
= liftDOM
(UIEvent <$>
new (jsg "UIEvent") [toJSVal type', toJSVal eventInitDict])
initUIEvent ::
(MonadDOM m, IsUIEvent self, ToJSString type') =>
self ->
Maybe type' -> Bool -> Bool -> Maybe Window -> Maybe Int -> m ()
initUIEvent self type' canBubble cancelable view detail
= liftDOM
(void
((toUIEvent self) ^. jsf "initUIEvent"
[toJSVal type', toJSVal canBubble, toJSVal cancelable,
toJSVal view, toJSVal detail]))
getView :: (MonadDOM m, IsUIEvent self) => self -> m Window
getView self
= liftDOM (((toUIEvent self) ^. js "view") >>= fromJSValUnchecked)
getDetail :: (MonadDOM m, IsUIEvent self) => self -> m Int
getDetail self
= liftDOM
(round <$> (((toUIEvent self) ^. js "detail") >>= valToNumber))
getLayerX :: (MonadDOM m, IsUIEvent self) => self -> m Int
getLayerX self
= liftDOM
(round <$> (((toUIEvent self) ^. js "layerX") >>= valToNumber))
getLayerY :: (MonadDOM m, IsUIEvent self) => self -> m Int
getLayerY self
= liftDOM
(round <$> (((toUIEvent self) ^. js "layerY") >>= valToNumber))
getPageX :: (MonadDOM m, IsUIEvent self) => self -> m Int
getPageX self
= liftDOM
(round <$> (((toUIEvent self) ^. js "pageX") >>= valToNumber))
getPageY :: (MonadDOM m, IsUIEvent self) => self -> m Int
getPageY self
= liftDOM
(round <$> (((toUIEvent self) ^. js "pageY") >>= valToNumber))
getWhich :: (MonadDOM m, IsUIEvent self) => self -> m Int
getWhich self
= liftDOM
(round <$> (((toUIEvent self) ^. js "which") >>= valToNumber))