import { css, CSSResult, customElement, html, LitElement, property, TemplateResult } from "lit-element"; import PFPage from "@patternfly/patternfly/components/Page/page.css"; import PFContent from "@patternfly/patternfly/components/Content/content.css"; import AKGlobal from "../authentik.css"; import PFBase from "@patternfly/patternfly/patternfly-base.css"; import PFButton from "@patternfly/patternfly/components/Button/button.css"; import { EVENT_SIDEBAR_TOGGLE, TITLE_SUFFIX } from "../constants"; @customElement("ak-page-header") export class PageHeader extends LitElement { @property() icon?: string; @property({type: Boolean}) iconImage = false @property() set header(value: string) { if (value !== "") { document.title = `${value} - ${TITLE_SUFFIX}`; } else { document.title = TITLE_SUFFIX; } this._header = value; } get header(): string { return this._header; } @property() description?: string; _header = ""; static get styles(): CSSResult[] { return [PFBase, PFButton, PFPage, PFContent, AKGlobal, css` :host { display: flex; flex-direction: row; } button.sidebar-trigger { background-color: var(--pf-c-page__main-section--m-light--BackgroundColor); } `]; } renderIcon(): TemplateResult { if (this.icon) { if (this.iconImage) { return html` `; } return html` `; } return html``; } render(): TemplateResult { return html`

${this.renderIcon()} ${this.header}

${this.description ? html`

${this.description}

` : html``}
`; } }