web/elements: fix resetForm is not a function

Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
This commit is contained in:
Jens Langhammer 2021-08-10 23:22:25 +02:00
parent 92990b4ded
commit 34fe250fb0

View file

@ -12,21 +12,23 @@ export class ProxyForm extends Form<unknown> {
@property({ attribute: false }) @property({ attribute: false })
typeMap: Record<string, string> = {}; typeMap: Record<string, string> = {};
innerElement?: Form<unknown>;
submit(ev: Event): Promise<unknown> | undefined { submit(ev: Event): Promise<unknown> | undefined {
return (this.shadowRoot?.firstElementChild as Form<unknown>).submit(ev); return this.innerElement?.submit(ev);
} }
resetForm(): void { resetForm(): void {
(this.shadowRoot?.firstElementChild as Form<unknown> | undefined)?.resetForm(); this.innerElement?.resetForm();
} }
getSuccessMessage(): string { getSuccessMessage(): string {
return (this.shadowRoot?.firstElementChild as Form<unknown>).getSuccessMessage(); return this.innerElement?.getSuccessMessage() || "";
} }
async requestUpdate(name?: PropertyKey | undefined, oldValue?: unknown): Promise<unknown> { async requestUpdate(name?: PropertyKey | undefined, oldValue?: unknown): Promise<unknown> {
const result = await super.requestUpdate(name, oldValue); const result = await super.requestUpdate(name, oldValue);
await (this.shadowRoot?.firstElementChild as Form<unknown> | undefined)?.requestUpdate(); await this.innerElement?.requestUpdate();
return result; return result;
} }
@ -35,11 +37,11 @@ export class ProxyForm extends Form<unknown> {
if (this.type in this.typeMap) { if (this.type in this.typeMap) {
elementName = this.typeMap[this.type]; elementName = this.typeMap[this.type];
} }
const el = document.createElement(elementName); this.innerElement = document.createElement(elementName) as Form<unknown>;
for (const k in this.args) { for (const k in this.args) {
el.setAttribute(k, this.args[k] as string); this.innerElement.setAttribute(k, this.args[k] as string);
(el as unknown as Record<string, unknown>)[k] = this.args[k]; (this.innerElement as unknown as Record<string, unknown>)[k] = this.args[k];
} }
return html`${el}`; return html`${this.innerElement}`;
} }
} }