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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374
  1. <div class="four wide column">
  2. <div class="ui segment metas">
  3. {{template "repo/issue/branch_selector_field" .}}
  4. <div class="ui {{if or (not .IsIssueWriter) .Repository.IsArchived}}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 has-emoji" 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 has-emoji {{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 or (not .IsIssueWriter) .Repository.IsArchived}}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 or (not .IsIssueWriter) .Repository.IsArchived}}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 and $.IssueWatch (not .Repository.IsArchived)}}
  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 and .CanUseTimetracker (not .Repository.IsArchived)}}
  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 .IsIssueWriter (not .Repository.IsArchived)}}
  215. <br/>
  216. <a style="cursor:pointer;" onclick="toggleDeadlineForm();"><i class="edit icon"></i>{{$.i18n.Tr "repo.issues.due_date_form_edit"}}</a> -
  217. <a style="cursor:pointer;" onclick="updateDeadline('');"><i class="remove icon"></i>{{$.i18n.Tr "repo.issues.due_date_form_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 .IsIssueWriter (not .Repository.IsArchived)}}
  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. {{if .Repository.IsDependenciesEnabled}}
  240. <div class="ui divider"></div>
  241. <div class="ui depending">
  242. {{if (and (not .BlockedByDependencies) (not .BlockingDependencies))}}
  243. <span class="text"><strong>{{.i18n.Tr "repo.issues.dependency.title"}}</strong></span>
  244. <br>
  245. <p>{{if .Issue.IsPull}}
  246. {{.i18n.Tr "repo.issues.dependency.pr_no_dependencies"}}
  247. {{else}}
  248. {{.i18n.Tr "repo.issues.dependency.issue_no_dependencies"}}
  249. {{end}}</p>
  250. {{end}}
  251. {{if .BlockingDependencies}}
  252. <span class="text" data-tooltip="{{if .Issue.IsPull}}
  253. {{.i18n.Tr "repo.issues.dependency.pr_close_blocks"}}
  254. {{else}}
  255. {{.i18n.Tr "repo.issues.dependency.issue_close_blocks"}}
  256. {{end}}" data-inverted="">
  257. <strong>{{.i18n.Tr "repo.issues.dependency.blocks_short"}}</strong>
  258. </span>
  259. <div class="ui relaxed divided list">
  260. {{range .BlockingDependencies}}
  261. <div class="item{{if .IsClosed}} is-closed{{end}}">
  262. <div class="ui black label">#{{.Index}}</div>
  263. <a class="title has-emoji" href="{{$.RepoLink}}/issues/{{.Index}}">{{.Title}}</a>
  264. <div class="ui transparent label right floated">
  265. {{if and $.CanCreateIssueDependencies (not $.Repository.IsArchived)}}
  266. <a class="delete-dependency-button" onclick="deleteDependencyModal({{.ID}}, 'blocking');"
  267. data-tooltip="{{$.i18n.Tr "repo.issues.dependency.remove_info"}}" data-inverted="">
  268. <i class="delete icon text red"></i>
  269. </a>
  270. {{end}}
  271. </div>
  272. </div>
  273. {{end}}
  274. </div>
  275. {{end}}
  276. {{if .BlockedByDependencies}}
  277. <span class="text" data-tooltip="{{if .Issue.IsPull}}
  278. {{.i18n.Tr "repo.issues.dependency.issue_closing_blockedby"}}
  279. {{else}}
  280. {{.i18n.Tr "repo.issues.dependency.pr_closing_blockedby"}}
  281. {{end}}" data-inverted="">
  282. <strong>{{.i18n.Tr "repo.issues.dependency.blocked_by_short"}}</strong>
  283. </span>
  284. <div class="ui relaxed divided list">
  285. {{range .BlockedByDependencies}}
  286. <div class="item{{if .IsClosed}} is-closed{{end}}">
  287. <div class="ui black label">#{{.Index}}</div>
  288. <a class="title has-emoji" href="{{$.RepoLink}}/issues/{{.Index}}">{{.Title}}</a>
  289. <div class="ui transparent label right floated">
  290. {{if and $.CanCreateIssueDependencies (not $.IsArchived)}}
  291. <a class="delete-dependency-button" onclick="deleteDependencyModal({{.ID}}, 'blockedBy');"
  292. data-tooltip="{{$.i18n.Tr "repo.issues.dependency.remove_info"}}" data-inverted="">
  293. <i class="delete icon text red"></i>
  294. </a>
  295. {{end}}
  296. </div>
  297. </div>
  298. {{end}}
  299. </div>
  300. {{end}}
  301. {{if and .CanCreateIssueDependencies (not .Repository.IsArchived)}}
  302. <div>
  303. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/dependency/add" id="addDependencyForm">
  304. {{$.CsrfTokenHtml}}
  305. <div class="ui fluid action input">
  306. <div class="ui search selection dropdown" id="new-dependency-drop-list" data-issue-id="{{.Issue.ID}}" style="min-width: 13.9rem;border-radius: 4px 0 0 4px;border-right: 0;white-space: nowrap;">
  307. <input name="newDependency" type="hidden">
  308. <i class="dropdown icon"></i>
  309. <input type="text" class="search">
  310. <div class="default text">{{.i18n.Tr "repo.issues.dependency.add"}}</div>
  311. </div>
  312. <button class="ui green icon button">
  313. <i class="plus icon"></i>
  314. </button>
  315. </div>
  316. </form>
  317. </div>
  318. {{end}}
  319. </div>
  320. </div>
  321. </div>
  322. {{if and .CanCreateIssueDependencies (not .Repository.IsArchived)}}
  323. <input type="hidden" id="repolink" value="{{$.RepoRelPath}}">
  324. <!-- I know, there is probably a better way to do this -->
  325. <input type="hidden" id="issueIndex" value="{{.Issue.Index}}"/>
  326. <div class="ui basic modal remove-dependency">
  327. <div class="ui icon header">
  328. <i class="trash icon"></i>
  329. {{.i18n.Tr "repo.issues.dependency.remove_header"}}
  330. </div>
  331. <div class="content">
  332. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/dependency/delete" id="removeDependencyForm">
  333. {{$.CsrfTokenHtml}}
  334. <input type="hidden" value="" name="removeDependencyID" id="removeDependencyID"/>
  335. <input type="hidden" value="" name="dependencyType" id="dependencyType"/>
  336. </form>
  337. <p>{{if .Issue.IsPull}}
  338. {{.i18n.Tr "repo.issues.dependency.pr_remove_text"}}
  339. {{else}}
  340. {{.i18n.Tr "repo.issues.dependency.issue_remove_text"}}
  341. {{end}}</p>
  342. </div>
  343. <div class="actions">
  344. <div class="ui basic red cancel inverted button">
  345. <i class="remove icon"></i>
  346. {{.i18n.Tr "repo.issues.dependency.cancel"}}
  347. </div>
  348. <div class="ui basic green ok inverted button">
  349. <i class="checkmark icon"></i>
  350. {{.i18n.Tr "repo.issues.dependency.remove"}}
  351. </div>
  352. </div>
  353. </div>
  354. {{end}}
  355. {{end}}