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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. {{template "base/head" .}}
  2. <div class="page-content 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-trash"}}
  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" data-id="{{.ID}}" data-sorting="{{.Sorting}}" data-url="{{$.RepoLink}}/projects/{{$.Project.ID}}/{{.ID}}">
  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. <span class="fitted not-mobile" tabindex="-1">{{svg "octicon-kebab-horizontal" 24}}</span>
  79. </span>
  80. <div class="menu user-menu" tabindex="-1">
  81. <a class="item show-modal button" data-modal="#edit-project-board-modal-{{.ID}}">
  82. {{svg "octicon-pencil"}}
  83. {{$.i18n.Tr "repo.projects.board.edit"}}
  84. </a>
  85. {{if not .Default}}
  86. <a class="item show-modal button" data-modal="#set-default-project-board-modal-{{.ID}}">
  87. {{svg "octicon-pin"}}
  88. {{$.i18n.Tr "repo.projects.board.set_default"}}
  89. </a>
  90. {{end}}
  91. <a class="item show-modal button" data-modal="#delete-board-modal-{{.ID}}">
  92. {{svg "octicon-trash"}}
  93. {{$.i18n.Tr "repo.projects.board.delete"}}
  94. </a>
  95. <div class="ui small modal edit-project-board" id="edit-project-board-modal-{{.ID}}">
  96. <div class="header">
  97. {{$.i18n.Tr "repo.projects.board.edit"}}
  98. </div>
  99. <div class="content">
  100. <form class="ui form">
  101. <div class="required field">
  102. <label for="new_board_title">{{$.i18n.Tr "repo.projects.board.edit_title"}}</label>
  103. <input class="project-board-title" id="new_board_title" name="title" value="{{.Title}}" required>
  104. </div>
  105. <div class="text right actions">
  106. <div class="ui cancel button">{{$.i18n.Tr "settings.cancel"}}</div>
  107. <button data-url="{{$.RepoLink}}/projects/{{$.Project.ID}}/{{.ID}}" class="ui red button">{{$.i18n.Tr "repo.projects.board.edit"}}</button>
  108. </div>
  109. </form>
  110. </div>
  111. </div>
  112. <div class="ui basic modal" id="set-default-project-board-modal-{{.ID}}">
  113. <div class="ui icon header">
  114. {{$.i18n.Tr "repo.projects.board.set_default"}}
  115. </div>
  116. <div class="content center">
  117. <label>
  118. {{$.i18n.Tr "repo.projects.board.set_default_desc"}}
  119. </label>
  120. </div>
  121. <div class="text right actions">
  122. <div class="ui cancel button">{{$.i18n.Tr "settings.cancel"}}</div>
  123. <button class="ui red button set-default-project-board" data-url="{{$.RepoLink}}/projects/{{$.Project.ID}}/{{.ID}}/default">{{$.i18n.Tr "repo.projects.board.set_default"}}</button>
  124. </div>
  125. </div>
  126. <div class="ui basic modal" id="delete-board-modal-{{.ID}}">
  127. <div class="ui icon header">
  128. {{$.i18n.Tr "repo.projects.board.delete"}}
  129. </div>
  130. <div class="content center">
  131. <label>
  132. {{$.i18n.Tr "repo.projects.board.deletion_desc"}}
  133. </label>
  134. </div>
  135. <div class="text right actions">
  136. <div class="ui cancel button">{{$.i18n.Tr "settings.cancel"}}</div>
  137. <button class="ui red button delete-project-board" data-url="{{$.RepoLink}}/projects/{{$.Project.ID}}/{{.ID}}">{{$.i18n.Tr "repo.projects.board.delete"}}</button>
  138. </div>
  139. </div>
  140. </div>
  141. </div>
  142. {{ end }}
  143. </div>
  144. <div class="ui divider"></div>
  145. <div class="ui cards board" data-url="{{$.RepoLink}}/projects/{{$.Project.ID}}/{{.ID}}" data-project="{{$.Project.ID}}" data-board="{{.ID}}" id="board_{{.ID}}">
  146. {{ range .Issues }}
  147. <!-- start issue card -->
  148. <div class="card board-card" data-issue="{{.ID}}">
  149. <div class="content">
  150. <div class="header">
  151. <span>
  152. {{if .IsPull}}
  153. {{if .PullRequest.HasMerged}}
  154. {{svg "octicon-git-merge" 16 "text purple"}}
  155. {{else}}
  156. {{if .IsClosed}}
  157. {{svg "octicon-git-pull-request" 16 "text red"}}
  158. {{else}}
  159. {{svg "octicon-git-pull-request" 16 "text green"}}
  160. {{end}}
  161. {{end}}
  162. {{else}}
  163. {{if .IsClosed}}
  164. {{svg "octicon-issue-closed" 16 "text red"}}
  165. {{else}}
  166. {{svg "octicon-issue-opened" 16 "text green"}}
  167. {{end}}
  168. {{end}}
  169. </span>
  170. <a class="project-board-title" href="{{$.RepoLink}}/issues/{{.Index}}">#{{.Index}} {{.Title}}</a>
  171. </div>
  172. {{- if .MilestoneID }}
  173. <div class="meta">
  174. <a class="milestone" href="{{$.RepoLink}}/milestone/{{ .MilestoneID}}">
  175. {{svg "octicon-milestone"}} {{ .Milestone.Name }}
  176. </a>
  177. </div>
  178. {{- end }}
  179. {{- range index $.LinkedPRs .ID }}
  180. <div class="meta">
  181. <a href="{{$.RepoLink}}/pulls/{{ .Index }}">
  182. <span class="{{if .PullRequest.HasMerged}}purple{{else if .IsClosed}}red{{else}}green{{end}}">{{svg "octicon-git-merge"}}</span>
  183. {{ .Title}} (#{{ .Index }})
  184. </a>
  185. </div>
  186. {{- end }}
  187. </div>
  188. <div class="extra content">
  189. {{ range .Labels }}
  190. <a class="ui label" href="{{$.RepoLink}}/issues?labels={{.ID}}" style="color: {{.ForegroundColor}}; background-color: {{.Color}}; margin-bottom: 3px;" title="{{.Description | RenderEmojiPlain}}">{{.Name | RenderEmoji}}</a>
  191. {{ end }}
  192. </div>
  193. </div>
  194. <!-- stop issue card -->
  195. {{ end }}
  196. </div>
  197. </div>
  198. {{ end }}
  199. </div>
  200. </div>
  201. </div>
  202. {{if or .CanWriteIssues .CanWritePulls}}
  203. <div class="ui small basic delete modal">
  204. <div class="ui icon header">
  205. {{svg "octicon-trash"}}
  206. {{.i18n.Tr "repo.projects.deletion"}}
  207. </div>
  208. <div class="content">
  209. <p>{{.i18n.Tr "repo.projects.deletion_desc"}}</p>
  210. </div>
  211. <div class="actions">
  212. <div class="ui red basic inverted cancel button">
  213. <i class="remove icon"></i>
  214. {{.i18n.Tr "modal.no"}}
  215. </div>
  216. <div class="ui green basic inverted ok button">
  217. <i class="checkmark icon"></i>
  218. {{.i18n.Tr "modal.yes"}}
  219. </div>
  220. </div>
  221. </div>
  222. {{end}}
  223. {{template "base/footer" .}}