import { customElement, html, LitElement, property, TemplateResult } from "lit-element"; import "../../elements/buttons/SpinnerButton"; import "../../elements/EmptyState"; import "../../elements/PageHeader"; import "./saml/SAMLProviderViewPage"; import "./oauth2/OAuth2ProviderViewPage"; import "./proxy/ProxyProviderViewPage"; import { Provider, ProvidersApi } from "authentik-api"; import { DEFAULT_CONFIG } from "../../api/Config"; import { ifDefined } from "lit-html/directives/if-defined"; @customElement("ak-provider-view") export class ProviderViewPage extends LitElement { @property({type: Number}) set providerID(value: number) { new ProvidersApi(DEFAULT_CONFIG).providersAllRead({ id: value, }).then((prov) => (this.provider = prov)); } @property({ attribute: false }) provider?: Provider; renderProvider(): TemplateResult { if (!this.provider) { return html``; } switch (this.provider?.component) { case "ak-provider-saml-form": return html``; case "ak-provider-oauth2-form": return html``; case "ak-provider-proxy-form": return html``; default: return html`

Invalid provider type ${this.provider?.component}

`; } } render(): TemplateResult { return html` ${this.renderProvider()}`; } }