UI: Deck: Projects list page

This commit is contained in:
Pere Lev 2023-11-02 14:48:22 +02:00
parent acc1d13c63
commit fe6f95d497
No known key found for this signature in database
GPG key ID: 5252C5C863E5E57D
7 changed files with 108 additions and 1 deletions

View file

@ -938,6 +938,8 @@ instance YesodBreadcrumbs App where
DeckInviteR d -> ("Invite", Just $ DeckR d) DeckInviteR d -> ("Invite", Just $ DeckR d)
DeckRemoveR _ _ -> ("", Nothing) DeckRemoveR _ _ -> ("", Nothing)
DeckProjectsR d -> ("Projects", Just $ DeckR d)
TicketR d t -> ("#" <> keyHashidText t, Just $ DeckTicketsR d) TicketR d t -> ("#" <> keyHashidText t, Just $ DeckTicketsR d)
TicketDiscussionR d t -> ("Discussion", Just $ TicketR d t) TicketDiscussionR d t -> ("Discussion", Just $ TicketR d t)
TicketEventsR d t -> ("Events", Just $ TicketR d t) TicketEventsR d t -> ("Events", Just $ TicketR d t)

View file

@ -40,6 +40,7 @@ module Vervis.Handler.Deck
, getDeckInviteR , getDeckInviteR
, postDeckInviteR , postDeckInviteR
, postDeckRemoveR , postDeckRemoveR
, getDeckProjectsR
@ -69,7 +70,7 @@ import Data.Bitraversable
import Data.ByteString (ByteString) import Data.ByteString (ByteString)
import Data.Default.Class import Data.Default.Class
import Data.Foldable import Data.Foldable
import Data.Maybe (fromMaybe) import Data.Maybe (fromMaybe, isJust)
import Data.Text (Text) import Data.Text (Text)
import Data.Time.Clock import Data.Time.Clock
import Data.Traversable import Data.Traversable
@ -529,6 +530,39 @@ postDeckRemoveR deckHash ctID = do
setMessage "Remove sent" setMessage "Remove sent"
redirect $ DeckCollabsR deckHash redirect $ DeckCollabsR deckHash
getDeckProjectsR :: KeyHashid Deck -> Handler Html
getDeckProjectsR deckHash = do
deckID <- decodeKeyHashid404 deckHash
(deck, actor, stems) <- runDB $ do
deck <- get404 deckID
actor <- getJust $ deckActor deck
stems <-
E.select $ E.from $ \ (ident `E.InnerJoin` stem `E.InnerJoin` accept `E.LeftOuterJoin` deleg) -> do
E.on $ E.just (accept E.^. StemComponentAcceptId) E.==. deleg E.?. StemDelegateLocalStem
E.on $ stem E.^. StemId E.==. accept E.^. StemComponentAcceptStem
E.on $ ident E.^. StemIdentDeckStem E.==. stem E.^. StemId
E.where_ $ ident E.^. StemIdentDeckDeck E.==. E.val deckID
return (stem, deleg)
stems' <- for stems $ \ (Entity stemID stem, deleg) -> do
j <- getStemProject stemID
projectView <-
bitraverse
(\ projectID -> do
actorID <- projectActor <$> getJust projectID
actor <- getJust actorID
return (projectID, actor)
)
(\ remoteActorID -> do
remoteActor <- getJust remoteActorID
remoteObject <- getJust $ remoteActorIdent remoteActor
inztance <- getJust $ remoteObjectInstance remoteObject
return (inztance, remoteObject, remoteActor)
)
j
return (projectView, stemRole stem, isJust deleg)
return (deck, actor, stems')
defaultLayout $(widgetFile "deck/projects")

View file

@ -17,6 +17,7 @@ module Vervis.Persist.Collab
( getCollabTopic ( getCollabTopic
, getCollabTopic' , getCollabTopic'
, getStemIdent , getStemIdent
, getStemProject
, getGrantRecip , getGrantRecip
, getComponentE , getComponentE
, getTopicGrants , getTopicGrants
@ -121,6 +122,17 @@ getStemIdent stemID = do
(Nothing, Nothing, Just l) -> ComponentLoom $ stemIdentLoomLoom l (Nothing, Nothing, Just l) -> ComponentLoom $ stemIdentLoomLoom l
_ -> error "Found Stem with multiple idents" _ -> error "Found Stem with multiple idents"
getStemProject
:: MonadIO m
=> StemId
-> ReaderT SqlBackend m (Either ProjectId RemoteActorId)
getStemProject stemID =
requireEitherAlt
(fmap stemProjectLocalProject <$> getValBy (UniqueStemProjectLocal stemID))
(fmap stemProjectRemoteProject <$> getValBy (UniqueStemProjectRemote stemID))
"Found Stem without project"
"Found Stem with multiple projects"
getGrantRecip (GrantRecipPerson k) e = GrantRecipPerson <$> getEntityE k e getGrantRecip (GrantRecipPerson k) e = GrantRecipPerson <$> getEntityE k e
getComponentE (ComponentRepo k) e = ComponentRepo <$> getEntityE k e getComponentE (ComponentRepo k) e = ComponentRepo <$> getEntityE k e

View file

@ -18,6 +18,7 @@ module Vervis.Widget.Tracker
, loomNavW , loomNavW
, projectNavW , projectNavW
, componentLinkFedW , componentLinkFedW
, projectLinkFedW
) )
where where
@ -83,3 +84,23 @@ componentLinkFedW (Right (inztance, object, actor)) =
|] |]
where where
uActor = ObjURI (instanceHost inztance) (remoteObjectIdent object) uActor = ObjURI (instanceHost inztance) (remoteObjectIdent object)
projectLinkFedW
:: Either (ProjectId, Actor) (Instance, RemoteObject, RemoteActor)
-> Widget
projectLinkFedW (Left (j, actor)) = do
h <- encodeKeyHashid j
[whamlet|
<a href=@{ProjectR h}>
\$#{keyHashidText h} #{actorName actor}
|]
projectLinkFedW (Right (inztance, object, actor)) =
[whamlet|
<a href="#{renderObjURI uActor}">
$maybe name <- remoteActorName actor
#{name}
$nothing
#{renderAuthority $ instanceHost inztance}#{localUriPath $ remoteObjectIdent object}
|]
where
uActor = ObjURI (instanceHost inztance) (remoteObjectIdent object)

