import { t } from "@lingui/macro"; import { css, CSSResult, html, LitElement, TemplateResult } from "lit"; import { customElement, property } from "lit/decorators"; import AKGlobal from "../../authentik.css"; import PFButton from "@patternfly/patternfly/components/Button/button.css"; import PFCard from "@patternfly/patternfly/components/Card/card.css"; import PFContent from "@patternfly/patternfly/components/Content/content.css"; import PFDescriptionList from "@patternfly/patternfly/components/DescriptionList/description-list.css"; import PFPage from "@patternfly/patternfly/components/Page/page.css"; import PFGrid from "@patternfly/patternfly/layouts/Grid/grid.css"; import PFBase from "@patternfly/patternfly/patternfly-base.css"; import { Flow, FlowsApi } from "@goauthentik/api"; import { DEFAULT_CONFIG } from "../../api/Config"; import "../../elements/PageHeader"; import "../../elements/Tabs"; import "../../elements/buttons/SpinnerButton"; import "../../elements/events/ObjectChangelog"; import "../policies/BoundPoliciesList"; import "./BoundStagesList"; import "./FlowDiagram"; @customElement("ak-flow-view") export class FlowViewPage extends LitElement { @property() set flowSlug(value: string) { new FlowsApi(DEFAULT_CONFIG) .flowsInstancesRetrieve({ slug: value, }) .then((flow) => { this.flow = flow; }); } @property({ attribute: false }) flow!: Flow; static get styles(): CSSResult[] { return [ PFBase, PFPage, PFDescriptionList, PFButton, PFCard, PFContent, PFGrid, AKGlobal, ].concat( css` img.pf-icon { max-height: 24px; } ak-tabs { height: 100%; } `, ); } render(): TemplateResult { if (!this.flow) { return html``; } return html`
${t`Related`}
${t`Execute flow`}
${t`Export flow`}
${t`These bindings control which users can access this flow.`}
`; } }