module GHCJS.DOM.JSFFI.Generated.RTCDTMFSender
(js_insertDTMF, insertDTMF, js_getCanInsertDTMF, getCanInsertDTMF,
js_getTrack, getTrack, getTrackUnsafe, getTrackUnchecked,
js_getToneBuffer, getToneBuffer, js_getDuration, getDuration,
js_getInterToneGap, getInterToneGap, toneChange, RTCDTMFSender(..),
gTypeRTCDTMFSender)
where
import Prelude ((.), (==), (>>=), return, IO, Int, Float, Double, Bool(..), Maybe, maybe, fromIntegral, round, fmap, Show, Read, Eq, Ord)
import qualified Prelude (error)
import Data.Typeable (Typeable)
import GHCJS.Types (JSVal(..), JSString)
import GHCJS.Foreign (jsNull)
import GHCJS.Foreign.Callback (syncCallback, asyncCallback, syncCallback1, asyncCallback1, syncCallback2, asyncCallback2, OnBlocked(..))
import GHCJS.Marshal (ToJSVal(..), FromJSVal(..))
import GHCJS.Marshal.Pure (PToJSVal(..), PFromJSVal(..))
import Control.Monad (void)
import Control.Monad.IO.Class (MonadIO(..))
import Data.Int (Int64)
import Data.Word (Word, Word64)
import Data.Maybe (fromJust)
import GHCJS.DOM.Types
import Control.Applicative ((<$>))
import GHCJS.DOM.EventTargetClosures (EventName, unsafeEventName)
import GHCJS.DOM.JSFFI.Generated.Enums
foreign import javascript unsafe "$1[\"insertDTMF\"]($2, $3, $4)"
js_insertDTMF :: RTCDTMFSender -> JSString -> Int -> Int -> IO ()
insertDTMF ::
(MonadIO m, ToJSString tones) =>
RTCDTMFSender -> tones -> Int -> Int -> m ()
insertDTMF self tones duration interToneGap
= liftIO
(js_insertDTMF (self) (toJSString tones) duration interToneGap)
foreign import javascript unsafe "($1[\"canInsertDTMF\"] ? 1 : 0)"
js_getCanInsertDTMF :: RTCDTMFSender -> IO Bool
getCanInsertDTMF :: (MonadIO m) => RTCDTMFSender -> m Bool
getCanInsertDTMF self = liftIO (js_getCanInsertDTMF (self))
foreign import javascript unsafe "$1[\"track\"]" js_getTrack ::
RTCDTMFSender -> IO (Nullable MediaStreamTrack)
getTrack ::
(MonadIO m) => RTCDTMFSender -> m (Maybe MediaStreamTrack)
getTrack self = liftIO (nullableToMaybe <$> (js_getTrack (self)))
getTrackUnsafe ::
(MonadIO m, HasCallStack) => RTCDTMFSender -> m MediaStreamTrack
getTrackUnsafe self
= liftIO
((nullableToMaybe <$> (js_getTrack (self))) >>=
maybe (Prelude.error "Nothing to return") return)
getTrackUnchecked ::
(MonadIO m) => RTCDTMFSender -> m MediaStreamTrack
getTrackUnchecked self
= liftIO (fromJust . nullableToMaybe <$> (js_getTrack (self)))
foreign import javascript unsafe "$1[\"toneBuffer\"]"
js_getToneBuffer :: RTCDTMFSender -> IO JSString
getToneBuffer ::
(MonadIO m, FromJSString result) => RTCDTMFSender -> m result
getToneBuffer self
= liftIO (fromJSString <$> (js_getToneBuffer (self)))
foreign import javascript unsafe "$1[\"duration\"]" js_getDuration
:: RTCDTMFSender -> IO Int
getDuration :: (MonadIO m) => RTCDTMFSender -> m Int
getDuration self = liftIO (js_getDuration (self))
foreign import javascript unsafe "$1[\"interToneGap\"]"
js_getInterToneGap :: RTCDTMFSender -> IO Int
getInterToneGap :: (MonadIO m) => RTCDTMFSender -> m Int
getInterToneGap self = liftIO (js_getInterToneGap (self))
toneChange :: EventName RTCDTMFSender Event
toneChange = unsafeEventName (toJSString "tonechange")