{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.CharacterData
(substringData, substringData_, appendData, insertData, deleteData,
replaceData, setData, getData, getLength, CharacterData(..),
gTypeCharacterData, IsCharacterData, toCharacterData)
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
substringData ::
(MonadDOM m, IsCharacterData self, FromJSString result) =>
self -> Word -> Word -> m result
substringData :: forall (m :: * -> *) self result.
(MonadDOM m, IsCharacterData self, FromJSString result) =>
self -> Word -> Word -> m result
substringData self
self Word
offset Word
count
= DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(((self -> CharacterData
forall o. IsCharacterData o => o -> CharacterData
toCharacterData self
self) CharacterData
-> Getting (JSM JSVal) CharacterData (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
"substringData"
[Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
offset, Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
count])
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)
substringData_ ::
(MonadDOM m, IsCharacterData self) => self -> Word -> Word -> m ()
substringData_ :: forall (m :: * -> *) self.
(MonadDOM m, IsCharacterData self) =>
self -> Word -> Word -> m ()
substringData_ self
self Word
offset Word
count
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void
((self -> CharacterData
forall o. IsCharacterData o => o -> CharacterData
toCharacterData self
self) CharacterData
-> Getting (JSM JSVal) CharacterData (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
"substringData"
[Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
offset, Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
count]))
appendData ::
(MonadDOM m, IsCharacterData self, ToJSString data') =>
self -> data' -> m ()
appendData :: forall (m :: * -> *) self data'.
(MonadDOM m, IsCharacterData self, ToJSString data') =>
self -> data' -> m ()
appendData self
self data'
data'
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void ((self -> CharacterData
forall o. IsCharacterData o => o -> CharacterData
toCharacterData self
self) CharacterData
-> Getting (JSM JSVal) CharacterData (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
"appendData" [data' -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal data'
data']))
insertData ::
(MonadDOM m, IsCharacterData self, ToJSString data') =>
self -> Word -> data' -> m ()
insertData :: forall (m :: * -> *) self data'.
(MonadDOM m, IsCharacterData self, ToJSString data') =>
self -> Word -> data' -> m ()
insertData self
self Word
offset data'
data'
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void
((self -> CharacterData
forall o. IsCharacterData o => o -> CharacterData
toCharacterData self
self) CharacterData
-> Getting (JSM JSVal) CharacterData (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
"insertData"
[Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
offset, data' -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal data'
data']))
deleteData ::
(MonadDOM m, IsCharacterData self) => self -> Word -> Word -> m ()
deleteData :: forall (m :: * -> *) self.
(MonadDOM m, IsCharacterData self) =>
self -> Word -> Word -> m ()
deleteData self
self Word
offset Word
count
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void
((self -> CharacterData
forall o. IsCharacterData o => o -> CharacterData
toCharacterData self
self) CharacterData
-> Getting (JSM JSVal) CharacterData (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
"deleteData"
[Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
offset, Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
count]))
replaceData ::
(MonadDOM m, IsCharacterData self, ToJSString data') =>
self -> Word -> Word -> data' -> m ()
replaceData :: forall (m :: * -> *) self data'.
(MonadDOM m, IsCharacterData self, ToJSString data') =>
self -> Word -> Word -> data' -> m ()
replaceData self
self Word
offset Word
count data'
data'
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void
((self -> CharacterData
forall o. IsCharacterData o => o -> CharacterData
toCharacterData self
self) CharacterData
-> Getting (JSM JSVal) CharacterData (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
"replaceData"
[Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
offset, Word -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Word
count, data' -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal data'
data']))
setData ::
(MonadDOM m, IsCharacterData self, ToJSString val) =>
self -> val -> m ()
setData :: forall (m :: * -> *) self data'.
(MonadDOM m, IsCharacterData self, ToJSString data') =>
self -> data' -> m ()
setData self
self val
val
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((self -> CharacterData
forall o. IsCharacterData o => o -> CharacterData
toCharacterData self
self) CharacterData -> Getting (DOM ()) CharacterData (DOM ()) -> DOM ()
forall s a. s -> Getting a s a -> a
^. String
-> JSM JSVal
-> forall o. MakeObject o => IndexPreservingGetter o (DOM ())
forall name val.
(ToJSString name, ToJSVal val) =>
name
-> val
-> forall o. MakeObject o => IndexPreservingGetter o (DOM ())
jss String
"data" (val -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal val
val))
getData ::
(MonadDOM m, IsCharacterData self, FromJSString result) =>
self -> m result
getData :: forall (m :: * -> *) self result.
(MonadDOM m, IsCharacterData self, FromJSString result) =>
self -> m result
getData self
self
= DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(((self -> CharacterData
forall o. IsCharacterData o => o -> CharacterData
toCharacterData self
self) CharacterData
-> Getting (JSM JSVal) CharacterData (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> IndexPreservingGetter CharacterData (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js String
"data") 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)
getLength :: (MonadDOM m, IsCharacterData self) => self -> m Word
getLength :: forall (m :: * -> *) self.
(MonadDOM m, IsCharacterData self) =>
self -> m Word
getLength self
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
<$>
(((self -> CharacterData
forall o. IsCharacterData o => o -> CharacterData
toCharacterData self
self) CharacterData
-> Getting (JSM JSVal) CharacterData (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> IndexPreservingGetter CharacterData (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))