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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463
  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}}/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}}"> {{.GetDisplayName}}
  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;{{.GetDisplayName}}</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 {{if gt .ID 0}}href="{{.HomeLink}}"{{end}}>
  107. <img class="ui avatar image poping up" src="{{.RelAvatarLink}}" data-content="{{.GetDisplayName}}" 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 .Issue.IsClosed}} is-closed{{end}}">
  262. <span class="text grey right floated">#{{.Issue.Index}}</span>
  263. <a class="title has-emoji" href="{{.Repository.Link}}/issues/{{.Issue.Index}}">{{.Issue.Title}}</a>
  264. <div class="text small">{{.Repository.OwnerName}}/{{.Repository.Name}}</div>
  265. <div class="ui transparent label right floated nopadding">
  266. {{if and $.CanCreateIssueDependencies (not $.Repository.IsArchived)}}
  267. <a class="delete-dependency-button" onclick="deleteDependencyModal({{.Issue.ID}}, 'blocking');"
  268. data-tooltip="{{$.i18n.Tr "repo.issues.dependency.remove_info"}}" data-inverted="">
  269. <i class="delete icon text red nopadding nomargin"></i>
  270. </a>
  271. {{end}}
  272. </div>
  273. </div>
  274. {{end}}
  275. </div>
  276. {{end}}
  277. {{if .BlockedByDependencies}}
  278. <span class="text" data-tooltip="{{if .Issue.IsPull}}
  279. {{.i18n.Tr "repo.issues.dependency.issue_closing_blockedby"}}
  280. {{else}}
  281. {{.i18n.Tr "repo.issues.dependency.pr_closing_blockedby"}}
  282. {{end}}" data-inverted="">
  283. <strong>{{.i18n.Tr "repo.issues.dependency.blocked_by_short"}}</strong>
  284. </span>
  285. <div class="ui relaxed divided list">
  286. {{range .BlockedByDependencies}}
  287. <div class="item{{if .Issue.IsClosed}} is-closed{{end}}">
  288. <span class="text grey right floated">#{{.Issue.Index}}</span>
  289. <a class="title has-emoji" href="{{.Repository.Link}}/issues/{{.Issue.Index}}">{{.Issue.Title}}</a>
  290. <div class="text small">{{.Repository.OwnerName}}/{{.Repository.Name}}</div>
  291. <div class="ui transparent label right floated nopadding">
  292. {{if and $.CanCreateIssueDependencies (not $.Repository.IsArchived)}}
  293. <a class="delete-dependency-button" onclick="deleteDependencyModal({{.Issue.ID}}, 'blockedBy');"
  294. data-tooltip="{{$.i18n.Tr "repo.issues.dependency.remove_info"}}" data-inverted="">
  295. <i class="delete icon text red nopadding nomargin"></i>
  296. </a>
  297. {{end}}
  298. </div>
  299. </div>
  300. {{end}}
  301. </div>
  302. {{end}}
  303. {{if and .CanCreateIssueDependencies (not .Repository.IsArchived)}}
  304. <div>
  305. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/dependency/add" id="addDependencyForm">
  306. {{$.CsrfTokenHtml}}
  307. <div class="ui fluid action input">
  308. <div class="ui search selection dropdown" id="new-dependency-drop-list" data-issue-id="{{.Issue.ID}}">
  309. <input name="newDependency" type="hidden">
  310. <i class="dropdown icon"></i>
  311. <input type="text" class="search">
  312. <div class="default text">{{.i18n.Tr "repo.issues.dependency.add"}}</div>
  313. </div>
  314. <button class="ui green icon button">
  315. <i class="plus icon"></i>
  316. </button>
  317. </div>
  318. </form>
  319. </div>
  320. {{end}}
  321. </div>
  322. {{ if and .IsRepoAdmin (not .Repository.IsArchived) }}
  323. <div class="ui divider"></div>
  324. <div class="ui watching">
  325. <div>
  326. <button class="fluid ui show-modal button {{if .Issue.IsLocked }} negative {{ end }}" data-modal="#lock">
  327. {{if .Issue.IsLocked}}
  328. <i class="octicon octicon-key"></i>
  329. {{.i18n.Tr "repo.issues.unlock"}}
  330. {{else}}
  331. <i class="octicon octicon-lock"></i>
  332. {{.i18n.Tr "repo.issues.lock"}}
  333. {{end}}
  334. </button>
  335. </form>
  336. </div>
  337. </div>
  338. <div class="ui tiny modal" id="lock">
  339. <div class="header">
  340. {{ if .Issue.IsLocked }}
  341. {{.i18n.Tr "repo.issues.unlock.title"}}
  342. {{ else }}
  343. {{.i18n.Tr "repo.issues.lock.title"}}
  344. {{ end }}
  345. </div>
  346. <div class="content">
  347. <div class="ui warning message text left">
  348. {{ if .Issue.IsLocked }}
  349. {{.i18n.Tr "repo.issues.unlock.notice_1"}}<br>
  350. {{.i18n.Tr "repo.issues.unlock.notice_2"}}<br>
  351. {{ else }}
  352. {{.i18n.Tr "repo.issues.lock.notice_1"}}<br>
  353. {{.i18n.Tr "repo.issues.lock.notice_2"}}<br>
  354. {{.i18n.Tr "repo.issues.lock.notice_3"}}<br>
  355. {{ end }}
  356. </div>
  357. <form class="ui form" action="{{$.RepoLink}}/issues/{{.Issue.Index}}{{ if .Issue.IsLocked }}/unlock{{ else }}/lock{{ end }}"
  358. method="post">
  359. {{.CsrfTokenHtml}}
  360. {{ if not .Issue.IsLocked }}
  361. <div class="field">
  362. <strong> {{ .i18n.Tr "repo.issues.lock.reason" }} </strong>
  363. </div>
  364. <div class="field">
  365. <div class="ui fluid dropdown selection" tabindex="0">
  366. <select name="reason">
  367. <option value=""> </option>
  368. {{range .LockReasons}}
  369. <option value="{{.}}">{{.}}</option>
  370. {{end}}
  371. </select>
  372. <i class="dropdown icon"></i>
  373. <div class="default text"> </div>
  374. <div class="menu transition hidden" tabindex="-1" style="display: block !important;">
  375. {{range .LockReasons}}
  376. <div class="item" data-value="{{.}}">{{.}}</div>
  377. {{end}}
  378. </div>
  379. </div>
  380. </div>
  381. {{ end }}
  382. <div class="text right actions">
  383. <div class="ui cancel button">{{.i18n.Tr "settings.cancel"}}</div>
  384. <button class="ui red button">
  385. {{ if .Issue.IsLocked }}
  386. {{.i18n.Tr "repo.issues.unlock_confirm"}}
  387. {{ else }}
  388. {{.i18n.Tr "repo.issues.lock_confirm"}}
  389. {{ end }}
  390. </button>
  391. </div>
  392. </form>
  393. </div>
  394. </div>
  395. {{ end }}
  396. </div>
  397. </div>
  398. {{if and .CanCreateIssueDependencies (not .Repository.IsArchived)}}
  399. <input type="hidden" id="repolink" value="{{$.RepoRelPath}}">
  400. <input type="hidden" id="repoId" value="{{.Repository.ID}}">
  401. <input type="hidden" id="crossRepoSearch" value="{{.AllowCrossRepositoryDependencies}}">
  402. <!-- I know, there is probably a better way to do this -->
  403. <input type="hidden" id="issueIndex" value="{{.Issue.Index}}"/>
  404. <div class="ui basic modal remove-dependency">
  405. <div class="ui icon header">
  406. <i class="trash icon"></i>
  407. {{.i18n.Tr "repo.issues.dependency.remove_header"}}
  408. </div>
  409. <div class="content">
  410. <form method="POST" action="{{$.RepoLink}}/issues/{{.Issue.Index}}/dependency/delete" id="removeDependencyForm">
  411. {{$.CsrfTokenHtml}}
  412. <input type="hidden" value="" name="removeDependencyID" id="removeDependencyID"/>
  413. <input type="hidden" value="" name="dependencyType" id="dependencyType"/>
  414. </form>
  415. <p>{{if .Issue.IsPull}}
  416. {{.i18n.Tr "repo.issues.dependency.pr_remove_text"}}
  417. {{else}}
  418. {{.i18n.Tr "repo.issues.dependency.issue_remove_text"}}
  419. {{end}}</p>
  420. </div>
  421. <div class="actions">
  422. <div class="ui basic red cancel inverted button">
  423. <i class="remove icon"></i>
  424. {{.i18n.Tr "repo.issues.dependency.cancel"}}
  425. </div>
  426. <div class="ui basic green ok inverted button">
  427. <i class="checkmark icon"></i>
  428. {{.i18n.Tr "repo.issues.dependency.remove"}}
  429. </div>
  430. </div>
  431. </div>
  432. {{end}}
  433. {{end}}