mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-30 15:43:52 +03:00
add collaboration page ui
This commit is contained in:
parent
49dc57e336
commit
52fbb9788a
7 changed files with 306 additions and 126 deletions
|
@ -387,6 +387,12 @@ html, body {
|
||||||
|
|
||||||
/* gogits user setting */
|
/* gogits user setting */
|
||||||
|
|
||||||
|
#user-setting-nav {
|
||||||
|
background-color: #FFF;
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
#user-setting-nav > h4, #user-setting-container > h4, #user-setting-container > div > h4,
|
#user-setting-nav > h4, #user-setting-container > h4, #user-setting-container > div > h4,
|
||||||
#ssh-keys > h4, #user-delete > h4, #repo-setting-container .tab-pane > h4 {
|
#ssh-keys > h4, #user-delete > h4, #repo-setting-container .tab-pane > h4 {
|
||||||
padding-bottom: 18px;
|
padding-bottom: 18px;
|
||||||
|
@ -396,13 +402,14 @@ html, body {
|
||||||
|
|
||||||
#user-setting-nav .list-group .list-group-item a {
|
#user-setting-nav .list-group .list-group-item a {
|
||||||
margin-left: 0;
|
margin-left: 0;
|
||||||
padding: .6em;
|
padding: .6em 1.2em;
|
||||||
font-size: 14px;
|
font-size: 14px;
|
||||||
color: #3B73AF;
|
color: #3B73AF;
|
||||||
}
|
}
|
||||||
|
|
||||||
#user-setting-nav .list-group .list-group-item {
|
#user-setting-nav .list-group .list-group-item {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
|
margin-bottom: .6em;
|
||||||
}
|
}
|
||||||
|
|
||||||
#user-setting-nav .list-group .list-group-item-success a {
|
#user-setting-nav .list-group .list-group-item-success a {
|
||||||
|
@ -431,10 +438,60 @@ html, body {
|
||||||
border-left: 4px solid #DD4B39;
|
border-left: 4px solid #DD4B39;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#repo-setting-container{
|
||||||
|
padding-right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
#repo-setting-container .form-horizontal label {
|
#repo-setting-container .form-horizontal label {
|
||||||
line-height: 30px;
|
line-height: 30px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#repo-collab-list li.collab{
|
||||||
|
margin-bottom: .6em;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-collab-list .avatar{
|
||||||
|
margin-right: 1em;
|
||||||
|
width: 40px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-collab-list a.member{
|
||||||
|
color: #444;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-collab-list .remove-collab{
|
||||||
|
color: #DD4B39;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-collab-form .dropdown-menu{
|
||||||
|
margin-left: 15px;
|
||||||
|
margin-top: 4px;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-collab-form .dropdown-menu li{
|
||||||
|
padding: 0 1em;
|
||||||
|
line-height: 36px;
|
||||||
|
cursor: pointer;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-collab-form .dropdown-menu li:hover{
|
||||||
|
background-color: #e8f0ff;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-collab-form .dropdown-menu img{
|
||||||
|
width: 28px;
|
||||||
|
height: 28px;
|
||||||
|
margin-right: 1em;
|
||||||
|
vertical-align: middle;
|
||||||
|
margin-top: -3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-collab-form .dropdown-menu ul{
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
|
||||||
/* gogits user ssh keys */
|
/* gogits user ssh keys */
|
||||||
|
|
||||||
#ssh-keys .list-group-item {
|
#ssh-keys .list-group-item {
|
||||||
|
@ -649,6 +706,10 @@ html, body {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#repo-toolbar ul.navbar-right {
|
||||||
|
margin-right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
.activity-list {
|
.activity-list {
|
||||||
font-size: 14px;
|
font-size: 14px;
|
||||||
}
|
}
|
||||||
|
|
|
@ -240,7 +240,7 @@ var Gogits = {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$(window).on('hashchange',function (e) {
|
$(window).on('hashchange', function (e) {
|
||||||
var m = window.location.hash.match(/^#(L\d+)\-(L\d+)$/);
|
var m = window.location.hash.match(/^#(L\d+)\-(L\d+)$/);
|
||||||
var $list = $('.code-view ol.linenums > li');
|
var $list = $('.code-view ol.linenums > li');
|
||||||
if (m) {
|
if (m) {
|
||||||
|
@ -387,7 +387,7 @@ function initRepository() {
|
||||||
var $clone = $('.clone-group-btn');
|
var $clone = $('.clone-group-btn');
|
||||||
if ($clone.length) {
|
if ($clone.length) {
|
||||||
var $url = $('.clone-group-url');
|
var $url = $('.clone-group-url');
|
||||||
$clone.find('button[data-link]').on("click",function (e) {
|
$clone.find('button[data-link]').on("click", function (e) {
|
||||||
var $this = $(this);
|
var $this = $(this);
|
||||||
if (!$this.hasClass('btn-primary')) {
|
if (!$this.hasClass('btn-primary')) {
|
||||||
$clone.find('.input-group-btn .btn-primary').removeClass('btn-primary').addClass("btn-default");
|
$clone.find('.input-group-btn .btn-primary').removeClass('btn-primary').addClass("btn-default");
|
||||||
|
@ -408,7 +408,7 @@ function initRepository() {
|
||||||
var $watch = $('#repo-watching'),
|
var $watch = $('#repo-watching'),
|
||||||
watchLink = $watch.data("watch"),
|
watchLink = $watch.data("watch"),
|
||||||
unwatchLink = $watch.data("unwatch");
|
unwatchLink = $watch.data("unwatch");
|
||||||
$watch.on('click', '.to-watch',function () {
|
$watch.on('click', '.to-watch', function () {
|
||||||
if ($watch.hasClass("watching")) {
|
if ($watch.hasClass("watching")) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -585,6 +585,39 @@ function initRelease() {
|
||||||
}());
|
}());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function initRepoSetting() {
|
||||||
|
// repo member add
|
||||||
|
$('#repo-collaborator').on('keyup', function () {
|
||||||
|
var $this = $(this);
|
||||||
|
if (!$this.val()) {
|
||||||
|
$this.next().toggleHide();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
$.ajax({
|
||||||
|
url: '/api/v1/users/search?q=' + $this.val(),
|
||||||
|
dataType: "json",
|
||||||
|
success: function (json) {
|
||||||
|
if (json.ok && json.data) {
|
||||||
|
var html = '';
|
||||||
|
$.each(json.data, function (i, item) {
|
||||||
|
html += '<li><img src="' + item.avatar + '">' + item.username + '</li>';
|
||||||
|
});
|
||||||
|
$this.next().toggleShow();
|
||||||
|
$this.next().find('ul').html(html);
|
||||||
|
}else{
|
||||||
|
$this.next().toggleHide();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}).on('focus', function () {
|
||||||
|
if (!$(this).val()) {
|
||||||
|
$(this).next().toggleHide();
|
||||||
|
}
|
||||||
|
}).next().on("click",'li',function(){
|
||||||
|
$('#repo-collaborator').val($(this).text());
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
(function ($) {
|
(function ($) {
|
||||||
$(function () {
|
$(function () {
|
||||||
initCore();
|
initCore();
|
||||||
|
@ -607,5 +640,8 @@ function initRelease() {
|
||||||
if ($('#release').length) {
|
if ($('#release').length) {
|
||||||
initRelease();
|
initRelease();
|
||||||
}
|
}
|
||||||
|
if ($('#repo-setting-container').length) {
|
||||||
|
initRepoSetting();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
})(jQuery);
|
})(jQuery);
|
||||||
|
|
|
@ -286,119 +286,6 @@ func authRequired(ctx *middleware.Context) {
|
||||||
ctx.HTML(401, fmt.Sprintf("status/401"))
|
ctx.HTML(401, fmt.Sprintf("status/401"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func Setting(ctx *middleware.Context, params martini.Params) {
|
|
||||||
if !ctx.Repo.IsOwner {
|
|
||||||
ctx.Handle(404, "repo.Setting", nil)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx.Data["IsRepoToolbarSetting"] = true
|
|
||||||
|
|
||||||
var title string
|
|
||||||
if t, ok := ctx.Data["Title"].(string); ok {
|
|
||||||
title = t
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx.Data["Title"] = title + " - settings"
|
|
||||||
ctx.HTML(200, "repo/setting")
|
|
||||||
}
|
|
||||||
|
|
||||||
func SettingPost(ctx *middleware.Context) {
|
|
||||||
if !ctx.Repo.IsOwner {
|
|
||||||
ctx.Error(404)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx.Data["IsRepoToolbarSetting"] = true
|
|
||||||
|
|
||||||
switch ctx.Query("action") {
|
|
||||||
case "update":
|
|
||||||
newRepoName := ctx.Query("name")
|
|
||||||
// Check if repository name has been changed.
|
|
||||||
if ctx.Repo.Repository.Name != newRepoName {
|
|
||||||
isExist, err := models.IsRepositoryExist(ctx.Repo.Owner, newRepoName)
|
|
||||||
if err != nil {
|
|
||||||
ctx.Handle(500, "repo.SettingPost(update: check existence)", err)
|
|
||||||
return
|
|
||||||
} else if isExist {
|
|
||||||
ctx.RenderWithErr("Repository name has been taken in your repositories.", "repo/setting", nil)
|
|
||||||
return
|
|
||||||
} else if err = models.ChangeRepositoryName(ctx.Repo.Owner.Name, ctx.Repo.Repository.Name, newRepoName); err != nil {
|
|
||||||
ctx.Handle(500, "repo.SettingPost(change repository name)", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
log.Trace("%s Repository name changed: %s/%s -> %s", ctx.Req.RequestURI, ctx.User.Name, ctx.Repo.Repository.Name, newRepoName)
|
|
||||||
|
|
||||||
ctx.Repo.Repository.Name = newRepoName
|
|
||||||
}
|
|
||||||
|
|
||||||
br := ctx.Query("branch")
|
|
||||||
|
|
||||||
if git.IsBranchExist(models.RepoPath(ctx.User.Name, ctx.Repo.Repository.Name), br) {
|
|
||||||
ctx.Repo.Repository.DefaultBranch = br
|
|
||||||
}
|
|
||||||
ctx.Repo.Repository.Description = ctx.Query("desc")
|
|
||||||
ctx.Repo.Repository.Website = ctx.Query("site")
|
|
||||||
ctx.Repo.Repository.IsPrivate = ctx.Query("private") == "on"
|
|
||||||
ctx.Repo.Repository.IsGoget = ctx.Query("goget") == "on"
|
|
||||||
if err := models.UpdateRepository(ctx.Repo.Repository); err != nil {
|
|
||||||
ctx.Handle(404, "repo.SettingPost(update)", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
log.Trace("%s Repository updated: %s/%s", ctx.Req.RequestURI, ctx.Repo.Owner.Name, ctx.Repo.Repository.Name)
|
|
||||||
|
|
||||||
if ctx.Repo.Repository.IsMirror {
|
|
||||||
if len(ctx.Query("interval")) > 0 {
|
|
||||||
var err error
|
|
||||||
ctx.Repo.Mirror.Interval, err = base.StrTo(ctx.Query("interval")).Int()
|
|
||||||
if err != nil {
|
|
||||||
log.Error("repo.SettingPost(get mirror interval): %v", err)
|
|
||||||
} else if err = models.UpdateMirror(ctx.Repo.Mirror); err != nil {
|
|
||||||
log.Error("repo.SettingPost(UpdateMirror): %v", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx.Flash.Success("Repository options has been successfully updated.")
|
|
||||||
ctx.Redirect(fmt.Sprintf("/%s/%s/settings", ctx.Repo.Owner.Name, ctx.Repo.Repository.Name))
|
|
||||||
case "transfer":
|
|
||||||
if len(ctx.Repo.Repository.Name) == 0 || ctx.Repo.Repository.Name != ctx.Query("repository") {
|
|
||||||
ctx.RenderWithErr("Please make sure you entered repository name is correct.", "repo/setting", nil)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
newOwner := ctx.Query("owner")
|
|
||||||
// Check if new owner exists.
|
|
||||||
isExist, err := models.IsUserExist(newOwner)
|
|
||||||
if err != nil {
|
|
||||||
ctx.Handle(500, "repo.SettingPost(transfer: check existence)", err)
|
|
||||||
return
|
|
||||||
} else if !isExist {
|
|
||||||
ctx.RenderWithErr("Please make sure you entered owner name is correct.", "repo/setting", nil)
|
|
||||||
return
|
|
||||||
} else if err = models.TransferOwnership(ctx.User, newOwner, ctx.Repo.Repository); err != nil {
|
|
||||||
ctx.Handle(500, "repo.SettingPost(transfer repository)", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
log.Trace("%s Repository transfered: %s/%s -> %s", ctx.Req.RequestURI, ctx.User.Name, ctx.Repo.Repository.Name, newOwner)
|
|
||||||
|
|
||||||
ctx.Redirect("/")
|
|
||||||
case "delete":
|
|
||||||
if len(ctx.Repo.Repository.Name) == 0 || ctx.Repo.Repository.Name != ctx.Query("repository") {
|
|
||||||
ctx.RenderWithErr("Please make sure you entered repository name is correct.", "repo/setting", nil)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := models.DeleteRepository(ctx.User.Id, ctx.Repo.Repository.Id, ctx.User.LowerName); err != nil {
|
|
||||||
ctx.Handle(500, "repo.Delete", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
log.Trace("%s Repository deleted: %s/%s", ctx.Req.RequestURI, ctx.User.LowerName, ctx.Repo.Repository.LowerName)
|
|
||||||
|
|
||||||
ctx.Redirect("/")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func Action(ctx *middleware.Context, params martini.Params) {
|
func Action(ctx *middleware.Context, params martini.Params) {
|
||||||
var err error
|
var err error
|
||||||
switch params["action"] {
|
switch params["action"] {
|
||||||
|
|
144
routers/repo/setting.go
Normal file
144
routers/repo/setting.go
Normal file
|
@ -0,0 +1,144 @@
|
||||||
|
// Copyright 2014 The Gogs Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
package repo
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"github.com/gogits/git"
|
||||||
|
"github.com/gogits/gogs/models"
|
||||||
|
"github.com/gogits/gogs/modules/base"
|
||||||
|
"github.com/gogits/gogs/modules/log"
|
||||||
|
"github.com/gogits/gogs/modules/middleware"
|
||||||
|
)
|
||||||
|
|
||||||
|
func Setting(ctx *middleware.Context) {
|
||||||
|
if !ctx.Repo.IsOwner {
|
||||||
|
ctx.Handle(404, "repo.Setting", nil)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Data["IsRepoToolbarSetting"] = true
|
||||||
|
|
||||||
|
var title string
|
||||||
|
if t, ok := ctx.Data["Title"].(string); ok {
|
||||||
|
title = t
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Data["Title"] = title + " - settings"
|
||||||
|
ctx.HTML(200, "repo/setting")
|
||||||
|
}
|
||||||
|
|
||||||
|
func SettingPost(ctx *middleware.Context) {
|
||||||
|
if !ctx.Repo.IsOwner {
|
||||||
|
ctx.Error(404)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Data["IsRepoToolbarSetting"] = true
|
||||||
|
|
||||||
|
switch ctx.Query("action") {
|
||||||
|
case "update":
|
||||||
|
newRepoName := ctx.Query("name")
|
||||||
|
// Check if repository name has been changed.
|
||||||
|
if ctx.Repo.Repository.Name != newRepoName {
|
||||||
|
isExist, err := models.IsRepositoryExist(ctx.Repo.Owner, newRepoName)
|
||||||
|
if err != nil {
|
||||||
|
ctx.Handle(500, "repo.SettingPost(update: check existence)", err)
|
||||||
|
return
|
||||||
|
} else if isExist {
|
||||||
|
ctx.RenderWithErr("Repository name has been taken in your repositories.", "repo/setting", nil)
|
||||||
|
return
|
||||||
|
} else if err = models.ChangeRepositoryName(ctx.Repo.Owner.Name, ctx.Repo.Repository.Name, newRepoName); err != nil {
|
||||||
|
ctx.Handle(500, "repo.SettingPost(change repository name)", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
log.Trace("%s Repository name changed: %s/%s -> %s", ctx.Req.RequestURI, ctx.User.Name, ctx.Repo.Repository.Name, newRepoName)
|
||||||
|
|
||||||
|
ctx.Repo.Repository.Name = newRepoName
|
||||||
|
}
|
||||||
|
|
||||||
|
br := ctx.Query("branch")
|
||||||
|
|
||||||
|
if git.IsBranchExist(models.RepoPath(ctx.User.Name, ctx.Repo.Repository.Name), br) {
|
||||||
|
ctx.Repo.Repository.DefaultBranch = br
|
||||||
|
}
|
||||||
|
ctx.Repo.Repository.Description = ctx.Query("desc")
|
||||||
|
ctx.Repo.Repository.Website = ctx.Query("site")
|
||||||
|
ctx.Repo.Repository.IsPrivate = ctx.Query("private") == "on"
|
||||||
|
ctx.Repo.Repository.IsGoget = ctx.Query("goget") == "on"
|
||||||
|
if err := models.UpdateRepository(ctx.Repo.Repository); err != nil {
|
||||||
|
ctx.Handle(404, "repo.SettingPost(update)", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
log.Trace("%s Repository updated: %s/%s", ctx.Req.RequestURI, ctx.Repo.Owner.Name, ctx.Repo.Repository.Name)
|
||||||
|
|
||||||
|
if ctx.Repo.Repository.IsMirror {
|
||||||
|
if len(ctx.Query("interval")) > 0 {
|
||||||
|
var err error
|
||||||
|
ctx.Repo.Mirror.Interval, err = base.StrTo(ctx.Query("interval")).Int()
|
||||||
|
if err != nil {
|
||||||
|
log.Error("repo.SettingPost(get mirror interval): %v", err)
|
||||||
|
} else if err = models.UpdateMirror(ctx.Repo.Mirror); err != nil {
|
||||||
|
log.Error("repo.SettingPost(UpdateMirror): %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Flash.Success("Repository options has been successfully updated.")
|
||||||
|
ctx.Redirect(fmt.Sprintf("/%s/%s/settings", ctx.Repo.Owner.Name, ctx.Repo.Repository.Name))
|
||||||
|
case "transfer":
|
||||||
|
if len(ctx.Repo.Repository.Name) == 0 || ctx.Repo.Repository.Name != ctx.Query("repository") {
|
||||||
|
ctx.RenderWithErr("Please make sure you entered repository name is correct.", "repo/setting", nil)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
newOwner := ctx.Query("owner")
|
||||||
|
// Check if new owner exists.
|
||||||
|
isExist, err := models.IsUserExist(newOwner)
|
||||||
|
if err != nil {
|
||||||
|
ctx.Handle(500, "repo.SettingPost(transfer: check existence)", err)
|
||||||
|
return
|
||||||
|
} else if !isExist {
|
||||||
|
ctx.RenderWithErr("Please make sure you entered owner name is correct.", "repo/setting", nil)
|
||||||
|
return
|
||||||
|
} else if err = models.TransferOwnership(ctx.User, newOwner, ctx.Repo.Repository); err != nil {
|
||||||
|
ctx.Handle(500, "repo.SettingPost(transfer repository)", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
log.Trace("%s Repository transfered: %s/%s -> %s", ctx.Req.RequestURI, ctx.User.Name, ctx.Repo.Repository.Name, newOwner)
|
||||||
|
|
||||||
|
ctx.Redirect("/")
|
||||||
|
case "delete":
|
||||||
|
if len(ctx.Repo.Repository.Name) == 0 || ctx.Repo.Repository.Name != ctx.Query("repository") {
|
||||||
|
ctx.RenderWithErr("Please make sure you entered repository name is correct.", "repo/setting", nil)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := models.DeleteRepository(ctx.User.Id, ctx.Repo.Repository.Id, ctx.User.LowerName); err != nil {
|
||||||
|
ctx.Handle(500, "repo.Delete", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
log.Trace("%s Repository deleted: %s/%s", ctx.Req.RequestURI, ctx.User.LowerName, ctx.Repo.Repository.LowerName)
|
||||||
|
|
||||||
|
ctx.Redirect("/")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func Collaboration(ctx *middleware.Context) {
|
||||||
|
if !ctx.Repo.IsOwner {
|
||||||
|
ctx.Handle(404, "repo.Setting", nil)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Data["IsRepoToolbarSetting"] = true
|
||||||
|
|
||||||
|
var title string
|
||||||
|
if t, ok := ctx.Data["Title"].(string); ok {
|
||||||
|
title = t
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Data["Title"] = title + " - collaboration"
|
||||||
|
ctx.HTML(200, "repo/collaboration")
|
||||||
|
}
|
51
templates/repo/collaboration.tmpl
Normal file
51
templates/repo/collaboration.tmpl
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
{{template "base/head" .}}
|
||||||
|
{{template "base/navbar" .}}
|
||||||
|
{{template "repo/nav" .}}
|
||||||
|
{{template "repo/toolbar" .}}
|
||||||
|
<div id="body" class="container">
|
||||||
|
<div id="user-setting-nav" class="col-md-2">
|
||||||
|
<ul class="list-group">
|
||||||
|
<li class="list-group-item"><a href="/{{.Owner.Name}}/{{.Repository.Name}}/settings">Options</a></li>
|
||||||
|
<li class="list-group-item active"><a href="/{{.Owner.Name}}/{{.Repository.Name}}/collaboration">Collaborators</a></li>
|
||||||
|
<!--<li class="list-group-item"><a href="#">Notifications</a></li>-->
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="repo-setting-container" class="col-md-10">
|
||||||
|
{{template "base/alert" .}}
|
||||||
|
<div class="panel panel-default">
|
||||||
|
<div class="panel-heading">
|
||||||
|
Collaborators
|
||||||
|
</div>
|
||||||
|
<div class="panel-body">
|
||||||
|
<ul id="repo-collab-list" class="list-unstyled">
|
||||||
|
<li>No Collaborators</li>
|
||||||
|
<li class="collab">
|
||||||
|
<a href="/{{.Owner.Name}}/{{.Repository.Name}}/remove_member?name=" class="remove-collab pull-right"><i class="fa fa-times"></i></a>
|
||||||
|
<a class="member" href="#">
|
||||||
|
<img alt="无闻" class="pull-left avatar" src="https://avatars2.githubusercontent.com/u/2946214?s=140">
|
||||||
|
<strong class="access-member-fullname">无闻</strong><br/>
|
||||||
|
Unknwon
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div class="panel-footer">
|
||||||
|
<form action="/{{.Owner.Name}}/{{.Repository.Name}}/collaboration" method="post" class="form-horizontal" id="repo-collab-form">
|
||||||
|
{{.CsrfTokenHtml}}
|
||||||
|
<div class="form-group" style="margin-bottom: 0">
|
||||||
|
<div class="col-md-4">
|
||||||
|
<input type="text" name="collaborator" class="form-control dropdown-toggle" id="repo-collaborator" required="required" data-toggle="dropdown"/>
|
||||||
|
<div class="dropdown-menu">
|
||||||
|
<ul class="list-unstyled"></ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<button class="col-md-2 btn btn-primary">Add collaborator</button>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{{template "base/footer" .}}
|
|
@ -3,15 +3,15 @@
|
||||||
{{template "repo/nav" .}}
|
{{template "repo/nav" .}}
|
||||||
{{template "repo/toolbar" .}}
|
{{template "repo/toolbar" .}}
|
||||||
<div id="body" class="container">
|
<div id="body" class="container">
|
||||||
<div id="user-setting-nav" class="col-md-3">
|
<div id="user-setting-nav" class="col-md-2">
|
||||||
<ul class="list-group">
|
<ul class="list-group">
|
||||||
<li class="list-group-item active"><a href="/{{.Owner.Name}}/{{.Repository.Name}}/settings">Options</a></li>
|
<li class="list-group-item active"><a href="/{{.Owner.Name}}/{{.Repository.Name}}/settings">Options</a></li>
|
||||||
<!--<li class="list-group-item"><a href="#">Collaborators</a></li>
|
<li class="list-group-item"><a href="/{{.Owner.Name}}/{{.Repository.Name}}/collaboration">Collaborators</a></li>
|
||||||
<li class="list-group-item"><a href="#">Notifications</a></li>-->
|
<!--<li class="list-group-item"><a href="#">Notifications</a></li>-->
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="repo-setting-container" class="col-md-9">
|
<div id="repo-setting-container" class="col-md-10">
|
||||||
{{template "base/alert" .}}
|
{{template "base/alert" .}}
|
||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading">
|
<div class="panel-heading">
|
||||||
|
|
9
web.go
9
web.go
|
@ -121,10 +121,10 @@ func runWeb(*cli.Context) {
|
||||||
m.Get("/user/:username", ignSignIn, user.Profile)
|
m.Get("/user/:username", ignSignIn, user.Profile)
|
||||||
|
|
||||||
m.Group("/repo", func(r martini.Router) {
|
m.Group("/repo", func(r martini.Router) {
|
||||||
m.Get("/create", repo.Create)
|
r.Get("/create", repo.Create)
|
||||||
m.Post("/create", bindIgnErr(auth.CreateRepoForm{}), repo.CreatePost)
|
r.Post("/create", bindIgnErr(auth.CreateRepoForm{}), repo.CreatePost)
|
||||||
m.Get("/migrate", repo.Migrate)
|
r.Get("/migrate", repo.Migrate)
|
||||||
m.Post("/migrate", bindIgnErr(auth.MigrateRepoForm{}), repo.MigratePost)
|
r.Post("/migrate", bindIgnErr(auth.MigrateRepoForm{}), repo.MigratePost)
|
||||||
}, reqSignIn)
|
}, reqSignIn)
|
||||||
|
|
||||||
adminReq := middleware.Toggle(&middleware.ToggleOptions{SignInRequire: true, AdminRequire: true})
|
adminReq := middleware.Toggle(&middleware.ToggleOptions{SignInRequire: true, AdminRequire: true})
|
||||||
|
@ -150,6 +150,7 @@ func runWeb(*cli.Context) {
|
||||||
m.Group("/:username/:reponame", func(r martini.Router) {
|
m.Group("/:username/:reponame", func(r martini.Router) {
|
||||||
r.Get("/settings", repo.Setting)
|
r.Get("/settings", repo.Setting)
|
||||||
r.Post("/settings", repo.SettingPost)
|
r.Post("/settings", repo.SettingPost)
|
||||||
|
r.Get("/collaboration", repo.Collaboration)
|
||||||
r.Get("/action/:action", repo.Action)
|
r.Get("/action/:action", repo.Action)
|
||||||
r.Get("/issues/new", repo.CreateIssue)
|
r.Get("/issues/new", repo.CreateIssue)
|
||||||
r.Post("/issues/new", bindIgnErr(auth.CreateIssueForm{}), repo.CreateIssuePost)
|
r.Post("/issues/new", bindIgnErr(auth.CreateIssueForm{}), repo.CreateIssuePost)
|
||||||
|
|
Loading…
Reference in a new issue