{-# LANGUAGE PatternSynonyms #-}
-- For HasCallStack compatibility
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.MutationObserver
       (newMutationObserver, observe, disconnect, takeRecords,
        takeRecords_, MutationObserver(..), gTypeMutationObserver)
       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/MutationObserver Mozilla MutationObserver documentation> 
newMutationObserver ::
                    (MonadDOM m, IsMutationCallback callback) =>
                      callback -> m MutationObserver
newMutationObserver :: callback -> m MutationObserver
newMutationObserver callback
callback
  = DOM MutationObserver -> m MutationObserver
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
      (JSVal -> MutationObserver
MutationObserver (JSVal -> MutationObserver) -> JSM JSVal -> DOM MutationObserver
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 ([Char] -> JSM JSVal
forall a. ToJSString a => a -> JSM JSVal
jsg [Char]
"MutationObserver") [callback -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal callback
callback])

-- | <https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver.observe Mozilla MutationObserver.observe documentation> 
observe ::
        (MonadDOM m, IsNode target) =>
          MutationObserver -> target -> Maybe MutationObserverInit -> m ()
observe :: MutationObserver -> target -> Maybe MutationObserverInit -> m ()
observe MutationObserver
self target
target Maybe MutationObserverInit
options
  = DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
      (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (MutationObserver
self MutationObserver
-> Getting (JSM JSVal) MutationObserver (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char] -> [JSM JSVal] -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf [Char]
"observe" [target -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal target
target, Maybe MutationObserverInit -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Maybe MutationObserverInit
options]))

-- | <https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver.disconnect Mozilla MutationObserver.disconnect documentation> 
disconnect :: (MonadDOM m) => MutationObserver -> m ()
disconnect :: MutationObserver -> m ()
disconnect MutationObserver
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 (MutationObserver
self MutationObserver
-> Getting (JSM JSVal) MutationObserver (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char] -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf [Char]
"disconnect" ()))

-- | <https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver.takeRecords Mozilla MutationObserver.takeRecords documentation> 
takeRecords ::
            (MonadDOM m) => MutationObserver -> m [MutationRecord]
takeRecords :: MutationObserver -> m [MutationRecord]
takeRecords MutationObserver
self
  = DOM [MutationRecord] -> m [MutationRecord]
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((MutationObserver
self MutationObserver
-> Getting (JSM JSVal) MutationObserver (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char] -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf [Char]
"takeRecords" ()) JSM JSVal
-> (JSVal -> DOM [MutationRecord]) -> DOM [MutationRecord]
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM [MutationRecord]
forall o. FromJSVal o => JSVal -> JSM [o]
fromJSArrayUnchecked)

-- | <https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver.takeRecords Mozilla MutationObserver.takeRecords documentation> 
takeRecords_ :: (MonadDOM m) => MutationObserver -> m ()
takeRecords_ :: MutationObserver -> m ()
takeRecords_ MutationObserver
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 (MutationObserver
self MutationObserver
-> Getting (JSM JSVal) MutationObserver (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char] -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf [Char]
"takeRecords" ()))