import { css, CSSResult, html, LitElement, TemplateResult } from "lit"; import { customElement, property } from "lit/decorators"; import PFBase from "@patternfly/patternfly/patternfly-base.css"; import PFButton from "@patternfly/patternfly/components/Button/button.css"; import PFSpinner from "@patternfly/patternfly/components/Spinner/spinner.css"; import AKGlobal from "../../authentik.css"; import { PFSize } from "../Spinner"; import { ERROR_CLASS, PROGRESS_CLASS, SUCCESS_CLASS } from "../../constants"; @customElement("ak-spinner-button") export class SpinnerButton extends LitElement { @property({ type: Boolean }) isRunning = false; @property() callAction?: () => Promise; static get styles(): CSSResult[] { return [ PFBase, PFButton, PFSpinner, AKGlobal, css` button { /* Have to use !important here, as buttons with pf-m-progress have transition already */ transition: all var(--pf-c-button--m-progress--TransitionDuration) ease 0s !important; } `, ]; } constructor() { super(); } setLoading(): void { this.isRunning = true; this.classList.add(PROGRESS_CLASS); this.requestUpdate(); } setDone(statusClass: string): void { this.isRunning = false; this.classList.remove(PROGRESS_CLASS); this.classList.add(statusClass); this.requestUpdate(); setTimeout(() => { this.classList.remove(statusClass); this.requestUpdate(); }, 1000); } render(): TemplateResult { return html``; } }