Safe Haskell | None |
---|---|
Language | Haskell98 |
- data ContextField
- = StringField String
- | forall a . ListField (Context a) [Item a]
- newtype Context a = Context {}
- field :: String -> (Item a -> Compiler String) -> Context a
- constField :: String -> String -> Context a
- listField :: String -> Context a -> Compiler [Item a] -> Context b
- listFieldWith :: String -> Context a -> (Item b -> Compiler [Item a]) -> Context b
- functionField :: String -> ([String] -> Item a -> Compiler String) -> Context a
- mapContext :: (String -> String) -> Context a -> Context a
- defaultContext :: Context String
- bodyField :: String -> Context String
- metadataField :: Context a
- urlField :: String -> Context a
- pathField :: String -> Context a
- titleField :: String -> Context a
- dateField :: String -> String -> Context a
- dateFieldWith :: TimeLocale -> String -> String -> Context a
- getItemUTC :: MonadMetadata m => TimeLocale -> Identifier -> m UTCTime
- modificationTimeField :: String -> String -> Context a
- modificationTimeFieldWith :: TimeLocale -> String -> String -> Context a
- teaserField :: String -> Snapshot -> Context String
- missingField :: Context a
Documentation
data ContextField Source
Mostly for internal usage
StringField String | |
forall a . ListField (Context a) [Item a] |
The Context
monoid. Please note that the order in which you
compose the items is important. For example in
field "A" f1 <> field "A" f2
the first context will overwrite the second. This is especially
important when something is being composed with
metadataField
(or defaultContext
). If you want your context to be
overwritten by the metadata fields, compose it from the right:
metadataField
<> field "date" fDate
:: String | Key |
-> (Item a -> Compiler String) | Function that constructs a value based on the item |
-> Context a |
Constructs a new field in the 'Context.'
defaultContext :: Context String Source
A context that contains (in that order)
- A
$body$
field- Metadata fields
- A
$url$
urlField
- A
$path$
pathField
- A
$title$
titleField
metadataField :: Context a Source
Map any field to its metadata value, if present
titleField :: String -> Context a Source
This title field
takes the basename of the underlying file by default
:: String | Key in which the rendered date should be placed |
-> String | Format to use on the date |
-> Context a | Resulting context |
When the metadata has a field called published
in one of the
following formats then this function can render the date.
Mon, 06 Sep 2010 00:01:00 +0000
Mon, 06 Sep 2010 00:01:00 UTC
Mon, 06 Sep 2010 00:01:00
2010-09-06T00:01:00+0000
2010-09-06T00:01:00Z
2010-09-06T00:01:00
2010-09-06 00:01:00+0000
2010-09-06 00:01:00
September 06, 2010 00:01 AM
Following date-only formats are supported too (00:00:00
for time is
assumed)
2010-09-06
September 06, 2010
Alternatively, when the metadata has a field called path
in a
folder/yyyy-mm-dd-title.extension
format (the convention for pages)
and no published
metadata field set, this function can render
the date. This pattern matches the file name or directory names
that begins with yyyy-mm-dd
. For example:
folder/yyyy-mm-dd-titledist/main.extension
.
In case of multiple matches, the rightmost one is used.
:: TimeLocale | Output time locale |
-> String | Destination key |
-> String | Format to use on the date |
-> Context a | Resulting context |
:: MonadMetadata m | |
=> TimeLocale | Output time locale |
-> Identifier | Input page |
-> m UTCTime | Parsed UTCTime |
Parser to try to extract and parse the time from the published
field or from the filename. See dateField
for more information.
Exported for user convenience.
modificationTimeFieldWith Source
:: TimeLocale | Time output locale |
-> String | Key |
-> String | Format |
-> Context a | Resulting context |
A context with "teaser" key which contain a teaser of the item. The item is loaded from the given snapshot (which should be saved in the user code before any templates are applied).
missingField :: Context a Source