{-# LANGUAGE PatternSynonyms #-} -- For HasCallStack compatibility {-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} module JSDOM.Generated.HTMLOptionsCollection (namedItem, namedItem_, namedItemUnsafe, namedItemUnchecked, addBefore, add, remove, setSelectedIndex, getSelectedIndex, setLength, getLength, HTMLOptionsCollection(..), gTypeHTMLOptionsCollection) 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 Language.Javascript.JSaddle (JSM(..), JSVal(..), JSString, strictEqual, toJSVal, valToStr, valToNumber, valToBool, js, jss, jsf, jsg, function, new, array) 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) import JSDOM.Enums -- | namedItem :: (MonadDOM m, ToJSString name) => HTMLOptionsCollection -> name -> m (Maybe Node) namedItem self name = liftDOM ((self ^. jsf "namedItem" [toJSVal name]) >>= fromJSVal) -- | namedItem_ :: (MonadDOM m, ToJSString name) => HTMLOptionsCollection -> name -> m () namedItem_ self name = liftDOM (void (self ^. jsf "namedItem" [toJSVal name])) -- | namedItemUnsafe :: (MonadDOM m, ToJSString name, HasCallStack) => HTMLOptionsCollection -> name -> m Node namedItemUnsafe self name = liftDOM (((self ^. jsf "namedItem" [toJSVal name]) >>= fromJSVal) >>= maybe (Prelude.error "Nothing to return") return) -- | namedItemUnchecked :: (MonadDOM m, ToJSString name) => HTMLOptionsCollection -> name -> m Node namedItemUnchecked self name = liftDOM ((self ^. jsf "namedItem" [toJSVal name]) >>= fromJSValUnchecked) -- | addBefore :: (MonadDOM m, IsHTMLElement element, IsHTMLElement before) => HTMLOptionsCollection -> Maybe element -> Maybe before -> m () addBefore self element before = liftDOM (void (self ^. jsf "add" [toJSVal element, toJSVal before])) -- | add :: (MonadDOM m, IsHTMLElement element) => HTMLOptionsCollection -> Maybe element -> Int -> m () add self element index = liftDOM (void (self ^. jsf "add" [toJSVal element, toJSVal index])) -- | remove :: (MonadDOM m) => HTMLOptionsCollection -> Word -> m () remove self index = liftDOM (void (self ^. jsf "remove" [toJSVal index])) -- | setSelectedIndex :: (MonadDOM m) => HTMLOptionsCollection -> Int -> m () setSelectedIndex self val = liftDOM (self ^. jss "selectedIndex" (toJSVal val)) -- | getSelectedIndex :: (MonadDOM m) => HTMLOptionsCollection -> m Int getSelectedIndex self = liftDOM (round <$> ((self ^. js "selectedIndex") >>= valToNumber)) -- | setLength :: (MonadDOM m) => HTMLOptionsCollection -> Word -> m () setLength self val = liftDOM (self ^. jss "length" (toJSVal val)) -- | getLength :: (MonadDOM m) => HTMLOptionsCollection -> m Word getLength self = liftDOM (round <$> ((self ^. js "length") >>= valToNumber))