5
0
Fork 0
mirror of https://0xacab.org/sutty/sutty synced 2024-11-23 00:56:22 +00:00
panel/app/javascript/controllers/form_validation_controller.js

53 lines
1.3 KiB
JavaScript
Raw Normal View History

2024-06-19 16:12:54 +00:00
import { Controller } from "stimulus";
export default class extends Controller {
static targets = ["invalid", "submitting"];
2024-06-19 16:12:54 +00:00
connect() {
this.element.setAttribute("novalidate", true);
for (const input of this.element.elements) {
if (input.type === "button" || input.type === "submit") continue;
if (input.dataset.action) {
input.dataset.action = `${input.dataset.action} htmx:validation:validate->form-validation#submit`;
} else {
input.dataset.action = "htmx:validation:validate->form-validation#submit";
}
}
}
submit(event = undefined) {
event?.preventDefault();
event?.stopPropagation();
if (this.element.reportValidity()) {
this.element.classList.remove("was-validated");
this.element.submit();
this.show(this.submittingTargets);
this.hide(this.invalidTargets);
2024-06-19 16:12:54 +00:00
} else {
this.element.classList.add("was-validated");
this.hide(this.submittingTargets);
this.show(this.invalidTargets);
}
}
show(elements) {
for (const element of elements) {
element.classList.remove("d-none");
setTimeout(() => element.classList.add("show"), 1);
}
}
hide(elements) {
for (const element of elements) {
element.classList.remove("show");
setTimeout(() => element.classList.add("d-none"), 2000);
2024-06-19 16:12:54 +00:00
}
}
}