You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

milestones.tmpl 7.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. {{template "base/head" .}}
  2. <div class="dashboard issues repository milestones">
  3. {{template "user/dashboard/navbar" .}}
  4. <div class="ui container">
  5. <div class="ui stackable grid">
  6. <div class="four wide column">
  7. <div class="ui secondary vertical filter menu">
  8. <a class="item" href="{{.Link}}?type=your_repositories&sort={{$.SortType}}&state={{.State}}">
  9. {{.i18n.Tr "home.issues.in_your_repos"}}
  10. <strong class="ui right">{{.Total}}</strong>
  11. </a>
  12. <div class="ui divider"></div>
  13. {{range .Repos}}
  14. {{with $Repo := .}}
  15. <a class="{{range $.RepoIDs}}{{if eq . $Repo.ID}}ui basic blue button{{end}}{{end}} repo name item" href="{{$.Link}}?repos=[
  16. {{with $include := true}}
  17. {{range $.RepoIDs}}
  18. {{if eq . $Repo.ID}}
  19. {{$include = false}}
  20. {{else}}
  21. {{.}}%2C
  22. {{end}}
  23. {{end}}
  24. {{if eq $include true}}
  25. {{$Repo.ID}}%2C
  26. {{end}}
  27. {{end}}
  28. ]&sort={{$.SortType}}&state={{$.State}}" title="{{.FullName}}">
  29. <span class="text truncate">{{$Repo.FullName}}</span>
  30. <div class="ui {{if $.IsShowClosed}}red{{else}}green{{end}} label">{{index $.Counts $Repo.ID}}</div>
  31. </a>
  32. {{end}}
  33. {{end}}
  34. </div>
  35. </div>
  36. <div class="twelve wide column content">
  37. <div class="ui tiny basic status buttons">
  38. <a class="ui {{if not .IsShowClosed}}green active{{end}} basic button" href="{{.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort={{$.SortType}}&state=open">
  39. {{svg "octicon-issue-opened" 16}}
  40. {{.i18n.Tr "repo.milestones.open_tab" .MilestoneStats.OpenCount}}
  41. </a>
  42. <a class="ui {{if .IsShowClosed}}red active{{end}} basic button" href="{{.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort={{$.SortType}}&state=closed">
  43. {{svg "octicon-issue-closed" 16}}
  44. {{.i18n.Tr "repo.milestones.close_tab" .MilestoneStats.ClosedCount}}
  45. </a>
  46. </div>
  47. <div class="ui right floated secondary filter menu">
  48. <!-- Sort -->
  49. <div class="ui dropdown type jump item">
  50. <span class="text">
  51. {{.i18n.Tr "repo.issues.filter_sort"}}
  52. <i class="dropdown icon"></i>
  53. </span>
  54. <div class="menu">
  55. <a class="{{if or (eq .SortType "closestduedate") (not .SortType)}}active{{end}} item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=closestduedate&state={{$.State}}">{{.i18n.Tr "repo.milestones.filter_sort.closest_due_date"}}</a>
  56. <a class="{{if eq .SortType "furthestduedate"}}active{{end}} item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=furthestduedate&state={{$.State}}">{{.i18n.Tr "repo.milestones.filter_sort.furthest_due_date"}}</a>
  57. <a class="{{if eq .SortType "leastcomplete"}}active{{end}} item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=leastcomplete&state={{$.State}}">{{.i18n.Tr "repo.milestones.filter_sort.least_complete"}}</a>
  58. <a class="{{if eq .SortType "mostcomplete"}}active{{end}} item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=mostcomplete&state={{$.State}}">{{.i18n.Tr "repo.milestones.filter_sort.most_complete"}}</a>
  59. <a class="{{if eq .SortType "mostissues"}}active{{end}} item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=mostissues&state={{$.State}}">{{.i18n.Tr "repo.milestones.filter_sort.most_issues"}}</a>
  60. <a class="{{if eq .SortType "leastissues"}}active{{end}} item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=leastissues&state={{$.State}}">{{.i18n.Tr "repo.milestones.filter_sort.least_issues"}}</a>
  61. </div>
  62. </div>
  63. </div>
  64. <div class="milestone list">
  65. {{range .Milestones}}
  66. <li class="item">
  67. <div class="ui label">{{.Repo.FullName}}</div>
  68. {{svg "octicon-milestone" 16}} <a href="{{.Repo.Link }}/milestone/{{.ID}}">{{.Name}}</a>
  69. <div class="ui right green progress" data-percent="{{.Completeness}}">
  70. <div class="bar" {{if not .Completeness}}style="background-color: transparent"{{end}}>
  71. <div class="progress"></div>
  72. </div>
  73. </div>
  74. <div class="meta">
  75. {{ $closedDate:= TimeSinceUnix .ClosedDateUnix $.Lang }}
  76. {{if .IsClosed}}
  77. {{svg "octicon-clock" 16}} {{$.i18n.Tr "repo.milestones.closed" $closedDate|Str2html}}
  78. {{else}}
  79. {{svg "octicon-calendar" 16}}
  80. {{if .DeadlineString}}
  81. <span {{if .IsOverdue}}class="overdue"{{end}}>{{.DeadlineString}}</span>
  82. {{else}}
  83. {{$.i18n.Tr "repo.milestones.no_due_date"}}
  84. {{end}}
  85. {{end}}
  86. <span class="issue-stats">
  87. {{svg "octicon-issue-opened" 16}} {{$.i18n.Tr "repo.milestones.open_tab" .NumOpenIssues}}
  88. {{svg "octicon-issue-closed" 16}} {{$.i18n.Tr "repo.milestones.close_tab" .NumClosedIssues}}
  89. {{if .TotalTrackedTime}}{{svg "octicon-clock" 16}} {{.TotalTrackedTime|Sec2Time}}{{end}}
  90. </span>
  91. </div>
  92. {{if and (or $.CanWriteIssues $.CanWritePulls) (not $.Repository.IsArchived)}}
  93. <div class="ui right operate">
  94. <a href="{{$.Link}}/{{.ID}}/edit" data-id={{.ID}} data-title={{.Name}}>{{svg "octicon-pencil" 16}} {{$.i18n.Tr "repo.issues.label_edit"}}</a>
  95. {{if .IsClosed}}
  96. <a href="{{$.Link}}/{{.ID}}/open" data-id={{.ID}} data-title={{.Name}}>{{svg "octicon-check" 16}} {{$.i18n.Tr "repo.milestones.open"}}</a>
  97. {{else}}
  98. <a href="{{$.Link}}/{{.ID}}/close" data-id={{.ID}} data-title={{.Name}}>{{svg "octicon-x" 16}} {{$.i18n.Tr "repo.milestones.close"}}</a>
  99. {{end}}
  100. <a class="delete-button" href="#" data-url="{{$.RepoLink}}/milestones/delete" data-id="{{.ID}}">{{svg "octicon-trashcan" 16}} {{$.i18n.Tr "repo.issues.label_delete"}}</a>
  101. </div>
  102. {{end}}
  103. {{if .Content}}
  104. <div class="content">
  105. {{.RenderedContent|Str2html}}
  106. </div>
  107. {{end}}
  108. </li>
  109. {{end}}
  110. {{template "base/paginate" .}}
  111. </div>
  112. </div>
  113. </div>
  114. </div>
  115. </div>
  116. {{template "base/footer" .}}