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 6.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. {{template "base/head" .}}
  2. <div role="main" aria-label="{{.Title}}" class="page-content repository milestones">
  3. {{template "repo/header" .}}
  4. <div class="ui container">
  5. <div class="navbar">
  6. {{template "repo/issue/navbar" .}}
  7. {{if and (or .CanWriteIssues .CanWritePulls) (not .Repository.IsArchived)}}
  8. <div class="ui right">
  9. <a class="ui green button" href="{{$.Link}}/new">{{.locale.Tr "repo.milestones.new"}}</a>
  10. </div>
  11. {{end}}
  12. </div>
  13. <div class="ui divider"></div>
  14. {{template "base/alert" .}}
  15. <div class="ui three column stackable grid">
  16. <div class="column">
  17. <div class="ui compact tiny menu">
  18. <a class="item{{if not .IsShowClosed}} active{{end}}" href="{{.RepoLink}}/milestones?state=open&q={{$.Keyword}}">
  19. {{svg "octicon-milestone" 16 "mr-3"}}
  20. {{JsPrettyNumber .OpenCount}}&nbsp;{{.locale.Tr "repo.issues.open_title"}}
  21. </a>
  22. <a class="item{{if .IsShowClosed}} active{{end}}" href="{{.RepoLink}}/milestones?state=closed&q={{$.Keyword}}">
  23. {{svg "octicon-check" 16 "mr-3"}}
  24. {{JsPrettyNumber .ClosedCount}}&nbsp;{{.locale.Tr "repo.issues.closed_title"}}
  25. </a>
  26. </div>
  27. </div>
  28. <!-- Search -->
  29. <div class="column center aligned">
  30. <form class="ui form ignore-dirty">
  31. <div class="ui search fluid action input">
  32. <input type="hidden" name="state" value="{{$.State}}"/>
  33. <input name="q" value="{{.Keyword}}" placeholder="{{.locale.Tr "explore.search"}}...">
  34. <button class="ui primary button" type="submit">{{.locale.Tr "explore.search"}}</button>
  35. </div>
  36. </form>
  37. </div>
  38. <div class="column right aligned df ac je">
  39. <!-- Sort -->
  40. <div class="ui dropdown type jump item">
  41. <span class="text">
  42. {{.locale.Tr "repo.issues.filter_sort"}}
  43. {{svg "octicon-triangle-down" 14 "dropdown icon"}}
  44. </span>
  45. <div class="menu">
  46. <a class="{{if or (eq .SortType "closestduedate") (not .SortType)}}active {{end}}item" href="{{$.Link}}?sort=closestduedate&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.closest_due_date"}}</a>
  47. <a class="{{if eq .SortType "furthestduedate"}}active {{end}}item" href="{{$.Link}}?sort=furthestduedate&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.furthest_due_date"}}</a>
  48. <a class="{{if eq .SortType "leastcomplete"}}active {{end}}item" href="{{$.Link}}?sort=leastcomplete&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.least_complete"}}</a>
  49. <a class="{{if eq .SortType "mostcomplete"}}active {{end}}item" href="{{$.Link}}?sort=mostcomplete&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.most_complete"}}</a>
  50. <a class="{{if eq .SortType "mostissues"}}active {{end}}item" href="{{$.Link}}?sort=mostissues&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.most_issues"}}</a>
  51. <a class="{{if eq .SortType "leastissues"}}active {{end}}item" href="{{$.Link}}?sort=leastissues&state={{$.State}}&q={{$.Keyword}}">{{.locale.Tr "repo.milestones.filter_sort.least_issues"}}</a>
  52. </div>
  53. </div>
  54. </div>
  55. </div>
  56. <!-- milestone list -->
  57. <div class="milestone list">
  58. {{range .Milestones}}
  59. <li class="item">
  60. <div class="df ac sb">
  61. <h2 class="df ac m-0 fw">
  62. {{svg "octicon-milestone" 16 "mr-3"}}<a class="muted" href="{{$.RepoLink}}/milestone/{{.ID}}">{{.Name}}</a>
  63. </h2>
  64. <div class="df ac">
  65. <span class="mr-3">{{.Completeness}}%</span>
  66. <progress value="{{.Completeness}}" max="100"></progress>
  67. </div>
  68. </div>
  69. <div class="meta">
  70. {{$closedDate:= TimeSinceUnix .ClosedDateUnix $.locale}}
  71. {{if .IsClosed}}
  72. {{svg "octicon-clock"}} {{$.locale.Tr "repo.milestones.closed" $closedDate|Str2html}}
  73. {{else}}
  74. {{svg "octicon-calendar"}}
  75. {{if .DeadlineString}}
  76. <span {{if .IsOverdue}}class="overdue"{{end}}>{{.DeadlineString}}</span>
  77. {{else}}
  78. {{$.locale.Tr "repo.milestones.no_due_date"}}
  79. {{end}}
  80. {{end}}
  81. <span class="issue-stats">
  82. {{svg "octicon-issue-opened" 16 "mr-3"}}
  83. {{JsPrettyNumber .NumOpenIssues}}&nbsp;{{$.locale.Tr "repo.issues.open_title"}}
  84. {{svg "octicon-check" 16 "mr-3"}}
  85. {{JsPrettyNumber .NumClosedIssues}}&nbsp;{{$.locale.Tr "repo.issues.closed_title"}}
  86. {{if .TotalTrackedTime}}{{svg "octicon-clock"}} {{.TotalTrackedTime|Sec2Time}}{{end}}
  87. {{if .UpdatedUnix}}{{svg "octicon-clock"}} {{$.locale.Tr "repo.milestones.update_ago" (.TimeSinceUpdate|Sec2Time)}}{{end}}
  88. </span>
  89. </div>
  90. {{if and (or $.CanWriteIssues $.CanWritePulls) (not $.Repository.IsArchived)}}
  91. <div class="ui right operate">
  92. <a href="{{$.Link}}/{{.ID}}/edit" data-id={{.ID}} data-title={{.Name}}>{{svg "octicon-pencil"}} {{$.locale.Tr "repo.issues.label_edit"}}</a>
  93. {{if .IsClosed}}
  94. <a class="link-action" href data-url="{{$.Link}}/{{.ID}}/open">{{svg "octicon-check"}} {{$.locale.Tr "repo.milestones.open"}}</a>
  95. {{else}}
  96. <a class="link-action" href data-url="{{$.Link}}/{{.ID}}/close">{{svg "octicon-x"}} {{$.locale.Tr "repo.milestones.close"}}</a>
  97. {{end}}
  98. <a class="delete-button" href="#" data-url="{{$.RepoLink}}/milestones/delete" data-id="{{.ID}}">{{svg "octicon-trash"}} {{$.locale.Tr "repo.issues.label_delete"}}</a>
  99. </div>
  100. {{end}}
  101. {{if .Content}}
  102. <div class="markup content">
  103. {{.RenderedContent|Str2html}}
  104. </div>
  105. {{end}}
  106. </li>
  107. {{end}}
  108. {{template "base/paginate" .}}
  109. </div>
  110. </div>
  111. </div>
  112. {{if or .CanWriteIssues .CanWritePulls}}
  113. <div class="ui small basic delete modal">
  114. <div class="ui icon header">
  115. {{svg "octicon-trash"}}
  116. {{.locale.Tr "repo.milestones.deletion"}}
  117. </div>
  118. <div class="content">
  119. <p>{{.locale.Tr "repo.milestones.deletion_desc"}}</p>
  120. </div>
  121. <div class="actions">
  122. <div class="ui red basic inverted cancel button">
  123. <i class="remove icon"></i>
  124. {{.locale.Tr "modal.no"}}
  125. </div>
  126. <div class="ui green basic inverted ok button">
  127. <i class="checkmark icon"></i>
  128. {{.locale.Tr "modal.yes"}}
  129. </div>
  130. </div>
  131. </div>
  132. {{end}}
  133. {{template "base/footer" .}}