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
0
Merge Requests
0
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
Léo-Paul Géneau
gitlab-ce
Commits
e4472cee
Commit
e4472cee
authored
Jun 23, 2015
by
Robert Speicher
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add "Requires Input" JS behavior
parent
9f166a86
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
106 additions
and
0 deletions
+106
-0
app/assets/javascripts/behaviors/requires_input.js.coffee
app/assets/javascripts/behaviors/requires_input.js.coffee
+39
-0
spec/javascripts/behaviors/requires_input_spec.js.coffee
spec/javascripts/behaviors/requires_input_spec.js.coffee
+49
-0
spec/javascripts/fixtures/behaviors/requires_input.html.haml
spec/javascripts/fixtures/behaviors/requires_input.html.haml
+18
-0
No files found.
app/assets/javascripts/behaviors/requires_input.js.coffee
0 → 100644
View file @
e4472cee
# Requires Input behavior
#
# When called on a form with input fields with the `required` attribute, the
# form's submit button will be disabled until all required fields have values.
#
#= require extensions/jquery
#
# ### Example Markup
#
# <form class="js-requires-input">
# <input type="text" required="required">
# <input type="submit" value="Submit">
# </form>
#
$
.
fn
.
requiresInput
=
->
$form
=
$
(
this
)
$button
=
$
(
'button[type=submit], input[type=submit]'
,
$form
)
required
=
'[required=required]'
fieldSelector
=
"input
#{
required
}
, select
#{
required
}
, textarea
#{
required
}
"
requireInput
=
->
# Collect the input values of *all* required fields
values
=
_
.
map
$
(
fieldSelector
,
$form
),
(
field
)
->
field
.
value
# Disable the button if any required fields are empty
if
values
.
length
&&
_
.
any
(
values
,
_
.
isEmpty
)
$button
.
disable
()
else
$button
.
enable
()
# Set initial button state
requireInput
()
$form
.
on
'change input'
,
fieldSelector
,
requireInput
# Triggered on standard document `ready` and on Turbolinks `page:load` events
$
(
document
).
on
'ready page:load'
,
->
$
(
'form.js-requires-input'
).
requiresInput
()
spec/javascripts/behaviors/requires_input_spec.js.coffee
0 → 100644
View file @
e4472cee
#= require behaviors/requires_input
describe
'requiresInput'
,
->
fixture
.
preload
(
'behaviors/requires_input.html'
)
beforeEach
->
fixture
.
load
(
'behaviors/requires_input.html'
)
it
'disables submit when any field is required'
,
->
$
(
'.js-requires-input'
).
requiresInput
()
expect
(
$
(
'.submit'
)).
toBeDisabled
()
it
'enables submit when no field is required'
,
->
$
(
'*[required=required]'
).
removeAttr
(
'required'
)
$
(
'.js-requires-input'
).
requiresInput
()
expect
(
$
(
'.submit'
)).
not
.
toBeDisabled
()
it
'enables submit when all required fields are pre-filled'
,
->
$
(
'*[required=required]'
).
remove
()
$
(
'.js-requires-input'
).
requiresInput
()
expect
(
$
(
'.submit'
)).
not
.
toBeDisabled
()
it
'enables submit when all required fields receive input'
,
->
$
(
'.js-requires-input'
).
requiresInput
()
$
(
'#required1'
).
val
(
'input1'
).
change
()
expect
(
$
(
'.submit'
)).
toBeDisabled
()
$
(
'#optional1'
).
val
(
'input1'
).
change
()
expect
(
$
(
'.submit'
)).
toBeDisabled
()
$
(
'#required2'
).
val
(
'input2'
).
change
()
$
(
'#required3'
).
val
(
'input3'
).
change
()
$
(
'#required4'
).
val
(
'input4'
).
change
()
$
(
'#required5'
).
val
(
'1'
).
change
()
expect
(
$
(
'.submit'
)).
not
.
toBeDisabled
()
it
'is called on page:load event'
,
->
spy
=
spyOn
(
$
.
fn
,
'requiresInput'
)
$
(
document
).
trigger
(
'page:load'
)
expect
(
spy
).
toHaveBeenCalled
()
spec/javascripts/fixtures/behaviors/requires_input.html.haml
0 → 100644
View file @
e4472cee
%form
.js-requires-input
%input
{
type:
'text'
,
id:
'required1'
,
required:
'required'
}
%input
{
type:
'text'
,
id:
'required2'
,
required:
'required'
}
%input
{
type:
'text'
,
id:
'required3'
,
required:
'required'
,
value:
'Pre-filled'
}
%input
{
type:
'text'
,
id:
'optional1'
}
%textarea
{
id:
'required4'
,
required:
'required'
}
%textarea
{
id:
'optional2'
}
%select
{
id:
'required5'
,
required:
'required'
}
%option
Zero
%option
{
value:
'1'
}
One
%select
{
id:
'optional3'
,
required:
'required'
}
%option
Zero
%option
{
value:
'1'
}
One
%button
.submit
{
type:
'submit'
,
value:
'Submit'
}
%input
.submit
{
type:
'submit'
,
value:
'Submit'
}
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