I have a hidden Single Line field that is being auto-populated with a Lookup Rule. If this field is not populated, I want the Submit button hidden. Since it is hidden, I can't use "required" to force this or else it displays an error upon submit instead of simply hiding Submit. I have found code that should work for this, one does not work at all and one hides submit even when the field is populated so I must be coding incorrectly. Here is the hidden field with the Q # from the JavaScript screen.
Question
Question
Hide submit on form if hidden field is blank - Classic Designer
Answer
Here is my work around for this issue as none of the JS codes worked.
I added a new field that will populate a piece of data from the table that does the match, it is required and is read only. It will always populate if there is a match and can't be filled by the user if there isn't. Because it is required, it will not allow submit without it being filled.
Replies
I'm curious to know what is keeping you from using the new form designer because as mentioned field rules makes this much easier. But the code you need is here:
const $submit = $('.Submit'); const $hiddenVerification = $('#q64 input'); $hiddenVerification.on('change', function () { const val = $hiddenVerification.val(); if (val === "") { $submit.hide(); } else { $submit.show(); } });
Try using this
$(document).ready(function () { // Initially hide the submit button $('.Submit').hide(); // Function to check the value of the field and toggle the submit button function checkFieldAndToggleSubmit() { var fieldValue = $('#Field6').val(); if (fieldValue && fieldValue.replace(/\s/g, '') !== '') { $('.Submit').show(); } else { $('.Submit').hide(); } } // Attach the function to the change event of the field $('#Field6').on('change', checkFieldAndToggleSubmit); // Initial check when the form loads checkFieldAndToggleSubmit(); });
Change out #Field6 with your fieldID. I couldn't get it to work on the q6 but this did.
FYI - if referencing #q6 that it the entire field (labels, helptext, input element, etc.), not just the input element, which is why it acts differently with #Field6 which targets the input element specifically. Either of these two should work about the same:
$('#Field6').val()
$('#q6 input').val()
This does hide the submit button, but once the field populates, it does not show it.
What is populating this field specifically, this is a better version of the code I provided and the only reason it wouldn't work is whatever is setting it is not firing a "change" event. Is it being populated by a lookup or formula? Or is it being populated via JS
@████████ By lookup. The user enters their account number then their personal id #. If there is a match in the system of record, a hidden field is populated to indicate said match. I want submit hidden until that hidden fields is populated. I have "unhid" the field to be sure it is populating, and it is, yet the submit button is still missing using Angela's code and it is there from the start using the one you provided.
I'm on Cloud so I apologize if this doesn't work for you, but are you able to hide the Submit button using just field rules as opposed to Javascript in LF 11?
Here is how I would set it up: