Ticket discussion and message routes
This commit is contained in:
parent
cdfaec81f2
commit
c942c7d398
7 changed files with 87 additions and 16 deletions
|
@ -80,6 +80,7 @@ Ticket
|
||||||
UniqueTicket project number
|
UniqueTicket project number
|
||||||
|
|
||||||
Discussion
|
Discussion
|
||||||
|
nextMessage Int
|
||||||
|
|
||||||
Message
|
Message
|
||||||
author PersonId
|
author PersonId
|
||||||
|
@ -87,3 +88,6 @@ Message
|
||||||
content Text -- Assume this is Pandoc Markdown
|
content Text -- Assume this is Pandoc Markdown
|
||||||
parent MessageId Maybe
|
parent MessageId Maybe
|
||||||
root DiscussionId
|
root DiscussionId
|
||||||
|
number Int
|
||||||
|
|
||||||
|
UniqueMessage root number
|
||||||
|
|
|
@ -60,6 +60,8 @@
|
||||||
/u/#Text/p/#Text/t/!new TicketNewR GET
|
/u/#Text/p/#Text/t/!new TicketNewR GET
|
||||||
/u/#Text/p/#Text/t/#Int TicketR GET PUT DELETE POST
|
/u/#Text/p/#Text/t/#Int TicketR GET PUT DELETE POST
|
||||||
/u/#Text/p/#Text/t/#Int/edit TicketEditR GET
|
/u/#Text/p/#Text/t/#Int/edit TicketEditR GET
|
||||||
|
/u/#Text/p/#Text/t/#Int/d TicketDiscussionR GET
|
||||||
|
/u/#Text/p/#Text/t/#Int/d/#Int TicketCommentR GET
|
||||||
|
|
||||||
-- /u/#Text/p/#Text/w WikiR GET
|
-- /u/#Text/p/#Text/w WikiR GET
|
||||||
-- /u/#Text/p/#Text/w/+Texts WikiPageR GET
|
-- /u/#Text/p/#Text/w/+Texts WikiPageR GET
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
-}
|
-}
|
||||||
|
|
||||||
module Vervis.Discussion
|
module Vervis.Discussion
|
||||||
( getDiscussion
|
( getDiscussionTree
|
||||||
)
|
)
|
||||||
where
|
where
|
||||||
|
|
||||||
|
@ -67,5 +67,5 @@ sortByTime = sortForestOn $ messageCreated . fst
|
||||||
|
|
||||||
-- | Get the tree of messages in a given discussion, with siblings sorted from
|
-- | Get the tree of messages in a given discussion, with siblings sorted from
|
||||||
-- old to new.
|
-- old to new.
|
||||||
getDiscussion :: DiscussionId -> Handler (Forest (Message, Sharer))
|
getDiscussionTree :: DiscussionId -> Handler (Forest (Message, Sharer))
|
||||||
getDiscussion did = sortByTime . discussionTree <$> getMessages did
|
getDiscussionTree did = sortByTime . discussionTree <$> getMessages did
|
||||||
|
|
46
src/Vervis/Handler/Discussion.hs
Normal file
46
src/Vervis/Handler/Discussion.hs
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
{- 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.Handler.Discussion
|
||||||
|
( getDiscussion
|
||||||
|
, getComment
|
||||||
|
)
|
||||||
|
where
|
||||||
|
|
||||||
|
import Prelude
|
||||||
|
|
||||||
|
import Control.Monad.IO.Class (liftIO)
|
||||||
|
import Data.Time.Clock (getCurrentTime)
|
||||||
|
import Database.Persist (Entity (..))
|
||||||
|
import Text.Blaze.Html (Html)
|
||||||
|
import Yesod.Core (defaultLayout)
|
||||||
|
import Yesod.Persist.Core (runDB, get404, getBy404)
|
||||||
|
|
||||||
|
import Vervis.Foundation (Handler)
|
||||||
|
import Vervis.Model
|
||||||
|
import Vervis.Widget.Discussion
|
||||||
|
|
||||||
|
getDiscussion :: DiscussionId -> Handler Html
|
||||||
|
getDiscussion did = defaultLayout $ discussionW did
|
||||||
|
|
||||||
|
getComment :: DiscussionId -> Int -> Handler Html
|
||||||
|
getComment did num = do
|
||||||
|
(msg, shr) <- runDB $ do
|
||||||
|
Entity _mid m <- getBy404 $ UniqueMessage did num
|
||||||
|
p <- get404 $ messageAuthor m
|
||||||
|
s <- get404 $ personIdent p
|
||||||
|
return (m, s)
|
||||||
|
now <- liftIO getCurrentTime
|
||||||
|
defaultLayout $ messageW shr (messageCreated msg) now (messageContent msg)
|
|
@ -22,6 +22,8 @@ module Vervis.Handler.Ticket
|
||||||
, deleteTicketR
|
, deleteTicketR
|
||||||
, postTicketR
|
, postTicketR
|
||||||
, getTicketEditR
|
, getTicketEditR
|
||||||
|
, getTicketDiscussionR
|
||||||
|
, getTicketCommentR
|
||||||
)
|
)
|
||||||
where
|
where
|
||||||
|
|
||||||
|
@ -39,7 +41,6 @@ import Text.Blaze.Html (Html, toHtml)
|
||||||
import Yesod.Auth (requireAuthId)
|
import Yesod.Auth (requireAuthId)
|
||||||
import Yesod.Core (defaultLayout)
|
import Yesod.Core (defaultLayout)
|
||||||
import Yesod.Core.Handler (setMessage, redirect, lookupPostParam, notFound)
|
import Yesod.Core.Handler (setMessage, redirect, lookupPostParam, notFound)
|
||||||
import Yesod.Core.Widget (setTitle)
|
|
||||||
import Yesod.Form.Functions (runFormPost)
|
import Yesod.Form.Functions (runFormPost)
|
||||||
import Yesod.Form.Types (FormResult (..))
|
import Yesod.Form.Types (FormResult (..))
|
||||||
import Yesod.Persist.Core (runDB, get404, getBy404)
|
import Yesod.Persist.Core (runDB, get404, getBy404)
|
||||||
|
@ -49,6 +50,7 @@ import qualified Database.Esqueleto as E ((==.))
|
||||||
|
|
||||||
import Vervis.Form.Ticket
|
import Vervis.Form.Ticket
|
||||||
import Vervis.Foundation
|
import Vervis.Foundation
|
||||||
|
import Vervis.Handler.Discussion
|
||||||
import Vervis.MediaType (MediaType (Markdown))
|
import Vervis.MediaType (MediaType (Markdown))
|
||||||
import Vervis.Model
|
import Vervis.Model
|
||||||
import Vervis.Render (renderSourceT)
|
import Vervis.Render (renderSourceT)
|
||||||
|
@ -85,7 +87,10 @@ postTicketsR shar proj = do
|
||||||
Entity sid _sharer <- getBy404 $ UniqueSharerIdent shar
|
Entity sid _sharer <- getBy404 $ UniqueSharerIdent shar
|
||||||
getBy404 $ UniqueProject proj sid
|
getBy404 $ UniqueProject proj sid
|
||||||
update pid [ProjectNextTicket +=. 1]
|
update pid [ProjectNextTicket +=. 1]
|
||||||
did <- insert Discussion
|
let discussion = Discussion
|
||||||
|
{ discussionNextMessage = 1
|
||||||
|
}
|
||||||
|
did <- insert discussion
|
||||||
let ticket = Ticket
|
let ticket = Ticket
|
||||||
{ ticketProject = pid
|
{ ticketProject = pid
|
||||||
, ticketNumber = projectNextTicket project
|
, ticketNumber = projectNextTicket project
|
||||||
|
@ -130,10 +135,7 @@ getTicketR shar proj num = do
|
||||||
else return author
|
else return author
|
||||||
return (author, closer, ticket)
|
return (author, closer, ticket)
|
||||||
let desc = renderSourceT Markdown $ T.filter (/= '\r') $ ticketDesc ticket
|
let desc = renderSourceT Markdown $ T.filter (/= '\r') $ ticketDesc ticket
|
||||||
defaultLayout $ do
|
defaultLayout $(widgetFile "ticket/one")
|
||||||
setTitle $ toHtml $ T.intercalate " :: "
|
|
||||||
[shar, proj, "Tickets", T.pack ('#' : show num)]
|
|
||||||
$(widgetFile "ticket/one")
|
|
||||||
|
|
||||||
putTicketR :: Text -> Text -> Int -> Handler Html
|
putTicketR :: Text -> Text -> Int -> Handler Html
|
||||||
putTicketR shar proj num = do
|
putTicketR shar proj num = do
|
||||||
|
@ -177,7 +179,22 @@ getTicketEditR shar proj num = do
|
||||||
getBy404 $ UniqueTicket pid num
|
getBy404 $ UniqueTicket pid num
|
||||||
user <- requireAuthId
|
user <- requireAuthId
|
||||||
((_result, widget), enctype) <- runFormPost $ editTicketForm ticket user
|
((_result, widget), enctype) <- runFormPost $ editTicketForm ticket user
|
||||||
defaultLayout $ do
|
defaultLayout $(widgetFile "ticket/edit")
|
||||||
setTitle $ toHtml $ T.intercalate " :: "
|
|
||||||
[shar, proj, "Tickets", T.pack ('#' : show num), "Edit"]
|
getTicketDiscussionR :: Text -> Text -> Int -> Handler Html
|
||||||
$(widgetFile "ticket/edit")
|
getTicketDiscussionR shar proj num = do
|
||||||
|
did <- runDB $ do
|
||||||
|
Entity sid _sharer <- getBy404 $ UniqueSharerIdent shar
|
||||||
|
Entity pid _project <- getBy404 $ UniqueProject proj sid
|
||||||
|
Entity _tid ticket <- getBy404 $ UniqueTicket pid num
|
||||||
|
return $ ticketDiscuss ticket
|
||||||
|
getDiscussion did
|
||||||
|
|
||||||
|
getTicketCommentR :: Text -> Text -> Int -> Int -> Handler Html
|
||||||
|
getTicketCommentR shar proj tnum cnum = do
|
||||||
|
did <- runDB $ do
|
||||||
|
Entity sid _sharer <- getBy404 $ UniqueSharerIdent shar
|
||||||
|
Entity pid _project <- getBy404 $ UniqueProject proj sid
|
||||||
|
Entity _tid ticket <- getBy404 $ UniqueTicket pid tnum
|
||||||
|
return $ ticketDiscuss ticket
|
||||||
|
getComment did cnum
|
||||||
|
|
|
@ -14,7 +14,8 @@
|
||||||
-}
|
-}
|
||||||
|
|
||||||
module Vervis.Widget.Discussion
|
module Vervis.Widget.Discussion
|
||||||
( discussionW
|
( messageW
|
||||||
|
, discussionW
|
||||||
)
|
)
|
||||||
where
|
where
|
||||||
|
|
||||||
|
@ -32,7 +33,7 @@ import Yesod.Core.Widget (whamlet, toWidget, handlerToWidget)
|
||||||
|
|
||||||
import Data.EventTime.Local (intervalToEventTime, showEventTime)
|
import Data.EventTime.Local (intervalToEventTime, showEventTime)
|
||||||
import Data.Time.Clock.Local ()
|
import Data.Time.Clock.Local ()
|
||||||
import Vervis.Discussion (getDiscussion)
|
import Vervis.Discussion (getDiscussionTree)
|
||||||
import Vervis.Foundation
|
import Vervis.Foundation
|
||||||
import Vervis.MediaType (MediaType (Markdown))
|
import Vervis.MediaType (MediaType (Markdown))
|
||||||
import Vervis.Model
|
import Vervis.Model
|
||||||
|
@ -56,7 +57,7 @@ messageTreeW cReplies now t = go t
|
||||||
|
|
||||||
discussionW :: DiscussionId -> Widget
|
discussionW :: DiscussionId -> Widget
|
||||||
discussionW did = do
|
discussionW did = do
|
||||||
forest <- handlerToWidget $ getDiscussion did
|
forest <- handlerToWidget $ getDiscussionTree did
|
||||||
cReplies <- newIdent
|
cReplies <- newIdent
|
||||||
now <- liftIO getCurrentTime
|
now <- liftIO getCurrentTime
|
||||||
toWidget $(cassiusFile "templates/discussion/widget/tree.cassius")
|
toWidget $(cassiusFile "templates/discussion/widget/tree.cassius")
|
||||||
|
|
|
@ -85,6 +85,7 @@ library
|
||||||
Vervis.Git
|
Vervis.Git
|
||||||
Vervis.GitOld
|
Vervis.GitOld
|
||||||
Vervis.Handler.Common
|
Vervis.Handler.Common
|
||||||
|
Vervis.Handler.Discussion
|
||||||
Vervis.Handler.Git
|
Vervis.Handler.Git
|
||||||
Vervis.Handler.Home
|
Vervis.Handler.Home
|
||||||
Vervis.Handler.Key
|
Vervis.Handler.Key
|
||||||
|
|
Loading…
Reference in a new issue