module Handler.Pager (getThreadPagerR) where
import Import
import Prelude (tail)
import Settings
import StaticFiles
import NotmuchCmd
import Data.Maybe (listToMaybe)
import Handler.View
import qualified Data.Text as T
import qualified Data.HashMap.Strict as H
import Text.Blaze (unsafeLazyByteString)
import Data.Aeson (encode)
encodeSearch :: (Route App -> T.Text) -> [SearchResult] -> Html
encodeSearch ur search = unsafeLazyByteString $ encode $ map enc search
where
enc s = uncurry H.insert ("url" .= ur (ThreadR $ searchThread s)) (toObj s)
toObj s = case toJSON s of
Object o -> o
_ -> error "Search is not an object"
getThreadPagerR :: String -> Handler RepHtml
getThreadPagerR s = defaultLayout $ do
search <- notmuchSearch s
ur <- getUrlRender
retags <- extraRetag <$> getExtra
addScript $ StaticR js_jquery_pjax_1_7_0_js
$(widgetFile "pager")