mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-04 05:18:25 +00:00 
			
		
		
		
	Finish change issue’s milestone
This commit is contained in:
		@@ -543,18 +543,20 @@ func ChangeMilestoneAssign(oldMid, mid int64, isIssueClosed bool) (err error) {
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	m, err := GetMilestoneById(mid)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	m.NumIssues++
 | 
			
		||||
	if isIssueClosed {
 | 
			
		||||
		m.NumClosedIssues++
 | 
			
		||||
	}
 | 
			
		||||
	m.Completeness = m.NumClosedIssues * 100 / m.NumIssues
 | 
			
		||||
	if _, err = sess.Id(m.Id).Update(m); err != nil {
 | 
			
		||||
		sess.Rollback()
 | 
			
		||||
		return err
 | 
			
		||||
	if mid > 0 {
 | 
			
		||||
		m, err := GetMilestoneById(mid)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			return err
 | 
			
		||||
		}
 | 
			
		||||
		m.NumIssues++
 | 
			
		||||
		if isIssueClosed {
 | 
			
		||||
			m.NumClosedIssues++
 | 
			
		||||
		}
 | 
			
		||||
		m.Completeness = m.NumClosedIssues * 100 / m.NumIssues
 | 
			
		||||
		if _, err = sess.Id(m.Id).Update(m); err != nil {
 | 
			
		||||
			sess.Rollback()
 | 
			
		||||
			return err
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	return sess.Commit()
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -53,17 +53,21 @@ func Issues(ctx *middleware.Context) {
 | 
			
		||||
		filterMode = models.FM_MENTION
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	var mid int64
 | 
			
		||||
	midx, _ := base.StrTo(ctx.Query("milestone")).Int64()
 | 
			
		||||
	mile, err := models.GetMilestoneByIndex(ctx.Repo.Repository.Id, midx)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "issue.Issues(GetMilestoneByIndex): %v", err)
 | 
			
		||||
		return
 | 
			
		||||
	if midx > 0 {
 | 
			
		||||
		mile, err := models.GetMilestoneByIndex(ctx.Repo.Repository.Id, midx)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			ctx.Handle(500, "issue.Issues(GetMilestoneByIndex): %v", err)
 | 
			
		||||
			return
 | 
			
		||||
		}
 | 
			
		||||
		mid = mile.Id
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	page, _ := base.StrTo(ctx.Query("page")).Int()
 | 
			
		||||
 | 
			
		||||
	// Get issues.
 | 
			
		||||
	issues, err := models.GetIssues(assigneeId, ctx.Repo.Repository.Id, posterId, mile.Id, page,
 | 
			
		||||
	issues, err := models.GetIssues(assigneeId, ctx.Repo.Repository.Id, posterId, mid, page,
 | 
			
		||||
		isShowClosed, ctx.Query("labels"), ctx.Query("sortType"))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "issue.Issues(GetIssues): %v", err)
 | 
			
		||||
@@ -120,6 +124,19 @@ func CreateIssue(ctx *middleware.Context, params martini.Params) {
 | 
			
		||||
	ctx.Data["IsRepoToolbarIssues"] = true
 | 
			
		||||
	ctx.Data["IsRepoToolbarIssuesList"] = false
 | 
			
		||||
 | 
			
		||||
	var err error
 | 
			
		||||
	// Get all milestones.
 | 
			
		||||
	ctx.Data["OpenMilestones"], err = models.GetMilestones(ctx.Repo.Repository.Id, false)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "issue.ViewIssue(GetMilestones.1): %v", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	ctx.Data["ClosedMilestones"], err = models.GetMilestones(ctx.Repo.Repository.Id, true)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "issue.ViewIssue(GetMilestones.2): %v", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	us, err := models.GetCollaborators(strings.TrimPrefix(ctx.Repo.RepoLink, "/"))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "issue.CreateIssue(GetCollaborators)", err)
 | 
			
		||||
@@ -134,6 +151,19 @@ func CreateIssuePost(ctx *middleware.Context, params martini.Params, form auth.C
 | 
			
		||||
	ctx.Data["IsRepoToolbarIssues"] = true
 | 
			
		||||
	ctx.Data["IsRepoToolbarIssuesList"] = false
 | 
			
		||||
 | 
			
		||||
	var err error
 | 
			
		||||
	// Get all milestones.
 | 
			
		||||
	ctx.Data["OpenMilestones"], err = models.GetMilestones(ctx.Repo.Repository.Id, false)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "issue.ViewIssue(GetMilestones.1): %v", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	ctx.Data["ClosedMilestones"], err = models.GetMilestones(ctx.Repo.Repository.Id, true)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "issue.ViewIssue(GetMilestones.2): %v", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	us, err := models.GetCollaborators(strings.TrimPrefix(ctx.Repo.RepoLink, "/"))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "issue.CreateIssue(GetCollaborators)", err)
 | 
			
		||||
 
 | 
			
		||||
@@ -48,25 +48,33 @@
 | 
			
		||||
                                    </ul>
 | 
			
		||||
                                    <div class="tab-content">
 | 
			
		||||
                                        <div class="tab-pane active" id="milestone-open">
 | 
			
		||||
                                            {{if not .OpenMilestones}}
 | 
			
		||||
                                            <p class="milestone-item">Nothing to show</p>
 | 
			
		||||
                                            {{else}}
 | 
			
		||||
                                            <ul class="list-unstyled">
 | 
			
		||||
                                                <li class="milestone-item" data-id="1">
 | 
			
		||||
                                                    <p><strong>Milestone name</strong></p>
 | 
			
		||||
                                                    <p>due to 3 days later</p>
 | 
			
		||||
                                                </li>
 | 
			
		||||
                                                <li class="milestone-item" data-id="1">
 | 
			
		||||
                                                    <p><strong>Milestone name</strong></p>
 | 
			
		||||
                                                    <p>due to 3 days later</p>
 | 
			
		||||
                                                {{range .OpenMilestones}}
 | 
			
		||||
                                                <li class="milestone-item" data-id="{{.Id}}">
 | 
			
		||||
                                                    <p><strong>{{.Name}}</strong></p>
 | 
			
		||||
                                                    <!-- <p>due to 3 days later</p> -->
 | 
			
		||||
                                                </li>
 | 
			
		||||
                                                {{end}}
 | 
			
		||||
                                            </ul>
 | 
			
		||||
                                            {{end}}
 | 
			
		||||
                                        </div>
 | 
			
		||||
 | 
			
		||||
                                        <div class="tab-pane" id="milestone-close">
 | 
			
		||||
                                            {{if not .ClosedMilestones}}
 | 
			
		||||
                                            <p class="milestone-item">Nothing to show</p>
 | 
			
		||||
                                            {{else}}
 | 
			
		||||
                                            <ul class="list-unstyled">
 | 
			
		||||
                                                <li class="milestone-item" data-id="1">
 | 
			
		||||
                                                    <p><strong>Milestone name</strong></p>
 | 
			
		||||
                                                    <p>closed 3 days ago</p>
 | 
			
		||||
                                                {{range .ClosedMilestones}}
 | 
			
		||||
                                                <li class="milestone-item" data-id="{{.Id}}">
 | 
			
		||||
                                                    <p><strong>{{.Name}}</strong></p>
 | 
			
		||||
                                                    <p>Closed {{TimeSince .ClosedDate}}</p>
 | 
			
		||||
                                                </li>
 | 
			
		||||
                                                {{end}}
 | 
			
		||||
                                            </ul>
 | 
			
		||||
                                            {{end}}
 | 
			
		||||
                                        </div>
 | 
			
		||||
                                    </div>
 | 
			
		||||
                                </li>
 | 
			
		||||
 
 | 
			
		||||
@@ -100,7 +100,7 @@
 | 
			
		||||
            </div>
 | 
			
		||||
 | 
			
		||||
            <div class="issue-bar col-md-2">
 | 
			
		||||
                <div class="milestone" data-milestone="0" data-ajax="{{.Issue.Index}}/milestone">
 | 
			
		||||
                <div class="milestone" data-milestone="{{.Milestone.Id}}" data-ajax="{{.Issue.Index}}/milestone">
 | 
			
		||||
                    <div class="pull-right action">
 | 
			
		||||
                        <button class="btn btn-default btn-sm" data-toggle="dropdown">
 | 
			
		||||
                            <i class="fa fa-check-square-o"></i>
 | 
			
		||||
@@ -108,7 +108,7 @@
 | 
			
		||||
                        </button>
 | 
			
		||||
                        <div class="dropdown-menu dropdown-menu-right">
 | 
			
		||||
                            <ul class="list-unstyled">
 | 
			
		||||
                                <li data-id="0" class="clear-milestone milestone-item hidden"><i class="fa fa-times-circle-o"></i> Clear milestone </li>
 | 
			
		||||
                                <li data-id="0" class="clear-milestone milestone-item  hidden"><i class="fa fa-times-circle-o"></i> Clear milestone </li>
 | 
			
		||||
                                <li class="milestone-list">
 | 
			
		||||
                                    <ul class="nav nav-tabs" data-init="tabs">
 | 
			
		||||
                                        <li class="active"><a href="#milestone-open" data-toggle="tab">Open</a></li>
 | 
			
		||||
@@ -138,7 +138,7 @@
 | 
			
		||||
                                                {{range .ClosedMilestones}}
 | 
			
		||||
                                                <li class="milestone-item" data-id="{{.Id}}">
 | 
			
		||||
                                                    <p><strong>{{.Name}}</strong></p>
 | 
			
		||||
                                                    <p>{{TimeSince .ClosedDate}}</p>
 | 
			
		||||
                                                    <p>Closed {{TimeSince .ClosedDate}}</p>
 | 
			
		||||
                                                </li>
 | 
			
		||||
                                                {{end}}
 | 
			
		||||
                                            </ul>
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user