summaryrefslogtreecommitdiff
path: root/web/site.hs
diff options
context:
space:
mode:
authorJasper Van der Jeugt <m@jaspervdj.be>2016-03-30 21:32:12 +0200
committerJasper Van der Jeugt <m@jaspervdj.be>2016-03-30 21:32:12 +0200
commitbb3f0d3cff573fe20df41b715b787e77d6bc9b40 (patch)
tree3219ccb94d5112e5bd680c9098c556bf2f8256a1 /web/site.hs
parent7d4a83294dc7cc88b0823759364bab39bae56276 (diff)
downloadhakyll-bb3f0d3cff573fe20df41b715b787e77d6bc9b40.tar.gz
Add external articles
Diffstat (limited to 'web/site.hs')
-rw-r--r--web/site.hs57
1 files changed, 34 insertions, 23 deletions
diff --git a/web/site.hs b/web/site.hs
index a1c2a49..bf84f1e 100644
--- a/web/site.hs
+++ b/web/site.hs
@@ -1,14 +1,13 @@
--------------------------------------------------------------------------------
{-# LANGUAGE OverloadedStrings #-}
-import Control.Applicative ((<$>))
-import Control.Arrow (second)
-import Control.Monad (forM_)
-import Data.Char (isDigit)
-import Data.List (isPrefixOf, partition, sortBy)
-import Data.Monoid (mappend)
-import Data.Ord (comparing)
+import Control.Arrow (second)
+import Control.Monad (forM_)
+import Data.Char (isDigit)
+import Data.List (isPrefixOf, sortBy)
+import Data.Monoid ((<>))
+import Data.Ord (comparing)
import Hakyll
-import System.FilePath (dropTrailingPathSeparator, splitPath)
+import System.FilePath (dropTrailingPathSeparator, splitPath)
import Text.Pandoc
@@ -53,18 +52,12 @@ main = hakyllWith config $ do
create ["tutorials.html"] $ do
route idRoute
compile $ do
- tutorials <- loadAll "tutorials/*"
- itemTpl <- loadBody "templates/tutorial-item.html"
- let (series, articles) = partitionTutorials $
- sortBy (comparing itemIdentifier) tutorials
-
- series' <- applyTemplateList itemTpl defaultContext series
- articles' <- applyTemplateList itemTpl defaultContext articles
+ tuts <-
+ sortBy (comparing itemIdentifier) <$> loadAll "tutorials/*"
let tutorialsCtx =
constField "title" "Tutorials" `mappend`
- constField "series" series' `mappend`
- constField "articles" articles' `mappend`
+ listField "tutorials" tutorialCtx (return tuts) `mappend`
defaultContext
makeItem ""
@@ -112,9 +105,27 @@ hackage url
--------------------------------------------------------------------------------
--- | Partition tutorials into tutorial series & other articles
-partitionTutorials :: [Item a] -> ([Item a], [Item a])
-partitionTutorials = partition $ \i ->
- case splitPath (toFilePath $ itemIdentifier i) of
- [_, (x : _)] -> isDigit x
- _ -> False
+data TutorialType = SeriesTutorial | ArticlesTutorial | ExternalTutorial
+ deriving (Eq)
+
+
+--------------------------------------------------------------------------------
+-- | Partition tutorials into tutorial series, other articles, external articles
+tutorialCtx :: Context String
+tutorialCtx =
+ field "isSeries" (isTutorialType SeriesTutorial) <>
+ field "isArticle" (isTutorialType ArticlesTutorial) <>
+ field "isExternal" (isTutorialType ExternalTutorial) <>
+ defaultContext
+ where
+ getTutorialType item = do
+ mbExternal <- getMetadataField (itemIdentifier item) "external"
+ return $ case mbExternal of
+ Just _ -> ExternalTutorial
+ _ -> case splitPath (toFilePath $ itemIdentifier item) of
+ [_, (x : _)] -> if isDigit x then SeriesTutorial else ArticlesTutorial
+ _ -> ArticlesTutorial
+
+ isTutorialType ty0 item = do
+ ty1 <- getTutorialType item
+ if ty0 == ty1 then return "yes" else fail "no"