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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645
  1. <div class="four wide column">
  2. <div class="ui segment metas">
  3. {{template "repo/issue/branch_selector_field" .}}
  4. {{if .Issue.IsPull }}
  5. <input id="reviewer_id" name="reviewer_id" type="hidden" value="{{.reviewer_id}}">
  6. <div class="ui {{if or (not .Reviewers) (not .CanChooseReviewer) .Repository.IsArchived}}disabled{{end}} floating jump select-reviewers-modify dropdown">
  7. <span class="text">
  8. <strong>{{.i18n.Tr "repo.issues.review.reviewers"}}</strong>
  9. {{if and .CanChooseReviewer (not .Repository.IsArchived)}}
  10. {{svg "octicon-gear"}}
  11. {{end}}
  12. </span>
  13. <div class="filter menu" data-action="update" data-issue-id="{{$.Issue.ID}}" data-update-url="{{$.RepoLink}}/issues/request_review">
  14. <div class="header" style="text-transform: none;font-size:16px;">{{.i18n.Tr "repo.issues.new.add_reviewer_title"}}</div>
  15. {{if .Reviewers}}
  16. <div class="ui icon search input">
  17. <i class="icon df ac jc">{{svg "octicon-search" 16}}</i>
  18. <input type="text" placeholder="{{.i18n.Tr "repo.issues.filter_reviewers"}}">
  19. </div>
  20. {{end}}
  21. {{if .Reviewers}}
  22. {{range .Reviewers}}
  23. {{if .User}}
  24. <a class="{{if not .CanChange}}ui poping up{{end}} item {{if .Checked}} checked {{end}} {{if not .CanChange}}ban-change{{end}}" href="#" data-id="{{.ItemID}}" data-id-selector="#review_request_{{.ItemID}}" {{if not .CanChange}} data-content="{{$.i18n.Tr "repo.issues.remove_request_review_block"}}"{{end}}>
  25. <span class="octicon-check {{if not .Checked}}invisible{{end}}">{{svg "octicon-check"}}</span>
  26. <span class="text">
  27. <img class="ui avatar image" src="{{.User.RelAvatarLink}}"> {{.User.GetDisplayName}}
  28. </span>
  29. </a>
  30. {{end}}
  31. {{end}}
  32. {{end}}
  33. {{if .TeamReviewers}}
  34. <div class="ui divider"></div>
  35. {{range .TeamReviewers}}
  36. {{if .Team}}
  37. <a class="{{if not .CanChange}}ui poping up{{end}} item {{if .Checked}} checked {{end}} {{if not .CanChange}}ban-change{{end}}" href="#" data-id="{{.ItemID}}" data-id-selector="#review_request_team_{{.Team.ID}}" {{if not .CanChange}} data-content="{{$.i18n.Tr "repo.issues.remove_request_review_block"}}"{{end}}>
  38. <span class="octicon-check {{if not .Checked}}invisible{{end}}">{{svg "octicon-check" 16}}</span>
  39. <span class="text">
  40. {{svg "octicon-people" 16 "ml-4 mr-2"}}{{$.Issue.Repo.OwnerName}}/{{.Team.Name}}
  41. </span>
  42. </a>
  43. {{end}}
  44. {{end}}
  45. {{end}}
  46. </div>
  47. </div>
  48. <div class="ui assignees list">
  49. <span class="no-select item {{if or .OriginalReviews .PullReviewers}}hide{{end}}">{{.i18n.Tr "repo.issues.new.no_reviewers"}}</span>
  50. <div class="selected">
  51. {{range .PullReviewers}}
  52. <div class="item" style="margin-bottom: 10px;">
  53. {{if .User}}
  54. <a href="{{.User.HomeLink}}"><img class="ui avatar image" src="{{.User.RelAvatarLink}}">&nbsp;{{.User.GetDisplayName}}</a>
  55. {{else if .Team}}
  56. <span class="text">{{svg "octicon-people" 16 "teamavatar"}}{{$.Issue.Repo.OwnerName}}/{{.Team.Name}}</span>
  57. {{end}}
  58. <span class="ui right type-icon text {{if eq .Review.Type 1}}green
  59. {{- else if eq .Review.Type 2}}grey
  60. {{- else if eq .Review.Type 3}}red
  61. {{- else if eq .Review.Type 4}}yellow
  62. {{- else}}grey{{end}} right ">
  63. {{if .CanChange}}
  64. <a href="#" class="ui poping up icon re-request-review {{if .Checked}}checked{{end}}" data-content="{{if .Checked}} {{$.i18n.Tr "repo.issues.remove_request_review"}} {{else}} {{$.i18n.Tr "repo.issues.re_request_review"}} {{end}}" data-issue-id="{{$.Issue.ID}}" data-id="{{.ItemID}}" data-update-url="{{$.RepoLink}}/issues/request_review">
  65. {{svg "octicon-sync"}}
  66. </a>
  67. {{end}}
  68. {{svg (printf "octicon-%s" .Review.Type.Icon)}}
  69. </span>
  70. </div>
  71. {{end}}
  72. {{range .OriginalReviews}}
  73. <div class="item" style="margin-bottom: 10px;">
  74. <a href="{{$.Repository.OriginalURL}}" class="ui poping up" data-content="{{$.i18n.Tr "repo.migrated_from_fake" $.Repository.GetOriginalURLHostname | Safe }}"><span class="text black "><i class="fa {{MigrationIcon $.Repository.GetOriginalURLHostname}}" aria-hidden="true"></i> {{ .OriginalAuthor }}</span></a>
  75. <span class="ui right type-icon text {{if eq .Type 1}}green
  76. {{- else if eq .Type 2}}grey
  77. {{- else if eq .Type 3}}red
  78. {{- else if eq .Type 4}}yellow
  79. {{- else}}grey{{end}} right ">
  80. {{svg (printf "octicon-%s" .Type.Icon)}}
  81. </span>
  82. </div>
  83. {{end}}
  84. </div>
  85. </div>
  86. <div class="ui divider"></div>
  87. {{end}}
  88. <div class="ui {{if or (not .HasIssuesOrPullsWritePermission) .Repository.IsArchived}}disabled{{end}} floating jump select-label dropdown">
  89. <span class="text">
  90. <strong>{{.i18n.Tr "repo.issues.new.labels"}}</strong>
  91. {{if and .HasIssuesOrPullsWritePermission (not .Repository.IsArchived)}}
  92. {{svg "octicon-gear"}}
  93. {{end}}
  94. </span>
  95. <div class="filter menu" data-action="update" data-issue-id="{{$.Issue.ID}}" data-update-url="{{$.RepoLink}}/issues/labels">
  96. <div class="header" style="text-transform: none;font-size:16px;">{{.i18n.Tr "repo.issues.new.add_labels_title"}}</div>
  97. {{if or .Labels .OrgLabels}}
  98. <div class="ui icon search input">
  99. <i class="icon df ac jc">{{svg "octicon-search" 16}}</i>
  100. <input type="text" placeholder="{{.i18n.Tr "repo.issues.filter_labels"}}">
  101. </div>
  102. {{end}}
  103. <div class="no-select item">{{.i18n.Tr "repo.issues.new.clear_labels"}}</div>
  104. {{if or .Labels .OrgLabels}}
  105. {{range .Labels}}
  106. <a class="{{if .IsChecked}}checked{{end}} item" href="#" data-id="{{.ID}}" data-id-selector="#label_{{.ID}}"><span class="octicon-check {{if not .IsChecked}}invisible{{end}}">{{svg "octicon-check"}}</span><span class="label color" style="background-color: {{.Color}}"></span> {{.Name | RenderEmoji}}
  107. {{if .Description }}<br><small class="desc">{{.Description | RenderEmoji}}</small>{{end}}</a>
  108. {{end}}
  109. <div class="ui divider"></div>
  110. {{range .OrgLabels}}
  111. <a class="{{if .IsChecked}}checked{{end}} item" href="#" data-id="{{.ID}}" data-id-selector="#label_{{.ID}}"><span class="octicon-check {{if not .IsChecked}}invisible{{end}}">{{svg "octicon-check"}}</span><span class="label color" style="background-color: {{.Color}}"></span> {{.Name | RenderEmoji}}
  112. {{if .Description }}<br><small class="desc">{{.Description | RenderEmoji}}</small>{{end}}</a>
  113. {{end}}
  114. {{else}}
  115. <div class="header" style="text-transform: none;font-size:14px;">{{.i18n.Tr "repo.issues.new.no_items"}}</div>
  116. {{end}}
  117. </div>
  118. </div>
  119. <div class="ui labels list">
  120. <span class="no-select item {{if .HasSelectedLabel}}hide{{end}}">{{.i18n.Tr "repo.issues.new.no_label"}}</span>
  121. {{range .Labels}}
  122. <div class="item">
  123. <a class="ui label {{if not .IsChecked}}hide{{end}}" id="label_{{.ID}}" href="{{$.RepoLink}}/{{if $.Issue.IsPull}}pulls{{else}}issues{{end}}?labels={{.ID}}" style="color: {{.ForegroundColor}}; background-color: {{.Color}}" title="{{.Description | RenderEmojiPlain}}">{{.Name | RenderEmoji}}</a>
  124. </div>
  125. {{end}}
  126. {{range .OrgLabels}}
  127. <div class="item">
  128. <a class="ui label {{if not .IsChecked}}hide{{end}}" id="label_{{.ID}}" href="{{$.RepoLink}}/{{if $.Issue.IsPull}}pulls{{else}}issues{{end}}?labels={{.ID}}" style="color: {{.ForegroundColor}}; background-color: {{.Color}}" title="{{.Description | RenderEmojiPlain}}">{{.Name | RenderEmoji}}</a>
  129. </div>
  130. {{end}}
  131. </div>
  132. <div class="ui divider"></div>
  133. <div class="ui {{if or (not .HasIssuesOrPullsWritePermission) .Repository.IsArchived}}disabled{{end}} floating jump select-milestone dropdown">
  134. <span class="text">
  135. <strong>{{.i18n.Tr "repo.issues.new.milestone"}}</strong>
  136. {{if and .HasIssuesOrPullsWritePermission (not .Repository.IsArchived)}}
  137. {{svg "octicon-gear"}}
  138. {{end}}
  139. </span>
  140. <div class="menu" data-action="update" data-issue-id="{{$.Issue.ID}}" data-update-url="{{$.RepoLink}}/issues/milestone">
  141. <div class="header" style="text-transform: none;font-size:16px;">{{.i18n.Tr "repo.issues.new.add_milestone_title"}}</div>
  142. {{if or .OpenMilestones .ClosedMilestones}}
  143. <div class="ui icon search input">
  144. <i class="icon df ac jc">{{svg "octicon-search" 16}}</i>
  145. <input type="text" placeholder="{{.i18n.Tr "repo.issues.filter_milestones"}}">
  146. </div>
  147. {{end}}
  148. <div class="no-select item">{{.i18n.Tr "repo.issues.new.clear_milestone"}}</div>
  149. {{if and (not .OpenMilestones) (not .ClosedMilestones)}}
  150. <div class="header" style="text-transform: none;font-size:14px;">
  151. {{.i18n.Tr "repo.issues.new.no_items"}}
  152. </div>
  153. {{else}}
  154. {{if .OpenMilestones}}
  155. <div class="divider"></div>
  156. <div class="header">
  157. {{svg "octicon-milestone"}}
  158. {{.i18n.Tr "repo.issues.new.open_milestone"}}
  159. </div>
  160. {{range .OpenMilestones}}
  161. <div class="item" data-id="{{.ID}}" data-href="{{$.RepoLink}}/issues?milestone={{.ID}}"> {{.Name}}</div>
  162. {{end}}
  163. {{end}}
  164. {{if .ClosedMilestones}}
  165. <div class="divider"></div>
  166. <div class="header">
  167. {{svg "octicon-milestone"}}
  168. {{.i18n.Tr "repo.issues.new.closed_milestone"}}
  169. </div>
  170. {{range .ClosedMilestones}}
  171. <a class="item" data-id="{{.ID}}" data-href="{{$.RepoLink}}/issues?milestone={{.ID}}"> {{.Name}}</a>
  172. {{end}}
  173. {{end}}
  174. {{end}}
  175. </div>
  176. </div>
  177. <div class="ui select-milestone list">
  178. <span class="no-select item {{if .Issue.Milestone}}hide{{end}}">{{.i18n.Tr "repo.issues.new.no_milestone"}}</span>
  179. <div class="selected">
  180. {{if .Issue.Milestone}}
  181. <a class="item" href="{{.RepoLink}}/milestone/{{.Issue.Milestone.ID}}"> {{.Issue.Milestone.Name}}</a>
  182. {{end}}
  183. </div>
  184. </div>
  185. {{if .IsProjectsEnabled}}
  186. <div class="ui divider"></div>
  187. <div class="ui {{if or (not .HasIssuesOrPullsWritePermission) .Repository.IsArchived}}disabled{{end}} floating jump select-project dropdown">
  188. <span class="text">
  189. <strong>{{.i18n.Tr "repo.issues.new.projects"}}</strong>
  190. {{svg "octicon-gear"}}
  191. </span>
  192. <div class="menu" data-action="update" data-issue-id="{{$.Issue.ID}}" data-update-url="{{$.RepoLink}}/issues/projects">
  193. <div class="no-select item">{{.i18n.Tr "repo.issues.new.clear_projects"}}</div>
  194. {{if .OpenProjects}}
  195. <div class="divider"></div>
  196. <div class="header">
  197. {{svg "octicon-project"}}
  198. {{.i18n.Tr "repo.issues.new.open_projects"}}
  199. </div>
  200. {{range .OpenProjects}}
  201. <div class="item" data-id="{{.ID}}" data-href="{{$.RepoLink}}/projects/{{.ID}}">{{svg "octicon-project"}} {{.Title}}</div>
  202. {{end}}
  203. {{end}}
  204. {{if .ClosedProjects}}
  205. <div class="divider"></div>
  206. <div class="header">
  207. {{svg "octicon-project"}}
  208. {{.i18n.Tr "repo.issues.new.closed_projects"}}
  209. </div>
  210. {{range .ClosedProjects}}
  211. <a class="item" data-id="{{.ID}}" data-href="{{$.RepoLink}}/projects/{{.ID}}">{{svg "octicon-project"}} {{.Title}}</a>
  212. {{end}}
  213. {{end}}
  214. </div>
  215. </div>
  216. <div class="ui select-project list">
  217. <span class="no-select item {{if .Issue.ProjectID}}hide{{end}}">{{.i18n.Tr "repo.issues.new.no_projects"}}</span>
  218. <div class="selected">
  219. {{if .Issue.ProjectID}}
  220. <a class="item" href="{{.RepoLink}}/projects/{{.Issue.ProjectID}}">{{svg "octicon-project"}} {{.Issue.Project.Title}}</a>
  221. {{end}}
  222. </div>
  223. </div>
  224. {{end}}
  225. <div class="ui divider"></div>
  226. <input id="assignee_id" name="assignee_id" type="hidden" value="{{.assignee_id}}">
  227. <div class="ui {{if or (not .HasIssuesOrPullsWritePermission) .Repository.IsArchived}}disabled{{end}} floating jump select-assignees-modify dropdown">
  228. <span class="text">
  229. <strong>{{.i18n.Tr "repo.issues.new.assignees"}}</strong>
  230. {{if and .HasIssuesOrPullsWritePermission (not .Repository.IsArchived)}}
  231. {{svg "octicon-gear"}}
  232. {{end}}
  233. </span>
  234. <div class="filter menu" data-action="update" data-issue-id="{{$.Issue.ID}}" data-update-url="{{$.RepoLink}}/issues/assignee">
  235. <div class="header" style="text-transform: none;font-size:16px;">{{.i18n.Tr "repo.issues.new.add_assignees_title"}}</div>
  236. <div class="ui icon search input">
  237. <i class="icon df ac jc">{{svg "octicon-search" 16}}</i>
  238. <input type="text" placeholder="{{.i18n.Tr "repo.issues.filter_assignees"}}">
  239. </div>
  240. <div class="no-select item">{{.i18n.Tr "repo.issues.new.clear_assignees"}}</div>
  241. {{range .Assignees}}
  242. {{$AssigneeID := .ID}}
  243. <a class="item{{range $.Issue.Assignees}}
  244. {{if eq .ID $AssigneeID}}
  245. checked
  246. {{end}}
  247. {{end}}" href="#" data-id="{{.ID}}" data-id-selector="#assignee_{{.ID}}">
  248. {{$checked := false}}
  249. {{range $.Issue.Assignees}}
  250. {{if eq .ID $AssigneeID}}
  251. {{$checked = true}}
  252. {{end}}
  253. {{end}}
  254. <span class="octicon-check {{if not $checked}}invisible{{end}}">{{svg "octicon-check"}}</span>
  255. <span class="text">
  256. <img class="ui avatar image" src="{{.RelAvatarLink}}"> {{.GetDisplayName}}
  257. </span>
  258. </a>
  259. {{end}}
  260. </div>
  261. </div>
  262. <div class="ui assignees list">
  263. <span class="no-select item {{if .Issue.Assignees}}hide{{end}}">{{.i18n.Tr "repo.issues.new.no_assignees"}}</span>
  264. <div class="selected">
  265. {{range .Issue.Assignees}}
  266. <div class="item" style="margin-bottom: 10px;">
  267. <a href="{{$.RepoLink}}/{{if $.Issue.IsPull}}pulls{{else}}issues{{end}}?assignee={{.ID}}"><img class="ui avatar image" src="{{.RelAvatarLink}}">&nbsp;{{.GetDisplayName}}</a>
  268. </div>
  269. {{end}}
  270. </div>
  271. </div>
  272. <div class="ui divider"></div>
  273. <div class="ui participants">
  274. <span class="text"><strong>{{.i18n.Tr "repo.issues.num_participants" .NumParticipants}}</strong></span>
  275. <div>
  276. {{range .Participants}}
  277. <a {{if gt .ID 0}}href="{{.HomeLink}}"{{end}}>
  278. <img class="ui avatar image poping up" src="{{.RelAvatarLink}}" data-content="{{.GetDisplayName}}" data-position="top center" data-variation="small inverted">
  279. </a>
  280. {{end}}
  281. </div>
  282. </div>
  283. {{if and $.IssueWatch (not .Repository.IsArchived)}}
  284. <div class="ui divider"></div>
  285. <div class="ui watching">
  286. <span class="text"><strong>{{.i18n.Tr "notification.notifications"}}</strong></span>
  287. <div class="mt-3">
  288. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/watch">
  289. <input type="hidden" name="watch" value="{{if $.IssueWatch.IsWatching}}0{{else}}1{{end}}" />
  290. {{$.CsrfTokenHtml}}
  291. <button class="fluid ui button">
  292. {{if $.IssueWatch.IsWatching}}
  293. {{svg "octicon-mute"}}
  294. {{.i18n.Tr "repo.issues.unsubscribe"}}
  295. {{else}}
  296. {{svg "octicon-unmute"}}
  297. {{.i18n.Tr "repo.issues.subscribe"}}
  298. {{end}}
  299. </button>
  300. </form>
  301. </div>
  302. </div>
  303. {{end}}
  304. {{if .Repository.IsTimetrackerEnabled }}
  305. {{if and .CanUseTimetracker (not .Repository.IsArchived)}}
  306. <div class="ui divider"></div>
  307. <div class="ui timetrack">
  308. <span class="text"><strong>{{.i18n.Tr "repo.issues.tracker"}}</strong></span>
  309. <div>
  310. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/times/stopwatch/toggle" id="toggle_stopwatch_form">
  311. {{$.CsrfTokenHtml}}
  312. </form>
  313. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/times/stopwatch/cancel" id="cancel_stopwatch_form">
  314. {{$.CsrfTokenHtml}}
  315. </form>
  316. {{if $.IsStopwatchRunning}}
  317. <div class="ui buttons fluid stop-cancel">
  318. <button onclick="this.disabled=true;window.toggleStopwatch()" class="ui button stop">{{.i18n.Tr "repo.issues.stop_tracking"}}</button>
  319. <button onclick="this.disabled=true;window.cancelStopwatch()" class="ui negative button cancel">{{.i18n.Tr "repo.issues.cancel_tracking"}}</button>
  320. </div>
  321. {{else}}
  322. {{if .HasUserStopwatch}}
  323. <div class="ui warning message">
  324. {{.i18n.Tr "repo.issues.tracking_already_started" .OtherStopwatchURL | Safe}}
  325. </div>
  326. {{end}}
  327. <div class="ui buttons two fluid start-add">
  328. <button onclick="this.disabled=true;window.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>
  329. <div class="ui mini modal">
  330. <div class="header">{{.i18n.Tr "repo.issues.add_time"}}</div>
  331. <div class="content">
  332. <form method="POST" id="add_time_manual_form" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/times/add" class="ui action input fluid">
  333. {{$.CsrfTokenHtml}}
  334. <input placeholder='{{.i18n.Tr "repo.issues.add_time_hours"}}' type="number" name="hours">
  335. <input placeholder='{{.i18n.Tr "repo.issues.add_time_minutes"}}' type="number" name="minutes" class="ui compact">
  336. </form>
  337. </div>
  338. <div class="actions">
  339. <div class="ui green approve button">{{.i18n.Tr "repo.issues.add_time_short"}}</div>
  340. <div class="ui red cancel button">{{.i18n.Tr "repo.issues.add_time_cancel"}}</div>
  341. </div>
  342. </div>
  343. <button onclick="window.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>
  344. </div>
  345. {{end}}
  346. </div>
  347. </div>
  348. {{end}}
  349. {{if gt (len .WorkingUsers) 0}}
  350. <div class="ui divider"></div>
  351. <div class="ui participants comments">
  352. <span class="text"><strong>{{.i18n.Tr "repo.issues.time_spent_from_all_authors" ($.Issue.TotalTrackedTime | Sec2Time) | Safe}}</strong></span>
  353. <div>
  354. {{range $user, $trackedtime := .WorkingUsers}}
  355. <div class="comment">
  356. <a class="avatar">
  357. <img src="{{$user.RelAvatarLink}}">
  358. </a>
  359. <div class="content">
  360. <a class="author">{{$user.DisplayName}}</a>
  361. <div class="text">
  362. {{$trackedtime}}
  363. </div>
  364. </div>
  365. </div>
  366. {{end}}
  367. </div>
  368. </div>
  369. {{end}}
  370. {{end}}
  371. <div class="ui divider"></div>
  372. <span class="text"><strong>{{.i18n.Tr "repo.issues.due_date"}}</strong></span>
  373. <div class="ui form" id="deadline-loader">
  374. <div class="ui negative message" id="deadline-err-invalid-date" style="display: none;">
  375. <i class="close icon"></i>
  376. {{.i18n.Tr "repo.issues.due_date_invalid"}}
  377. </div>
  378. {{if ne .Issue.DeadlineUnix 0}}
  379. <p>
  380. {{svg "octicon-calendar"}}
  381. {{.Issue.DeadlineUnix.FormatDate}}
  382. {{if .Issue.IsOverdue}}
  383. <span style="color: red;">{{.i18n.Tr "repo.issues.due_date_overdue"}}</span>
  384. {{end}}
  385. {{if and .HasIssuesOrPullsWritePermission (not .Repository.IsArchived)}}
  386. <br/>
  387. <a style="cursor:pointer;" onclick="window.toggleDeadlineForm();"><i class="edit icon"></i>{{$.i18n.Tr "repo.issues.due_date_form_edit"}}</a> -
  388. <a style="cursor:pointer;" onclick="window.updateDeadline('');"><i class="remove icon"></i>{{$.i18n.Tr "repo.issues.due_date_form_remove"}}</a>
  389. {{end}}
  390. </p>
  391. {{else}}
  392. <p><i>{{.i18n.Tr "repo.issues.due_date_not_set"}}</i></p>
  393. {{end}}
  394. {{if and .HasIssuesOrPullsWritePermission (not .Repository.IsArchived)}}
  395. <div {{if ne .Issue.DeadlineUnix 0}} style="display: none;"{{end}} id="deadlineForm">
  396. <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="window.setDeadline();return false;">
  397. {{$.CsrfTokenHtml}}
  398. <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">
  399. <button class="ui green icon button">
  400. {{if ne .Issue.DeadlineUnix 0}}
  401. <i class="edit icon"></i>
  402. {{else}}
  403. <i class="plus icon"></i>
  404. {{end}}
  405. </button>
  406. </form>
  407. </div>
  408. {{end}}
  409. </div>
  410. {{if .Repository.IsDependenciesEnabled}}
  411. <div class="ui divider"></div>
  412. <div class="ui depending">
  413. {{if (and (not .BlockedByDependencies) (not .BlockingDependencies))}}
  414. <span class="text"><strong>{{.i18n.Tr "repo.issues.dependency.title"}}</strong></span>
  415. <br>
  416. <p>
  417. {{if .Issue.IsPull}}
  418. {{.i18n.Tr "repo.issues.dependency.pr_no_dependencies"}}
  419. {{else}}
  420. {{.i18n.Tr "repo.issues.dependency.issue_no_dependencies"}}
  421. {{end}}
  422. </p>
  423. {{end}}
  424. {{if .BlockingDependencies}}
  425. <span class="text poping up" data-content="{{if .Issue.IsPull}}{{.i18n.Tr "repo.issues.dependency.pr_close_blocks"}}{{else}}{{.i18n.Tr "repo.issues.dependency.issue_close_blocks"}}{{end}}">
  426. <strong>{{.i18n.Tr "repo.issues.dependency.blocks_short"}}</strong>
  427. </span>
  428. <div class="ui relaxed divided list">
  429. {{range .BlockingDependencies}}
  430. <div class="item{{if .Issue.IsClosed}} is-closed{{end}} df ac sb">
  431. <div class="item-left df jc fc f1">
  432. <a class="title" href="{{.Repository.Link}}/issues/{{.Issue.Index}}">
  433. #{{.Issue.Index}} {{.Issue.Title | RenderEmoji}}
  434. </a>
  435. <div class="text small">
  436. {{.Repository.OwnerName}}/{{.Repository.Name}}
  437. </div>
  438. </div>
  439. <div class="item-right df ac">
  440. {{if and $.CanCreateIssueDependencies (not $.Repository.IsArchived)}}
  441. <a class="delete-dependency-button poping up ci" onclick="window.deleteDependencyModal({{.Issue.ID}}, 'blocking');"
  442. data-content="{{$.i18n.Tr "repo.issues.dependency.remove_info"}}" data-inverted="">
  443. {{svg "octicon-trashcan" 16}}
  444. </a>
  445. {{end}}
  446. </div>
  447. </div>
  448. {{end}}
  449. </div>
  450. {{end}}
  451. {{if .BlockedByDependencies}}
  452. <span class="text poping up" data-content="{{if .Issue.IsPull}}{{.i18n.Tr "repo.issues.dependency.pr_closing_blockedby"}}{{else}}{{.i18n.Tr "repo.issues.dependency.issue_closing_blockedby"}}{{end}}">
  453. <strong>{{.i18n.Tr "repo.issues.dependency.blocked_by_short"}}</strong>
  454. </span>
  455. <div class="ui relaxed divided list">
  456. {{range .BlockedByDependencies}}
  457. <div class="item{{if .Issue.IsClosed}} is-closed{{end}} df ac sb">
  458. <div class="item-left df jc fc f1">
  459. <a class="title" href="{{.Repository.Link}}/issues/{{.Issue.Index}}">
  460. #{{.Issue.Index}} {{.Issue.Title | RenderEmoji}}
  461. </a>
  462. <div class="text small">
  463. {{.Repository.OwnerName}}/{{.Repository.Name}}
  464. </div>
  465. </div>
  466. <div class="item-right df ac">
  467. {{if and $.CanCreateIssueDependencies (not $.Repository.IsArchived)}}
  468. <a class="delete-dependency-button poping up ci" onclick="window.deleteDependencyModal({{.Issue.ID}}, 'blockedBy');"
  469. data-content="{{$.i18n.Tr "repo.issues.dependency.remove_info"}}" data-inverted="">
  470. {{svg "octicon-trashcan" 16}}
  471. </a>
  472. {{end}}
  473. </div>
  474. </div>
  475. {{end}}
  476. </div>
  477. {{end}}
  478. {{if and .CanCreateIssueDependencies (not .Repository.IsArchived)}}
  479. <div>
  480. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/dependency/add" id="addDependencyForm">
  481. {{$.CsrfTokenHtml}}
  482. <div class="ui fluid action input">
  483. <div class="ui search selection dropdown" id="new-dependency-drop-list" data-issue-id="{{.Issue.ID}}">
  484. <input name="newDependency" type="hidden">
  485. {{svg "octicon-triangle-down" 14 "dropdown icon"}}
  486. <input type="text" class="search">
  487. <div class="default text">{{.i18n.Tr "repo.issues.dependency.add"}}</div>
  488. </div>
  489. <button class="ui green icon button">
  490. <i class="plus icon"></i>
  491. </button>
  492. </div>
  493. </form>
  494. </div>
  495. {{end}}
  496. </div>
  497. {{ if and .IsRepoAdmin (not .Repository.IsArchived) }}
  498. <div class="ui divider"></div>
  499. <div class="ui watching">
  500. <div>
  501. <button class="fluid ui show-modal button {{if .Issue.IsLocked }} negative {{ end }}" data-modal="#lock">
  502. {{if .Issue.IsLocked}}
  503. {{svg "octicon-key"}}
  504. {{.i18n.Tr "repo.issues.unlock"}}
  505. {{else}}
  506. {{svg "octicon-lock"}}
  507. {{.i18n.Tr "repo.issues.lock"}}
  508. {{end}}
  509. </button>
  510. </form>
  511. </div>
  512. </div>
  513. <div class="ui tiny modal" id="lock">
  514. <div class="header">
  515. {{ if .Issue.IsLocked }}
  516. {{.i18n.Tr "repo.issues.unlock.title"}}
  517. {{ else }}
  518. {{.i18n.Tr "repo.issues.lock.title"}}
  519. {{ end }}
  520. </div>
  521. <div class="content">
  522. <div class="ui warning message text left">
  523. {{ if .Issue.IsLocked }}
  524. {{.i18n.Tr "repo.issues.unlock.notice_1"}}<br>
  525. {{.i18n.Tr "repo.issues.unlock.notice_2"}}<br>
  526. {{ else }}
  527. {{.i18n.Tr "repo.issues.lock.notice_1"}}<br>
  528. {{.i18n.Tr "repo.issues.lock.notice_2"}}<br>
  529. {{.i18n.Tr "repo.issues.lock.notice_3"}}<br>
  530. {{ end }}
  531. </div>
  532. <form class="ui form" action="{{$.RepoLink}}/issues/{{.Issue.Index}}{{ if .Issue.IsLocked }}/unlock{{ else }}/lock{{ end }}"
  533. method="post">
  534. {{.CsrfTokenHtml}}
  535. {{ if not .Issue.IsLocked }}
  536. <div class="field">
  537. <strong> {{ .i18n.Tr "repo.issues.lock.reason" }} </strong>
  538. </div>
  539. <div class="field">
  540. <div class="ui fluid dropdown selection" tabindex="0">
  541. <select name="reason">
  542. <option value=""> </option>
  543. {{range .LockReasons}}
  544. <option value="{{.}}">{{.}}</option>
  545. {{end}}
  546. </select>
  547. {{svg "octicon-triangle-down" 14 "dropdown icon"}}
  548. <div class="default text"> </div>
  549. <div class="menu transition hidden" tabindex="-1" style="display: block !important;">
  550. {{range .LockReasons}}
  551. <div class="item" data-value="{{.}}">{{.}}</div>
  552. {{end}}
  553. </div>
  554. </div>
  555. </div>
  556. {{ end }}
  557. <div class="text right actions">
  558. <div class="ui cancel button">{{.i18n.Tr "settings.cancel"}}</div>
  559. <button class="ui red button">
  560. {{ if .Issue.IsLocked }}
  561. {{.i18n.Tr "repo.issues.unlock_confirm"}}
  562. {{ else }}
  563. {{.i18n.Tr "repo.issues.lock_confirm"}}
  564. {{ end }}
  565. </button>
  566. </div>
  567. </form>
  568. </div>
  569. </div>
  570. {{ end }}
  571. </div>
  572. </div>
  573. {{if and .CanCreateIssueDependencies (not .Repository.IsArchived)}}
  574. <input type="hidden" id="repolink" value="{{$.RepoRelPath}}">
  575. <input type="hidden" id="repoId" value="{{.Repository.ID}}">
  576. <input type="hidden" id="crossRepoSearch" value="{{.AllowCrossRepositoryDependencies}}">
  577. <input type="hidden" id="type" value="{{.IssueType}}">
  578. <!-- I know, there is probably a better way to do this -->
  579. <input type="hidden" id="issueIndex" value="{{.Issue.Index}}"/>
  580. <div class="ui basic modal remove-dependency">
  581. <div class="ui icon header">
  582. {{svg "octicon-trashcan"}}
  583. {{.i18n.Tr "repo.issues.dependency.remove_header"}}
  584. </div>
  585. <div class="content">
  586. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/dependency/delete" id="removeDependencyForm">
  587. {{$.CsrfTokenHtml}}
  588. <input type="hidden" value="" name="removeDependencyID" id="removeDependencyID"/>
  589. <input type="hidden" value="" name="dependencyType" id="dependencyType"/>
  590. </form>
  591. <p>{{if .Issue.IsPull}}
  592. {{.i18n.Tr "repo.issues.dependency.pr_remove_text"}}
  593. {{else}}
  594. {{.i18n.Tr "repo.issues.dependency.issue_remove_text"}}
  595. {{end}}</p>
  596. </div>
  597. <div class="actions">
  598. <div class="ui basic red cancel inverted button">
  599. <i class="remove icon"></i>
  600. {{.i18n.Tr "repo.issues.dependency.cancel"}}
  601. </div>
  602. <div class="ui basic green ok inverted button">
  603. <i class="checkmark icon"></i>
  604. {{.i18n.Tr "repo.issues.dependency.remove"}}
  605. </div>
  606. </div>
  607. </div>
  608. {{end}}
  609. {{end}}