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