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
197a0a19
Commit
197a0a19
authored
Jan 22, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
3db92d7c
ed1da730
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
82 additions
and
24 deletions
+82
-24
app/assets/javascripts/dirty_submit/dirty_submit_form.js
app/assets/javascripts/dirty_submit/dirty_submit_form.js
+4
-3
changelogs/unreleased/53856-changing-group-visibility-does-not-re-enable-save-button.yml
...nging-group-visibility-does-not-re-enable-save-button.yml
+6
-0
spec/features/groups_spec.rb
spec/features/groups_spec.rb
+3
-1
spec/javascripts/dirty_submit/dirty_submit_collection_spec.js
.../javascripts/dirty_submit/dirty_submit_collection_spec.js
+3
-3
spec/javascripts/dirty_submit/dirty_submit_form_spec.js
spec/javascripts/dirty_submit/dirty_submit_form_spec.js
+24
-4
spec/javascripts/dirty_submit/helper.js
spec/javascripts/dirty_submit/helper.js
+23
-6
spec/support/shared_examples/dirty_submit_form_shared_examples.rb
...port/shared_examples/dirty_submit_form_shared_examples.rb
+19
-7
No files found.
app/assets/javascripts/dirty_submit/dirty_submit_form.js
View file @
197a0a19
...
@@ -25,15 +25,16 @@ class DirtySubmitForm {
...
@@ -25,15 +25,16 @@ class DirtySubmitForm {
DirtySubmitForm
.
THROTTLE_DURATION
,
DirtySubmitForm
.
THROTTLE_DURATION
,
);
);
this
.
form
.
addEventListener
(
'
input
'
,
throttledUpdateDirtyInput
);
this
.
form
.
addEventListener
(
'
input
'
,
throttledUpdateDirtyInput
);
this
.
form
.
addEventListener
(
'
change
'
,
throttledUpdateDirtyInput
);
this
.
form
.
addEventListener
(
'
submit
'
,
event
=>
this
.
formSubmit
(
event
));
this
.
form
.
addEventListener
(
'
submit
'
,
event
=>
this
.
formSubmit
(
event
));
}
}
updateDirtyInput
(
event
)
{
updateDirtyInput
(
event
)
{
const
input
=
event
.
targe
t
;
const
{
target
}
=
even
t
;
if
(
!
inpu
t
.
dataset
.
isDirtySubmitInput
)
return
;
if
(
!
targe
t
.
dataset
.
isDirtySubmitInput
)
return
;
this
.
updateDirtyInputs
(
inpu
t
);
this
.
updateDirtyInputs
(
targe
t
);
this
.
toggleSubmission
();
this
.
toggleSubmission
();
}
}
...
...
changelogs/unreleased/53856-changing-group-visibility-does-not-re-enable-save-button.yml
0 → 100644
View file @
197a0a19
---
title
:
Fix suboptimal handling of checkbox and radio input events causing
group general settings submit button to stay disabled after changing its visibility
merge_request
:
23022
author
:
type
:
fixed
spec/features/groups_spec.rb
View file @
197a0a19
...
@@ -154,7 +154,7 @@ describe 'Group' do
...
@@ -154,7 +154,7 @@ describe 'Group' do
end
end
describe
'group edit'
,
:js
do
describe
'group edit'
,
:js
do
let
(
:group
)
{
create
(
:group
)
}
let
(
:group
)
{
create
(
:group
,
:public
)
}
let
(
:path
)
{
edit_group_path
(
group
)
}
let
(
:path
)
{
edit_group_path
(
group
)
}
let
(
:new_name
)
{
'new-name'
}
let
(
:new_name
)
{
'new-name'
}
...
@@ -163,6 +163,8 @@ describe 'Group' do
...
@@ -163,6 +163,8 @@ describe 'Group' do
end
end
it_behaves_like
'dirty submit form'
,
[{
form:
'.js-general-settings-form'
,
input:
'input[name="group[name]"]'
},
it_behaves_like
'dirty submit form'
,
[{
form:
'.js-general-settings-form'
,
input:
'input[name="group[name]"]'
},
{
form:
'.js-general-settings-form'
,
input:
'#group_visibility_level_0'
},
{
form:
'.js-general-permissions-form'
,
input:
'#group_request_access_enabled'
},
{
form:
'.js-general-permissions-form'
,
input:
'input[name="group[two_factor_grace_period]"]'
}]
{
form:
'.js-general-permissions-form'
,
input:
'input[name="group[two_factor_grace_period]"]'
}]
it
'saves new settings'
do
it
'saves new settings'
do
...
...
spec/javascripts/dirty_submit/dirty_submit_collection_spec.js
View file @
197a0a19
import
DirtySubmitCollection
from
'
~/dirty_submit/dirty_submit_collection
'
;
import
DirtySubmitCollection
from
'
~/dirty_submit/dirty_submit_collection
'
;
import
{
setInput
,
createForm
}
from
'
./helper
'
;
import
{
setInput
Value
,
createForm
}
from
'
./helper
'
;
describe
(
'
DirtySubmitCollection
'
,
()
=>
{
describe
(
'
DirtySubmitCollection
'
,
()
=>
{
it
(
'
disables submits until there are changes
'
,
done
=>
{
it
(
'
disables submits until there are changes
'
,
done
=>
{
...
@@ -14,11 +14,11 @@ describe('DirtySubmitCollection', () => {
...
@@ -14,11 +14,11 @@ describe('DirtySubmitCollection', () => {
expect
(
submit
.
disabled
).
toBe
(
true
);
expect
(
submit
.
disabled
).
toBe
(
true
);
return
setInput
(
input
,
`
${
originalValue
}
changes`
)
return
setInput
Value
(
input
,
`
${
originalValue
}
changes`
)
.
then
(()
=>
{
.
then
(()
=>
{
expect
(
submit
.
disabled
).
toBe
(
false
);
expect
(
submit
.
disabled
).
toBe
(
false
);
})
})
.
then
(()
=>
setInput
(
input
,
originalValue
))
.
then
(()
=>
setInput
Value
(
input
,
originalValue
))
.
then
(()
=>
{
.
then
(()
=>
{
expect
(
submit
.
disabled
).
toBe
(
true
);
expect
(
submit
.
disabled
).
toBe
(
true
);
})
})
...
...
spec/javascripts/dirty_submit/dirty_submit_form_spec.js
View file @
197a0a19
import
DirtySubmitForm
from
'
~/dirty_submit/dirty_submit_form
'
;
import
DirtySubmitForm
from
'
~/dirty_submit/dirty_submit_form
'
;
import
{
setInput
,
createForm
}
from
'
./helper
'
;
import
{
getInputValue
,
setInputValue
,
createForm
}
from
'
./helper
'
;
function
expectToToggleDisableOnDirtyUpdate
(
submit
,
input
)
{
function
expectToToggleDisableOnDirtyUpdate
(
submit
,
input
)
{
const
originalValue
=
input
.
value
;
const
originalValue
=
getInputValue
(
input
)
;
expect
(
submit
.
disabled
).
toBe
(
true
);
expect
(
submit
.
disabled
).
toBe
(
true
);
return
setInput
(
input
,
`
${
originalValue
}
changes`
)
return
setInput
Value
(
input
,
`
${
originalValue
}
changes`
)
.
then
(()
=>
expect
(
submit
.
disabled
).
toBe
(
false
))
.
then
(()
=>
expect
(
submit
.
disabled
).
toBe
(
false
))
.
then
(()
=>
setInput
(
input
,
originalValue
))
.
then
(()
=>
setInput
Value
(
input
,
originalValue
))
.
then
(()
=>
expect
(
submit
.
disabled
).
toBe
(
true
));
.
then
(()
=>
expect
(
submit
.
disabled
).
toBe
(
true
));
}
}
...
@@ -33,4 +33,24 @@ describe('DirtySubmitForm', () => {
...
@@ -33,4 +33,24 @@ describe('DirtySubmitForm', () => {
.
then
(
done
)
.
then
(
done
)
.
catch
(
done
.
fail
);
.
catch
(
done
.
fail
);
});
});
it
(
'
disables submit until there are changes for radio inputs
'
,
done
=>
{
const
{
form
,
input
,
submit
}
=
createForm
(
'
radio
'
);
new
DirtySubmitForm
(
form
);
// eslint-disable-line no-new
return
expectToToggleDisableOnDirtyUpdate
(
submit
,
input
)
.
then
(
done
)
.
catch
(
done
.
fail
);
});
it
(
'
disables submit until there are changes for checkbox inputs
'
,
done
=>
{
const
{
form
,
input
,
submit
}
=
createForm
(
'
checkbox
'
);
new
DirtySubmitForm
(
form
);
// eslint-disable-line no-new
return
expectToToggleDisableOnDirtyUpdate
(
submit
,
input
)
.
then
(
done
)
.
catch
(
done
.
fail
);
});
});
});
spec/javascripts/dirty_submit/helper.js
View file @
197a0a19
import
DirtySubmitForm
from
'
~/dirty_submit/dirty_submit_form
'
;
import
DirtySubmitForm
from
'
~/dirty_submit/dirty_submit_form
'
;
import
setTimeoutPromiseHelper
from
'
../helpers/set_timeout_promise_helper
'
;
import
setTimeoutPromiseHelper
from
'
../helpers/set_timeout_promise_helper
'
;
export
function
setInput
(
element
,
value
)
{
function
isCheckableType
(
type
)
{
return
/^
(
radio|checkbox
)
$/
.
test
(
type
);
}
export
function
setInputValue
(
element
,
value
)
{
const
{
type
}
=
element
;
let
eventType
;
if
(
isCheckableType
(
type
))
{
element
.
checked
=
!
element
.
checked
;
eventType
=
'
change
'
;
}
else
{
element
.
value
=
value
;
element
.
value
=
value
;
eventType
=
'
input
'
;
}
element
.
dispatchEvent
(
element
.
dispatchEvent
(
new
Event
(
'
input
'
,
{
new
Event
(
eventType
,
{
bubbles
:
true
,
bubbles
:
true
,
cancelable
:
true
,
}),
}),
);
);
return
setTimeoutPromiseHelper
(
DirtySubmitForm
.
THROTTLE_DURATION
);
return
setTimeoutPromiseHelper
(
DirtySubmitForm
.
THROTTLE_DURATION
);
}
}
export
function
createForm
()
{
export
function
getInputValue
(
input
)
{
return
isCheckableType
(
input
.
type
)
?
input
.
checked
:
input
.
value
;
}
export
function
createForm
(
type
=
'
text
'
)
{
const
form
=
document
.
createElement
(
'
form
'
);
const
form
=
document
.
createElement
(
'
form
'
);
form
.
innerHTML
=
`
form
.
innerHTML
=
`
<input type="
text" value="original" class="js-input" name="input"
/>
<input type="
${
type
}
" name="
${
type
}
" class="js-input"
/>
<button type="submit" class="js-dirty-submit"></button>
<button type="submit" class="js-dirty-submit"></button>
`
;
`
;
const
input
=
form
.
querySelector
(
'
.js-input
'
);
const
input
=
form
.
querySelector
(
'
.js-input
'
);
const
submit
=
form
.
querySelector
(
'
.js-dirty-submit
'
);
const
submit
=
form
.
querySelector
(
'
.js-dirty-submit
'
);
...
...
spec/support/shared_examples/dirty_submit_form_shared_examples.rb
View file @
197a0a19
shared_examples
'dirty submit form'
do
|
selector_args
|
shared_examples
'dirty submit form'
do
|
selector_args
|
selectors
=
selector_args
.
is_a?
(
Array
)
?
selector_args
:
[
selector_args
]
selectors
=
selector_args
.
is_a?
(
Array
)
?
selector_args
:
[
selector_args
]
def
expect_disabled_state
(
form
,
submit
,
is_disabled
=
true
)
disabled_selector
=
is_disabled
==
true
?
'[disabled]'
:
':not([disabled])'
form
.
find
(
".js-dirty-submit
#{
disabled_selector
}
"
,
match: :first
)
expect
(
submit
.
disabled?
).
to
be
is_disabled
end
selectors
.
each
do
|
selector
|
selectors
.
each
do
|
selector
|
it
"disables
#{
selector
[
:form
]
}
submit until there are changes"
,
:js
do
it
"disables
#{
selector
[
:form
]
}
submit until there are changes
on
#{
selector
[
:input
]
}
"
,
:js
do
form
=
find
(
selector
[
:form
])
form
=
find
(
selector
[
:form
])
submit
=
form
.
first
(
'.js-dirty-submit'
)
submit
=
form
.
first
(
'.js-dirty-submit'
)
input
=
form
.
first
(
selector
[
:input
])
input
=
form
.
first
(
selector
[
:input
])
is_radio
=
input
[
:type
]
==
'radio'
is_checkbox
=
input
[
:type
]
==
'checkbox'
is_checkable
=
is_radio
||
is_checkbox
original_value
=
input
.
value
original_value
=
input
.
value
original_checkable
=
form
.
find
(
"input[name='
#{
input
[
:name
]
}
'][checked]"
)
if
is_radio
original_checkable
=
input
if
is_checkbox
expect
(
submit
.
disabled?
).
to
be
true
expect
(
submit
.
disabled?
).
to
be
true
expect
(
input
.
checked?
).
to
be
false
input
.
set
(
"
#{
original_value
}
changes"
)
i
s_checkable
?
input
.
click
:
i
nput
.
set
(
"
#{
original_value
}
changes"
)
form
.
find
(
'.js-dirty-submit:not([disabled])'
,
match: :first
)
expect_disabled_state
(
form
,
submit
,
false
)
expect
(
submit
.
disabled?
).
to
be
false
input
.
set
(
original_value
)
i
s_checkable
?
original_checkable
.
click
:
i
nput
.
set
(
original_value
)
form
.
find
(
'.js-dirty-submit[disabled]'
,
match: :first
)
expect_disabled_state
(
form
,
submit
)
expect
(
submit
.
disabled?
).
to
be
true
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