{-# LANGUAGE PatternSynonyms #-}
-- For HasCallStack compatibility
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.WebKitMediaKeyNeededEvent
       (newWebKitMediaKeyNeededEvent, getInitData,
        WebKitMediaKeyNeededEvent(..), gTypeWebKitMediaKeyNeededEvent)
       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

-- | <https://developer.mozilla.org/en-US/docs/Web/API/WebKitMediaKeyNeededEvent Mozilla WebKitMediaKeyNeededEvent documentation> 
newWebKitMediaKeyNeededEvent ::
                             (MonadDOM m, ToJSString type') =>
                               type' ->
                                 Maybe WebKitMediaKeyNeededEventInit -> m WebKitMediaKeyNeededEvent
newWebKitMediaKeyNeededEvent :: forall (m :: * -> *) type'.
(MonadDOM m, ToJSString type') =>
type'
-> Maybe WebKitMediaKeyNeededEventInit
-> m WebKitMediaKeyNeededEvent
newWebKitMediaKeyNeededEvent type'
type' Maybe WebKitMediaKeyNeededEventInit
eventInitDict
  = DOM WebKitMediaKeyNeededEvent -> m WebKitMediaKeyNeededEvent
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
      (JSVal -> WebKitMediaKeyNeededEvent
WebKitMediaKeyNeededEvent (JSVal -> WebKitMediaKeyNeededEvent)
-> JSM JSVal -> DOM WebKitMediaKeyNeededEvent
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
"WebKitMediaKeyNeededEvent")
           [type' -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal type'
type', Maybe WebKitMediaKeyNeededEventInit -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Maybe WebKitMediaKeyNeededEventInit
eventInitDict])

-- | <https://developer.mozilla.org/en-US/docs/Web/API/WebKitMediaKeyNeededEvent.initData Mozilla WebKitMediaKeyNeededEvent.initData documentation> 
getInitData ::
            (MonadDOM m) => WebKitMediaKeyNeededEvent -> m Uint8Array
getInitData :: forall (m :: * -> *).
MonadDOM m =>
WebKitMediaKeyNeededEvent -> m Uint8Array
getInitData WebKitMediaKeyNeededEvent
self
  = DOM Uint8Array -> m Uint8Array
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((WebKitMediaKeyNeededEvent
self WebKitMediaKeyNeededEvent
-> Getting (JSM JSVal) WebKitMediaKeyNeededEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String
-> IndexPreservingGetter WebKitMediaKeyNeededEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js String
"initData") JSM JSVal -> (JSVal -> DOM Uint8Array) -> DOM Uint8Array
forall a b. JSM a -> (a -> JSM b) -> JSM b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM Uint8Array
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)