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.

sidebar.tmpl 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  1. <div class="four wide column">
  2. <div class="ui segment metas">
  3. {{template "repo/issue/branch_selector_field" .}}
  4. <div class="ui {{if not .IsRepositoryWriter}}disabled{{end}} floating jump select-label dropdown">
  5. <span class="text">
  6. <strong>{{.i18n.Tr "repo.issues.new.labels"}}</strong>
  7. <span class="octicon octicon-gear"></span>
  8. </span>
  9. <div class="filter menu" data-action="update" data-issue-id="{{$.Issue.ID}}" data-update-url="{{$.RepoLink}}/issues/labels">
  10. <div class="no-select item">{{.i18n.Tr "repo.issues.new.clear_labels"}}</div>
  11. {{range .Labels}}
  12. <a class="{{if .IsChecked}}checked{{end}} item" href="#" data-id="{{.ID}}" data-id-selector="#label_{{.ID}}"><span class="octicon {{if .IsChecked}}octicon-check{{end}}"></span><span class="label color" style="background-color: {{.Color}}"></span> {{.Name}}
  13. {{if .Description }}<br><small class="desc">{{.Description}}</small>{{end}}</a>
  14. {{end}}
  15. </div>
  16. </div>
  17. <div class="ui labels list">
  18. <span class="no-select item {{if .HasSelectedLabel}}hide{{end}}">{{.i18n.Tr "repo.issues.new.no_label"}}</span>
  19. {{range .Labels}}
  20. <div class="item">
  21. <a class="ui label {{if not .IsChecked}}hide{{end}}" id="label_{{.ID}}" href="{{$.RepoLink}}/issues?labels={{.ID}}" style="color: {{.ForegroundColor}}; background-color: {{.Color}}" title="{{.Description}}">{{.Name}}</a>
  22. </div>
  23. {{end}}
  24. </div>
  25. <div class="ui divider"></div>
  26. <div class="ui {{if not .IsRepositoryWriter}}disabled{{end}} floating jump select-milestone dropdown">
  27. <span class="text">
  28. <strong>{{.i18n.Tr "repo.issues.new.milestone"}}</strong>
  29. <span class="octicon octicon-gear"></span>
  30. </span>
  31. <div class="menu" data-action="update" data-issue-id="{{$.Issue.ID}}" data-update-url="{{$.RepoLink}}/issues/milestone">
  32. <div class="no-select item">{{.i18n.Tr "repo.issues.new.clear_milestone"}}</div>
  33. {{if .OpenMilestones}}
  34. <div class="divider"></div>
  35. <div class="header">
  36. <i class="octicon octicon-milestone"></i>
  37. {{.i18n.Tr "repo.issues.new.open_milestone"}}
  38. </div>
  39. {{range .OpenMilestones}}
  40. <div class="item" data-id="{{.ID}}" data-href="{{$.RepoLink}}/issues?milestone={{.ID}}"> {{.Name}}</div>
  41. {{end}}
  42. {{end}}
  43. {{if .ClosedMilestones}}
  44. <div class="divider"></div>
  45. <div class="header">
  46. <i class="octicon octicon-milestone"></i>
  47. {{.i18n.Tr "repo.issues.new.closed_milestone"}}
  48. </div>
  49. {{range .ClosedMilestones}}
  50. <a class="item" data-id="{{.ID}}" data-href="{{$.RepoLink}}/issues?milestone={{.ID}}"> {{.Name}}</a>
  51. {{end}}
  52. {{end}}
  53. </div>
  54. </div>
  55. <div class="ui select-milestone list">
  56. <span class="no-select item {{if .Issue.Milestone}}hide{{end}}">{{.i18n.Tr "repo.issues.new.no_milestone"}}</span>
  57. <div class="selected">
  58. {{if .Issue.Milestone}}
  59. <a class="item" href="{{.RepoLink}}/issues?milestone={{.Issue.Milestone.ID}}"> {{.Issue.Milestone.Name}}</a>
  60. {{end}}
  61. </div>
  62. </div>
  63. <div class="ui divider"></div>
  64. <input id="assignee_id" name="assignee_id" type="hidden" value="{{.assignee_id}}">
  65. <div class="ui {{if not .IsRepositoryWriter}}disabled{{end}} floating jump select-assignees-modify dropdown">
  66. <span class="text">
  67. <strong>{{.i18n.Tr "repo.issues.new.assignees"}}</strong>
  68. <span class="octicon octicon-gear"></span>
  69. </span>
  70. <div class="filter menu" data-action="" data-issue-id="{{$.Issue.ID}}" data-update-url="{{$.RepoLink}}/issues/assignee">
  71. <div class="no-select item">{{.i18n.Tr "repo.issues.new.clear_assignees"}}</div>
  72. {{range .Assignees}}
  73. {{$AssigneeID := .ID}}
  74. <a class="item{{range $.Issue.Assignees}}
  75. {{if eq .ID $AssigneeID}}
  76. checked
  77. {{end}}
  78. {{end}}" href="#" data-id="{{.ID}}" data-id-selector="#assignee_{{.ID}}">
  79. <span class="octicon{{range $.Issue.Assignees}}
  80. {{if eq .ID $AssigneeID}}
  81. octicon-check
  82. {{end}}
  83. {{end}}"></span>
  84. <span class="text">
  85. <img class="ui avatar image" src="{{.RelAvatarLink}}"> {{.Name}}
  86. </span>
  87. </a>
  88. {{end}}
  89. </div>
  90. </div>
  91. <div class="ui assignees list">
  92. <span class="no-select item {{if .Issue.Assignees}}hide{{end}}">{{.i18n.Tr "repo.issues.new.no_assignees"}}</span>
  93. <div class="selected">
  94. {{range .Issue.Assignees}}
  95. <div class="item" style="margin-bottom: 10px;">
  96. <a href="{{$.RepoLink}}/issues?assignee={{.ID}}"><img class="ui avatar image" src="{{.RelAvatarLink}}">&nbsp;{{.Name}}</a>
  97. </div>
  98. {{end}}
  99. </div>
  100. </div>
  101. <div class="ui divider"></div>
  102. <div class="ui participants">
  103. <span class="text"><strong>{{.i18n.Tr "repo.issues.num_participants" .NumParticipants}}</strong></span>
  104. <div>
  105. {{range .Participants}}
  106. <a href="{{.HomeLink}}">
  107. <img class="ui avatar image poping up" src="{{.RelAvatarLink}}" data-content="{{.DisplayName}}" data-position="top center" data-variation="small inverted">
  108. </a>
  109. {{end}}
  110. </div>
  111. </div>
  112. {{if $.IssueWatch}}
  113. <div class="ui divider"></div>
  114. <div class="ui watching">
  115. <span class="text"><strong>{{.i18n.Tr "notification.notifications"}}</strong></span>
  116. <div>
  117. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/watch">
  118. <input type="hidden" name="watch" value="{{if $.IssueWatch.IsWatching}}0{{else}}1{{end}}" />
  119. {{$.CsrfTokenHtml}}
  120. <button class="fluid ui button">
  121. {{if $.IssueWatch.IsWatching}}
  122. <i class="octicon octicon-mute"></i>
  123. {{.i18n.Tr "repo.issues.unsubscribe"}}
  124. {{else}}
  125. <i class="octicon octicon-unmute"></i>
  126. {{.i18n.Tr "repo.issues.subscribe"}}
  127. {{end}}
  128. </button>
  129. </form>
  130. </div>
  131. </div>
  132. {{end}}
  133. {{if .Repository.IsTimetrackerEnabled }}
  134. {{if .CanUseTimetracker }}
  135. <div class="ui divider"></div>
  136. <div class="ui timetrack">
  137. <span class="text"><strong>{{.i18n.Tr "repo.issues.tracker"}}</strong></span>
  138. <div>
  139. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/times/stopwatch/toggle" id="toggle_stopwatch_form">
  140. {{$.CsrfTokenHtml}}
  141. </form>
  142. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/times/stopwatch/cancel" id="cancel_stopwatch_form">
  143. {{$.CsrfTokenHtml}}
  144. </form>
  145. {{if $.IsStopwatchRunning}}
  146. <div class="ui buttons fluid stop-cancel">
  147. <button onclick="this.disabled=true;toggleStopwatch()" class="ui button stop">{{.i18n.Tr "repo.issues.stop_tracking"}}</button>
  148. <button onclick="this.disabled=true;cancelStopwatch()" class="ui negative button cancel">{{.i18n.Tr "repo.issues.cancel_tracking"}}</button>
  149. </div>
  150. {{else}}
  151. {{if .HasUserStopwatch}}
  152. <div class="ui warning message">
  153. {{.i18n.Tr "repo.issues.tracking_already_started" .OtherStopwatchURL | Safe}}
  154. </div>
  155. {{end}}
  156. <div class="ui buttons two fluid start-add">
  157. <button onclick="this.disabled=true;toggleStopwatch()" class="ui button poping up start" data-content='{{.i18n.Tr "repo.issues.start_tracking"}}' data-position="top center" data-variation="small inverted">{{.i18n.Tr "repo.issues.start_tracking_short"}}</button>
  158. <button onclick="timeAddManual()" class="ui button green poping up add-time" data-content='{{.i18n.Tr "repo.issues.add_time"}}' data-position="top center" data-variation="small inverted">{{.i18n.Tr "repo.issues.add_time_short"}}</button>
  159. <div class="ui mini modal">
  160. <div class="header">{{.i18n.Tr "repo.issues.add_time"}}</div>
  161. <div class="content">
  162. <form method="POST" id="add_time_manual_form" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/times/add" class="ui action input fluid">
  163. {{$.CsrfTokenHtml}}
  164. <input placeholder='{{.i18n.Tr "repo.issues.add_time_hours"}}' type="number" name="hours">
  165. <input placeholder='{{.i18n.Tr "repo.issues.add_time_minutes"}}' type="number" name="minutes" class="ui compact">
  166. </form>
  167. </div>
  168. <div class="actions">
  169. <div class="ui green approve button">{{.i18n.Tr "repo.issues.add_time_short"}}</div>
  170. <div class="ui red cancel button">{{.i18n.Tr "repo.issues.add_time_cancel"}}</div>
  171. </div>
  172. </div>
  173. </div>
  174. {{end}}
  175. </div>
  176. </div>
  177. {{end}}
  178. {{if gt (len .WorkingUsers) 0}}
  179. <div class="ui divider"></div>
  180. <div class="ui participants comments">
  181. <span class="text"><strong>{{.i18n.Tr "repo.issues.time_spent_from_all_authors" ($.Issue.TotalTrackedTime | Sec2Time) | Safe}}</strong></span>
  182. <div>
  183. {{range $user, $trackedtime := .WorkingUsers}}
  184. <div class="comment">
  185. <a class="avatar">
  186. <img src="{{$user.RelAvatarLink}}">
  187. </a>
  188. <div class="content">
  189. <a class="author">{{$user.DisplayName}}</a>
  190. <div class="text">
  191. {{$trackedtime}}
  192. </div>
  193. </div>
  194. </div>
  195. {{end}}
  196. </div>
  197. </div>
  198. {{end}}
  199. {{end}}
  200. <div class="ui divider"></div>
  201. <span class="text"><strong>{{.i18n.Tr "repo.issues.due_date"}}</strong></span>
  202. <div class="ui form" id="deadline-loader">
  203. <div class="ui negative message" id="deadline-err-invalid-date" style="display: none;">
  204. <i class="close icon"></i>
  205. {{.i18n.Tr "repo.issues.due_date_invalid"}}
  206. </div>
  207. {{if ne .Issue.DeadlineUnix 0}}
  208. <p>
  209. <span class="octicon octicon-calendar"></span>
  210. {{.Issue.DeadlineUnix.FormatShort}}
  211. {{if .Issue.IsOverdue}}
  212. <span style="color: red;">{{.i18n.Tr "repo.issues.due_date_overdue"}}</span>
  213. {{end}}
  214. {{if and .IsSigned .IsRepositoryWriter}}
  215. <br/>
  216. <a style="cursor:pointer;" onclick="toggleDeadlineForm();"><i class="edit icon"></i>Edit</a> -
  217. <a style="cursor:pointer;" onclick="updateDeadline('');"><i class="remove icon"></i>Remove</a>
  218. {{end}}
  219. </p>
  220. {{else}}
  221. <p><i>{{.i18n.Tr "repo.issues.due_date_not_set"}}</i></p>
  222. {{end}}
  223. {{if and .IsSigned .IsRepositoryWriter}}
  224. <div {{if ne .Issue.DeadlineUnix 0}} style="display: none;"{{end}} id="deadlineForm">
  225. <form class="ui fluid action input" action="{{AppSubUrl}}/api/v1/repos/{{.Repository.Owner.Name}}/{{.Repository.Name}}/issues/{{.Issue.Index}}" method="post" id="update-issue-deadline-form" onsubmit="setDeadline();return false;">
  226. {{$.CsrfTokenHtml}}
  227. <input required placeholder="{{.i18n.Tr "repo.issues.due_date_form"}}" {{if gt .Issue.DeadlineUnix 0}}value="{{.Issue.DeadlineUnix.Format "2006-01-02"}}"{{end}} type="date" name="deadlineDate" id="deadlineDate">
  228. <button class="ui green icon button">
  229. {{if ne .Issue.DeadlineUnix 0}}
  230. <i class="edit icon"></i>
  231. {{else}}
  232. <i class="plus icon"></i>
  233. {{end}}
  234. </button>
  235. </form>
  236. </div>
  237. {{end}}
  238. </div>
  239. </div>
  240. </div>