This repository has been archived on 2024-05-31. You can view files and clone it, but cannot push or open issues or pull requests.
authentik/web/src/pages/admin-overview/AdminOverviewPage.ts

130 lines
5.4 KiB
TypeScript
Raw Normal View History

2020-12-01 21:17:07 +00:00
import { gettext } from "django";
import { CSSResult, customElement, html, LitElement, property, TemplateResult } from "lit-element";
import { AdminOverview } from "../../api/admin_overview";
import { DefaultClient } from "../../api/client";
import { User } from "../../api/user";
import { COMMON_STYLES } from "../../common/styles";
import { AggregatePromiseCard } from "../../elements/cards/AggregatePromiseCard";
2020-12-02 14:44:40 +00:00
import { SpinnerSize } from "../../elements/Spinner";
import "../../elements/AdminLoginsChart";
import "./TopApplicationsTable";
2020-12-01 21:17:07 +00:00
2020-12-05 21:08:42 +00:00
@customElement("ak-admin-status-card")
2020-12-01 21:17:07 +00:00
export class AdminStatusCard extends AggregatePromiseCard {
2020-12-02 14:44:40 +00:00
@property({type: Number})
2020-12-01 21:17:07 +00:00
value?: number;
@property()
warningText?: string;
2020-12-02 14:44:40 +00:00
@property({type: Number})
2020-12-01 21:17:07 +00:00
lessThanThreshold?: number;
renderNone(): TemplateResult {
2020-12-05 21:08:42 +00:00
return html`<ak-spinner size=${SpinnerSize.Large}></ak-spinner>`;
2020-12-01 21:17:07 +00:00
}
renderGood(): TemplateResult {
2020-12-05 21:08:42 +00:00
return html`<p class="ak-aggregate-card">
2020-12-01 21:17:07 +00:00
<i class="fa fa-check-circle"></i> ${this.value}
</p>`;
}
renderBad(): TemplateResult {
2020-12-05 21:08:42 +00:00
return html`<p class="ak-aggregate-card">
2020-12-01 21:17:07 +00:00
<i class="fa fa-exclamation-triangle"></i> ${this.value}
</p>
<p class="subtext">${this.warningText ? gettext(this.warningText) : ""}</p>`;
}
renderInner(): TemplateResult {
if (!this.value) {
return this.renderNone();
}
return html``;
}
}
2020-12-05 21:08:42 +00:00
@customElement("ak-admin-overview")
2020-12-01 21:17:07 +00:00
export class AdminOverviewPage extends LitElement {
2020-12-02 14:44:40 +00:00
@property({attribute: false})
2020-12-01 21:17:07 +00:00
data?: AdminOverview;
2020-12-02 14:44:40 +00:00
@property({attribute: false})
2020-12-01 21:17:07 +00:00
users?: Promise<number>;
static get styles(): CSSResult[] {
return COMMON_STYLES;
}
firstUpdated(): void {
AdminOverview.get().then(value => this.data = value);
this.users = User.count();
}
render(): TemplateResult {
return html`<section class="pf-c-page__main-section pf-m-light">
<div class="pf-c-content">
<h1>${gettext("System Overview")}</h1>
</div>
</section>
<section class="pf-c-page__main-section">
<div class="pf-l-gallery pf-m-gutter">
2020-12-05 21:08:42 +00:00
<ak-aggregate-card class="pf-l-gallery__item pf-m-4-col" icon="pf-icon pf-icon-server" header="Logins over the last 24 hours" style="grid-column-end: span 3;grid-row-end: span 2;">
<ak-admin-logins-chart url="${DefaultClient.makeUrl(["admin", "metrics"])}"></ak-admin-logins-chart>
</ak-aggregate-card>
<ak-aggregate-card class="pf-l-gallery__item pf-m-4-col" icon="pf-icon pf-icon-server" header="Apps with most usage" style="grid-column-end: span 2;grid-row-end: span 3;">
<ak-top-applications-table></ak-top-applications-table>
</ak-aggregate-card>
<ak-aggregate-card class="pf-l-gallery__item pf-m-4-col" icon="pf-icon pf-icon-server" header="Workers">
${this.data ?
this.data?.worker_count < 1 ?
html`<p class="ak-aggregate-card">
<i class="fa fa-exclamation-triangle"></i> ${this.data?.worker_count}
</p>
<p class="subtext">${gettext("No workers connected.")}</p>` :
html`<p class="ak-aggregate-card">
<i class="fa fa-check-circle"></i> ${this.data?.worker_count}
</p>`
: html`<ak-spinner size=${SpinnerSize.Large}></ak-spinner>`}
</ak-aggregate-card>
<ak-aggregate-card class="pf-l-gallery__item pf-m-4-col" icon="pf-icon pf-icon-plugged" header="Providers" headerLink="#/administration/providers/">
2020-12-01 21:17:07 +00:00
${this.data ?
this.data?.providers_without_application > 1 ?
2020-12-05 21:08:42 +00:00
html`<p class="ak-aggregate-card">
2020-12-01 21:17:07 +00:00
<i class="fa fa-exclamation-triangle"></i> 0
</p>
<p class="subtext">${gettext("At least one Provider has no application assigned.")}</p>` :
2020-12-05 21:08:42 +00:00
html`<p class="ak-aggregate-card">
2020-12-01 21:17:07 +00:00
<i class="fa fa-check-circle"></i> 0
</p>`
2020-12-05 21:08:42 +00:00
: html`<ak-spinner size=${SpinnerSize.Large}></ak-spinner>`}
</ak-aggregate-card>
<ak-aggregate-card class="pf-l-gallery__item pf-m-4-col" icon="pf-icon pf-icon-plugged" header="Policies" headerLink="#/administration/policies/">
2020-12-01 21:17:07 +00:00
${this.data ?
this.data?.policies_without_binding > 1 ?
2020-12-05 21:08:42 +00:00
html`<p class="ak-aggregate-card">
2020-12-01 21:17:07 +00:00
<i class="fa fa-exclamation-triangle"></i> 0
</p>
<p class="subtext">${gettext("Policies without binding exist.")}</p>` :
2020-12-05 21:08:42 +00:00
html`<p class="ak-aggregate-card">
2020-12-01 21:17:07 +00:00
<i class="fa fa-check-circle"></i> 0
</p>`
2020-12-05 21:08:42 +00:00
: html`<ak-spinner size=${SpinnerSize.Large}></ak-spinner>`}
</ak-aggregate-card>
<ak-aggregate-card-promise
2020-12-01 21:17:07 +00:00
icon="pf-icon pf-icon-user"
header="Users"
headerLink="#/administration/users/"
.promise=${this.users}>
2020-12-05 21:08:42 +00:00
</ak-aggregate-card-promise>
2020-12-01 21:17:07 +00:00
</div>
</section>`;
}
}