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
4870a75f
Commit
4870a75f
authored
Jul 18, 2017
by
Eric Eastwood
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add native enter submit to related issues form
Fix
https://gitlab.com/gitlab-org/gitlab-ee/issues/2925
parent
833969f4
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
62 additions
and
11 deletions
+62
-11
app/assets/javascripts/issuable/related_issues/components/add_issuable_form.vue
.../issuable/related_issues/components/add_issuable_form.vue
+5
-5
app/assets/javascripts/issuable/related_issues/components/related_issues_root.vue
...ssuable/related_issues/components/related_issues_root.vue
+7
-2
spec/features/issuables/related_issues_spec.rb
spec/features/issuables/related_issues_spec.rb
+14
-0
spec/javascripts/issuable/related_issues/components/add_issuable_form_spec.js
...uable/related_issues/components/add_issuable_form_spec.js
+3
-1
spec/javascripts/issuable/related_issues/components/related_issues_root_spec.js
...ble/related_issues/components/related_issues_root_spec.js
+33
-3
No files found.
app/assets/javascripts/issuable/related_issues/components/add_issuable_form.vue
View file @
4870a75f
...
@@ -75,7 +75,8 @@ export default {
...
@@ -75,7 +75,8 @@ export default {
this
.
$refs
.
input
.
focus
();
this
.
$refs
.
input
.
focus
();
},
},
onFormSubmit
()
{
onFormSubmit
()
{
eventHub
.
$emit
(
'
addIssuableFormSubmit
'
);
const
value
=
this
.
$refs
.
input
.
value
;
eventHub
.
$emit
(
'
addIssuableFormSubmit
'
,
value
);
},
},
onFormCancel
()
{
onFormCancel
()
{
eventHub
.
$emit
(
'
addIssuableFormCancel
'
);
eventHub
.
$emit
(
'
addIssuableFormCancel
'
);
...
@@ -105,7 +106,7 @@ export default {
...
@@ -105,7 +106,7 @@ export default {
</
script
>
</
script
>
<
template
>
<
template
>
<
div
>
<
form
@
submit.prevent=
"onFormSubmit"
>
<div
<div
ref=
"issuableFormWrapper"
ref=
"issuableFormWrapper"
class=
"add-issuable-form-input-wrapper form-control"
class=
"add-issuable-form-input-wrapper form-control"
...
@@ -139,9 +140,8 @@ export default {
...
@@ -139,9 +140,8 @@ export default {
<div
class=
"add-issuable-form-actions clearfix"
>
<div
class=
"add-issuable-form-actions clearfix"
>
<button
<button
ref=
"addButton"
ref=
"addButton"
type=
"
button
"
type=
"
submit
"
class=
"js-add-issuable-form-add-button btn btn-new pull-left"
class=
"js-add-issuable-form-add-button btn btn-new pull-left"
@
click=
"onFormSubmit"
:disabled=
"isSubmitButtonDisabled"
>
:disabled=
"isSubmitButtonDisabled"
>
Add
Add
<loadingIcon
<loadingIcon
...
@@ -157,5 +157,5 @@ export default {
...
@@ -157,5 +157,5 @@ export default {
Cancel
Cancel
</button>
</button>
</div>
</div>
</
div
>
</
form
>
</
template
>
</
template
>
app/assets/javascripts/issuable/related_issues/components/related_issues_root.vue
View file @
4870a75f
...
@@ -102,7 +102,9 @@ export default {
...
@@ -102,7 +102,9 @@ export default {
onPendingIssueRemoveRequest
(
indexToRemove
)
{
onPendingIssueRemoveRequest
(
indexToRemove
)
{
this
.
store
.
removePendingRelatedIssue
(
indexToRemove
);
this
.
store
.
removePendingRelatedIssue
(
indexToRemove
);
},
},
onPendingFormSubmit
()
{
onPendingFormSubmit
(
newValue
)
{
this
.
processAllReferences
(
newValue
);
if
(
this
.
state
.
pendingReferences
.
length
>
0
)
{
if
(
this
.
state
.
pendingReferences
.
length
>
0
)
{
this
.
isSubmitting
=
true
;
this
.
isSubmitting
=
true
;
this
.
service
.
addRelatedIssues
(
this
.
state
.
pendingReferences
)
this
.
service
.
addRelatedIssues
(
this
.
state
.
pendingReferences
)
...
@@ -165,7 +167,10 @@ export default {
...
@@ -165,7 +167,10 @@ export default {
this
.
inputValue
=
`
${
touchedReference
}
`
;
this
.
inputValue
=
`
${
touchedReference
}
`
;
},
},
onBlur
(
newValue
)
{
onBlur
(
newValue
)
{
const
rawReferences
=
newValue
this
.
processAllReferences
(
newValue
);
},
processAllReferences
(
value
=
''
)
{
const
rawReferences
=
value
.
split
(
/
\s
+/
)
.
split
(
/
\s
+/
)
.
filter
(
reference
=>
reference
.
trim
().
length
>
0
);
.
filter
(
reference
=>
reference
.
trim
().
length
>
0
);
...
...
spec/features/issuables/related_issues_spec.rb
View file @
4870a75f
...
@@ -125,6 +125,20 @@ describe 'Related issues', feature: true, js: true do
...
@@ -125,6 +125,20 @@ describe 'Related issues', feature: true, js: true do
expect
(
items
[
0
].
text
).
to
eq
(
issue_project_b_a
.
title
)
expect
(
items
[
0
].
text
).
to
eq
(
issue_project_b_a
.
title
)
expect
(
find
(
'.js-related-issues-header-issue-count'
)).
to
have_content
(
'1'
)
expect
(
find
(
'.js-related-issues-header-issue-count'
)).
to
have_content
(
'1'
)
end
end
it
'pressing enter should submit the form'
do
find
(
'.js-issue-count-badge-add-button'
).
click
find
(
'.js-add-issuable-form-input'
).
set
"
#{
issue_project_b_a
.
to_reference
(
project
)
}
"
find
(
'.js-add-issuable-form-input'
).
native
.
send_key
(
:enter
)
wait_for_requests
items
=
all
(
'.js-related-issues-token-list-item .js-issue-token-title'
)
expect
(
items
.
count
).
to
eq
(
1
)
expect
(
items
[
0
].
text
).
to
eq
(
issue_project_b_a
.
title
)
expect
(
find
(
'.js-related-issues-header-issue-count'
)).
to
have_content
(
'1'
)
end
end
end
context
'with existing related issues'
do
context
'with existing related issues'
do
...
...
spec/javascripts/issuable/related_issues/components/add_issuable_form_spec.js
View file @
4870a75f
...
@@ -227,9 +227,11 @@ describe('AddIssuableForm', () => {
...
@@ -227,9 +227,11 @@ describe('AddIssuableForm', () => {
it
(
'
when submitting pending issues
'
,
()
=>
{
it
(
'
when submitting pending issues
'
,
()
=>
{
expect
(
addIssuableFormSubmitSpy
).
not
.
toHaveBeenCalled
();
expect
(
addIssuableFormSubmitSpy
).
not
.
toHaveBeenCalled
();
const
newInputValue
=
'
filling in things
'
;
vm
.
$refs
.
input
.
value
=
newInputValue
;
vm
.
onFormSubmit
();
vm
.
onFormSubmit
();
expect
(
addIssuableFormSubmitSpy
).
toHaveBeenCalled
(
);
expect
(
addIssuableFormSubmitSpy
).
toHaveBeenCalled
With
(
newInputValue
);
});
});
it
(
'
when canceling form to collapse
'
,
()
=>
{
it
(
'
when canceling form to collapse
'
,
()
=>
{
...
...
spec/javascripts/issuable/related_issues/components/related_issues_root_spec.js
View file @
4870a75f
...
@@ -134,6 +134,18 @@ describe('RelatedIssuesRoot', () => {
...
@@ -134,6 +134,18 @@ describe('RelatedIssuesRoot', () => {
vm
=
new
RelatedIssuesRoot
({
vm
=
new
RelatedIssuesRoot
({
propsData
:
defaultProps
,
propsData
:
defaultProps
,
}).
$mount
();
}).
$mount
();
spyOn
(
vm
,
'
processAllReferences
'
).
and
.
callThrough
();
spyOn
(
vm
.
service
,
'
addRelatedIssues
'
).
and
.
callThrough
();
});
it
(
'
processes references before submitting
'
,
()
=>
{
const
input
=
'
#123
'
;
vm
.
onPendingFormSubmit
(
input
);
expect
(
vm
.
processAllReferences
).
toHaveBeenCalledWith
(
input
);
expect
(
vm
.
service
.
addRelatedIssues
).
toHaveBeenCalledWith
([
input
]);
});
});
it
(
'
submit zero pending issue as related issue
'
,
(
done
)
=>
{
it
(
'
submit zero pending issue as related issue
'
,
(
done
)
=>
{
...
@@ -369,19 +381,37 @@ describe('RelatedIssuesRoot', () => {
...
@@ -369,19 +381,37 @@ describe('RelatedIssuesRoot', () => {
vm
=
new
RelatedIssuesRoot
({
vm
=
new
RelatedIssuesRoot
({
propsData
:
defaultProps
,
propsData
:
defaultProps
,
}).
$mount
();
}).
$mount
();
spyOn
(
vm
,
'
processAllReferences
'
);
});
});
it
(
'
add
valid reference
to pending when blurring
'
,
()
=>
{
it
(
'
add
any references
to pending when blurring
'
,
()
=>
{
const
input
=
'
#123
'
;
const
input
=
'
#123
'
;
vm
.
onBlur
(
input
);
vm
.
onBlur
(
input
);
expect
(
vm
.
processAllReferences
).
toHaveBeenCalledWith
(
input
);
});
});
describe
(
'
processAllReferences
'
,
()
=>
{
beforeEach
(()
=>
{
vm
=
new
RelatedIssuesRoot
({
propsData
:
defaultProps
,
}).
$mount
();
});
it
(
'
add valid reference to pending
'
,
()
=>
{
const
input
=
'
#123
'
;
vm
.
processAllReferences
(
input
);
expect
(
vm
.
state
.
pendingReferences
.
length
).
toEqual
(
1
);
expect
(
vm
.
state
.
pendingReferences
.
length
).
toEqual
(
1
);
expect
(
vm
.
state
.
pendingReferences
[
0
]).
toEqual
(
'
#123
'
);
expect
(
vm
.
state
.
pendingReferences
[
0
]).
toEqual
(
'
#123
'
);
});
});
it
(
'
add any valid references to pending
when blurring
'
,
()
=>
{
it
(
'
add any valid references to pending
'
,
()
=>
{
const
input
=
'
asdf #123
'
;
const
input
=
'
asdf #123
'
;
vm
.
onBlur
(
input
);
vm
.
processAllReferences
(
input
);
expect
(
vm
.
state
.
pendingReferences
.
length
).
toEqual
(
2
);
expect
(
vm
.
state
.
pendingReferences
.
length
).
toEqual
(
2
);
expect
(
vm
.
state
.
pendingReferences
[
0
]).
toEqual
(
'
asdf
'
);
expect
(
vm
.
state
.
pendingReferences
[
0
]).
toEqual
(
'
asdf
'
);
...
...
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