| Safe Haskell | None |
|---|---|
| Language | Haskell98 |
Yesod.Core.Widget
Contents
Description
Widgets combine HTML with JS and CSS dependencies with a unique identifier generator, allowing you to create truly modular HTML components.
- type WidgetT site (m :: * -> *) = WidgetFor site
- data WidgetFor site a
- data PageContent url = PageContent {}
- whamlet :: QuasiQuoter
- whamletFile :: FilePath -> Q Exp
- ihamletToRepHtml :: (MonadHandler m, RenderMessage (HandlerSite m) message) => HtmlUrlI18n message (Route (HandlerSite m)) -> m Html
- ihamletToHtml :: (MonadHandler m, RenderMessage (HandlerSite m) message) => HtmlUrlI18n message (Route (HandlerSite m)) -> m Html
- class ToWidget site a where
- class ToWidgetHead site a where
- class ToWidgetBody site a where
- class ToWidgetMedia site a where
- setTitle :: MonadWidget m => Html -> m ()
- setTitleI :: (MonadWidget m, RenderMessage (HandlerSite m) msg) => msg -> m ()
- addStylesheet :: MonadWidget m => Route (HandlerSite m) -> m ()
- addStylesheetAttrs :: MonadWidget m => Route (HandlerSite m) -> [(Text, Text)] -> m ()
- addStylesheetRemote :: MonadWidget m => Text -> m ()
- addStylesheetRemoteAttrs :: MonadWidget m => Text -> [(Text, Text)] -> m ()
- addStylesheetEither :: MonadWidget m => Either (Route (HandlerSite m)) Text -> m ()
- newtype CssBuilder = CssBuilder {}
- addScript :: MonadWidget m => Route (HandlerSite m) -> m ()
- addScriptAttrs :: MonadWidget m => Route (HandlerSite m) -> [(Text, Text)] -> m ()
- addScriptRemote :: MonadWidget m => Text -> m ()
- addScriptRemoteAttrs :: MonadWidget m => Text -> [(Text, Text)] -> m ()
- addScriptEither :: MonadWidget m => Either (Route (HandlerSite m)) Text -> m ()
- handlerToWidget :: HandlerFor site a -> WidgetFor site a
- whamletFileWithSettings :: HamletSettings -> FilePath -> Q Exp
- asWidgetT :: WidgetT site m () -> WidgetT site m ()
Datatype
data WidgetFor site a Source #
A generic widget, allowing specification of both the subsite and master
site datatypes. While this is simply a WriterT, we define a newtype for
better error messages.
Instances
| ((~) * site' site, (~) * a ()) => ToWidget site' (WidgetFor site a) Source # | |
| Monad (WidgetFor site) Source # | |
| Functor (WidgetFor site) Source # | |
| Applicative (WidgetFor site) Source # | |
| MonadIO (WidgetFor site) Source # | |
| MonadUnliftIO (WidgetFor site) Source # | Since: 1.4.38 |
| MonadResource (WidgetFor site) Source # | |
| MonadThrow (WidgetFor site) Source # | |
| MonadLogger (WidgetFor site) Source # | |
| MonadLoggerIO (WidgetFor site) Source # | |
| MonadWidget (WidgetFor site) Source # | |
| MonadHandler (WidgetFor site) Source # | |
| MonadReader (WidgetData site) (WidgetFor site) Source # | |
| (~) * a () => IsString (WidgetFor site a) Source # | A For example, in a yesod-scaffold site you could use: getHomeR = do defaultLayout "Widget text" |
| (~) * a () => Semigroup (WidgetFor site a) Source # | |
| (~) * a () => Monoid (WidgetFor site a) Source # | |
| type HandlerSite (WidgetFor site) Source # | |
| type SubHandlerSite (WidgetFor site) Source # | |
data PageContent url Source #
Content for a web page. By providing this datatype, we can easily create generic site templates, which would have the type signature:
PageContent url -> HtmlUrl url
Special Hamlet quasiquoter/TH for Widgets
ihamletToRepHtml :: (MonadHandler m, RenderMessage (HandlerSite m) message) => HtmlUrlI18n message (Route (HandlerSite m)) -> m Html Source #
ihamletToHtml :: (MonadHandler m, RenderMessage (HandlerSite m) message) => HtmlUrlI18n message (Route (HandlerSite m)) -> m Html Source #
Convert to Widget
class ToWidget site a where Source #
Minimal complete definition
Methods
toWidget :: (MonadWidget m, HandlerSite m ~ site) => a -> m () Source #
Instances
| ToWidget site Builder Source # | Since: 1.4.28 |
| ToWidget site Text Source # | Since: 1.4.28 |
| ToWidget site Text Source # | Since: 1.4.28 |
| ToWidget site Html Source # | |
| ToWidget site Javascript Source # | |
| ToWidget site CssBuilder Source # | |
| ToWidget site Css Source # | |
| ((~) * site' site, (~) * a ()) => ToWidget site' (WidgetFor site a) Source # | |
| (~) * render (RY site) => ToWidget site (render -> Javascript) Source # | |
| (~) * render (RY site) => ToWidget site (render -> CssBuilder) Source # | |
| (~) * render (RY site) => ToWidget site (render -> Css) Source # | |
| (~) * render (RY site) => ToWidget site (render -> Html) Source # | |
class ToWidgetHead site a where Source #
Minimal complete definition
Methods
toWidgetHead :: (MonadWidget m, HandlerSite m ~ site) => a -> m () Source #
Instances
| ToWidgetHead site Html Source # | |
| ToWidgetHead site Javascript Source # | |
| ToWidgetHead site CssBuilder Source # | |
| ToWidgetHead site Css Source # | |
| (~) * render (RY site) => ToWidgetHead site (render -> Javascript) Source # | |
| (~) * render (RY site) => ToWidgetHead site (render -> CssBuilder) Source # | |
| (~) * render (RY site) => ToWidgetHead site (render -> Css) Source # | |
| (~) * render (RY site) => ToWidgetHead site (render -> Html) Source # | |
class ToWidgetBody site a where Source #
Minimal complete definition
Methods
toWidgetBody :: (MonadWidget m, HandlerSite m ~ site) => a -> m () Source #
Instances
| ToWidgetBody site Html Source # | |
| ToWidgetBody site Javascript Source # | |
| (~) * render (RY site) => ToWidgetBody site (render -> Javascript) Source # | |
| (~) * render (RY site) => ToWidgetBody site (render -> Html) Source # | |
class ToWidgetMedia site a where Source #
Allows adding some CSS to the page with a specific media type.
Since 1.2
Minimal complete definition
Methods
Arguments
| :: (MonadWidget m, HandlerSite m ~ site) | |
| => Text | media value |
| -> a | |
| -> m () |
Add the given content to the page, but only for the given media type.
Since 1.2
Instances
| ToWidgetMedia site CssBuilder Source # | |
| ToWidgetMedia site Css Source # | |
| (~) * render (RY site) => ToWidgetMedia site (render -> CssBuilder) Source # | |
| (~) * render (RY site) => ToWidgetMedia site (render -> Css) Source # | |
Creating
Head of page
setTitle :: MonadWidget m => Html -> m () Source #
Set the page title. Calling setTitle multiple times overrides previously
set values.
setTitleI :: (MonadWidget m, RenderMessage (HandlerSite m) msg) => msg -> m () Source #
Set the page title. Calling setTitle multiple times overrides previously
set values.
CSS
addStylesheet :: MonadWidget m => Route (HandlerSite m) -> m () Source #
Link to the specified local stylesheet.
addStylesheetAttrs :: MonadWidget m => Route (HandlerSite m) -> [(Text, Text)] -> m () Source #
Link to the specified local stylesheet.
addStylesheetRemote :: MonadWidget m => Text -> m () Source #
Link to the specified remote stylesheet.
addStylesheetRemoteAttrs :: MonadWidget m => Text -> [(Text, Text)] -> m () Source #
Link to the specified remote stylesheet.
addStylesheetEither :: MonadWidget m => Either (Route (HandlerSite m)) Text -> m () Source #
newtype CssBuilder Source #
Newtype wrapper allowing injection of arbitrary content into CSS.
Usage:
toWidget $ CssBuilder "p { color: red }"Since: 1.1.3
Constructors
| CssBuilder | |
Fields | |
Instances
| ToWidgetHead site CssBuilder Source # | |
| ToWidgetMedia site CssBuilder Source # | |
| ToWidget site CssBuilder Source # | |
| (~) * render (RY site) => ToWidgetHead site (render -> CssBuilder) Source # | |
| (~) * render (RY site) => ToWidgetMedia site (render -> CssBuilder) Source # | |
| (~) * render (RY site) => ToWidget site (render -> CssBuilder) Source # | |
Javascript
addScript :: MonadWidget m => Route (HandlerSite m) -> m () Source #
Link to the specified local script.
addScriptAttrs :: MonadWidget m => Route (HandlerSite m) -> [(Text, Text)] -> m () Source #
Link to the specified local script.
addScriptRemote :: MonadWidget m => Text -> m () Source #
Link to the specified remote script.
addScriptRemoteAttrs :: MonadWidget m => Text -> [(Text, Text)] -> m () Source #
Link to the specified remote script.
addScriptEither :: MonadWidget m => Either (Route (HandlerSite m)) Text -> m () Source #
Subsites
handlerToWidget :: HandlerFor site a -> WidgetFor site a Source #
Internal
whamletFileWithSettings :: HamletSettings -> FilePath -> Q Exp Source #