mirror of
https://github.com/FJurmanovic/wallet-web.git
synced 2026-02-06 06:08:10 +00:00
custom app form
This commit is contained in:
@@ -1,11 +1,12 @@
|
||||
import { attr, controller, target } from "@github/catalyst";
|
||||
import { firstUpper } from "core/utils";
|
||||
import { closest, firstUpper } from "core/utils";
|
||||
import { html, TemplateResult } from "@github/jtml";
|
||||
import { RouterService } from "core/services";
|
||||
import randomId from "core/utils/random-id";
|
||||
import validator from "validator";
|
||||
import { validatorErrors } from "core/constants";
|
||||
import { BaseComponentElement } from "common/";
|
||||
import { AppFormElement } from "components/app-form/AppFormElement";
|
||||
|
||||
@controller
|
||||
class InputFieldElement extends BaseComponentElement {
|
||||
@@ -15,7 +16,9 @@ class InputFieldElement extends BaseComponentElement {
|
||||
@attr rules: string;
|
||||
@target main: HTMLElement;
|
||||
@target inp: HTMLElement;
|
||||
@closest appForm: AppFormElement;
|
||||
error: string;
|
||||
displayError: boolean;
|
||||
randId: string;
|
||||
constructor() {
|
||||
super();
|
||||
@@ -34,7 +37,7 @@ class InputFieldElement extends BaseComponentElement {
|
||||
return this.rules.includes("required");
|
||||
}
|
||||
|
||||
validate(): boolean {
|
||||
validate = (): boolean => {
|
||||
let _return = true;
|
||||
const rules = this.rules?.split("|").filter((a) => a);
|
||||
const value = (this.inp as HTMLInputElement)?.value;
|
||||
@@ -62,18 +65,55 @@ class InputFieldElement extends BaseComponentElement {
|
||||
if (_return) {
|
||||
this.error = null;
|
||||
}
|
||||
this.update();
|
||||
return _return;
|
||||
}
|
||||
};
|
||||
|
||||
validateDisplay = () => {
|
||||
if (!this.validate()) {
|
||||
this.displayError = true;
|
||||
} else {
|
||||
this.displayError = false;
|
||||
}
|
||||
this.update();
|
||||
};
|
||||
|
||||
inputChange = (e) => {
|
||||
this.validate();
|
||||
this.appForm?.inputChange(e);
|
||||
};
|
||||
|
||||
render = (): TemplateResult => {
|
||||
const renderMessage = (label: string) => {
|
||||
if (this.label) {
|
||||
return html`<label for="${this.randId}"
|
||||
>${this.label}${this.required ? " (*)" : ""}</label
|
||||
>`;
|
||||
}
|
||||
return html``;
|
||||
};
|
||||
|
||||
const renderError = (displayError: boolean, error: string) => {
|
||||
if (displayError) {
|
||||
return html`<span>${error}</span>`;
|
||||
}
|
||||
return html``;
|
||||
};
|
||||
|
||||
const renderInput = (type) => {
|
||||
return html` <input
|
||||
type="${this.type}"
|
||||
data-target="input-field.inp"
|
||||
data-action="
|
||||
input:input-field#inputChange
|
||||
keyup:app-form#keyUp
|
||||
blur:input-field#validateDisplay
|
||||
"
|
||||
/>`;
|
||||
};
|
||||
|
||||
return html`<div data-target="input-field.main">
|
||||
${this.label &&
|
||||
html`<label for="${this.randId}"
|
||||
>${this.label}${this.required ? " (*)" : ""}</label
|
||||
>`}
|
||||
<input type="${this.type}" data-target="input-field.inp" />
|
||||
${this.error && html`<span>${this.error}</span>`}
|
||||
${renderMessage(this.label)} ${renderInput(this.type)}
|
||||
${renderError(this.displayError, this.error)}
|
||||
</div>`;
|
||||
};
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user