mirror of
https://code.sup39.dev/repos/Wqawg
synced 2025-01-16 05:25:09 +09:00
Move repo collab selector fields to the field module
This commit is contained in:
parent
52b9717a3a
commit
c86c0f547a
2 changed files with 41 additions and 28 deletions
|
@ -15,6 +15,8 @@
|
|||
|
||||
module Vervis.Field.Repo
|
||||
( mkIdentField
|
||||
, selectCollabFromAll
|
||||
, selectCollabFromProject
|
||||
, selectProjectForNew
|
||||
, selectProjectForExisting
|
||||
)
|
||||
|
@ -29,7 +31,7 @@ import Database.Esqueleto
|
|||
|
||||
import qualified Database.Persist as P ((==.))
|
||||
|
||||
import Vervis.Model.Ident (text2rp, prj2text)
|
||||
import Vervis.Model.Ident (shr2text, text2rp, prj2text)
|
||||
|
||||
checkIdentTemplate :: Field Handler Text -> Field Handler Text
|
||||
checkIdentTemplate =
|
||||
|
@ -59,6 +61,42 @@ checkIdentUnique sid = checkM $ \ ident -> do
|
|||
mkIdentField :: SharerId -> Field Handler Text
|
||||
mkIdentField sid = checkIdentUnique sid . checkIdentTemplate $ textField
|
||||
|
||||
-- | Select a new collaborator for a repo, from the list of users of the
|
||||
-- server. It can be any person who isn't already a collaborator.
|
||||
selectCollabFromAll :: RepoId -> Field Handler PersonId
|
||||
selectCollabFromAll rid = selectField $ do
|
||||
l <- runDB $ select $
|
||||
from $ \ (collab `RightOuterJoin` person `InnerJoin` sharer) -> do
|
||||
on $ person ^. PersonIdent ==. sharer ^. SharerId
|
||||
on $
|
||||
collab ?. RepoCollabRepo ==. just (val rid) &&.
|
||||
collab ?. RepoCollabPerson ==. just (person ^. PersonId)
|
||||
where_ $ isNothing $ collab ?. RepoCollabId
|
||||
return (sharer ^. SharerIdent, person ^. PersonId)
|
||||
optionsPairs $ map (shr2text . unValue *** unValue) l
|
||||
|
||||
-- | Select a new collaborator for a repo, from the list of collaborators of
|
||||
-- the project it belongs to. It can be any collaborator of the project, who
|
||||
-- isn't yet a collaborator of the repo.
|
||||
selectCollabFromProject :: ProjectId -> RepoId -> Field Handler PersonId
|
||||
selectCollabFromProject jid rid = selectField $ do
|
||||
l <- runDB $ select $ from $
|
||||
\ ( pcollab `InnerJoin`
|
||||
person `LeftOuterJoin`
|
||||
rcollab `InnerJoin`
|
||||
sharer
|
||||
) -> do
|
||||
on $ person ^. PersonIdent ==. sharer ^. SharerId
|
||||
on $
|
||||
rcollab ?. RepoCollabRepo ==. just (val rid) &&.
|
||||
rcollab ?. RepoCollabPerson ==. just (person ^. PersonId)
|
||||
on $
|
||||
pcollab ^. ProjectCollabProject ==. val jid &&.
|
||||
pcollab ^. ProjectCollabPerson ==. person ^. PersonId
|
||||
where_ $ isNothing $ rcollab ?. RepoCollabId
|
||||
return (sharer ^. SharerIdent, person ^. PersonId)
|
||||
optionsPairs $ map (shr2text . unValue *** unValue) l
|
||||
|
||||
-- | Select a project for a new repository to belong to. It can be any project
|
||||
-- of the same sharer who's sharing the repo.
|
||||
selectProjectForNew :: SharerId -> Field Handler ProjectId
|
||||
|
|
|
@ -75,33 +75,8 @@ newRepoCollabAForm pid mjid rid = NewRepoCollab
|
|||
<$> areq (selectPerson mjid) "Person*" Nothing
|
||||
<*> areq selectRole "Role*" Nothing
|
||||
where
|
||||
selectPerson Nothing = selectField $ do
|
||||
l <- runDB $ select $
|
||||
from $ \ (collab `RightOuterJoin` person `InnerJoin` sharer) -> do
|
||||
on $ person ^. PersonIdent E.==. sharer ^. SharerId
|
||||
on $
|
||||
collab ?. RepoCollabRepo E.==. just (val rid) &&.
|
||||
collab ?. RepoCollabPerson E.==. just (person ^. PersonId)
|
||||
where_ $ isNothing $ collab ?. RepoCollabId
|
||||
return (sharer ^. SharerIdent, person ^. PersonId)
|
||||
optionsPairs $ map (shr2text . unValue *** unValue) l
|
||||
selectPerson (Just jid) = selectField $ do
|
||||
l <- runDB $ select $ from $
|
||||
\ ( pcollab `InnerJoin`
|
||||
person `LeftOuterJoin`
|
||||
rcollab `InnerJoin`
|
||||
sharer
|
||||
) -> do
|
||||
on $ person ^. PersonIdent E.==. sharer ^. SharerId
|
||||
on $
|
||||
rcollab ?. RepoCollabRepo E.==. just (val rid) &&.
|
||||
rcollab ?. RepoCollabPerson E.==. just (person ^. PersonId)
|
||||
on $
|
||||
pcollab ^. ProjectCollabProject E.==. val jid &&.
|
||||
pcollab ^. ProjectCollabPerson E.==. person ^. PersonId
|
||||
where_ $ isNothing $ rcollab ?. RepoCollabId
|
||||
return (sharer ^. SharerIdent, person ^. PersonId)
|
||||
optionsPairs $ map (shr2text . unValue *** unValue) l
|
||||
selectPerson Nothing = selectCollabFromAll rid
|
||||
selectPerson (Just jid) = selectCollabFromProject jid rid
|
||||
selectRole =
|
||||
selectField $
|
||||
optionsPersistKey [RepoRolePerson ==. pid] [] $
|
||||
|
|
Loading…
Reference in a new issue