{-# LANGUAGE CPP #-} {-# LANGUAGE PatternSynonyms #-} {-# LANGUAGE ForeignFunctionInterface #-} {-# LANGUAGE JavaScriptFFI #-} -- For HasCallStack compatibility {-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-} module GHCJS.DOM.JSFFI.Generated.HTMLOptionsCollection (js_namedItem, namedItem, namedItem_, namedItemUnsafe, namedItemUnchecked, js_addBefore, addBefore, js_add, add, js_remove, remove, js_setSelectedIndex, setSelectedIndex, js_getSelectedIndex, getSelectedIndex, js_setLength, setLength, js_getLength, getLength, HTMLOptionsCollection(..), gTypeHTMLOptionsCollection) 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 #if MIN_VERSION_base(4,9,0) import GHC.Stack (HasCallStack) #else import GHC.Exts (Constraint) type HasCallStack = (() :: Constraint) #endif foreign import javascript unsafe "$1[\"namedItem\"]($2)" js_namedItem :: HTMLOptionsCollection -> JSString -> IO (Nullable Node) -- | namedItem :: (MonadIO m, ToJSString name) => HTMLOptionsCollection -> name -> m (Maybe Node) namedItem self name = liftIO (nullableToMaybe <$> (js_namedItem (self) (toJSString name))) -- | namedItem_ :: (MonadIO m, ToJSString name) => HTMLOptionsCollection -> name -> m () namedItem_ self name = liftIO (void (js_namedItem (self) (toJSString name))) -- | namedItemUnsafe :: (MonadIO m, ToJSString name, HasCallStack) => HTMLOptionsCollection -> name -> m Node namedItemUnsafe self name = liftIO ((nullableToMaybe <$> (js_namedItem (self) (toJSString name))) >>= maybe (Prelude.error "Nothing to return") return) -- | namedItemUnchecked :: (MonadIO m, ToJSString name) => HTMLOptionsCollection -> name -> m Node namedItemUnchecked self name = liftIO (fromJust . nullableToMaybe <$> (js_namedItem (self) (toJSString name))) foreign import javascript unsafe "$1[\"add\"]($2, $3)" js_addBefore :: HTMLOptionsCollection -> Nullable HTMLElement -> Nullable HTMLElement -> IO () -- | addBefore :: (MonadIO m, IsHTMLElement element, IsHTMLElement before) => HTMLOptionsCollection -> Maybe element -> Maybe before -> m () addBefore self element before = liftIO (js_addBefore (self) (maybeToNullable (fmap toHTMLElement element)) (maybeToNullable (fmap toHTMLElement before))) foreign import javascript unsafe "$1[\"add\"]($2, $3)" js_add :: HTMLOptionsCollection -> Nullable HTMLElement -> Int -> IO () -- | add :: (MonadIO m, IsHTMLElement element) => HTMLOptionsCollection -> Maybe element -> Int -> m () add self element index = liftIO (js_add (self) (maybeToNullable (fmap toHTMLElement element)) index) foreign import javascript unsafe "$1[\"remove\"]($2)" js_remove :: HTMLOptionsCollection -> Word -> IO () -- | remove :: (MonadIO m) => HTMLOptionsCollection -> Word -> m () remove self index = liftIO (js_remove (self) index) foreign import javascript unsafe "$1[\"selectedIndex\"] = $2;" js_setSelectedIndex :: HTMLOptionsCollection -> Int -> IO () -- | setSelectedIndex :: (MonadIO m) => HTMLOptionsCollection -> Int -> m () setSelectedIndex self val = liftIO (js_setSelectedIndex (self) val) foreign import javascript unsafe "$1[\"selectedIndex\"]" js_getSelectedIndex :: HTMLOptionsCollection -> IO Int -- | getSelectedIndex :: (MonadIO m) => HTMLOptionsCollection -> m Int getSelectedIndex self = liftIO (js_getSelectedIndex (self)) foreign import javascript unsafe "$1[\"length\"] = $2;" js_setLength :: HTMLOptionsCollection -> Word -> IO () -- | setLength :: (MonadIO m) => HTMLOptionsCollection -> Word -> m () setLength self val = liftIO (js_setLength (self) val) foreign import javascript unsafe "$1[\"length\"]" js_getLength :: HTMLOptionsCollection -> IO Word -- | getLength :: (MonadIO m) => HTMLOptionsCollection -> m Word getLength self = liftIO (js_getLength (self))