web/elements: add ProxyForm to instantiate forms based on string type
Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
This commit is contained in:
parent
e264e10ad6
commit
f814f7792c
|
@ -162,11 +162,7 @@ export class Form<T> extends LitElement {
|
|||
</div>`;
|
||||
}
|
||||
|
||||
render(): TemplateResult {
|
||||
const rect = this.getBoundingClientRect();
|
||||
if (rect.x + rect.y + rect.width + rect.height === 0) {
|
||||
return html``;
|
||||
}
|
||||
renderVisible(): TemplateResult {
|
||||
return html`<iron-form
|
||||
@iron-form-presubmit=${(ev: Event) => { this.submit(ev); }}>
|
||||
${this.renderNonFieldErrors()}
|
||||
|
@ -174,4 +170,12 @@ export class Form<T> extends LitElement {
|
|||
</iron-form>`;
|
||||
}
|
||||
|
||||
render(): TemplateResult {
|
||||
const rect = this.getBoundingClientRect();
|
||||
if (rect.x + rect.y + rect.width + rect.height === 0) {
|
||||
return html``;
|
||||
}
|
||||
return this.renderVisible();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
41
web/src/elements/forms/ProxyForm.ts
Normal file
41
web/src/elements/forms/ProxyForm.ts
Normal file
|
@ -0,0 +1,41 @@
|
|||
import { customElement, html, property, TemplateResult } from "lit-element";
|
||||
import { Form } from "./Form";
|
||||
|
||||
@customElement("ak-proxy-form")
|
||||
export class ProxyForm extends Form<unknown> {
|
||||
|
||||
@property()
|
||||
type!: string;
|
||||
|
||||
@property({attribute: false})
|
||||
args: Record<string, unknown> = {};
|
||||
|
||||
@property({attribute: false})
|
||||
typeMap: Record<string, string> = {};
|
||||
|
||||
submit(ev: Event): Promise<unknown> | undefined {
|
||||
return (this.shadowRoot?.firstElementChild as Form<unknown>).submit(ev);
|
||||
}
|
||||
|
||||
reset(): void {
|
||||
(this.shadowRoot?.firstElementChild as Form<unknown>).reset();
|
||||
}
|
||||
|
||||
getSuccessMessage(): string {
|
||||
return (this.shadowRoot?.firstElementChild as Form<unknown>).getSuccessMessage();
|
||||
}
|
||||
|
||||
renderVisible(): TemplateResult {
|
||||
let elementName = this.type;
|
||||
if (this.type in this.typeMap) {
|
||||
elementName = this.typeMap[this.type];
|
||||
}
|
||||
const el = document.createElement(elementName);
|
||||
for (const k in this.args) {
|
||||
el.setAttribute(k, this.args[k] as string);
|
||||
(el as unknown as Record<string, unknown>)[k] = this.args[k];
|
||||
}
|
||||
return html`${el}`;
|
||||
}
|
||||
|
||||
}
|
Reference in a new issue