2024-01-19 18:25:59 -06:00
|
|
|
<%= form_with(model: worker, local: true, html: { class: 'needs-validation', novalidate: true }) do |form| %>
|
|
|
|
<% if worker.errors.any? %>
|
|
|
|
<div id="error_explanation" class="alert alert-danger" role="alert">
|
|
|
|
<h4><%= pluralize(worker.errors.count, "error") %> prohibited this worker from being saved:</h4>
|
|
|
|
<ul>
|
|
|
|
<% worker.errors.full_messages.each do |message| %>
|
|
|
|
<li><%= message %></li>
|
|
|
|
<% end %>
|
|
|
|
</ul>
|
2024-01-17 01:21:20 -06:00
|
|
|
</div>
|
|
|
|
<% end %>
|
2024-01-19 18:25:59 -06:00
|
|
|
|
|
|
|
<div class="mb-3">
|
2024-01-29 23:51:42 -06:00
|
|
|
<%= form.label :first_name, 'First Name', class: 'form-label' %>
|
2024-01-23 19:14:58 -06:00
|
|
|
<%= form.text_field :first_name, class: 'form-control' %>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
2024-01-29 23:51:42 -06:00
|
|
|
<%= form.label :last_name, 'Last Name', class: 'form-label' %>
|
2024-01-23 19:14:58 -06:00
|
|
|
<%= form.text_field :last_name, class: 'form-control' %>
|
2024-01-19 18:25:59 -06:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
2024-01-29 23:51:42 -06:00
|
|
|
<%= form.label :address_line_1, 'Address Line 1' %>
|
|
|
|
<%= form.text_field :address_line_1, class: 'form-control' %>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
|
|
|
<%= form.label :address_line_2, 'Address Line 2' %>
|
|
|
|
<%= form.text_field :address_line_2, class: 'form-control' %>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
|
|
|
<%= form.label :city %>
|
|
|
|
<%= form.text_field :city, class: 'form-control' %>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
|
|
|
<%= form.label :state %>
|
|
|
|
<%= form.text_field :state, class: 'form-control' %>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
|
|
|
<%= form.label :zip, 'ZIP' %>
|
|
|
|
<%= form.text_field :zip, class: 'form-control' %>
|
2024-01-19 18:25:59 -06:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
|
|
|
<%= form.label :phone, class: 'form-label' %>
|
|
|
|
<%= form.telephone_field :phone, id: 'phone-field', class: 'form-control', placeholder: '(XXX)-XX-XXXX' %>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
|
|
|
<%= form.label :email, class: 'form-label' %>
|
|
|
|
<%= form.email_field :email, id: 'email-field', class: 'form-control', required: true, placeholder: 'Make sure to include @ sign' %>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
|
|
|
<%= form.label :dob, 'DOB', class: 'form-label' %>
|
|
|
|
<%= form.date_field :dob, class: 'form-control' %>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
|
|
|
<%= form.label :ssn, 'Social Security Number', class: 'form-label' %>
|
|
|
|
<%= form.text_field :ssn, id: 'ssn-field', class: 'form-control', maxlength: 11, placeholder: 'XXX-XX-XXXX' %>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mb-3">
|
|
|
|
<%= form.label :gender, class: 'form-label' %>
|
|
|
|
<%= form.select :gender, ['Unknown', 'Female', 'Male', 'Non-Binary', 'Other'], {}, class: 'form-select' %>
|
|
|
|
</div>
|
|
|
|
|
2024-01-29 23:51:42 -06:00
|
|
|
<div class="actions">
|
|
|
|
<%= form.submit class: 'btn btn-dark' %>
|
2024-01-19 18:25:59 -06:00
|
|
|
</div>
|
|
|
|
<% end %>
|
|
|
|
|
2024-01-17 01:21:20 -06:00
|
|
|
|
|
|
|
|
|
|
|
<%# This is to correct phone number entry %>
|
|
|
|
<script>
|
|
|
|
document.addEventListener("DOMContentLoaded", function() {
|
|
|
|
const phoneField = document.getElementById('phone-field');
|
|
|
|
|
|
|
|
phoneField.addEventListener('input', function() {
|
|
|
|
let input = phoneField.value.replace(/\D/g, ''); // Remove non-numeric characters
|
|
|
|
const inputLength = input.length;
|
|
|
|
|
|
|
|
if (inputLength > 3 && inputLength <= 6) {
|
|
|
|
input = `(${input.slice(0, 3)}) ${input.slice(3)}`;
|
|
|
|
} else if (inputLength > 6) {
|
|
|
|
input = `(${input.slice(0, 3)}) ${input.slice(3, 6)}-${input.slice(6, 10)}`;
|
|
|
|
}
|
|
|
|
|
|
|
|
phoneField.value = input;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<%# This is for auto resizing the address field %>
|
|
|
|
<script>
|
|
|
|
document.addEventListener("DOMContentLoaded", function() {
|
|
|
|
const textareas = document.querySelectorAll('.auto-expand');
|
|
|
|
|
|
|
|
const resizeTextarea = function(el) {
|
|
|
|
el.style.height = 'auto';
|
|
|
|
el.style.height = (el.scrollHeight) + 'px';
|
|
|
|
}
|
|
|
|
|
|
|
|
textareas.forEach(textarea => {
|
|
|
|
textarea.addEventListener('input', function() {
|
|
|
|
resizeTextarea(textarea);
|
|
|
|
});
|
|
|
|
|
|
|
|
// Initial resize
|
|
|
|
resizeTextarea(textarea);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<%# This is to require 1 @ sign for email entry %>
|
|
|
|
<script>
|
|
|
|
document.addEventListener('turbolinks:load', function() {
|
|
|
|
const emailField = document.getElementById('email-field');
|
|
|
|
|
|
|
|
emailField.addEventListener('input', function() {
|
|
|
|
const emailValue = emailField.value;
|
|
|
|
const atSignCount = (emailValue.match(/@/g) || []).length;
|
|
|
|
|
|
|
|
if (atSignCount !== 1) {
|
|
|
|
emailField.setCustomValidity("Email must contain exactly one '@' sign.");
|
|
|
|
} else {
|
|
|
|
emailField.setCustomValidity('');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
2024-01-17 03:00:03 -06:00
|
|
|
<%# This is for Social Security formatting and # of digits %>
|
|
|
|
<script>
|
|
|
|
document.addEventListener('DOMContentLoaded', () => {
|
|
|
|
const ssnField = document.getElementById('ssn-field');
|
|
|
|
|
|
|
|
ssnField.addEventListener('input', () => {
|
|
|
|
let ssn = ssnField.value.split('-').join(''); // Remove dashes
|
|
|
|
ssn = ssn.replace(/\D/g, ''); // Keep numbers only
|
|
|
|
|
|
|
|
if (ssn.length > 3 && ssn.length <= 5) {
|
|
|
|
ssn = ssn.slice(0, 3) + '-' + ssn.slice(3);
|
|
|
|
} else if (ssn.length > 5) {
|
|
|
|
ssn = ssn.slice(0, 3) + '-' + ssn.slice(3, 5) + '-' + ssn.slice(5, 9);
|
|
|
|
}
|
|
|
|
ssnField.value = ssn; // Update the field value
|
|
|
|
});
|
|
|
|
});
|
|
|
|
</script>
|