{-# LANGUAGE PatternSynonyms #-}
-- For HasCallStack compatibility
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.TextEncoder
       (newTextEncoder, encode, encode_, getEncoding, TextEncoder(..),
        gTypeTextEncoder)
       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

-- | <https://developer.mozilla.org/en-US/docs/Web/API/TextEncoder Mozilla TextEncoder documentation> 
newTextEncoder :: (MonadDOM m) => m TextEncoder
newTextEncoder :: forall (m :: * -> *). MonadDOM m => m TextEncoder
newTextEncoder
  = DOM TextEncoder -> m TextEncoder
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSVal -> TextEncoder
TextEncoder (JSVal -> TextEncoder) -> JSM JSVal -> DOM TextEncoder
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
"TextEncoder") ())

-- | <https://developer.mozilla.org/en-US/docs/Web/API/TextEncoder.encode Mozilla TextEncoder.encode documentation> 
encode ::
       (MonadDOM m, ToJSString input) =>
         TextEncoder -> Maybe input -> m Uint8Array
encode :: forall (m :: * -> *) input.
(MonadDOM m, ToJSString input) =>
TextEncoder -> Maybe input -> m Uint8Array
encode TextEncoder
self Maybe input
input
  = DOM Uint8Array -> m Uint8Array
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
      ((TextEncoder
self TextEncoder
-> Getting (JSM JSVal) TextEncoder (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
"encode" [Maybe input -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Maybe input
input]) JSM JSVal -> (JSVal -> DOM Uint8Array) -> DOM Uint8Array
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 Uint8Array
forall a. FromJSVal a => JSVal -> JSM a
fromJSValUnchecked)

-- | <https://developer.mozilla.org/en-US/docs/Web/API/TextEncoder.encode Mozilla TextEncoder.encode documentation> 
encode_ ::
        (MonadDOM m, ToJSString input) =>
          TextEncoder -> Maybe input -> m ()
encode_ :: forall (m :: * -> *) input.
(MonadDOM m, ToJSString input) =>
TextEncoder -> Maybe input -> m ()
encode_ TextEncoder
self Maybe input
input
  = DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (TextEncoder
self TextEncoder
-> Getting (JSM JSVal) TextEncoder (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
"encode" [Maybe input -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Maybe input
input]))

-- | <https://developer.mozilla.org/en-US/docs/Web/API/TextEncoder.encoding Mozilla TextEncoder.encoding documentation> 
getEncoding ::
            (MonadDOM m, FromJSString result) => TextEncoder -> m result
getEncoding :: forall (m :: * -> *) result.
(MonadDOM m, FromJSString result) =>
TextEncoder -> m result
getEncoding TextEncoder
self
  = DOM result -> m result
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM ((TextEncoder
self TextEncoder
-> Getting (JSM JSVal) TextEncoder (JSM JSVal) -> JSM JSVal
forall s a. s -> Getting a s a -> a
^. String -> IndexPreservingGetter TextEncoder (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js String
"encoding") 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)