import { DEFAULT_CONFIG } from "@goauthentik/common/api/config"; import { EVENT_API_DRAWER_TOGGLE, EVENT_NOTIFICATION_DRAWER_TOGGLE, EVENT_SIDEBAR_TOGGLE, EVENT_WS_MESSAGE, TITLE_DEFAULT, } from "@goauthentik/common/constants"; import { currentInterface } from "@goauthentik/common/sentry"; import { me } from "@goauthentik/common/users"; import { AKElement, rootInterface } from "@goauthentik/elements/Base"; import { msg } from "@lit/localize"; import { CSSResult, TemplateResult, css, html } from "lit"; import { customElement, property } from "lit/decorators.js"; import PFButton from "@patternfly/patternfly/components/Button/button.css"; import PFContent from "@patternfly/patternfly/components/Content/content.css"; import PFPage from "@patternfly/patternfly/components/Page/page.css"; import PFBase from "@patternfly/patternfly/patternfly-base.css"; import { EventsApi } from "@goauthentik/api"; @customElement("ak-page-header") export class PageHeader extends AKElement { @property() icon?: string; @property({ type: Boolean }) iconImage = false; @property({ type: Boolean }) hasNotifications = false; @property() set header(value: string) { const tenant = rootInterface()?.tenant; const currentIf = currentInterface(); let title = tenant?.brandingTitle || TITLE_DEFAULT; if (currentIf === "admin") { title = `${msg("Admin")} - ${title}`; } if (value !== "") { title = `${value} - ${title}`; } document.title = title; this._header = value; } get header(): string { return this._header; } @property() description?: string; _header = ""; static get styles(): CSSResult[] { return [ PFBase, PFButton, PFPage, PFContent, css` .bar { display: flex; flex-direction: row; min-height: 114px; } .pf-c-button.pf-m-plain { background-color: var(--pf-c-page__main-section--m-light--BackgroundColor); border-radius: 0px; } .pf-c-page__main-section { flex-grow: 1; display: flex; flex-direction: column; justify-content: center; } img.pf-icon { max-height: 24px; } .sidebar-trigger, .notification-trigger { font-size: 24px; } .notification-trigger.has-notifications { color: var(--pf-global--active-color--100); } `, ]; } constructor() { super(); window.addEventListener(EVENT_WS_MESSAGE, () => { this.firstUpdated(); }); } firstUpdated(): void { me().then((user) => { new EventsApi(DEFAULT_CONFIG) .eventsNotificationsList({ seen: false, ordering: "-created", pageSize: 1, user: user.user.pk, }) .then((r) => { this.hasNotifications = r.pagination.count > 0; }); }); } renderIcon(): TemplateResult { if (this.icon) { if (this.iconImage && !this.icon.startsWith("fa://")) { return html`page icon `; } const icon = this.icon.replaceAll("fa://", "fa "); return html` `; } return html``; } render(): TemplateResult { return html`

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

${this.description ? html`

${this.description}

` : html``}
`; } }