From e4472cee78c1904b801d25d51c14b557afc44816 Mon Sep 17 00:00:00 2001 From: Robert Speicher Date: Tue, 23 Jun 2015 23:23:25 -0400 Subject: Add "Requires Input" JS behavior --- .../javascripts/behaviors/requires_input.js.coffee | 39 ++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 app/assets/javascripts/behaviors/requires_input.js.coffee (limited to 'app/assets/javascripts/behaviors') diff --git a/app/assets/javascripts/behaviors/requires_input.js.coffee b/app/assets/javascripts/behaviors/requires_input.js.coffee new file mode 100644 index 00000000000..8318fe435b3 --- /dev/null +++ b/app/assets/javascripts/behaviors/requires_input.js.coffee @@ -0,0 +1,39 @@ +# 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 +# +#
+# +# +#
+# +$.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() -- cgit v1.2.1