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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. {{$canWriteProject := and .CanWriteProjects (or (not .Repository) (not .Repository.IsArchived))}}
  2. <div class="ui container">
  3. <div class="tw-flex tw-justify-between tw-content-center gt-mb-4">
  4. <h2 class="gt-mb-0">{{.Project.Title}}</h2>
  5. {{if $canWriteProject}}
  6. <div class="ui compact mini menu">
  7. <a class="item" href="{{.Link}}/edit?redirect=project">
  8. {{svg "octicon-pencil"}}
  9. {{ctx.Locale.Tr "repo.issues.label_edit"}}
  10. </a>
  11. {{if .Project.IsClosed}}
  12. <button class="item btn link-action" data-url="{{.Link}}/open">
  13. {{svg "octicon-check"}}
  14. {{ctx.Locale.Tr "repo.projects.open"}}
  15. </button>
  16. {{else}}
  17. <button class="item btn link-action" data-url="{{.Link}}/close">
  18. {{svg "octicon-skip"}}
  19. {{ctx.Locale.Tr "repo.projects.close"}}
  20. </button>
  21. {{end}}
  22. <button class="item btn delete-button" data-url="{{.Link}}/delete" data-id="{{.Project.ID}}">
  23. {{svg "octicon-trash"}}
  24. {{ctx.Locale.Tr "repo.issues.label_delete"}}
  25. </button>
  26. <button class="item btn show-modal" data-modal="#new-project-column-item">
  27. {{svg "octicon-plus"}}
  28. {{ctx.Locale.Tr "new_project_column"}}
  29. </button>
  30. </div>
  31. <div class="ui small modal new-project-column-modal" id="new-project-column-item">
  32. <div class="header">
  33. {{ctx.Locale.Tr "repo.projects.column.new"}}
  34. </div>
  35. <div class="content">
  36. <form class="ui form">
  37. <div class="required field">
  38. <label for="new_project_column">{{ctx.Locale.Tr "repo.projects.column.new_title"}}</label>
  39. <input class="new-project-column" id="new_project_column" name="title" required>
  40. </div>
  41. <div class="field color-field">
  42. <label for="new_project_column_color_picker">{{ctx.Locale.Tr "repo.projects.column.color"}}</label>
  43. <div class="color picker column">
  44. <input class="color-picker" maxlength="7" placeholder="#c320f6" id="new_project_column_color_picker" name="color">
  45. {{template "repo/issue/label_precolors"}}
  46. </div>
  47. </div>
  48. <div class="text right actions">
  49. <button class="ui cancel button">{{ctx.Locale.Tr "settings.cancel"}}</button>
  50. <button data-url="{{$.Link}}" class="ui primary button" id="new_project_column_submit">{{ctx.Locale.Tr "repo.projects.column.new_submit"}}</button>
  51. </div>
  52. </form>
  53. </div>
  54. </div>
  55. {{end}}
  56. </div>
  57. <div class="content">{{$.Project.RenderedContent}}</div>
  58. <div class="divider"></div>
  59. </div>
  60. <div id="project-board">
  61. <div class="board {{if .CanWriteProjects}}sortable{{end}}">
  62. {{range .Columns}}
  63. <div class="ui segment project-column" style="background: {{.Color}} !important;" data-id="{{.ID}}" data-sorting="{{.Sorting}}" data-url="{{$.Link}}/{{.ID}}">
  64. <div class="project-column-header">
  65. <div class="ui large label project-column-title gt-py-2">
  66. <div class="ui small circular grey label project-column-issue-count">
  67. {{.NumIssues ctx}}
  68. </div>
  69. {{.Title}}
  70. </div>
  71. {{if and $canWriteProject (ne .ID 0)}}
  72. <div class="ui dropdown jump item">
  73. <div class="gt-px-3">
  74. {{svg "octicon-kebab-horizontal"}}
  75. </div>
  76. <div class="menu user-menu">
  77. <a class="item show-modal button" data-modal="#edit-project-column-modal-{{.ID}}">
  78. {{svg "octicon-pencil"}}
  79. {{ctx.Locale.Tr "repo.projects.column.edit"}}
  80. </a>
  81. {{if not .Default}}
  82. <a class="item show-modal button default-project-column-show"
  83. data-modal="#default-project-column-modal-{{.ID}}"
  84. data-modal-default-project-column-header="{{ctx.Locale.Tr "repo.projects.column.set_default"}}"
  85. data-modal-default-project-column-content="{{ctx.Locale.Tr "repo.projects.column.set_default_desc"}}"
  86. data-url="{{$.Link}}/{{.ID}}/default">
  87. {{svg "octicon-pin"}}
  88. {{ctx.Locale.Tr "repo.projects.column.set_default"}}
  89. </a>
  90. {{else}}
  91. <a class="item show-modal button default-project-column-show"
  92. data-modal="#default-project-column-modal-{{.ID}}"
  93. data-modal-default-project-column-header="{{ctx.Locale.Tr "repo.projects.column.unset_default"}}"
  94. data-modal-default-project-column-content="{{ctx.Locale.Tr "repo.projects.column.unset_default_desc"}}"
  95. data-url="{{$.Link}}/{{.ID}}/unsetdefault">
  96. {{svg "octicon-pin-slash"}}
  97. {{ctx.Locale.Tr "repo.projects.column.unset_default"}}
  98. </a>
  99. {{end}}
  100. <a class="item show-modal button show-delete-project-column-modal"
  101. data-modal="#delete-project-column-modal-{{.ID}}"
  102. data-url="{{$.Link}}/{{.ID}}">
  103. {{svg "octicon-trash"}}
  104. {{ctx.Locale.Tr "repo.projects.column.delete"}}
  105. </a>
  106. <div class="ui small modal edit-project-column-modal" id="edit-project-column-modal-{{.ID}}">
  107. <div class="header">
  108. {{ctx.Locale.Tr "repo.projects.column.edit"}}
  109. </div>
  110. <div class="content">
  111. <form class="ui form">
  112. <div class="required field">
  113. <label for="new_project_column_title">{{ctx.Locale.Tr "repo.projects.column.edit_title"}}</label>
  114. <input class="project-column-title-input" id="new_project_column_title" name="title" value="{{.Title}}" required>
  115. </div>
  116. <div class="field color-field">
  117. <label for="new_project_column_color">{{ctx.Locale.Tr "repo.projects.column.color"}}</label>
  118. <div class="color picker column">
  119. <input class="color-picker" maxlength="7" placeholder="#c320f6" id="new_project_column_color" name="color" value="{{.Color}}">
  120. {{template "repo/issue/label_precolors"}}
  121. </div>
  122. </div>
  123. <div class="text right actions">
  124. <button class="ui cancel button">{{ctx.Locale.Tr "settings.cancel"}}</button>
  125. <button data-url="{{$.Link}}/{{.ID}}" class="ui primary button edit-project-column-button">{{ctx.Locale.Tr "repo.projects.column.edit"}}</button>
  126. </div>
  127. </form>
  128. </div>
  129. </div>
  130. <div class="ui g-modal-confirm modal default-project-column-modal" id="default-project-column-modal-{{.ID}}">
  131. <div class="header">
  132. <span id="default-project-column-header"></span>
  133. </div>
  134. <div class="content">
  135. <label id="default-project-column-content"></label>
  136. </div>
  137. {{template "base/modal_actions_confirm" (dict "ModalButtonTypes" "confirm")}}
  138. </div>
  139. <div class="ui g-modal-confirm modal" id="delete-project-column-modal-{{.ID}}">
  140. <div class="header">
  141. {{ctx.Locale.Tr "repo.projects.column.delete"}}
  142. </div>
  143. <div class="content">
  144. <label>
  145. {{ctx.Locale.Tr "repo.projects.column.deletion_desc"}}
  146. </label>
  147. </div>
  148. {{template "base/modal_actions_confirm" (dict "ModalButtonTypes" "confirm")}}
  149. </div>
  150. </div>
  151. </div>
  152. {{end}}
  153. </div>
  154. <div class="divider"></div>
  155. <div class="ui cards {{if and $canWriteProject (ne .ID 0)}}{{/* ID 0 is default column which cannot be moved */}}tw-cursor-grab{{end}}" data-url="{{$.Link}}/{{.ID}}" data-project="{{$.Project.ID}}" data-board="{{.ID}}" id="board_{{.ID}}">
  156. {{range (index $.IssuesMap .ID)}}
  157. <div class="issue-card gt-word-break {{if $canWriteProject}}tw-cursor-grab{{end}}" data-issue="{{.ID}}">
  158. {{template "repo/issue/card" (dict "Issue" . "Page" $)}}
  159. </div>
  160. {{end}}
  161. </div>
  162. </div>
  163. {{end}}
  164. </div>
  165. </div>
  166. {{if .CanWriteProjects}}
  167. <div class="ui g-modal-confirm delete modal">
  168. <div class="header">
  169. {{svg "octicon-trash"}}
  170. {{ctx.Locale.Tr "repo.projects.deletion"}}
  171. </div>
  172. <div class="content">
  173. <p>{{ctx.Locale.Tr "repo.projects.deletion_desc"}}</p>
  174. </div>
  175. {{template "base/modal_actions_confirm" .}}
  176. </div>
  177. {{end}}