milestones.tmpl 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. {{template "base/head" .}}
  2. <div class="repository milestones">
  3. {{template "repo/header" .}}
  4. <div class="ui container">
  5. <div class="navbar">
  6. {{template "repo/issue/navbar" .}}
  7. {{if .IsRepositoryWriter}}
  8. <div class="ui right">
  9. <a class="ui green button" href="{{$.Link}}/new">{{.i18n.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 buttons tiny">
  16. <a class="ui {{if not .IsShowClosed}}green{{else}}grey{{end}} basic button" href="{{.RepoLink}}/milestones?state=open">
  17. <i class="octicon octicon-milestone"></i>
  18. {{.i18n.Tr "repo.milestones.open_tab" .OpenCount}}
  19. </a>
  20. <a class="ui {{if .IsShowClosed}}red{{else}}grey{{end}} basic button" href="{{.RepoLink}}/milestones?state=closed">
  21. <i class="octicon octicon-milestone"></i>
  22. {{.i18n.Tr "repo.milestones.close_tab" .ClosedCount}}
  23. </a>
  24. </div>
  25. {{if not .Milestones}}
  26. <div class="ui center dashboard no-activity">
  27. <img class="ui avatar small image" src="https://gitote-cdn.netlify.com/img/svg/milestone.svg">
  28. <br/>
  29. <h2>No Milestones</h2>
  30. </div>
  31. {{end}}
  32. <div class="milestone list">
  33. {{range .Milestones}}
  34. <li class="item">
  35. <i class="octicon octicon-milestone"></i> <a href="{{$.RepoLink}}/issues?state={{$.State}}&milestone={{.ID}}">{{.Name | Sanitize}}</a>
  36. <div class="ui right green progress" data-percent="{{.Completeness}}">
  37. <div class="bar" {{if not .Completeness}}style="background-color: transparent"{{end}}>
  38. <div style="color:#f9f9f9;font-size:10px" class="progress"></div>
  39. </div>
  40. </div>
  41. <div class="meta">
  42. {{ $closedDate:= TimeSince .ClosedDate $.Lang }}
  43. {{if .IsClosed}}
  44. <span class="octicon octicon-clock"></span> {{$.i18n.Tr "repo.milestones.closed" $closedDate|Str2HTML}}
  45. {{else}}
  46. <span class="octicon octicon-calendar"></span>
  47. {{if .DeadlineString}}
  48. <span {{if .IsOverDue}}class="overdue"{{end}}>{{.DeadlineString}}</span>
  49. {{else}}
  50. {{$.i18n.Tr "repo.milestones.no_due_date"}}
  51. {{end}}
  52. {{end}}
  53. <span class="issue-stats">
  54. <i class="octicon octicon-issue-opened"></i> {{$.i18n.Tr "repo.issues.open_tab" .NumOpenIssues}}
  55. <i class="octicon octicon-issue-closed"></i> {{$.i18n.Tr "repo.issues.close_tab" .NumClosedIssues}}
  56. </span>
  57. </div>
  58. {{if $.IsRepositoryWriter}}
  59. <div class="ui right operate">
  60. <a href="{{$.Link}}/{{.ID}}/edit" data-id={{.ID}} data-title={{.Name}}><i class="octicon octicon-pencil"></i> {{$.i18n.Tr "repo.issues.label_edit"}}</a>
  61. {{if .IsClosed}}
  62. <a href="{{$.Link}}/{{.ID}}/open" data-id={{.ID}} data-title={{.Name}}><i class="octicon octicon-check"></i> {{$.i18n.Tr "repo.milestones.open"}}</a>
  63. {{else}}
  64. <a href="{{$.Link}}/{{.ID}}/close" data-id={{.ID}} data-title={{.Name}}><i class="octicon octicon-x"></i> {{$.i18n.Tr "repo.milestones.close"}}</a>
  65. {{end}}
  66. <a class="delete-button" href="#" data-url="{{$.RepoLink}}/milestones/delete" data-id="{{.ID}}"><i class="octicon octicon-trashcan"></i> {{$.i18n.Tr "repo.issues.label_delete"}}</a>
  67. </div>
  68. {{end}}
  69. {{if .Content}}
  70. <div class="content">
  71. {{.RenderedContent|Str2HTML}}
  72. </div>
  73. {{end}}
  74. </li>
  75. {{end}}
  76. {{with .Page}}
  77. {{if gt .TotalPages 1}}
  78. <div class="center page buttons">
  79. <div class="ui borderless pagination menu">
  80. <a class="{{if not .HasPrevious}}disabled{{end}} item" {{if .HasPrevious}}href="{{$.Link}}?state={{$.State}}&page={{.Previous}}"{{end}}>
  81. <i class="left arrow icon"></i> {{$.i18n.Tr "repo.issues.previous"}}
  82. </a>
  83. {{range .Pages}}
  84. {{if eq .Num -1}}
  85. <a class="disabled item">...</a>
  86. {{else}}
  87. <a class="{{if .IsCurrent}}active{{end}} item" {{if not .IsCurrent}}href="{{$.Link}}?state={{$.State}}&page={{.Num}}"{{end}}>{{.Num}}</a>
  88. {{end}}
  89. {{end}}
  90. <a class="{{if not .HasNext}}disabled{{end}} item" {{if .HasNext}}href="{{$.Link}}?state={{$.State}}&page={{.Next}}"{{end}}>
  91. {{$.i18n.Tr "repo.issues.next"}} <i class="icon right arrow"></i>
  92. </a>
  93. </div>
  94. </div>
  95. {{end}}
  96. {{end}}
  97. </div>
  98. </div>
  99. </div>
  100. {{if .IsRepositoryWriter}}
  101. <div class="ui small basic delete modal">
  102. <div class="ui icon header">
  103. <i class="trash icon"></i>
  104. {{.i18n.Tr "repo.milestones.deletion"}}
  105. </div>
  106. <div class="content">
  107. <p>{{.i18n.Tr "repo.milestones.deletion_desc"}}</p>
  108. </div>
  109. <div class="actions">
  110. <div class="ui red basic inverted cancel button">
  111. <i class="remove icon"></i>
  112. {{.i18n.Tr "modal.no"}}
  113. </div>
  114. <div class="ui green basic inverted ok button">
  115. <i class="checkmark icon"></i>
  116. {{.i18n.Tr "modal.yes"}}
  117. </div>
  118. </div>
  119. </div>
  120. {{end}}
  121. {{template "base/footer" .}}