mirror of
https://code.naskya.net/repos/ndqEd
synced 2025-01-12 01:45:07 +09:00
75 lines
2.1 KiB
Haskell
75 lines
2.1 KiB
Haskell
|
{- This file is part of Vervis.
|
||
|
-
|
||
|
- Written in 2016 by fr33domlover <fr33domlover@riseup.net>.
|
||
|
-
|
||
|
- ♡ Copying is an act of love. Please copy, reuse and share.
|
||
|
-
|
||
|
- The author(s) have dedicated all copyright and related and neighboring
|
||
|
- rights to this software to the public domain worldwide. This software is
|
||
|
- distributed without any warranty.
|
||
|
-
|
||
|
- You should have received a copy of the CC0 Public Domain Dedication along
|
||
|
- with this software. If not, see
|
||
|
- <http://creativecommons.org/publicdomain/zero/1.0/>.
|
||
|
-}
|
||
|
|
||
|
module Vervis.Paginate
|
||
|
( getPaginated
|
||
|
)
|
||
|
where
|
||
|
|
||
|
import Prelude
|
||
|
|
||
|
import Control.Arrow (second)
|
||
|
import Data.Default.Class (def)
|
||
|
import Data.Maybe (fromMaybe)
|
||
|
import Data.Monoid ((<>))
|
||
|
import Yesod.Core (MonadHandler (HandlerSite))
|
||
|
import Yesod.Core.Handler (getCurrentRoute, lookupGetParam)
|
||
|
import Yesod.Core.Widget (WidgetT)
|
||
|
|
||
|
import qualified Data.Text as T (null, pack)
|
||
|
import qualified Data.Text.Read as TR (decimal)
|
||
|
|
||
|
import Data.Functor.Local
|
||
|
import Data.Paginate.Local
|
||
|
import Yesod.Paginate.Local
|
||
|
|
||
|
navSettings :: NavSettings
|
||
|
navSettings = def
|
||
|
|
||
|
getCurrentPage :: MonadHandler m => m Int
|
||
|
getCurrentPage = lookupGetParam "page" <&> \ mpage ->
|
||
|
case mpage of
|
||
|
Nothing -> 1
|
||
|
Just page ->
|
||
|
case second T.null <$> TR.decimal page of
|
||
|
Right (p, True) -> p
|
||
|
_ -> 1
|
||
|
|
||
|
paginateSettings
|
||
|
:: MonadHandler m
|
||
|
=> (Int -> Int -> m (Int, f i))
|
||
|
-> PaginateSettings m f i
|
||
|
paginateSettings select = def
|
||
|
{ psSelect = select
|
||
|
, psCurrent = getCurrentPage
|
||
|
}
|
||
|
|
||
|
navWidgetSettings :: NavWidgetSettings
|
||
|
navWidgetSettings = def
|
||
|
|
||
|
getPaginated
|
||
|
:: MonadHandler m
|
||
|
=> (Int -> Int -> m (Int, f i))
|
||
|
-- ^ Given offset and limit, get total number of items and chosen subset
|
||
|
-> m (f i, WidgetT (HandlerSite m) IO ())
|
||
|
getPaginated select = do
|
||
|
(items, nm) <- paginate (paginateSettings select) navSettings
|
||
|
route <-
|
||
|
fromMaybe (error "Pagination in invalid response content") <$>
|
||
|
getCurrentRoute
|
||
|
let url n = (route, "?page=" <> T.pack (show n))
|
||
|
widget = pageNavWidget nm navWidgetSettings url
|
||
|
return (items, widget)
|