{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.VideoTrackList
(item, item_, getTrackById, getTrackById_, getLength,
getSelectedIndex, change, addTrack, removeTrack,
VideoTrackList(..), gTypeVideoTrackList)
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
item :: (MonadDOM m) => VideoTrackList -> Word -> m VideoTrack
item :: forall (m :: * -> *).
MonadDOM m =>
VideoTrackList -> Word -> m VideoTrack
item VideoTrackList
self Word
index
= DOM VideoTrack -> m VideoTrack
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
((VideoTrackList
self VideoTrackList
-> Getting (JSM JSVal) VideoTrackList (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
"item" [Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
index]) JSM JSVal -> (JSVal -> DOM VideoTrack) -> DOM VideoTrack
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 VideoTrack
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
item_ :: (MonadDOM m) => VideoTrackList -> Word -> m ()
item_ :: forall (m :: * -> *). MonadDOM m => VideoTrackList -> Word -> m ()
item_ VideoTrackList
self Word
index
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (VideoTrackList
self VideoTrackList
-> Getting (JSM JSVal) VideoTrackList (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
"item" [Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
index]))
getTrackById ::
(MonadDOM m, ToJSString id) => VideoTrackList -> id -> m VideoTrack
getTrackById :: forall (m :: * -> *) id.
(MonadDOM m, ToJSString id) =>
VideoTrackList -> id -> m VideoTrack
getTrackById VideoTrackList
self id
id
= DOM VideoTrack -> m VideoTrack
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
((VideoTrackList
self VideoTrackList
-> Getting (JSM JSVal) VideoTrackList (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" [id -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal id
id]) JSM JSVal -> (JSVal -> DOM VideoTrack) -> DOM VideoTrack
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 VideoTrack
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)
getTrackById_ ::
(MonadDOM m, ToJSString id) => VideoTrackList -> id -> m ()
getTrackById_ :: forall (m :: * -> *) id.
(MonadDOM m, ToJSString id) =>
VideoTrackList -> id -> m ()
getTrackById_ VideoTrackList
self id
id
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (VideoTrackList
self VideoTrackList
-> Getting (JSM JSVal) VideoTrackList (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" [id -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal id
id]))
getLength :: (MonadDOM m) => VideoTrackList -> m Word
getLength :: forall (m :: * -> *). MonadDOM m => VideoTrackList -> m Word
getLength VideoTrackList
self
= DOM Word -> m Word
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (Double -> Word
forall b. Integral b => Double -> b
forall a b. (RealFrac a, Integral b) => a -> b
round (Double -> Word) -> JSM Double -> DOM Word
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ((VideoTrackList
self VideoTrackList
-> Getting (JSM JSVal) VideoTrackList (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> IndexPreservingGetter VideoTrackList (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js String
"length") JSM JSVal -> (JSVal -> JSM Double) -> JSM Double
forall a b. JSM a -> (a -> JSM b) -> JSM b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> JSM Double
forall value. ToJSVal value => value -> JSM Double
valToNumber))
getSelectedIndex :: (MonadDOM m) => VideoTrackList -> m Int
getSelectedIndex :: forall (m :: * -> *). MonadDOM m => VideoTrackList -> m Int
getSelectedIndex VideoTrackList
self
= DOM Int -> m Int
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(Double -> Int
forall b. Integral b => Double -> b
forall a b. (RealFrac a, Integral b) => a -> b
round (Double -> Int) -> JSM Double -> DOM Int
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ((VideoTrackList
self VideoTrackList
-> Getting (JSM JSVal) VideoTrackList (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> IndexPreservingGetter VideoTrackList (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js String
"selectedIndex") JSM JSVal -> (JSVal -> JSM Double) -> JSM Double
forall a b. JSM a -> (a -> JSM b) -> JSM b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> JSM Double
forall value. ToJSVal value => value -> JSM Double
valToNumber))
change :: EventName VideoTrackList Event
change :: EventName VideoTrackList Event
change = DOMString -> EventName VideoTrackList Event
forall t e. DOMString -> EventName t e
unsafeEventName (String -> DOMString
forall a. ToJSString a => a -> DOMString
toJSString String
"change")
addTrack :: EventName VideoTrackList Event
addTrack :: EventName VideoTrackList Event
addTrack = DOMString -> EventName VideoTrackList Event
forall t e. DOMString -> EventName t e
unsafeEventName (String -> DOMString
forall a. ToJSString a => a -> DOMString
toJSString String
"addtrack")
removeTrack :: EventName VideoTrackList Event
removeTrack :: EventName VideoTrackList Event
removeTrack = DOMString -> EventName VideoTrackList Event
forall t e. DOMString -> EventName t e
unsafeEventName (String -> DOMString
forall a. ToJSString a => a -> DOMString
toJSString String
"removetrack")