{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.MediaStream
(newMediaStream, newMediaStream', newMediaStream'', getAudioTracks,
getAudioTracks_, getVideoTracks, getVideoTracks_, getTracks,
getTracks_, getTrackById, getTrackById_, addTrack, removeTrack,
clone, clone_, getId, getActive, addTrackEvent, removeTrackEvent,
active, inactive, MediaStream(..), gTypeMediaStream)
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
newMediaStream :: (MonadDOM m) => m MediaStream
newMediaStream :: forall (m :: * -> *). MonadDOM m => m MediaStream
newMediaStream
= DOM MediaStream -> m MediaStream
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSVal -> MediaStream
MediaStream (JSVal -> MediaStream) -> JSM JSVal -> DOM MediaStream
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> 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
"MediaStream") ())
newMediaStream' :: (MonadDOM m) => MediaStream -> m MediaStream
newMediaStream' :: forall (m :: * -> *). MonadDOM m => MediaStream -> m MediaStream
newMediaStream' MediaStream
stream
= DOM MediaStream -> m MediaStream
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(JSVal -> MediaStream
MediaStream (JSVal -> MediaStream) -> JSM JSVal -> DOM MediaStream
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
"MediaStream") [MediaStream -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal MediaStream
stream])
newMediaStream'' ::
(MonadDOM m, IsMediaStreamTrack tracks) =>
[tracks] -> m MediaStream
newMediaStream'' :: forall (m :: * -> *) tracks.
(MonadDOM m, IsMediaStreamTrack tracks) =>
[tracks] -> m MediaStream
newMediaStream'' [tracks]
tracks
= DOM MediaStream -> m MediaStream
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(JSVal -> MediaStream
MediaStream (JSVal -> MediaStream) -> JSM JSVal -> DOM MediaStream
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
"MediaStream") [JSM Object -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal ([tracks] -> JSM Object
forall args. MakeArgs args => args -> JSM Object
array [tracks]
tracks)])
getAudioTracks ::
(MonadDOM m) => MediaStream -> m [MediaStreamTrack]
getAudioTracks :: forall (m :: * -> *).
MonadDOM m =>
MediaStream -> m [MediaStreamTrack]
getAudioTracks MediaStream
self
= DOM [MediaStreamTrack] -> m [MediaStreamTrack]
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
((MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"getAudioTracks" ()) JSM JSVal
-> (JSVal -> DOM [MediaStreamTrack]) -> DOM [MediaStreamTrack]
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 [MediaStreamTrack]
forall o. FromJSVal o => JSVal -> JSM [o]
fromJSArrayUnchecked)
getAudioTracks_ :: (MonadDOM m) => MediaStream -> m ()
getAudioTracks_ :: forall (m :: * -> *). MonadDOM m => MediaStream -> m ()
getAudioTracks_ MediaStream
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 (MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"getAudioTracks" ()))
getVideoTracks ::
(MonadDOM m) => MediaStream -> m [MediaStreamTrack]
getVideoTracks :: forall (m :: * -> *).
MonadDOM m =>
MediaStream -> m [MediaStreamTrack]
getVideoTracks MediaStream
self
= DOM [MediaStreamTrack] -> m [MediaStreamTrack]
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
((MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"getVideoTracks" ()) JSM JSVal
-> (JSVal -> DOM [MediaStreamTrack]) -> DOM [MediaStreamTrack]
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 [MediaStreamTrack]
forall o. FromJSVal o => JSVal -> JSM [o]
fromJSArrayUnchecked)
getVideoTracks_ :: (MonadDOM m) => MediaStream -> m ()
getVideoTracks_ :: forall (m :: * -> *). MonadDOM m => MediaStream -> m ()
getVideoTracks_ MediaStream
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 (MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"getVideoTracks" ()))
getTracks :: (MonadDOM m) => MediaStream -> m [MediaStreamTrack]
getTracks :: forall (m :: * -> *).
MonadDOM m =>
MediaStream -> m [MediaStreamTrack]
getTracks MediaStream
self
= DOM [MediaStreamTrack] -> m [MediaStreamTrack]
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"getTracks" ()) JSM JSVal
-> (JSVal -> DOM [MediaStreamTrack]) -> DOM [MediaStreamTrack]
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 [MediaStreamTrack]
forall o. FromJSVal o => JSVal -> JSM [o]
fromJSArrayUnchecked)
getTracks_ :: (MonadDOM m) => MediaStream -> m ()
getTracks_ :: forall (m :: * -> *). MonadDOM m => MediaStream -> m ()
getTracks_ MediaStream
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 (MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"getTracks" ()))
getTrackById ::
(MonadDOM m, ToJSString trackId) =>
MediaStream -> trackId -> m MediaStreamTrack
getTrackById :: forall (m :: * -> *) trackId.
(MonadDOM m, ToJSString trackId) =>
MediaStream -> trackId -> m MediaStreamTrack
getTrackById MediaStream
self trackId
trackId
= DOM MediaStreamTrack -> m MediaStreamTrack
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
((MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> [JSM JSVal] -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"getTrackById" [trackId -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal trackId
trackId]) JSM JSVal
-> (JSVal -> DOM MediaStreamTrack) -> DOM MediaStreamTrack
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 MediaStreamTrack
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
getTrackById_ ::
(MonadDOM m, ToJSString trackId) => MediaStream -> trackId -> m ()
getTrackById_ :: forall (m :: * -> *) trackId.
(MonadDOM m, ToJSString trackId) =>
MediaStream -> trackId -> m ()
getTrackById_ MediaStream
self trackId
trackId
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> [JSM JSVal] -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"getTrackById" [trackId -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal trackId
trackId]))
addTrack ::
(MonadDOM m, IsMediaStreamTrack track) =>
MediaStream -> track -> m ()
addTrack :: forall (m :: * -> *) track.
(MonadDOM m, IsMediaStreamTrack track) =>
MediaStream -> track -> m ()
addTrack MediaStream
self track
track
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> [JSM JSVal] -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"addTrack" [track -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal track
track]))
removeTrack ::
(MonadDOM m, IsMediaStreamTrack track) =>
MediaStream -> track -> m ()
removeTrack :: forall (m :: * -> *) track.
(MonadDOM m, IsMediaStreamTrack track) =>
MediaStream -> track -> m ()
removeTrack MediaStream
self track
track
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> [JSM JSVal] -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"removeTrack" [track -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal track
track]))
clone :: (MonadDOM m) => MediaStream -> m MediaStream
clone :: forall (m :: * -> *). MonadDOM m => MediaStream -> m MediaStream
clone MediaStream
self
= DOM MediaStream -> m MediaStream
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"clone" ()) JSM JSVal -> (JSVal -> DOM MediaStream) -> DOM MediaStream
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 MediaStream
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
clone_ :: (MonadDOM m) => MediaStream -> m ()
clone_ :: forall (m :: * -> *). MonadDOM m => MediaStream -> m ()
clone_ MediaStream
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 (MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf String
"clone" ()))
getId ::
(MonadDOM m, FromJSString result) => MediaStream -> m result
getId :: forall (m :: * -> *) result.
(MonadDOM m, FromJSString result) =>
MediaStream -> m result
getId MediaStream
self = DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> IndexPreservingGetter MediaStream (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js String
"id") JSM JSVal -> (JSVal -> DOM result) -> DOM result
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 result
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
getActive :: (MonadDOM m) => MediaStream -> m Bool
getActive :: forall (m :: * -> *). MonadDOM m => MediaStream -> m Bool
getActive MediaStream
self = DOM Bool -> m Bool
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((MediaStream
self MediaStream
-> Getting (JSM JSVal) MediaStream (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> IndexPreservingGetter MediaStream (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js String
"active") JSM JSVal -> (JSVal -> DOM Bool) -> DOM Bool
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 Bool
forall value. ToJSVal value => value -> DOM Bool
valToBool)
addTrackEvent :: EventName MediaStream Event
addTrackEvent :: EventName MediaStream Event
addTrackEvent = DOMString -> EventName MediaStream Event
forall t e. DOMString -> EventName t e
unsafeEventName (String -> DOMString
forall a. ToJSString a => a -> DOMString
toJSString String
"addtrack")
removeTrackEvent :: EventName MediaStream Event
removeTrackEvent :: EventName MediaStream Event
removeTrackEvent = DOMString -> EventName MediaStream Event
forall t e. DOMString -> EventName t e
unsafeEventName (String -> DOMString
forall a. ToJSString a => a -> DOMString
toJSString String
"removetrack")
active :: EventName MediaStream Event
active :: EventName MediaStream Event
active = DOMString -> EventName MediaStream Event
forall t e. DOMString -> EventName t e
unsafeEventName (String -> DOMString
forall a. ToJSString a => a -> DOMString
toJSString String
"active")
inactive :: EventName MediaStream Event
inactive :: EventName MediaStream Event
inactive = DOMString -> EventName MediaStream Event
forall t e. DOMString -> EventName t e
unsafeEventName (String -> DOMString
forall a. ToJSString a => a -> DOMString
toJSString String
"inactive")