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
907b7541
Commit
907b7541
authored
Apr 07, 2017
by
Luke "Jared" Bennett
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixed bugs and added tests
parent
bb4bc215
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
33 additions
and
15 deletions
+33
-15
app/assets/javascripts/droplab/drop_down.js
app/assets/javascripts/droplab/drop_down.js
+1
-1
app/assets/javascripts/notes.js
app/assets/javascripts/notes.js
+1
-1
app/views/projects/notes/_comment_button.html.haml
app/views/projects/notes/_comment_button.html.haml
+3
-2
spec/features/discussion_comments_spec.rb
spec/features/discussion_comments_spec.rb
+11
-9
spec/javascripts/droplab/drop_down_spec.js
spec/javascripts/droplab/drop_down_spec.js
+16
-1
spec/javascripts/droplab/plugins/input_setter_spec.js
spec/javascripts/droplab/plugins/input_setter_spec.js
+1
-1
No files found.
app/assets/javascripts/droplab/drop_down.js
View file @
907b7541
...
@@ -37,7 +37,7 @@ Object.assign(DropDown.prototype, {
...
@@ -37,7 +37,7 @@ Object.assign(DropDown.prototype, {
clickEvent
:
function
(
e
)
{
clickEvent
:
function
(
e
)
{
if
(
e
.
target
.
tagName
===
'
UL
'
)
return
;
if
(
e
.
target
.
tagName
===
'
UL
'
)
return
;
var
selected
=
utils
.
closest
(
e
.
target
,
'
LI
'
,
''
);
var
selected
=
utils
.
closest
(
e
.
target
,
'
LI
'
);
if
(
!
selected
)
return
;
if
(
!
selected
)
return
;
this
.
addSelectedClass
(
selected
);
this
.
addSelectedClass
(
selected
);
...
...
app/assets/javascripts/notes.js
View file @
907b7541
...
@@ -143,7 +143,7 @@ require('./task_list');
...
@@ -143,7 +143,7 @@ require('./task_list');
form
.
querySelector
(
'
.js-comment-type-dropdown .dropdown-menu
'
),
form
.
querySelector
(
'
.js-comment-type-dropdown .dropdown-menu
'
),
form
.
querySelector
(
'
#note_type
'
),
form
.
querySelector
(
'
#note_type
'
),
form
.
querySelector
(
'
.js-comment-type-dropdown .js-comment-submit-button
'
),
form
.
querySelector
(
'
.js-comment-type-dropdown .js-comment-submit-button
'
),
form
.
querySelector
(
'
.js-note-target-close
'
),
form
.
querySelector
(
'
.js-note-target-close
:not(.hidden)
'
)
||
form
.
querySelector
(
'
.js-note-target-reopen
'
),
);
);
this
.
commentTypeToggle
.
initDroplab
();
this
.
commentTypeToggle
.
initDroplab
();
...
...
app/views/projects/notes/_comment_button.html.haml
View file @
907b7541
-
noteable_name
=
@note
.
noteable
.
human_class_name
-
noteable_name
=
@note
.
noteable
.
human_class_name
-
noteable_state_action
=
noteable_name
=~
/(merge request|issue)/
&&
@note
.
noteable
[
'state'
]
==
'closed'
?
'reopen'
:
'close'
.pull-left.btn-group.append-right-10.comment-type-dropdown.js-comment-type-dropdown
.pull-left.btn-group.append-right-10.comment-type-dropdown.js-comment-type-dropdown
%input
.btn.btn-nr.btn-create.comment-btn.js-comment-button.js-comment-submit-button
{
type:
'submit'
,
value:
'Comment'
}
%input
.btn.btn-nr.btn-create.comment-btn.js-comment-button.js-comment-submit-button
{
type:
'submit'
,
value:
'Comment'
}
...
@@ -8,7 +9,7 @@
...
@@ -8,7 +9,7 @@
=
icon
(
'caret-down'
)
=
icon
(
'caret-down'
)
%ul
#resolvable-comment-menu
.dropdown-menu
{
data:
{
dropdown:
true
}
}
%ul
#resolvable-comment-menu
.dropdown-menu
{
data:
{
dropdown:
true
}
}
%li
#comment
.droplab-item-selected
{
data:
{
value:
''
,
'button-text'
=>
'Comment'
,
'secondary-button-text'
=>
"Comment &
close
#{noteable_name}"
}
}
%li
#comment
.droplab-item-selected
{
data:
{
value:
''
,
'button-text'
=>
'Comment'
,
'secondary-button-text'
=>
"Comment &
#{noteable_state_action}
#{noteable_name}"
}
}
=
icon
(
'check'
)
=
icon
(
'check'
)
.description
.description
%strong
Comment
%strong
Comment
...
@@ -17,7 +18,7 @@
...
@@ -17,7 +18,7 @@
%li
.divider
%li
.divider
%li
#discussion
{
data:
{
value:
'DiscussionNote'
,
'button-text'
=>
'Start discussion'
,
'secondary-button-text'
=>
"Start discussion &
close
#{noteable_name}"
}
}
%li
#discussion
{
data:
{
value:
'DiscussionNote'
,
'button-text'
=>
'Start discussion'
,
'secondary-button-text'
=>
"Start discussion &
#{noteable_state_action}
#{noteable_name}"
}
}
=
icon
(
'check'
)
=
icon
(
'check'
)
.description
.description
%strong
Start discussion
%strong
Start discussion
...
...
spec/features/discussion_comments_spec.rb
View file @
907b7541
...
@@ -93,9 +93,9 @@ shared_examples 'discussion comments' do |resource_name|
...
@@ -93,9 +93,9 @@ shared_examples 'discussion comments' do |resource_name|
end
end
it
'clicking the ul padding should not change the text'
do
it
'clicking the ul padding should not change the text'
do
find
(
menu_selector
).
click
find
(
menu_selector
).
trigger
'click'
expect
(
find
(
submit
_selector
)).
to
have_content
'Comment'
expect
(
find
(
dropdown
_selector
)).
to
have_content
'Comment'
end
end
describe
'when selecting "Start discussion"'
do
describe
'when selecting "Start discussion"'
do
...
@@ -109,7 +109,7 @@ shared_examples 'discussion comments' do |resource_name|
...
@@ -109,7 +109,7 @@ shared_examples 'discussion comments' do |resource_name|
end
end
it
'updates the submit button text'
do
it
'updates the submit button text'
do
expect
(
find
(
dropdown_selector
)).
to
have_content
"Start discussion"
expect
(
find
(
dropdown_selector
)).
to
have_content
'Start discussion'
end
end
if
resource_name
=~
/(issue|merge request)/
if
resource_name
=~
/(issue|merge request)/
...
@@ -181,7 +181,7 @@ shared_examples 'discussion comments' do |resource_name|
...
@@ -181,7 +181,7 @@ shared_examples 'discussion comments' do |resource_name|
end
end
it
'updates the submit button text'
do
it
'updates the submit button text'
do
expect
(
find
(
dropdown_selector
)).
to
have_content
"Comment"
expect
(
find
(
dropdown_selector
)).
to
have_content
'Comment'
end
end
if
resource_name
=~
/(issue|merge request)/
if
resource_name
=~
/(issue|merge request)/
...
@@ -222,20 +222,22 @@ shared_examples 'discussion comments' do |resource_name|
...
@@ -222,20 +222,22 @@ shared_examples 'discussion comments' do |resource_name|
if
resource_name
=~
/(issue|merge request)/
if
resource_name
=~
/(issue|merge request)/
describe
"on a closed
#{
resource_name
}
"
do
describe
"on a closed
#{
resource_name
}
"
do
before
do
before
do
find
(
"
#{
form_selector
}
.close-mr-link"
).
click
find
(
"
#{
form_selector
}
.js-note-target-close"
).
click
find
(
"
#{
form_selector
}
.note-textarea"
).
send_keys
(
'a'
)
end
end
it
'should show a "Comment & reopen #{resource_name}" button'
do
it
"should show a 'Comment & reopen
#{
resource_name
}
' button"
do
expect
(
find
(
close_selector
)).
to
have_content
"Comment & reopen
#{
resource_name
}
"
expect
(
find
(
"
#{
form_selector
}
.js-note-target-reopen"
)).
to
have_content
"Comment & reopen
#{
resource_name
}
"
end
end
it
'should show a "Start discussion & reopen #{resource_name}" button when "Start discussion" is selected'
do
it
"should show a 'Start discussion & reopen
#{
resource_name
}
' button when 'Start discussion' is selected"
do
find
(
toggle_selector
).
click
find
(
toggle_selector
).
click
find
(
"
#{
menu_selector
}
li"
,
match: :first
)
find
(
"
#{
menu_selector
}
li"
,
match: :first
)
all
(
"
#{
menu_selector
}
li"
).
last
.
click
all
(
"
#{
menu_selector
}
li"
).
last
.
click
expect
(
find
(
close_selector
)).
to
have_content
"Start discussion & reopen
#{
resource_name
}
"
expect
(
find
(
"
#{
form_selector
}
.js-note-target-reopen"
)).
to
have_content
"Start discussion & reopen
#{
resource_name
}
"
end
end
end
end
end
end
...
...
spec/javascripts/droplab/drop_down_spec.js
View file @
907b7541
...
@@ -130,7 +130,7 @@ describe('DropDown', function () {
...
@@ -130,7 +130,7 @@ describe('DropDown', function () {
beforeEach
(
function
()
{
beforeEach
(
function
()
{
this
.
list
=
{
dispatchEvent
:
()
=>
{}
};
this
.
list
=
{
dispatchEvent
:
()
=>
{}
};
this
.
dropdown
=
{
hide
:
()
=>
{},
list
:
this
.
list
,
addSelectedClass
:
()
=>
{}
};
this
.
dropdown
=
{
hide
:
()
=>
{},
list
:
this
.
list
,
addSelectedClass
:
()
=>
{}
};
this
.
event
=
{
preventDefault
:
()
=>
{},
target
:
'
target
'
};
this
.
event
=
{
preventDefault
:
()
=>
{},
target
:
{}
};
this
.
customEvent
=
{};
this
.
customEvent
=
{};
this
.
closestElement
=
{};
this
.
closestElement
=
{};
...
@@ -168,6 +168,21 @@ describe('DropDown', function () {
...
@@ -168,6 +168,21 @@ describe('DropDown', function () {
expect
(
this
.
list
.
dispatchEvent
).
toHaveBeenCalledWith
(
this
.
customEvent
);
expect
(
this
.
list
.
dispatchEvent
).
toHaveBeenCalledWith
(
this
.
customEvent
);
});
});
describe
(
'
if the target is a UL element
'
,
function
()
{
beforeEach
(
function
()
{
this
.
event
=
{
preventDefault
:
()
=>
{},
target
:
{
tagName
:
'
UL
'
}
};
spyOn
(
this
.
event
,
'
preventDefault
'
);
utils
.
closest
.
calls
.
reset
();
DropDown
.
prototype
.
clickEvent
.
call
(
this
.
dropdown
,
this
.
event
);
});
it
(
'
should return immediately
'
,
function
()
{
expect
(
utils
.
closest
).
not
.
toHaveBeenCalled
();
});
});
describe
(
'
if no selected element exists
'
,
function
()
{
describe
(
'
if no selected element exists
'
,
function
()
{
beforeEach
(
function
()
{
beforeEach
(
function
()
{
this
.
event
.
preventDefault
.
calls
.
reset
();
this
.
event
.
preventDefault
.
calls
.
reset
();
...
...
spec/javascripts/droplab/plugins/input_setter_spec.js
View file @
907b7541
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
import
InputSetter
from
'
~/droplab/plugins/input_setter
'
;
import
InputSetter
from
'
~/droplab/plugins/input_setter
'
;
f
describe
(
'
InputSetter
'
,
function
()
{
describe
(
'
InputSetter
'
,
function
()
{
describe
(
'
init
'
,
function
()
{
describe
(
'
init
'
,
function
()
{
beforeEach
(
function
()
{
beforeEach
(
function
()
{
this
.
config
=
{
InputSetter
:
{}
};
this
.
config
=
{
InputSetter
:
{}
};
...
...
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