import { EVENT_REFRESH } from "@goauthentik/common/constants"; import "@goauthentik/elements/LoadingOverlay"; import { ModalButton } from "@goauthentik/elements/buttons/ModalButton"; import "@goauthentik/elements/buttons/SpinnerButton"; import { Form } from "@goauthentik/elements/forms/Form"; import { msg } from "@lit/localize"; import { TemplateResult, html } from "lit"; import { customElement, property } from "lit/decorators.js"; @customElement("ak-forms-modal") export class ModalForm extends ModalButton { @property({ type: Boolean }) closeAfterSuccessfulSubmit = true; @property({ type: Boolean }) showSubmitButton = true; @property({ type: Boolean }) loading = false; @property({ type: String }) cancelText = msg("Cancel"); async confirm(): Promise { const form = this.querySelector>("[slot=form]"); if (!form) { return Promise.reject(msg("No form found")); } const formPromise = form.submit(new Event("submit")); if (!formPromise) { return Promise.reject(msg("Form didn't return a promise for submitting")); } return formPromise .then(() => { if (this.closeAfterSuccessfulSubmit) { this.open = false; form?.resetForm(); } this.loading = false; this.locked = false; this.dispatchEvent( new CustomEvent(EVENT_REFRESH, { bubbles: true, composed: true, }), ); }) .catch((exc) => { this.loading = false; this.locked = false; throw exc; }); } renderModalInner(): TemplateResult { return html`${this.loading ? html`` : html``}

{ window.dispatchEvent( new CustomEvent("scroll", { bubbles: true, }), ); }} >
`; } }