Skip to content

Commit

Permalink
Switch from HsYaml -> yaml
Browse files Browse the repository at this point in the history
The 'tags' feature in template is broken. cf. snapframework/heist#128

One way to address it is to specify a frontmatter.yaml default for Aeson.Value, to ensure that all fields are present regardless of what's in the individual Markdown file.
  • Loading branch information
srid committed May 16, 2021
1 parent 9bccc12 commit 134990e
Show file tree
Hide file tree
Showing 5 changed files with 38 additions and 42 deletions.
14 changes: 7 additions & 7 deletions docs/.emabook/templates/_default.tpl
Original file line number Diff line number Diff line change
Expand Up @@ -69,17 +69,17 @@
<apply template="components/markdown" />
<apply template="components/backlinks" />

<ema:note:tags>
<apply template="components/breadcrumbs" />

<note-meta>
<div class="flex items-center justify-center mt-8 space-x-2 font-mono text-sm">
<tag>
<with var="tags">
<a title="Tag" class="px-1 bg-gray-100 rounded">
<tag:name />
<value />
</a>
</tag>
</with>
</div>
</ema:note:tags>

<apply template="components/breadcrumbs" />
</note-meta>

<footer class="flex items-center justify-center my-8 space-x-4 text-center text-gray-500">
<div>
Expand Down
2 changes: 1 addition & 1 deletion emabook.cabal
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,6 @@ executable emabook
, ema >=0.2
, filepath
, heist >=1.1.0.1
, HsYAML
, ixset-typed
, lens
, lvar
Expand All @@ -51,6 +50,7 @@ executable emabook
, text
, time
, unliftio
, yaml
, xmlhtml

mixins:
Expand Down
6 changes: 3 additions & 3 deletions flake.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

43 changes: 21 additions & 22 deletions src/Emabook/Model.hs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
module Emabook.Model where

import Control.Monad.Writer.Strict (MonadWriter (tell))
import Data.Aeson (FromJSON)
import qualified Data.Aeson as Aeson
import Data.Data (Data)
import Data.Default (Default (..))
Expand All @@ -19,15 +20,16 @@ import qualified Data.Map.Strict as Map
import qualified Data.Set as Set
import qualified Data.Text as T
import Data.Tree (Tree)
import qualified Data.YAML as Y
import Data.YAML.ToJSON ()
import qualified Data.Yaml as Yaml
import Ema (Ema (..), Slug)
import qualified Ema
import qualified Ema.Helper.PathTree as PathTree
import qualified Emabook.PandocUtil as PandocUtil
import Emabook.Route (MarkdownRoute)
import qualified Emabook.Route as R
import qualified Emabook.Template as T
import Relude.Extra.Map
import Text.Pandoc.Definition (Pandoc (..))
import qualified Text.Pandoc.Definition as B
import qualified Text.Pandoc.LinkContext as LC
Expand All @@ -46,15 +48,13 @@ data Model = Model
instance Default Model where
def = Model Ix.empty Ix.empty mempty Aeson.Null (Left $ one "Heist state not yet loaded")

parseYaml :: Y.FromYAML a => FilePath -> Text -> Either Text a
parseYaml n (encodeUtf8 -> v) = do
let mkError (loc, emsg) =
toText $ n <> ":" <> Y.prettyPosWithSource loc v " error" <> emsg
first mkError $ Y.decode1 v
parseYaml :: FromJSON a => ByteString -> Either Text a
parseYaml v = do
first show $ Yaml.decodeEither' v

data Note = Note
{ noteDoc :: Pandoc,
noteMeta :: Meta,
noteMeta :: Aeson.Value,
noteRoute :: MarkdownRoute
}
deriving (Eq, Ord, Data, Show, Generic, Aeson.ToJSON)
Expand Down Expand Up @@ -128,22 +128,21 @@ data Meta = Meta
}
deriving (Eq, Show, Ord, Data, Generic, Aeson.ToJSON)

instance Y.FromYAML Meta where
parseYAML = Y.withMap "FrontMatter" $ \m ->
Meta
<$> (fromMaybe def <$> m Y..:? "order")
<*> (fromMaybe mempty <$> m Y..:? "tags")

instance Default Meta where
def = Meta def mempty

