import { Flow, FlowDesignationEnum, PolicyEngineMode, FlowsApi, CapabilitiesEnum } from "authentik-api"; import { t } from "@lingui/macro"; import { customElement } from "lit-element"; import { html, TemplateResult } from "lit-html"; import { config, DEFAULT_CONFIG } from "../../api/Config"; import { ifDefined } from "lit-html/directives/if-defined"; import "../../elements/forms/HorizontalFormElement"; import { ModelForm } from "../../elements/forms/ModelForm"; import { until } from "lit-html/directives/until"; import { first } from "../../utils"; @customElement("ak-flow-form") export class FlowForm extends ModelForm { loadInstance(pk: string): Promise { return new FlowsApi(DEFAULT_CONFIG).flowsInstancesRetrieve({ slug: pk, }); } getSuccessMessage(): string { if (this.instance) { return t`Successfully updated flow.`; } else { return t`Successfully created flow.`; } } send = (data: Flow): Promise => { let writeOp: Promise; if (this.instance) { writeOp = new FlowsApi(DEFAULT_CONFIG).flowsInstancesUpdate({ slug: this.instance.slug, flowRequest: data }); } else { writeOp = new FlowsApi(DEFAULT_CONFIG).flowsInstancesCreate({ flowRequest: data }); } return config().then((c) => { if (c.capabilities.includes(CapabilitiesEnum.CanSaveMedia)) { const icon = this.getFormFile(); if (icon) { return writeOp.then(app => { return new FlowsApi(DEFAULT_CONFIG).flowsInstancesSetBackgroundCreate({ slug: app.slug, file: icon }); }); } } else { return writeOp.then(app => { return new FlowsApi(DEFAULT_CONFIG).flowsInstancesSetBackgroundUrlCreate({ slug: app.slug, setIconURLRequest: { url: data.background || "", } }); }); } }); }; renderDesignations(): TemplateResult { return html` `; } renderForm(): TemplateResult { return html`

${t`Shown as the Title in Flow pages.`}

${t`Visible in the URL.`}

${t`Decides what this Flow is used for. For example, the Authentication flow is redirect to when an un-authenticated user visits authentik.`}

${until(config().then((c) => { let type = "text"; if (c.capabilities.includes(CapabilitiesEnum.CanSaveMedia)) { type = "file"; } return html`

${t`Background shown during execution.`}

`; }))}
`; } }