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.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. {{template "base/head" .}}
  2. <div role="main" aria-label="{{.Title}}" class="page-content 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}}&q={{$.Keyword}}">
  9. {{.locale.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 primary 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}}&q={{$.Keyword}}" 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 three column stackable grid">
  38. <div class="column">
  39. <div class="ui compact tiny menu">
  40. <a class="item{{if not .IsShowClosed}} active{{end}}" href="{{.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort={{$.SortType}}&state=open&q={{$.Keyword}}">
  41. {{svg "octicon-milestone" 16 "gt-mr-3"}}
  42. {{JsPrettyNumber .MilestoneStats.OpenCount}}&nbsp;{{.locale.Tr "repo.issues.open_title"}}
  43. </a>
  44. <a class="item{{if .IsShowClosed}} active{{end}}" href="{{.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort={{$.SortType}}&state=closed&q={{$.Keyword}}">
  45. {{svg "octicon-check" 16 "gt-mr-3"}}
  46. {{JsPrettyNumber .MilestoneStats.ClosedCount}}&nbsp;{{.locale.Tr "repo.issues.closed_title"}}
  47. </a>
  48. </div>
  49. </div>
  50. <div class="column center aligned">
  51. <form class="ui form ignore-dirty">
  52. <div class="ui search fluid action input">
  53. <input type="hidden" name="type" value="{{$.ViewType}}">
  54. <input type="hidden" name="repos" value="[{{range $.RepoIDs}}{{.}},{{end}}]">
  55. <input type="hidden" name="sort" value="{{$.SortType}}">
  56. <input type="hidden" name="state" value="{{$.State}}">
  57. <input name="q" value="{{$.Keyword}}" placeholder="{{.locale.Tr "explore.search"}}...">
  58. <button class="ui primary button" type="submit">{{.locale.Tr "explore.search"}}</button>
  59. </div>
  60. </form>
  61. </div>
  62. <div class="column right aligned gt-df gt-ac gt-je">
  63. <!-- Sort -->
  64. <div class="ui dropdown type jump item">
  65. <span class="text">
  66. {{.locale.Tr "repo.issues.filter_sort"}}
  67. {{svg "octicon-triangle-down" 14 "dropdown icon"}}
  68. </span>
  69. <div class="menu">
  70. <a class="{{if or (eq .SortType "closestduedate") (not .SortType)}}active {{end}}item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=closestduedate&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.closest_due_date"}}</a>
  71. <a class="{{if eq .SortType "furthestduedate"}}active {{end}}item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=furthestduedate&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.furthest_due_date"}}</a>
  72. <a class="{{if eq .SortType "leastcomplete"}}active {{end}}item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=leastcomplete&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.least_complete"}}</a>
  73. <a class="{{if eq .SortType "mostcomplete"}}active {{end}}item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=mostcomplete&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.most_complete"}}</a>
  74. <a class="{{if eq .SortType "mostissues"}}active {{end}}item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=mostissues&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.most_issues"}}</a>
  75. <a class="{{if eq .SortType "leastissues"}}active {{end}}item" href="{{$.Link}}?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=leastissues&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.least_issues"}}</a>
  76. </div>
  77. </div>
  78. </div>
  79. </div>
  80. <div class="milestone list">
  81. {{range .Milestones}}
  82. <li class="item">
  83. <div class="gt-df gt-ac gt-sb">
  84. <h3 class="gt-df gt-ac gt-m-0 gt-fw">
  85. <span class="ui large label">{{.Repo.FullName}}</span>
  86. {{svg "octicon-milestone" 16 "gt-mr-3"}}<a class="muted" href="{{.Repo.Link}}/milestone/{{.ID}}">{{.Name}}</a>
  87. </h3>
  88. <div class="gt-df gt-ac">
  89. <span class="gt-mr-3">{{.Completeness}}%</span>
  90. <progress value="{{.Completeness}}" max="100"></progress>
  91. </div>
  92. </div>
  93. <div class="meta">
  94. {{$closedDate:= TimeSinceUnix .ClosedDateUnix $.locale}}
  95. {{if .IsClosed}}
  96. {{svg "octicon-clock"}} {{$.locale.Tr "repo.milestones.closed" $closedDate|Str2html}}
  97. {{else}}
  98. {{svg "octicon-calendar"}}
  99. {{if .DeadlineString}}
  100. <span {{if .IsOverdue}}class="overdue"{{end}}>{{.DeadlineString}}</span>
  101. {{else}}
  102. {{$.locale.Tr "repo.milestones.no_due_date"}}
  103. {{end}}
  104. {{end}}
  105. <span class="issue-stats">
  106. {{svg "octicon-issue-opened" 16 "gt-mr-3"}}
  107. {{JsPrettyNumber .NumOpenIssues}}&nbsp;{{$.locale.Tr "repo.issues.open_title"}}
  108. {{svg "octicon-check" 16 "gt-mr-3"}}
  109. {{JsPrettyNumber .NumClosedIssues}}&nbsp;{{$.locale.Tr "repo.issues.closed_title"}}
  110. {{if .TotalTrackedTime}}
  111. {{svg "octicon-clock"}} {{.TotalTrackedTime|Sec2Time}}
  112. {{end}}
  113. </span>
  114. </div>
  115. {{if and (or $.CanWriteIssues $.CanWritePulls) (not $.Repository.IsArchived)}}
  116. <div class="ui right operate">
  117. <a href="{{$.Link}}/{{.ID}}/edit" data-id={{.ID}} data-title={{.Name}}>{{svg "octicon-pencil"}} {{$.locale.Tr "repo.issues.label_edit"}}</a>
  118. {{if .IsClosed}}
  119. <a href="{{$.Link}}/{{.ID}}/open" data-id={{.ID}} data-title={{.Name}}>{{svg "octicon-check"}} {{$.locale.Tr "repo.milestones.open"}}</a>
  120. {{else}}
  121. <a href="{{$.Link}}/{{.ID}}/close" data-id={{.ID}} data-title={{.Name}}>{{svg "octicon-x"}} {{$.locale.Tr "repo.milestones.close"}}</a>
  122. {{end}}
  123. <a class="delete-button" href="#" data-url="{{$.RepoLink}}/milestones/delete" data-id="{{.ID}}">{{svg "octicon-trash"}} {{$.locale.Tr "repo.issues.label_delete"}}</a>
  124. </div>
  125. {{end}}
  126. {{if .Content}}
  127. <div class="markup content">
  128. {{.RenderedContent|Str2html}}
  129. </div>
  130. {{end}}
  131. </li>
  132. {{end}}
  133. {{template "base/paginate" .}}
  134. </div>
  135. </div>
  136. </div>
  137. </div>
  138. </div>
  139. {{template "base/footer" .}}