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/providers/ProviderViewPage.ts

53 lines
1.8 KiB
TypeScript
Raw Normal View History

2021-02-06 16:55:41 +00:00
import { CSSResult, customElement, html, LitElement, property, TemplateResult } from "lit-element";
2021-02-04 08:54:00 +00:00
import { Provider } from "../../api/Providers";
2021-02-06 16:55:41 +00:00
import { COMMON_STYLES } from "../../common/styles";
2021-02-04 08:54:00 +00:00
import "../../elements/buttons/ModalButton";
import "../../elements/buttons/SpinnerButton";
2021-02-06 16:55:41 +00:00
import { SpinnerSize } from "../../elements/Spinner";
import "./SAMLProviderViewPage";
2021-02-06 17:35:55 +00:00
import "./OAuth2ProviderViewPage";
2021-02-04 08:54:00 +00:00
@customElement("ak-provider-view")
export class ProviderViewPage extends LitElement {
@property()
set args(value: { [key: string]: number }) {
this.providerID = value.id;
}
2021-02-04 09:22:14 +00:00
@property({type: Number})
2021-02-04 08:54:00 +00:00
set providerID(value: number) {
Provider.get(value).then((app) => (this.provider = app));
}
@property({ attribute: false })
provider?: Provider;
2021-02-06 16:55:41 +00:00
static get styles(): CSSResult[] {
return COMMON_STYLES;
}
render(): TemplateResult {
if (!this.provider) {
return html`<div class="pf-c-empty-state pf-m-full-height">
<div class="pf-c-empty-state__content">
<div class="pf-l-bullseye">
<div class="pf-l-bullseye__item">
<ak-spinner size="${SpinnerSize.XLarge}"></ak-spinner>
</div>
</div>
</div>
</div>`;
}
switch (this.provider?.object_type) {
case "saml":
return html`<ak-provider-saml-view providerID=${this.provider.pk}></ak-provider-saml-view>`;
2021-02-06 17:35:55 +00:00
case "oauth2":
return html`<ak-provider-oauth2-view providerID=${this.provider.pk}></ak-provider-oauth2-view>`;
2021-02-06 16:55:41 +00:00
default:
return html`<p>Invalid provider type ${this.provider?.object_type}</p>`;
}
}
2021-02-04 08:54:00 +00:00
}