I would like to get back a true or false based on visible form elements, but not just inputs but radio and checkboxes too. So far I have this code but something doesn't right. Once I filled in all the inputs it gives true.
function isAllFilled() {
return $('.en__mandatory .form-control:visible').filter(function() {
if($(this).attr('type') == 'checkbox' || $(this).attr('type') == 'radio') {
return $(this).is(':checked').length == 0
} else {
return $(this).val().length == 0
}
}).length == 0
}
$('.form-control').on('input', function(){
console.log(isAllFilled());
})
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<form novalidate>
<div class="en__field en__field--text en__mandatory">
<div class="en__field__element">
<input id="en__field_supporter_firstName" type="text" class="en__field__input en__field__input--text form-control" name="supporter.firstName" placeholder="First Name" autocomplete="given-name">
</div>
</div>
<div class="en__field en__field--lastName en__mandatory">
<div class="en__field__element">
<input id="en__field_supporter_lastName" type="text" class="en__field__input en__field__input--text form-control" name="supporter.lastName" placeholder="Last Name" autocomplete="family-name">
</div>
</div>
<div class="en__field en__field--radio en__mandatory">
<div class="en__field__element">
<div class="en__field__item custom-control custom-radio custom-control-inline">
<input id="en__field_supporter_questions_1608560" type="radio" class="en__field__input en__field__input--radio form-control custom-control-input" value="Y" name="supporter.questions.160856">
<label for="en__field_supporter_questions_1608560" class="en__field__label en__field__label--item custom-control-label">Yes, I'm in</label>
</div>
<div class="en__field__item custom-control custom-radio custom-control-inline">
<input id="en__field_supporter_questions_1608561" type="radio" class="en__field__input en__field__input--radio form-control custom-control-input" value="N" name="supporter.questions.160856">
<label for="en__field_supporter_questions_1608561" class="en__field__label en__field__label--item custom-control-label">No</label>
</div>
</div>
</div>
</form>