{-# LANGUAGE PatternSynonyms #-}
-- For HasCallStack compatibility
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.RTCPeerConnectionIceEvent
       (getCandidate, getCandidateUnsafe, getCandidateUnchecked,
        RTCPeerConnectionIceEvent(..), gTypeRTCPeerConnectionIceEvent)
       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/RTCPeerConnectionIceEvent.candidate Mozilla RTCPeerConnectionIceEvent.candidate documentation> 
getCandidate ::
             (MonadDOM m) =>
               RTCPeerConnectionIceEvent -> m (Maybe RTCIceCandidate)
getCandidate :: RTCPeerConnectionIceEvent -> m (Maybe RTCIceCandidate)
getCandidate RTCPeerConnectionIceEvent
self
  = DOM (Maybe RTCIceCandidate) -> m (Maybe RTCIceCandidate)
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((RTCPeerConnectionIceEvent
self RTCPeerConnectionIceEvent
-> Getting (JSM JSVal) RTCPeerConnectionIceEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter RTCPeerConnectionIceEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"candidate") JSM JSVal
-> (JSVal -> DOM (Maybe RTCIceCandidate))
-> DOM (Maybe RTCIceCandidate)
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM (Maybe RTCIceCandidate)
forall a. FromJSVal a => JSVal -> JSM (Maybe a)
fromJSVal)

-- | <https://developer.mozilla.org/en-US/docs/Web/API/RTCPeerConnectionIceEvent.candidate Mozilla RTCPeerConnectionIceEvent.candidate documentation> 
getCandidateUnsafe ::
                   (MonadDOM m, HasCallStack) =>
                     RTCPeerConnectionIceEvent -> m RTCIceCandidate
getCandidateUnsafe :: RTCPeerConnectionIceEvent -> m RTCIceCandidate
getCandidateUnsafe RTCPeerConnectionIceEvent
self
  = DOM RTCIceCandidate -> m RTCIceCandidate
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
      (((RTCPeerConnectionIceEvent
self RTCPeerConnectionIceEvent
-> Getting (JSM JSVal) RTCPeerConnectionIceEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter RTCPeerConnectionIceEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"candidate") JSM JSVal
-> (JSVal -> DOM (Maybe RTCIceCandidate))
-> DOM (Maybe RTCIceCandidate)
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM (Maybe RTCIceCandidate)
forall a. FromJSVal a => JSVal -> JSM (Maybe a)
fromJSVal) DOM (Maybe RTCIceCandidate)
-> (Maybe RTCIceCandidate -> DOM RTCIceCandidate)
-> DOM RTCIceCandidate
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>=
         DOM RTCIceCandidate
-> (RTCIceCandidate -> DOM RTCIceCandidate)
-> Maybe RTCIceCandidate
-> DOM RTCIceCandidate
forall b a. b -> (a -> b) -> Maybe a -> b
maybe ([Char] -> DOM RTCIceCandidate
forall a. HasCallStack => [Char] -> a
Prelude.error [Char]
"Nothing to return") RTCIceCandidate -> DOM RTCIceCandidate
forall (m :: * -> *) a. Monad m => a -> m a
return)

-- | <https://developer.mozilla.org/en-US/docs/Web/API/RTCPeerConnectionIceEvent.candidate Mozilla RTCPeerConnectionIceEvent.candidate documentation> 
getCandidateUnchecked ::
                      (MonadDOM m) => RTCPeerConnectionIceEvent -> m RTCIceCandidate
getCandidateUnchecked :: RTCPeerConnectionIceEvent -> m RTCIceCandidate
getCandidateUnchecked RTCPeerConnectionIceEvent
self
  = DOM RTCIceCandidate -> m RTCIceCandidate
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((RTCPeerConnectionIceEvent
self RTCPeerConnectionIceEvent
-> Getting (JSM JSVal) RTCPeerConnectionIceEvent (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter RTCPeerConnectionIceEvent (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"candidate") JSM JSVal -> (JSVal -> DOM RTCIceCandidate) -> DOM RTCIceCandidate
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM RTCIceCandidate
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)