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.

notification_div.tmpl 8.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. <div class="page-content user notification" id="notification_div" data-params="{{.Page.GetParams}}">
  2. <div class="ui container">
  3. <h1 class="ui dividing header">{{.i18n.Tr "notification.notifications"}}</h1>
  4. <div class="ui top attached tabular menu">
  5. {{ $notificationUnreadCount := call .NotificationUnreadCount}}
  6. <a href="{{AppSubUrl}}/notifications?q=unread" class="{{if eq .Status 1}}active{{end}} item">
  7. {{.i18n.Tr "notification.unread"}}
  8. <div class="ui label {{if not $notificationUnreadCount}}hidden{{end}}">{{$notificationUnreadCount}}</div>
  9. </a>
  10. <a href="{{AppSubUrl}}/notifications?q=read" class="{{if eq .Status 2}}active{{end}} item">
  11. {{.i18n.Tr "notification.read"}}
  12. </a>
  13. {{if and (eq .Status 1)}}
  14. <form action="{{AppSubUrl}}/notifications/purge" method="POST" style="margin-left: auto;">
  15. {{$.CsrfTokenHtml}}
  16. <div class="{{if not $notificationUnreadCount}}hide{{end}}">
  17. <button class="ui mini button primary" title='{{$.i18n.Tr "notification.mark_all_as_read"}}'>
  18. {{svg "octicon-checklist"}}
  19. </button>
  20. </div>
  21. </form>
  22. {{end}}
  23. </div>
  24. <div class="ui bottom attached active tab segment">
  25. {{if eq (len .Notifications) 0}}
  26. {{if eq .Status 1}}
  27. {{.i18n.Tr "notification.no_unread"}}
  28. {{else}}
  29. {{.i18n.Tr "notification.no_read"}}
  30. {{end}}
  31. {{else}}
  32. <table class="ui unstackable striped very compact small selectable table" id="notification_table">
  33. <tbody>
  34. {{range $notification := .Notifications}}
  35. {{$issue := .Issue}}
  36. {{$repo := .Repository}}
  37. {{$repoOwner := $repo.MustOwner}}
  38. <tr id="notification_{{.ID}}">
  39. <td class="collapsing" data-href="{{.HTMLURL}}">
  40. {{if eq .Status 3}}
  41. <span class="blue">{{svg "octicon-pin"}}</span>
  42. {{else if not $issue}}
  43. <span class="gray">{{svg "octicon-repo"}}</span>
  44. {{else if $issue.IsPull}}
  45. {{if $issue.IsClosed}}
  46. {{if $issue.GetPullRequest.HasMerged}}
  47. <span class="purple">{{svg "octicon-git-merge"}}</span>
  48. {{else}}
  49. <span class="red">{{svg "octicon-git-pull-request"}}</span>
  50. {{end}}
  51. {{else}}
  52. <span class="green">{{svg "octicon-git-pull-request"}}</span>
  53. {{end}}
  54. {{else}}
  55. {{if $issue.IsClosed}}
  56. <span class="red">{{svg "octicon-issue-closed"}}</span>
  57. {{else}}
  58. <span class="green">{{svg "octicon-issue-opened"}}</span>
  59. {{end}}
  60. {{end}}
  61. </td>
  62. <td class="eleven wide" data-href="{{.HTMLURL}}">
  63. <a class="item" href="{{.HTMLURL}}">
  64. {{if $issue}}
  65. #{{$issue.Index}} - {{$issue.Title}}
  66. {{else}}
  67. {{$repo.FullName}}
  68. {{end}}
  69. </a>
  70. </td>
  71. <td data-href="{{AppSubUrl}}/{{$repoOwner.Name}}/{{$repo.Name}}">
  72. <a class="item" href="{{AppSubUrl}}/{{$repoOwner.Name}}/{{$repo.Name}}">
  73. {{$repoOwner.Name}}/{{$repo.Name}}
  74. </a>
  75. </td>
  76. <td class="collapsing">
  77. {{if ne .Status 3}}
  78. <form action="{{AppSubUrl}}/notifications/status" method="POST">
  79. {{$.CsrfTokenHtml}}
  80. <input type="hidden" name="notification_id" value="{{.ID}}" />
  81. <input type="hidden" name="status" value="pinned" />
  82. <button class="ui mini button" title='{{$.i18n.Tr "notification.pin"}}'
  83. data-url="{{AppSubUrl}}/notifications/status"
  84. data-status="pinned"
  85. data-page="{{$.Page.Paginater.Current}}"
  86. data-notification-id="{{.ID}}"
  87. data-q="{{$.Keyword}}">
  88. {{svg "octicon-pin"}}
  89. </button>
  90. </form>
  91. {{end}}
  92. </td>
  93. <td class="collapsing">
  94. {{if or (eq .Status 1) (eq .Status 3)}}
  95. <form action="{{AppSubUrl}}/notifications/status" method="POST">
  96. {{$.CsrfTokenHtml}}
  97. <input type="hidden" name="notification_id" value="{{.ID}}" />
  98. <input type="hidden" name="status" value="read" />
  99. <input type="hidden" name="page" value="{{$.Page.Paginater.Current}}" />
  100. <button class="ui mini button" title='{{$.i18n.Tr "notification.mark_as_read"}}'
  101. data-url="{{AppSubUrl}}/notifications/status"
  102. data-status="read"
  103. data-page="{{$.Page.Paginater.Current}}"
  104. data-notification-id="{{.ID}}"
  105. data-q="{{$.Keyword}}">
  106. {{svg "octicon-check"}}
  107. </button>
  108. </form>
  109. {{else if eq .Status 2}}
  110. <form action="{{AppSubUrl}}/notifications/status" method="POST">
  111. {{$.CsrfTokenHtml}}
  112. <input type="hidden" name="notification_id" value="{{.ID}}" />
  113. <input type="hidden" name="status" value="unread" />
  114. <input type="hidden" name="page" value="{{$.Page.Paginater.Current}}" />
  115. <button class="ui mini button" title='{{$.i18n.Tr "notification.mark_as_unread"}}'
  116. data-url="{{AppSubUrl}}/notifications/status"
  117. data-status="unread"
  118. data-page="{{$.Page.Paginater.Current}}"
  119. data-notification-id="{{.ID}}"
  120. data-q="{{$.Keyword}}">
  121. {{svg "octicon-bell"}}
  122. </button>
  123. </form>
  124. {{end}}
  125. </td>
  126. </tr>
  127. {{end}}
  128. </tbody>
  129. </table>
  130. {{end}}
  131. </div>
  132. {{template "base/paginate" .}}
  133. </div>
  134. </div>