View file

@ -0,0 +1,33 @@
$# This file is part of Vervis.
$#
$# Written in 2016, 2019, 2022, 2023 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/>.
^{deckNavW (Entity deckID deck) actor}
<h2>Collaborators
<table>
<tr>
<th>Role
<th>Project
<th>Enabled
$forall (project, role, enabled) <- stems
<tr>
<td>#{show role}
<td>^{projectLinkFedW project}
<td>
$if enabled
[x]
$else
[_]
$# <td>^{buttonW POST "Remove" (DeckRemoveR deckHash ctID)}

View file

@ -30,6 +30,10 @@ $# <http://creativecommons.org/publicdomain/zero/1.0/>.
<span> <span>
<a href=@{DeckCollabsR deckHash}> <a href=@{DeckCollabsR deckHash}>
[🤝 Collaborators] [🤝 Collaborators]
<span>
<a href=@{DeckProjectsR deckHash}>
[🏗 Projects]
<a href=@{DeckR deckHash}>
<span> <span>
<a href=@{DeckTicketsR deckHash}> <a href=@{DeckTicketsR deckHash}>
[🐛 Tickets] [🐛 Tickets]

View file

@ -223,6 +223,7 @@
/decks/#DeckKeyHashid/collabs DeckCollabsR GET /decks/#DeckKeyHashid/collabs DeckCollabsR GET
/decks/#DeckKeyHashid/invite DeckInviteR GET POST /decks/#DeckKeyHashid/invite DeckInviteR GET POST
/decks/#DeckKeyHashid/remove/#CollabTopicDeckId DeckRemoveR POST /decks/#DeckKeyHashid/remove/#CollabTopicDeckId DeckRemoveR POST
/decks/#DeckKeyHashid/projects DeckProjectsR GET
---- Ticket ------------------------------------------------------------------ ---- Ticket ------------------------------------------------------------------