UNPKG

@ribajs/bs4

Version:

Bootstrap 4 module for Riba.js

240 lines 18.7 kB
import { Component, HttpService, } from "@ribajs/core"; import { scrollTo, getViewportDimensions, getUID, hasChildNodesTrim, stripHtml, } from "@ribajs/utils"; export class Bs4FormComponent extends Component { static tagName = "bs4-form"; _debug = false; autobind = true; static get observedAttributes() { return [ "id", "disable-submit-until-change", "use-ajax", "ajax-request-type", "auto-set-form-data", "strip-html", "scroll-invalid-element", "animate-invalid-element", ]; } formEl = null; getDefaultScope() { const scope = { id: getUID("form"), form: { fields: {}, valid: false, error: undefined, }, disableSubmitUntilChange: false, submitDisabled: false, onSubmit: this.onSubmit, useAjax: true, ajaxRequestType: "form", autoSetFormData: true, stripHtml: true, scrollToInvalidElement: true, animateInvalidElement: true, }; return scope; } scope = this.getDefaultScope(); constructor() { super(); this.enableSubmit = this.enableSubmit.bind(this); } connectedCallback() { super.connectedCallback(); this.init(Bs4FormComponent.observedAttributes); this.addEventListeners(); } addEventListeners() { if (this.scope.disableSubmitUntilChange) { this.addEventListener("input", this.enableSubmit); } } removeEventListeners() { this.removeEventListener("input", this.enableSubmit); } enableSubmit() { this.scope.submitDisabled = false; } requiredAttributes() { return []; } async beforeBind() { await super.beforeBind(); this.id = this.scope.id; } async afterBind() { await super.afterBind(); } stripHtml() { for (const key in this.scope.form.fields) { if (this.scope.form.fields[key] && typeof this.scope.form.fields[key] === "string") { this.scope.form.fields[key] = stripHtml(this.scope.form.fields[key]); } } } onSubmit(event, el) { this.debug("onSubmit", event, el); if (!this.formEl) { console.warn("No form found"); return false; } if (this.scope.autoSetFormData) { this.getFormValues(); } if (this.scope.stripHtml) { this.stripHtml(); } this.validate(this.formEl, this.scope.form); if (!this.scope.form.valid) { this.onInvalidForm(event); return; } const submitSettings = this.getSubmitSettings(event); if (submitSettings?.target === "_blank") { return true; } if (this.scope.useAjax) { event.preventDefault(); event.stopPropagation(); this.ajaxSubmit(event, el); } } async ajaxSubmit(event, el) { this.debug("onSubmit", event, el, this.scope); const submitSettings = this.getSubmitSettings(event); if (!submitSettings) { console.warn("Can't get submit settings"); return; } if (this.scope.autoSetFormData) { this.getFormValues(); } try { const res = await HttpService.fetch(submitSettings.action, submitSettings.method, this.scope.form.fields, submitSettings.type); if (!res || !res.body) { return this.onErrorSubmit("500", "Error", "Empty body!"); } const message = res.body && res.body.message ? res.body.message : ""; if (Number(res.status) >= 400) { this.onErrorSubmit(res.status.toString(), message, res.body); } return this.onSuccessSubmit(res.status.toString(), message, res.body); } catch (err) { this.onErrorSubmit(err.status, err.body.message, err.body); } } getSubmitSettings(event) { if (!this.formEl) { console.warn("No form found"); return null; } let action = this.formEl.action; let method = this.formEl.method; let target = this.formEl.method; if (event?.originalEvent?.submitter) { const submitter = event?.originalEvent?.submitter; action = submitter?.formAction || action; method = submitter?.formMethod || method; target = submitter?.formTarget || target; } const settings = { action, method: method.toUpperCase(), target, type: this.scope.ajaxRequestType, }; return settings; } onInvalidForm(event) { this.debug("Form not valid", this.scope); event.preventDefault(); event.stopPropagation(); if (!this.formEl) { console.warn("No form found"); return; } const invalidElements = this.formEl.querySelectorAll(":invalid"); if (invalidElements && invalidElements.length) { const invalidElement = invalidElements[0]; if (this.scope.scrollToInvalidElement) { this.scrollToElement(invalidElement); } if (this.scope.animateInvalidElement) { this.scrollToElement(invalidElement); } } this.dispatchEvent(new CustomEvent("invalid", { detail: { elements: invalidElements }, })); } scrollToElement(invalidElement) { const vp = getViewportDimensions(); const offset = vp.h / 2; scrollTo(invalidElement, offset, window); this.animateInvalidElement(invalidElement); } animateInvalidElement(invalidElement, endsOn = 3000) { invalidElement.classList.add("invalid-flashing-animation"); setTimeout(() => { invalidElement.classList.remove("invalid-flashing-animation"); }, endsOn); } onErrorSubmit(status, message, response) { this.debug("onErrorSubmit"); this.dispatchEvent(new CustomEvent("submit-error", { detail: { status, message: message, response }, })); } onSuccessSubmit(status, message, response) { this.debug("onSuccessSubmit"); if (this.scope.disableSubmitUntilChange) { this.scope.submitDisabled = true; } this.dispatchEvent(new CustomEvent("submit-success", { detail: { status, message: message, response }, })); } validate(form, validationScope, errorEventName = "validation-error") { validationScope.valid = form.checkValidity(); validationScope.error = form.validationMessage; if (!validationScope.valid) { this.dispatchEvent(new CustomEvent(errorEventName)); form.classList.add("was-validated"); } } getFormValues() { if (!this.formEl) { console.warn("No form found"); return null; } this.scope.form.fields = new FormData(this.formEl); return this.scope.form.fields; } initForm() { const formEl = this.querySelector("form"); if (formEl && formEl.length > 0) { this.formEl = formEl; this.formEl.classList.add("needs-validation"); this.formEl.setAttribute("novalidate", ""); } else { console.warn("bs4 form without children found"); } } async template() { if (hasChildNodesTrim(this)) { this.initForm(); return null; } else { const { default: template } = await import("./bs4-form.component.html?raw"); return template; } } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs4-form.component.js","sourceRoot":"","sources":["../../../src/components/bs4-form/bs4-form.component.ts"],"names":[],"mappings":"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"}