modelLookup :: MarkdownRoute -> Model -> Maybe Note
modelLookup k =
Ix.getOne . Ix.getEQ k . modelNotes

modelLookupMeta :: MarkdownRoute -> Model -> Meta
modelLookupMeta k =
maybe def noteMeta . modelLookup k
lookupNoteMeta :: (Default a, FromJSON a) => a -> Text -> Note -> a
lookupNoteMeta x k note =
fromMaybe x $ do
Aeson.Object kw <- pure $ noteMeta note
val <- lookup k kw
case Aeson.fromJSON val of
Aeson.Error _ -> Nothing
Aeson.Success v -> pure v

modelLookupRouteByWikiLink :: R.WikiLinkTarget -> Model -> [MarkdownRoute]
modelLookupRouteByWikiLink wl model =
Expand All @@ -165,15 +164,15 @@ modelLookupTitle :: MarkdownRoute -> Model -> Text
modelLookupTitle r =
maybe (R.markdownRouteFileBase r) noteTitle . modelLookup r

modelUpdateSettings :: FilePath -> Text -> Model -> Model
modelUpdateSettings settingsFile s model =
modelUpdateSettings :: ByteString -> Model -> Model
modelUpdateSettings s model =
model
{ modelSettings =
either error Aeson.toJSON $
parseYaml @(Y.Node Y.Pos) settingsFile s
either error id $
parseYaml s
}

modelInsert :: MarkdownRoute -> (Meta, Pandoc) -> Model -> Model
modelInsert :: MarkdownRoute -> (Aeson.Value, Pandoc) -> Model -> Model
modelInsert k v model =
let note = Note (snd v) (fst v) k
modelNotes' =
Expand All @@ -198,7 +197,7 @@ modelInsert k v model =
note <- Ix.getOne $ Ix.getEQ r notes
pure $
(,)
(order $ noteMeta note)
(lookupNoteMeta @Int 0 "order" note)
(noteTitle note)

modelDelete :: MarkdownRoute -> Model -> Model
Expand Down
15 changes: 6 additions & 9 deletions src/Main.hs
Original file line number Diff line number Diff line change
Expand Up @@ -84,9 +84,9 @@ main =
SourceTemplate dir ->
M.modelSetHeistTemplate <$> T.loadHeistTemplates dir
SourceTemplateSettings _ ->
M.modelUpdateSettings fp <$> readFileText fp
M.modelUpdateSettings <$> readFileBS fp
where
readMarkdown :: (MonadIO m, MonadLogger m) => FilePath -> m (Maybe (MarkdownRoute, (M.Meta, Pandoc)))
readMarkdown :: (MonadIO m, MonadLogger m) => FilePath -> m (Maybe (MarkdownRoute, (Aeson.Value, Pandoc)))
readMarkdown fp =
runMaybeT $ do
r :: MarkdownRoute <- MaybeT $ pure $ R.mkMarkdownRouteFromFilePath fp
Expand All @@ -96,9 +96,9 @@ main =
Left (BadMarkdown -> err) -> do
throw err
Right (mMeta, doc) ->
pure (r, (fromMaybe def mMeta, doc))
pure (r, (fromMaybe Aeson.Null mMeta, doc))
parseMarkdown =
Markdown.parseMarkdownWithFrontMatter @M.Meta $
Markdown.parseMarkdownWithFrontMatter @Aeson.Value $
Markdown.wikilinkSpec <> Markdown.fullMarkdownSpec

newtype BadMarkdown = BadMarkdown Text
Expand Down Expand Up @@ -142,11 +142,8 @@ render _ model r = do
"ema:note:title"
## HI.textSplice
$ M.modelLookupTitle r model
"ema:note:tags"
## Splices.listSplice (maybe mempty (M.tags . M.noteMeta) mNote) "tag"
$ \tag ->
MapSyntax.mapV HI.textSplice $ do
"tag:name" ## tag
"note-meta"
## HJ.bindJson (traceShowId $ maybe Aeson.Null M.noteMeta mNote)
"ema:note:backlinks"
## Splices.listSplice (M.modelLookupBacklinks r model) "backlink"
$ \(source, ctx) -> do
Expand Down

0 comments on commit 134990e

Please sign in to comment.