{-# LANGUAGE PatternSynonyms #-} -- For HasCallStack compatibility {-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} module JSDOM.Generated.CSSValue (pattern CSS_INHERIT, pattern CSS_PRIMITIVE_VALUE, pattern CSS_VALUE_LIST, pattern CSS_CUSTOM, setCssText, getCssText, getCssTextUnsafe, getCssTextUnchecked, getCssValueType, CSSValue(..), gTypeCSSValue, IsCSSValue, toCSSValue) 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 pattern CSS_INHERIT = 0 pattern CSS_PRIMITIVE_VALUE = 1 pattern CSS_VALUE_LIST = 2 pattern CSS_CUSTOM = 3 -- | setCssText :: (MonadDOM m, IsCSSValue self, ToJSString val) => self -> Maybe val -> m () setCssText self val = liftDOM ((toCSSValue self) ^. jss "cssText" (toJSVal val)) -- | getCssText :: (MonadDOM m, IsCSSValue self, FromJSString result) => self -> m (Maybe result) getCssText self = liftDOM (((toCSSValue self) ^. js "cssText") >>= fromMaybeJSString) -- | getCssTextUnsafe :: (MonadDOM m, IsCSSValue self, HasCallStack, FromJSString result) => self -> m result getCssTextUnsafe self = liftDOM ((((toCSSValue self) ^. js "cssText") >>= fromMaybeJSString) >>= maybe (Prelude.error "Nothing to return") return) -- | getCssTextUnchecked :: (MonadDOM m, IsCSSValue self, FromJSString result) => self -> m result getCssTextUnchecked self = liftDOM (((toCSSValue self) ^. js "cssText") >>= fromJSValUnchecked) -- | getCssValueType :: (MonadDOM m, IsCSSValue self) => self -> m Word getCssValueType self = liftDOM (round <$> (((toCSSValue self) ^. js "cssValueType") >>= valToNumber))