Began converting AtomFeed to hamlet
This commit is contained in:
parent
3165b253ba
commit
654331f406
@ -1,5 +1,6 @@
|
|||||||
{-# LANGUAGE FlexibleInstances #-}
|
{-# LANGUAGE FlexibleInstances #-}
|
||||||
{-# LANGUAGE MultiParamTypeClasses #-}
|
{-# LANGUAGE MultiParamTypeClasses #-}
|
||||||
|
{-# LANGUAGE QuasiQuotes #-}
|
||||||
---------------------------------------------------------
|
---------------------------------------------------------
|
||||||
--
|
--
|
||||||
-- Module : Yesod.Helpers.AtomFeed
|
-- Module : Yesod.Helpers.AtomFeed
|
||||||
@ -17,64 +18,64 @@
|
|||||||
module Yesod.Helpers.AtomFeed
|
module Yesod.Helpers.AtomFeed
|
||||||
( AtomFeed (..)
|
( AtomFeed (..)
|
||||||
, AtomFeedEntry (..)
|
, AtomFeedEntry (..)
|
||||||
, AtomFeedResponse (..)
|
--, atomFeed
|
||||||
, atomFeed
|
, template -- FIXME
|
||||||
) where
|
) where
|
||||||
|
|
||||||
import Yesod
|
import Yesod
|
||||||
import Data.Time.Clock (UTCTime)
|
import Data.Time.Clock (UTCTime)
|
||||||
-- FIXME import Web.Encodings (formatW3)
|
import Web.Encodings (formatW3)
|
||||||
import Data.Convertible.Text
|
import Text.Hamlet.Monad
|
||||||
|
|
||||||
data AtomFeedResponse = AtomFeedResponse AtomFeed Approot
|
|
||||||
|
|
||||||
|
{-
|
||||||
atomFeed :: Yesod y => AtomFeed -> Handler y AtomFeedResponse
|
atomFeed :: Yesod y => AtomFeed -> Handler y AtomFeedResponse
|
||||||
atomFeed f = do
|
atomFeed f = do
|
||||||
y <- getYesod
|
y <- getYesod
|
||||||
return $ AtomFeedResponse f $ approot y
|
return $ AtomFeedResponse f $ approot y
|
||||||
|
-}
|
||||||
|
|
||||||
data AtomFeed = AtomFeed
|
data AtomFeed url = AtomFeed
|
||||||
{ atomTitle :: String
|
{ atomTitle :: String
|
||||||
, atomLinkSelf :: Location
|
, atomLinkSelf :: url
|
||||||
, atomLinkHome :: Location
|
, atomLinkHome :: url
|
||||||
, atomUpdated :: UTCTime
|
, atomUpdated :: UTCTime
|
||||||
, atomEntries :: [AtomFeedEntry]
|
, atomEntries :: [AtomFeedEntry url]
|
||||||
}
|
}
|
||||||
instance HasReps AtomFeedResponse where
|
{- FIXME
|
||||||
|
instance HasReps (AtomFeed url) where
|
||||||
chooseRep = defChooseRep
|
chooseRep = defChooseRep
|
||||||
[ (TypeAtom, return . cs)
|
[ (TypeAtom, return . cs)
|
||||||
]
|
]
|
||||||
|
-}
|
||||||
|
|
||||||
data AtomFeedEntry = AtomFeedEntry
|
data AtomFeedEntry url = AtomFeedEntry
|
||||||
{ atomEntryLink :: Location
|
{ atomEntryLink :: url
|
||||||
, atomEntryUpdated :: UTCTime
|
, atomEntryUpdated :: UTCTime
|
||||||
, atomEntryTitle :: String
|
, atomEntryTitle :: String
|
||||||
, atomEntryContent :: HtmlContent
|
, atomEntryContent :: HtmlContent
|
||||||
}
|
}
|
||||||
|
|
||||||
instance ConvertSuccess AtomFeedResponse Content where
|
xmlns :: a -> HtmlContent
|
||||||
convertSuccess = error "FIXME" -- cs . (cs :: Html -> XmlDoc) . cs
|
xmlns _ = cs "http://www.w3.org/2005/Atom"
|
||||||
{- FIXME
|
|
||||||
instance ConvertSuccess AtomFeedResponse Html where
|
|
||||||
convertSuccess (AtomFeedResponse f ar) =
|
|
||||||
Tag "feed" [("xmlns", "http://www.w3.org/2005/Atom")] $ HtmlList
|
|
||||||
[ Tag "title" [] $ cs $ atomTitle f
|
|
||||||
, EmptyTag "link" [ ("rel", "self")
|
|
||||||
, ("href", showLocation ar $ atomLinkSelf f)
|
|
||||||
]
|
|
||||||
, EmptyTag "link" [ ("href", showLocation ar $ atomLinkHome f)
|
|
||||||
]
|
|
||||||
, Tag "updated" [] $ cs $ formatW3 $ atomUpdated f
|
|
||||||
, Tag "id" [] $ cs $ showLocation ar $ atomLinkHome f
|
|
||||||
, HtmlList $ map cs $ zip (atomEntries f) $ repeat ar
|
|
||||||
]
|
|
||||||
|
|
||||||
instance ConvertSuccess (AtomFeedEntry, Approot) Html where
|
template :: AtomFeed url -> Hamlet url IO ()
|
||||||
convertSuccess (e, ar) = Tag "entry" [] $ HtmlList
|
template = [$hamlet|
|
||||||
[ Tag "id" [] $ cs $ showLocation ar $ atomEntryLink e
|
%feed!xmlns=$xmlns$
|
||||||
, EmptyTag "link" [("href", showLocation ar $ atomEntryLink e)]
|
%title $atomTitle.cs$
|
||||||
, Tag "updated" [] $ cs $ formatW3 $ atomEntryUpdated e
|
%link!rel=self!href=@atomLinkSelf@
|
||||||
, Tag "title" [] $ cs $ atomEntryTitle e
|
%link!href=@atomLinkHome@
|
||||||
, Tag "content" [("type", "html")] $ cdata $ atomEntryContent e
|
%updated $atomUpdated.formatW3.cs$
|
||||||
]
|
%id @atomLinkHome@
|
||||||
-}
|
$forall atomEntries entry
|
||||||
|
^entry.entryTemplate^
|
||||||
|
|]
|
||||||
|
|
||||||
|
entryTemplate :: AtomFeedEntry url -> Hamlet url IO ()
|
||||||
|
entryTemplate = [$hamlet|
|
||||||
|
%entry
|
||||||
|
%id @atomEntryLink@
|
||||||
|
%link!href=@atomEntryLink@
|
||||||
|
%updated $atomEntryUpdated.formatW3.cs$
|
||||||
|
%title $atomEntryTitle.cs$
|
||||||
|
%content!type=html $atomEntryContent.cdata$
|
||||||
|
|]
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user