import { EventGeo, renderEventUser } from "@goauthentik/admin/events/utils"; import { DEFAULT_CONFIG } from "@goauthentik/common/api/config"; import { EventWithContext } from "@goauthentik/common/events"; import { actionToLabel } from "@goauthentik/common/labels"; import { formatElapsedTime } from "@goauthentik/common/temporal"; import "@goauthentik/components/ak-event-info"; import "@goauthentik/elements/Tabs"; import "@goauthentik/elements/buttons/Dropdown"; import "@goauthentik/elements/buttons/ModalButton"; import "@goauthentik/elements/buttons/SpinnerButton"; import { PaginatedResponse } from "@goauthentik/elements/table/Table"; import { Table, TableColumn } from "@goauthentik/elements/table/Table"; import { SlottedTemplateResult } from "@goauthentik/elements/types"; import { msg } from "@lit/localize"; import { CSSResult, TemplateResult, css, html } from "lit"; import { customElement, property } from "lit/decorators.js"; import PFCard from "@patternfly/patternfly/components/Card/card.css"; import { Event, EventsApi } from "@goauthentik/api"; @customElement("ak-recent-events") export class RecentEventsCard extends Table { @property() order = "-created"; @property({ type: Number }) pageSize = 10; async apiEndpoint(): Promise> { return new EventsApi(DEFAULT_CONFIG).eventsEventsList({ ...(await this.defaultEndpointConfig()), pageSize: this.pageSize, }); } static get styles(): CSSResult[] { return super.styles.concat( PFCard, css` .pf-c-card__title { --pf-c-card__title--FontFamily: var( --pf-global--FontFamily--heading--sans-serif ); --pf-c-card__title--FontSize: var(--pf-global--FontSize--md); --pf-c-card__title--FontWeight: var(--pf-global--FontWeight--bold); } * { word-break: break-all; } `, ); } columns(): TableColumn[] { return [ new TableColumn(msg("Action"), "action"), new TableColumn(msg("User"), "user"), new TableColumn(msg("Creation Date"), "created"), new TableColumn(msg("Client IP"), "client_ip"), new TableColumn(msg("Brand"), "brand_name"), ]; } renderToolbar(): TemplateResult { return html`
 ${msg("Recent events")}
`; } row(item: EventWithContext): SlottedTemplateResult[] { return [ html`
${actionToLabel(item.action)}
${item.app}`, renderEventUser(item), html`
${formatElapsedTime(item.created)}
${item.created.toLocaleString()}`, html`
${item.clientIp || msg("-")}
${EventGeo(item)}`, html`${item.brand?.name || msg("-")}`, ]; } renderEmpty(inner?: SlottedTemplateResult): TemplateResult { if (this.error) { return super.renderEmpty(inner); } return super.renderEmpty( html`${msg("No Events found.")}
${msg("No matching events could be found.")}
`, ); } } declare global { interface HTMLElementTagNameMap { "ak-recent-events": RecentEventsCard; } }