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

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