import { css, CSSResult, customElement, html, LitElement, property, TemplateResult } from "lit-element"; // @ts-ignore import GlobalsStyle from "@patternfly/patternfly/base/patternfly-globals.css"; // @ts-ignore import ButtonStyle from "@patternfly/patternfly/components/Button/button.css"; // @ts-ignore import SpinnerStyle from "@patternfly/patternfly/components/Spinner/spinner.css"; import { ColorStyles, PRIMARY_CLASS, PROGRESS_CLASS } from "../../constants"; @customElement("pb-spinner-button") export class SpinnerButton extends LitElement { @property({type: Boolean}) isRunning = false; @property() form?: string; static get styles(): CSSResult[] { return [ GlobalsStyle, ButtonStyle, SpinnerStyle, ColorStyles, 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(); this.classList.add(PRIMARY_CLASS); } 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.replace(PRIMARY_CLASS, statusClass); this.requestUpdate(); setTimeout(() => { this.classList.replace(statusClass, PRIMARY_CLASS); this.requestUpdate(); }, 1000); } callAction(): void { if (this.isRunning === true) { return; } if (this.form) { // Because safari we can't just extend HTMLButtonElement, hence I have to implement // these attributes by myself here, sigh... document.querySelector(`#${this.form}`)?.submit(); } this.setLoading(); } render(): TemplateResult { return html``; } }