gitea源码

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  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="flex-container">
  6. <div class="flex-container-nav">
  7. <div class="ui secondary vertical filter menu tw-bg-transparent">
  8. <div class="item">
  9. {{ctx.Locale.Tr "home.issues.in_your_repos"}}
  10. <strong>{{.Total}}</strong>
  11. </div>
  12. <div class="divider"></div>
  13. {{range .Repos}}
  14. {{with $Repo := .}}
  15. <a class="{{range $.RepoIDs}}{{if eq . $Repo.ID}}active{{end}}{{end}} repo name item" href="?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="flex-container-main">
  37. <div class="list-header">
  38. <div class="small-menu-items ui compact tiny menu list-header-toggle">
  39. <a class="item{{if not .IsShowClosed}} active{{end}}" href="?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort={{$.SortType}}&state=open&q={{$.Keyword}}">
  40. {{svg "octicon-milestone" 16 "tw-mr-2"}}
  41. {{ctx.Locale.PrettyNumber .MilestoneStats.OpenCount}}&nbsp;{{ctx.Locale.Tr "repo.issues.open_title"}}
  42. </a>
  43. <a class="item{{if .IsShowClosed}} active{{end}}" href="?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort={{$.SortType}}&state=closed&q={{$.Keyword}}">
  44. {{svg "octicon-check" 16 "tw-mr-2"}}
  45. {{ctx.Locale.PrettyNumber .MilestoneStats.ClosedCount}}&nbsp;{{ctx.Locale.Tr "repo.issues.closed_title"}}
  46. </a>
  47. </div>
  48. <form class="list-header-search ui form ignore-dirty">
  49. <input type="hidden" name="type" value="{{$.ViewType}}">
  50. <input type="hidden" name="repos" value="[{{range $.RepoIDs}}{{.}},{{end}}]">
  51. <input type="hidden" name="sort" value="{{$.SortType}}">
  52. <input type="hidden" name="state" value="{{$.State}}">
  53. {{template "shared/search/combo" dict "Value" $.Keyword}}
  54. </form>
  55. <div class="list-header-filters">
  56. <!-- Sort -->
  57. <div class="item ui dropdown jump">
  58. <span class="text">
  59. {{ctx.Locale.Tr "repo.issues.filter_sort"}}
  60. </span>
  61. {{svg "octicon-triangle-down" 14 "dropdown icon"}}
  62. <div class="menu">
  63. <a class="{{if or (eq .SortType "closestduedate") (not .SortType)}}active {{end}}item" href="?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=closestduedate&state={{$.State}}&q={{$.Keyword}}">{{ctx.Locale.Tr "repo.milestones.filter_sort.earliest_due_data"}}</a>
  64. <a class="{{if eq .SortType "furthestduedate"}}active {{end}}item" href="?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=furthestduedate&state={{$.State}}&q={{$.Keyword}}">{{ctx.Locale.Tr "repo.milestones.filter_sort.latest_due_date"}}</a>
  65. <a class="{{if eq .SortType "leastcomplete"}}active {{end}}item" href="?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=leastcomplete&state={{$.State}}&q={{$.Keyword}}">{{ctx.Locale.Tr "repo.milestones.filter_sort.least_complete"}}</a>
  66. <a class="{{if eq .SortType "mostcomplete"}}active {{end}}item" href="?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=mostcomplete&state={{$.State}}&q={{$.Keyword}}">{{ctx.Locale.Tr "repo.milestones.filter_sort.most_complete"}}</a>
  67. <a class="{{if eq .SortType "mostissues"}}active {{end}}item" href="?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=mostissues&state={{$.State}}&q={{$.Keyword}}">{{ctx.Locale.Tr "repo.milestones.filter_sort.most_issues"}}</a>
  68. <a class="{{if eq .SortType "leastissues"}}active {{end}}item" href="?repos=[{{range $.RepoIDs}}{{.}}%2C{{end}}]&sort=leastissues&state={{$.State}}&q={{$.Keyword}}">{{ctx.Locale.Tr "repo.milestones.filter_sort.least_issues"}}</a>
  69. <a class="{{if eq .SortType "name"}}active {{end}}item" href="{{$.Link}}?sort=name&state={{$.State}}&q={{$.Keyword}}">{{ctx.Locale.Tr "repo.milestones.filter_sort.name"}}</a>
  70. </div>
  71. </div>
  72. </div>
  73. </div>
  74. <div class="milestone-list">
  75. {{range .Milestones}}
  76. <li class="milestone-card">
  77. <div class="milestone-header">
  78. <h3 class="flex-text-block tw-m-0">
  79. <span class="ui large label">
  80. {{.Repo.FullName}}
  81. </span>
  82. {{svg "octicon-milestone" 16}}
  83. <a class="muted" href="{{.Repo.Link}}/milestone/{{.ID}}">{{.Name}}</a>
  84. </h3>
  85. <div class="tw-flex tw-items-center">
  86. <span class="tw-mr-2">{{.Completeness}}%</span>
  87. <progress value="{{.Completeness}}" max="100"></progress>
  88. </div>
  89. </div>
  90. <div class="milestone-toolbar">
  91. <div class="group">
  92. <div class="flex-text-block">
  93. {{svg "octicon-issue-opened" 14}}
  94. {{ctx.Locale.PrettyNumber .NumOpenIssues}}&nbsp;{{ctx.Locale.Tr "repo.issues.open_title"}}
  95. </div>
  96. <div class="flex-text-block">
  97. {{svg "octicon-check" 14}}
  98. {{ctx.Locale.PrettyNumber .NumClosedIssues}}&nbsp;{{ctx.Locale.Tr "repo.issues.closed_title"}}
  99. </div>
  100. {{if .TotalTrackedTime}}
  101. <div class="flex-text-block">
  102. {{svg "octicon-clock"}}
  103. {{.TotalTrackedTime|Sec2Hour}}
  104. </div>
  105. {{end}}
  106. {{if .UpdatedUnix}}
  107. <div class="flex-text-block">
  108. {{svg "octicon-clock"}}
  109. {{ctx.Locale.Tr "repo.milestones.update_ago" (DateUtils.TimeSince .UpdatedUnix)}}
  110. </div>
  111. {{end}}
  112. <div class="flex-text-block">
  113. {{if .IsClosed}}
  114. {{$closedDate:= DateUtils.TimeSince .ClosedDateUnix}}
  115. {{svg "octicon-clock" 14}}
  116. {{ctx.Locale.Tr "repo.milestones.closed" $closedDate}}
  117. {{else}}
  118. {{if .DeadlineString}}
  119. <span class="flex-text-inline {{if .IsOverdue}}text red{{end}}">
  120. {{svg "octicon-calendar" 14}}
  121. {{DateUtils.AbsoluteShort (.DeadlineString|DateUtils.ParseLegacy)}}
  122. </span>
  123. {{else}}
  124. {{svg "octicon-calendar" 14}}
  125. {{ctx.Locale.Tr "repo.milestones.no_due_date"}}
  126. {{end}}
  127. {{end}}
  128. </div>
  129. </div>
  130. {{if and (or $.CanWriteIssues $.CanWritePulls) (not $.Repository.IsArchived)}}
  131. <div class="group">
  132. <a class="flex-text-inline" href="{{$.Link}}/{{.ID}}/edit">{{svg "octicon-pencil" 14}}{{ctx.Locale.Tr "repo.issues.label_edit"}}</a>
  133. {{if .IsClosed}}
  134. <a class="link-action flex-text-inline" href data-url="{{$.Link}}/{{.ID}}/open">{{svg "octicon-check" 14}}{{ctx.Locale.Tr "repo.milestones.open"}}</a>
  135. {{else}}
  136. <a class="link-action flex-text-inline" href data-url="{{$.Link}}/{{.ID}}/close">{{svg "octicon-x" 14}}{{ctx.Locale.Tr "repo.milestones.close"}}</a>
  137. {{end}}
  138. <a class="delete-button flex-text-inline" href="#" data-url="{{$.RepoLink}}/milestones/delete" data-id="{{.ID}}">{{svg "octicon-trash" 14}}{{ctx.Locale.Tr "repo.issues.label_delete"}}</a>
  139. </div>
  140. {{end}}
  141. </div>
  142. {{if .Content}}
  143. <div class="render-content markup">{{.RenderedContent}}</div>
  144. {{end}}
  145. </li>
  146. {{end}}
  147. {{template "base/paginate" .}}
  148. </div>
  149. </div>
  150. </div>
  151. </div>
  152. </div>
  153. {{template "base/footer" .}}