Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
0dcff519
Commit
0dcff519
authored
Oct 26, 2018
by
Heinrich Lee Yu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Port of 52545-guest-create-issue-in-group-board to EE
parent
c9ce4db3
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
44 additions
and
16 deletions
+44
-16
app/assets/javascripts/boards/components/board.js
app/assets/javascripts/boards/components/board.js
+3
-0
app/assets/javascripts/boards/components/project_select.vue
app/assets/javascripts/boards/components/project_select.vue
+1
-1
app/controllers/concerns/boards_responses.rb
app/controllers/concerns/boards_responses.rb
+4
-1
app/views/shared/boards/components/_board.html.haml
app/views/shared/boards/components/_board.html.haml
+8
-8
changelogs/unreleased/52545-guest-create-issue-in-group-board.yml
...gs/unreleased/52545-guest-create-issue-in-group-board.yml
+5
-0
spec/controllers/boards/issues_controller_spec.rb
spec/controllers/boards/issues_controller_spec.rb
+15
-4
spec/features/boards/new_issue_spec.rb
spec/features/boards/new_issue_spec.rb
+8
-2
No files found.
app/assets/javascripts/boards/components/board.js
View file @
0dcff519
...
@@ -53,6 +53,9 @@ export default Vue.extend({
...
@@ -53,6 +53,9 @@ export default Vue.extend({
const
{
issuesSize
}
=
this
.
list
;
const
{
issuesSize
}
=
this
.
list
;
return
`
${
n__
(
'
%d issue
'
,
'
%d issues
'
,
issuesSize
)}
`
;
return
`
${
n__
(
'
%d issue
'
,
'
%d issues
'
,
issuesSize
)}
`
;
},
},
isNewIssueShown
()
{
return
this
.
list
.
type
===
'
backlog
'
||
(
!
this
.
disabled
&&
this
.
list
.
type
!==
'
closed
'
);
}
},
},
watch
:
{
watch
:
{
filter
:
{
filter
:
{
...
...
app/assets/javascripts/boards/components/project_select.vue
View file @
0dcff519
...
@@ -46,7 +46,7 @@ export default {
...
@@ -46,7 +46,7 @@ export default {
selectable
:
true
,
selectable
:
true
,
data
:
(
term
,
callback
)
=>
{
data
:
(
term
,
callback
)
=>
{
this
.
loading
=
true
;
this
.
loading
=
true
;
return
Api
.
groupProjects
(
this
.
groupId
,
term
,
{},
projects
=>
{
return
Api
.
groupProjects
(
this
.
groupId
,
term
,
{
with_issues_enabled
:
true
},
projects
=>
{
this
.
loading
=
false
;
this
.
loading
=
false
;
callback
(
projects
);
callback
(
projects
);
});
});
...
...
app/controllers/concerns/boards_responses.rb
View file @
0dcff519
...
@@ -50,7 +50,10 @@ module BoardsResponses
...
@@ -50,7 +50,10 @@ module BoardsResponses
end
end
def
authorize_create_issue
def
authorize_create_issue
authorize_action_for!
(
project
,
:admin_issue
)
list
=
List
.
find
(
issue_params
[
:list_id
])
action
=
list
.
backlog?
?
:create_issue
:
:admin_issue
authorize_action_for!
(
project
,
action
)
end
end
def
authorize_admin_list
def
authorize_admin_list
...
...
app/views/shared/boards/components/_board.html.haml
View file @
0dcff519
...
@@ -39,14 +39,14 @@
...
@@ -39,14 +39,14 @@
{{ list.issuesSize }}
{{ list.issuesSize }}
=
render_if_exists
"shared/boards/components/list_weight"
=
render_if_exists
"shared/boards/components/list_weight"
-
if
can?
(
current_user
,
:admin_list
,
current_board_parent
)
%button
.issue-count-badge-add-button.btn.btn-sm.btn-default.ml-1.has-tooltip.js-no-trigger-collapse
{
type:
"button"
,
%button
.issue-count-badge-add-button.btn.btn-sm.btn-default.ml-1.has-tooltip.js-no-trigger-collapse
{
type:
"button
"
,
"@click"
=>
"showNewIssueForm
"
,
"@click"
=>
"showNewIssueForm
"
,
"v-if"
=>
"isNewIssueShown
"
,
"v-if"
=>
'list.type !== "closed"'
,
"aria-label"
=>
_
(
"New issue"
)
,
"aria-label
"
=>
_
(
"New issue"
),
"title
"
=>
_
(
"New issue"
),
"title"
=>
_
(
"New issue"
),
data:
{
placement:
"top"
,
container:
"body"
}
}
data:
{
placement:
"top"
,
container:
"body"
}
}
=
icon
(
"plus"
,
class:
"js-no-trigger-collapse"
)
=
icon
(
"plus"
,
class:
"js-no-trigger-collapse"
)
%board-list
{
"v-if"
=>
'list.type !== "blank" && list.type !== "promotion"'
,
%board-list
{
"v-if"
=>
'list.type !== "blank" && list.type !== "promotion"'
,
":list"
=>
"list"
,
":list"
=>
"list"
,
":issues"
=>
"list.issues"
,
":issues"
=>
"list.issues"
,
...
...
changelogs/unreleased/52545-guest-create-issue-in-group-board.yml
0 → 100644
View file @
0dcff519
---
title
:
Always show new issue button in boards' Open list
merge_request
:
22557
author
:
Heinrich Lee Yu
type
:
fixed
spec/controllers/boards/issues_controller_spec.rb
View file @
0dcff519
...
@@ -208,11 +208,22 @@ describe Boards::IssuesController do
...
@@ -208,11 +208,22 @@ describe Boards::IssuesController do
end
end
end
end
context
'with unauthorized user'
do
context
'with guest user'
do
it
'returns a forbidden 403 response'
do
context
'in open list'
do
create_issue
user:
guest
,
board:
board
,
list:
list1
,
title:
'New issue'
it
'returns a successful 200 response'
do
open_list
=
board
.
lists
.
create
(
list_type: :backlog
)
create_issue
user:
guest
,
board:
board
,
list:
open_list
,
title:
'New issue'
expect
(
response
).
to
have_gitlab_http_status
(
403
)
expect
(
response
).
to
have_gitlab_http_status
(
200
)
end
end
context
'in label list'
do
it
'returns a forbidden 403 response'
do
create_issue
user:
guest
,
board:
board
,
list:
list1
,
title:
'New issue'
expect
(
response
).
to
have_gitlab_http_status
(
403
)
end
end
end
end
end
...
...
spec/features/boards/new_issue_spec.rb
View file @
0dcff519
...
@@ -94,8 +94,14 @@ describe 'Issue Boards new issue', :js do
...
@@ -94,8 +94,14 @@ describe 'Issue Boards new issue', :js do
wait_for_requests
wait_for_requests
end
end
it
'does not display new issue button'
do
it
'displays new issue button in open list'
do
expect
(
page
).
to
have_selector
(
'.issue-count-badge-add-button'
,
count:
0
)
expect
(
first
(
'.board'
)).
to
have_selector
(
'.issue-count-badge-add-button'
,
count:
1
)
end
it
'does not display new issue button in label list'
do
page
.
within
(
'.board:nth-child(2)'
)
do
expect
(
page
).
not_to
have_selector
(
'.issue-count-badge-add-button'
)
end
end
end
end
end
end
end
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment