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.

view.tmpl 7.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. {{template "base/head" .}}
  2. <div class="repository">
  3. {{template "repo/header" .}}
  4. <div class="ui container">
  5. <div class="ui three column stackable grid">
  6. <div class="column">
  7. {{template "repo/issue/navbar" .}}
  8. </div>
  9. <div class="column center aligned">
  10. {{template "repo/issue/search" .}}
  11. </div>
  12. <div class="column right aligned">
  13. {{if and .CanWriteProjects (not .Repository.IsArchived) .PageIsProjects}}
  14. <a class="ui green button show-modal item" data-modal="#new-board-item">{{.i18n.Tr "new_project_board"}}</a>
  15. {{end}}
  16. <div class="ui small modal" id="new-board-item">
  17. <div class="header">
  18. {{$.i18n.Tr "repo.projects.board.new"}}
  19. </div>
  20. <div class="content">
  21. <form class="ui form">
  22. <div class="required field">
  23. <label for="new_board">{{$.i18n.Tr "repo.projects.board.new_title"}}</label>
  24. <input class="new-board" id="new_board" name="title" required>
  25. </div>
  26. <div class="text right actions">
  27. <div class="ui cancel button">{{$.i18n.Tr "settings.cancel"}}</div>
  28. <button data-url="{{$.RepoLink}}/projects/{{$.Project.ID}}" class="ui green button" id="new_board_submit">{{$.i18n.Tr "repo.projects.board.new_submit"}}</button>
  29. </div>
  30. </form>
  31. </div>
  32. </div>
  33. </div>
  34. </div>
  35. <div class="ui divider"></div>
  36. <div class="ui two column stackable grid">
  37. <div class="column">
  38. <h2 class="project-title">{{$.Project.Title}}</h2>
  39. <div class="content project-description">{{$.Project.RenderedContent|Str2html}}</div>
  40. </div>
  41. {{if and (or $.CanWriteIssues $.CanWritePulls) (not $.Repository.IsArchived)}}
  42. <div class="column right aligned">
  43. <div class="ui compact right small menu">
  44. <a class="item" href="{{$.RepoLink}}/projects/{{.Project.ID}}/edit" data-id={{$.Project.ID}} data-title={{$.Project.Title}}>
  45. {{svg "octicon-pencil"}}
  46. <span class="mx-3">{{$.i18n.Tr "repo.issues.label_edit"}}</span>
  47. </a>
  48. {{if .Project.IsClosed}}
  49. <a class="item link-action" href data-url="{{$.RepoLink}}/projects/{{.Project.ID}}/open">
  50. {{svg "octicon-check"}}
  51. <span class="mx-3">{{$.i18n.Tr "repo.projects.open"}}</span>
  52. </a>
  53. {{else}}
  54. <a class="item link-action" href data-url="{{$.RepoLink}}/projects/{{.Project.ID}}/close">
  55. {{svg "octicon-skip"}}
  56. <span class="mx-3">{{$.i18n.Tr "repo.projects.close"}}</span>
  57. </a>
  58. {{end}}
  59. <a class="item delete-button" href="#" data-url="{{$.RepoLink}}/projects/{{.Project.ID}}/delete" data-id="{{.Project.ID}}">
  60. {{svg "octicon-trashcan"}}
  61. <span class="mx-3">{{$.i18n.Tr "repo.issues.label_delete"}}</span>
  62. </a>
  63. </div>
  64. </div>
  65. {{end}}
  66. </div>
  67. <div class="ui divider"></div>
  68. </div>
  69. <div class="ui container fluid padded" id="project-board">
  70. <div class="board">
  71. {{ range $board := .Boards }}
  72. <div class="ui segment board-column">
  73. <div class="board-column-header">
  74. <div class="ui large label board-label">{{.Title}}</div>
  75. {{if and $.CanWriteProjects (not $.Repository.IsArchived) $.PageIsProjects (ne .ID 0)}}
  76. <div class="ui dropdown jump item poping up right" data-variation="tiny inverted">
  77. <span class="ui text">
  78. <img class="ui tiny avatar image" width="24" height="24">
  79. <span class="fitted not-mobile" tabindex="-1">{{svg "octicon-kebab-horizontal" 24}}</span>
  80. </span>
  81. <div class="menu user-menu" tabindex="-1">
  82. <a class="item show-modal button" data-modal="#edit-project-board-modal-{{.ID}}">
  83. {{svg "octicon-pencil"}}
  84. {{$.i18n.Tr "repo.projects.board.edit"}}
  85. </a>
  86. <a class="item show-modal button" data-modal="#delete-board-modal-{{.ID}}">
  87. {{svg "octicon-trashcan"}}
  88. {{$.i18n.Tr "repo.projects.board.delete"}}
  89. </a>
  90. <div class="ui small modal edit-project-board" id="edit-project-board-modal-{{.ID}}">
  91. <div class="header">
  92. {{$.i18n.Tr "repo.projects.board.edit"}}
  93. </div>
  94. <div class="content">
  95. <form class="ui form">
  96. <div class="required field">
  97. <label for="new_board_title">{{$.i18n.Tr "repo.projects.board.edit_title"}}</label>
  98. <input class="project-board-title" id="new_board_title" name="title" value="{{.Title}}" required>
  99. </div>
  100. <div class="text right actions">
  101. <div class="ui cancel button">{{$.i18n.Tr "settings.cancel"}}</div>
  102. <button data-url="{{$.RepoLink}}/projects/{{$.Project.ID}}/{{.ID}}" class="ui red button">{{$.i18n.Tr "repo.projects.board.edit"}}</button>
  103. </div>
  104. </form>
  105. </div>
  106. </div>
  107. <div class="ui basic modal" id="delete-board-modal-{{.ID}}">
  108. <div class="ui icon header">
  109. {{$.i18n.Tr "repo.projects.board.delete"}}
  110. </div>
  111. <div class="content center">
  112. <input type="hidden" name="action" value="delete">
  113. <div class="field">
  114. <label>
  115. {{$.i18n.Tr "repo.projects.board.deletion_desc"}}
  116. </label>
  117. </div>
  118. </div>
  119. <form class="ui form" method="post">
  120. <div class="text right actions">
  121. <div class="ui cancel button">{{$.i18n.Tr "settings.cancel"}}</div>
  122. <button class="ui red button delete-project-board" data-url="{{$.RepoLink}}/projects/{{$.Project.ID}}/{{.ID}}">{{$.i18n.Tr "repo.projects.board.delete"}}</button>
  123. </div>
  124. </form>
  125. </div>
  126. </div>
  127. </div>
  128. {{ end }}
  129. </div>
  130. <div class="ui divider"></div>
  131. <div class="ui cards board" data-url="{{$.RepoLink}}/projects/{{$.Project.ID}}/{{.ID}}" data-project="{{$.Project.ID}}" data-board="{{.ID}}" id="board_{{.ID}}">
  132. {{ range .Issues }}
  133. <!-- start issue card -->
  134. <div class="card board-card" data-issue="{{.ID}}">
  135. <div class="content">
  136. <div class="header">
  137. <span class="{{if .IsClosed}}red{{else}}green{{end}}">
  138. {{if .IsPull}}{{svg "octicon-git-merge"}}
  139. {{else if .IsClosed}}{{svg "octicon-issue-closed"}}
  140. {{else}}{{svg "octicon-issue-opened"}}
  141. {{end}}
  142. </span>
  143. <a class="project-board-title" href="{{$.RepoLink}}/issues/{{.Index}}">#{{.Index}} {{.Title}}</a>
  144. </div>
  145. <div class="meta">
  146. {{ if .MilestoneID }}
  147. <a class="milestone" href="{{$.RepoLink}}/milestone/{{ .MilestoneID}}">
  148. {{svg "octicon-milestone"}} {{ .Milestone.Name }}
  149. </a>
  150. {{ end }}
  151. </div>
  152. </div>
  153. <div class="extra content">
  154. {{ range .Labels }}
  155. <a class="ui label has-emoji" href="{{$.RepoLink}}/issues?labels={{.ID}}" style="color: {{.ForegroundColor}}; background-color: {{.Color}}; margin-bottom: 3px;" title="{{.Description}}">{{.Name}}</a>
  156. {{ end }}
  157. </div>
  158. </div>
  159. <!-- stop issue card -->
  160. {{ end }}
  161. </div>
  162. </div>
  163. {{ end }}
  164. </div>
  165. </div>
  166. </div>
  167. {{if or .CanWriteIssues .CanWritePulls}}
  168. <div class="ui small basic delete modal">
  169. <div class="ui icon header">
  170. {{svg "octicon-trashcan"}}
  171. {{.i18n.Tr "repo.projects.deletion"}}
  172. </div>
  173. <div class="content">
  174. <p>{{.i18n.Tr "repo.projects.deletion_desc"}}</p>
  175. </div>
  176. <div class="actions">
  177. <div class="ui red basic inverted cancel button">
  178. <i class="remove icon"></i>
  179. {{.i18n.Tr "modal.no"}}
  180. </div>
  181. <div class="ui green basic inverted ok button">
  182. <i class="checkmark icon"></i>
  183. {{.i18n.Tr "modal.yes"}}
  184. </div>
  185. </div>
  186. </div>
  187. {{end}}
  188. {{template "base/footer" .}}