import { ScopeMapping, PropertymappingsApi } from "authentik-api"; import { t } from "@lingui/macro"; import { customElement } from "lit-element"; import { html, TemplateResult } from "lit-html"; import { DEFAULT_CONFIG } from "../../api/Config"; import { ModelForm } from "../../elements/forms/ModelForm"; import { ifDefined } from "lit-html/directives/if-defined"; import "../../elements/forms/HorizontalFormElement"; import "../../elements/CodeMirror"; @customElement("ak-property-mapping-scope-form") export class PropertyMappingScopeForm extends ModelForm { loadInstance(pk: string): Promise { return new PropertymappingsApi(DEFAULT_CONFIG).propertymappingsScopeRetrieve({ pmUuid: pk, }); } getSuccessMessage(): string { if (this.instance) { return t`Successfully updated mapping.`; } else { return t`Successfully created mapping.`; } } send = (data: ScopeMapping): Promise => { if (this.instance) { return new PropertymappingsApi(DEFAULT_CONFIG).propertymappingsScopeUpdate({ pmUuid: this.instance.pk || "", scopeMappingRequest: data }); } else { return new PropertymappingsApi(DEFAULT_CONFIG).propertymappingsScopeCreate({ scopeMappingRequest: data }); } }; renderForm(): TemplateResult { return html`

${t`Scope which the client can specify to access these properties.`}

${t`Description shown to the user when consenting. If left empty, the user won't be informed.`}

${t`Expression using Python.`} ${t`See documentation for a list of all variables.`}

`; } }