import "../elements/messages/MessageContainer"; import { css, CSSResult, customElement, html, LitElement, property, TemplateResult, } from "lit-element"; import { me } from "../api/Users"; import "./locale"; import "../elements/sidebar/SidebarItem"; import { t } from "@lingui/macro"; import PFBase from "@patternfly/patternfly/patternfly-base.css"; import PFPage from "@patternfly/patternfly/components/Page/page.css"; import PFBrand from "@patternfly/patternfly/components/Brand/brand.css"; import PFButton from "@patternfly/patternfly/components/Button/button.css"; import PFDrawer from "@patternfly/patternfly/components/Drawer/drawer.css"; import PFAvatar from "@patternfly/patternfly/components/Avatar/avatar.css"; import PFDropdown from "@patternfly/patternfly/components/Dropdown/dropdown.css"; import PFNotificationBadge from "@patternfly/patternfly/components/NotificationBadge/notification-badge.css"; import AKGlobal from "../authentik.css"; import "../elements/router/RouterOutlet"; import "../elements/messages/MessageContainer"; import "../elements/notifications/NotificationDrawer"; import "../elements/sidebar/Sidebar"; import { EVENT_API_DRAWER_TOGGLE, EVENT_NOTIFICATION_DRAWER_TOGGLE, EVENT_REFRESH, } from "../constants"; import { CurrentTenant, EventsApi } from "@goauthentik/api"; import { DEFAULT_CONFIG, tenant } from "../api/Config"; import { WebsocketClient } from "../common/ws"; import { ROUTES } from "../routesUser"; import { first } from "../utils"; import { DefaultTenant } from "../elements/sidebar/SidebarBrand"; import { until } from "lit-html/directives/until"; import { uiConfig } from "../user/config"; @customElement("ak-interface-user") export class UserInterface extends LitElement { @property({ type: Boolean }) notificationOpen = false; @property({ type: Boolean }) apiDrawerOpen = false; ws: WebsocketClient; @property({ attribute: false }) tenant: CurrentTenant = DefaultTenant; @property({ type: Number }) notificationsCount = -1; static get styles(): CSSResult[] { return [ PFBase, PFBrand, PFPage, PFAvatar, PFButton, PFDrawer, PFDropdown, PFNotificationBadge, AKGlobal, css` .pf-c-page__main, .pf-c-drawer__content, .pf-c-page__drawer { z-index: auto !important; background-color: transparent !important; } .pf-c-page { background-color: var(--pf-global--BackgroundColor--light-300) !important; } .display-none { display: none; } .pf-c-brand { min-height: 48px; } .has-notifications { color: #2b9af3; } `, ]; } constructor() { super(); this.ws = new WebsocketClient(); window.addEventListener(EVENT_NOTIFICATION_DRAWER_TOGGLE, () => { this.notificationOpen = !this.notificationOpen; }); window.addEventListener(EVENT_API_DRAWER_TOGGLE, () => { this.apiDrawerOpen = !this.apiDrawerOpen; }); window.addEventListener(EVENT_REFRESH, () => { this.firstUpdated(); }); tenant().then((tenant) => (this.tenant = tenant)); } firstUpdated(): void { new EventsApi(DEFAULT_CONFIG) .eventsNotificationsList({ seen: false, ordering: "-created", pageSize: 1, }) .then((r) => { this.notificationsCount = r.pagination.count; }); } render(): TemplateResult { return html`${until( uiConfig().then((config) => { return html`