mirror of
https://code.naskya.net/repos/ndqEd
synced 2025-01-10 11:16:46 +09:00
UI: Some tweaks, following ikomi's suggestions, thank you ikomi :)
This commit is contained in:
parent
b95e9a8006
commit
4dcd6eb1b2
8 changed files with 63 additions and 46 deletions
|
@ -87,6 +87,8 @@
|
||||||
-- Projects
|
-- Projects
|
||||||
-- ----------------------------------------------------------------------------
|
-- ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
/browse BrowseR GET
|
||||||
|
|
||||||
/s/#ShrIdent/r ReposR GET POST
|
/s/#ShrIdent/r ReposR GET POST
|
||||||
/s/#ShrIdent/r/!new RepoNewR GET
|
/s/#ShrIdent/r/!new RepoNewR GET
|
||||||
/s/#ShrIdent/r/#RpIdent RepoR GET PUT DELETE POST
|
/s/#ShrIdent/r/#RpIdent RepoR GET PUT DELETE POST
|
||||||
|
|
|
@ -40,9 +40,9 @@ import Vervis.Model
|
||||||
import Vervis.Model.Ident (text2ky)
|
import Vervis.Model.Ident (text2ky)
|
||||||
|
|
||||||
sshKeyField :: Field Handler (ByteString, ByteString)
|
sshKeyField :: Field Handler (ByteString, ByteString)
|
||||||
sshKeyField = checkMMap (pure . parseKey) renderKey textField
|
sshKeyField = checkMMap (pure . parseKey) renderKey textareaField
|
||||||
where
|
where
|
||||||
parseKey t =
|
parseKey (Textarea t) =
|
||||||
case T.words t of
|
case T.words t of
|
||||||
a:c:_ ->
|
a:c:_ ->
|
||||||
(,) <$> parseAlgo a
|
(,) <$> parseAlgo a
|
||||||
|
@ -58,7 +58,7 @@ sshKeyField = checkMMap (pure . parseKey) renderKey textField
|
||||||
case B64.decode $ encodeUtf8 t of
|
case B64.decode $ encodeUtf8 t of
|
||||||
Left s -> Left $ T.pack s
|
Left s -> Left $ T.pack s
|
||||||
Right b -> Right b
|
Right b -> Right b
|
||||||
renderKey (a, c) = T.concat [decodeUtf8 a, " ", decodeUtf8 c]
|
renderKey (a, c) = Textarea $ T.concat [decodeUtf8 a, " ", decodeUtf8 c]
|
||||||
|
|
||||||
checkNameUnique :: PersonId -> Field Handler Text -> Field Handler Text
|
checkNameUnique :: PersonId -> Field Handler Text -> Field Handler Text
|
||||||
checkNameUnique pid = checkM $ \ ident -> do
|
checkNameUnique pid = checkM $ \ ident -> do
|
||||||
|
|
|
@ -833,6 +833,8 @@ instance YesodBreadcrumbs App where
|
||||||
GitRefDiscoverR _ _ -> ("", Nothing)
|
GitRefDiscoverR _ _ -> ("", Nothing)
|
||||||
GitUploadRequestR _ _ -> ("", Nothing)
|
GitUploadRequestR _ _ -> ("", Nothing)
|
||||||
|
|
||||||
|
BrowseR -> ("Browse", Just HomeR)
|
||||||
|
|
||||||
ProjectsR shar -> ("Projects", Just $ SharerR shar)
|
ProjectsR shar -> ("Projects", Just $ SharerR shar)
|
||||||
ProjectNewR shar -> ("New", Just $ ProjectsR shar)
|
ProjectNewR shar -> ("New", Just $ ProjectsR shar)
|
||||||
ProjectR shar proj -> ( prj2text proj
|
ProjectR shar proj -> ( prj2text proj
|
||||||
|
|
|
@ -18,6 +18,8 @@ module Vervis.Handler.Client
|
||||||
, postSharerOutboxR
|
, postSharerOutboxR
|
||||||
, postPublishR
|
, postPublishR
|
||||||
|
|
||||||
|
, getBrowseR
|
||||||
|
|
||||||
, postSharerFollowR
|
, postSharerFollowR
|
||||||
, postProjectFollowR
|
, postProjectFollowR
|
||||||
, postTicketFollowR
|
, postTicketFollowR
|
||||||
|
@ -82,9 +84,13 @@ import Vervis.Form.Ticket
|
||||||
import Vervis.Foundation
|
import Vervis.Foundation
|
||||||
import Vervis.Model
|
import Vervis.Model
|
||||||
import Vervis.Model.Ident
|
import Vervis.Model.Ident
|
||||||
|
import Vervis.Model.Repo
|
||||||
|
import Vervis.Path
|
||||||
import Vervis.Settings
|
import Vervis.Settings
|
||||||
|
|
||||||
import qualified Vervis.Client as C
|
import qualified Vervis.Client as C
|
||||||
|
import qualified Vervis.Darcs as D
|
||||||
|
import qualified Vervis.Git as G
|
||||||
|
|
||||||
getShowTime = showTime <$> liftIO getCurrentTime
|
getShowTime = showTime <$> liftIO getCurrentTime
|
||||||
where
|
where
|
||||||
|
@ -366,6 +372,43 @@ postPublishR = do
|
||||||
C.follow shrAuthor uObject uRecip False
|
C.follow shrAuthor uObject uRecip False
|
||||||
ExceptT $ followC shrAuthor summary audience followAP
|
ExceptT $ followC shrAuthor summary audience followAP
|
||||||
|
|
||||||
|
getBrowseR :: Handler Html
|
||||||
|
getBrowseR = do
|
||||||
|
rows <- do
|
||||||
|
repos <- runDB $ E.select $ E.from $
|
||||||
|
\ (repo `E.LeftOuterJoin` project `E.InnerJoin` sharer) -> do
|
||||||
|
E.on $ repo E.^. RepoSharer E.==. sharer E.^. SharerId
|
||||||
|
E.on $ repo E.^. RepoProject E.==. project E.?. ProjectId
|
||||||
|
E.orderBy
|
||||||
|
[ E.asc $ sharer E.^. SharerIdent
|
||||||
|
, E.asc $ project E.?. ProjectIdent
|
||||||
|
, E.asc $ repo E.^. RepoIdent
|
||||||
|
]
|
||||||
|
return
|
||||||
|
( sharer E.^. SharerIdent
|
||||||
|
, project E.?. ProjectIdent
|
||||||
|
, repo E.^. RepoIdent
|
||||||
|
, repo E.^. RepoVcs
|
||||||
|
)
|
||||||
|
now <- liftIO getCurrentTime
|
||||||
|
forM repos $
|
||||||
|
\ (E.Value sharer, E.Value mproj, E.Value repo, E.Value vcs) -> do
|
||||||
|
path <- askRepoDir sharer repo
|
||||||
|
mlast <- case vcs of
|
||||||
|
VCSDarcs -> liftIO $ D.lastChange path now
|
||||||
|
VCSGit -> do
|
||||||
|
mt <- liftIO $ G.lastCommitTime path
|
||||||
|
return $ Just $ case mt of
|
||||||
|
Nothing -> Never
|
||||||
|
Just t ->
|
||||||
|
intervalToEventTime $
|
||||||
|
FriendlyConvert $
|
||||||
|
now `diffUTCTime` t
|
||||||
|
return (sharer, mproj, repo, vcs, mlast)
|
||||||
|
defaultLayout $ do
|
||||||
|
setTitle "Welcome to Vervis!"
|
||||||
|
$(widgetFile "homepage")
|
||||||
|
|
||||||
setFollowMessage :: ShrIdent -> Either Text OutboxItemId -> Handler ()
|
setFollowMessage :: ShrIdent -> Either Text OutboxItemId -> Handler ()
|
||||||
setFollowMessage _ (Left err) = setMessage $ toHtml err
|
setFollowMessage _ (Left err) = setMessage $ toHtml err
|
||||||
setFollowMessage shr (Right obiid) = do
|
setFollowMessage shr (Right obiid) = do
|
||||||
|
|
|
@ -44,43 +44,6 @@ import Vervis.Settings
|
||||||
import qualified Vervis.Git as G
|
import qualified Vervis.Git as G
|
||||||
import qualified Vervis.Darcs as D
|
import qualified Vervis.Darcs as D
|
||||||
|
|
||||||
intro :: Handler Html
|
|
||||||
intro = do
|
|
||||||
rows <- do
|
|
||||||
repos <- runDB $ select $ from $
|
|
||||||
\ (repo `LeftOuterJoin` project `InnerJoin` sharer) -> do
|
|
||||||
on $ repo ^. RepoSharer E.==. sharer ^. SharerId
|
|
||||||
on $ repo ^. RepoProject E.==. project ?. ProjectId
|
|
||||||
orderBy
|
|
||||||
[ asc $ sharer ^. SharerIdent
|
|
||||||
, asc $ project ?. ProjectIdent
|
|
||||||
, asc $ repo ^. RepoIdent
|
|
||||||
]
|
|
||||||
return
|
|
||||||
( sharer ^. SharerIdent
|
|
||||||
, project ?. ProjectIdent
|
|
||||||
, repo ^. RepoIdent
|
|
||||||
, repo ^. RepoVcs
|
|
||||||
)
|
|
||||||
now <- liftIO getCurrentTime
|
|
||||||
forM repos $
|
|
||||||
\ (Value sharer, Value mproj, Value repo, Value vcs) -> do
|
|
||||||
path <- askRepoDir sharer repo
|
|
||||||
mlast <- case vcs of
|
|
||||||
VCSDarcs -> liftIO $ D.lastChange path now
|
|
||||||
VCSGit -> do
|
|
||||||
mt <- liftIO $ G.lastCommitTime path
|
|
||||||
return $ Just $ case mt of
|
|
||||||
Nothing -> Never
|
|
||||||
Just t ->
|
|
||||||
intervalToEventTime $
|
|
||||||
FriendlyConvert $
|
|
||||||
now `diffUTCTime` t
|
|
||||||
return (sharer, mproj, repo, vcs, mlast)
|
|
||||||
defaultLayout $ do
|
|
||||||
setTitle "Welcome to Vervis!"
|
|
||||||
$(widgetFile "homepage")
|
|
||||||
|
|
||||||
personalOverview :: Entity Person -> Handler Html
|
personalOverview :: Entity Person -> Handler Html
|
||||||
personalOverview (Entity _pid person) = do
|
personalOverview (Entity _pid person) = do
|
||||||
(ident, projects, repos) <- runDB $ do
|
(ident, projects, repos) <- runDB $ do
|
||||||
|
@ -104,4 +67,4 @@ getHomeR = do
|
||||||
mp <- maybeAuth
|
mp <- maybeAuth
|
||||||
case mp of
|
case mp of
|
||||||
Just p -> personalOverview p
|
Just p -> personalOverview p
|
||||||
Nothing -> intro
|
Nothing -> redirect BrowseR
|
||||||
|
|
|
@ -34,6 +34,9 @@ $maybe (Entity _pid person, verified, sharer, unread) <- mperson
|
||||||
<span>
|
<span>
|
||||||
<a href=@{SharerFollowingR $ sharerIdent sharer}>
|
<a href=@{SharerFollowingR $ sharerIdent sharer}>
|
||||||
[🐔 Following]
|
[🐔 Following]
|
||||||
|
<span>
|
||||||
|
<a href=@{BrowseR}>
|
||||||
|
[📚 Browse projects]
|
||||||
<span>
|
<span>
|
||||||
<a href=@{PublishR}>
|
<a href=@{PublishR}>
|
||||||
[📣 Publish an activity]
|
[📣 Publish an activity]
|
||||||
|
|
|
@ -23,4 +23,4 @@ $# <http://creativecommons.org/publicdomain/zero/1.0/>.
|
||||||
<form method=POST action=@{KeysR} enctype=#{enctype}>
|
<form method=POST action=@{KeysR} enctype=#{enctype}>
|
||||||
^{widget}
|
^{widget}
|
||||||
<div class="submit">
|
<div class="submit">
|
||||||
<input type="submit">
|
<input type="submit" value="Add key">
|
||||||
|
|
|
@ -12,10 +12,14 @@ $# You should have received a copy of the CC0 Public Domain Dedication along
|
||||||
$# with this software. If not, see
|
$# with this software. If not, see
|
||||||
$# <http://creativecommons.org/publicdomain/zero/1.0/>.
|
$# <http://creativecommons.org/publicdomain/zero/1.0/>.
|
||||||
|
|
||||||
<form method=POST action=@{NotificationsR shr} enctype=#{enctypeAll}>
|
$if null notifications
|
||||||
^{widgetAll}
|
<p>
|
||||||
<div class="submit">
|
Nothing new here :-)
|
||||||
<input type="submit" value="Mark all as read">
|
$else
|
||||||
|
<form method=POST action=@{NotificationsR shr} enctype=#{enctypeAll}>
|
||||||
|
^{widgetAll}
|
||||||
|
<div class="submit">
|
||||||
|
<input type="submit" value="Mark all as read">
|
||||||
|
|
||||||
<div>
|
<div>
|
||||||
$forall ((obj, (time, isRemote)), widget, enctype) <- notifications
|
$forall ((obj, (time, isRemote)), widget, enctype) <- notifications
|
||||||
|
|
Loading…
Reference in a new issue