import { CoreApi, User } 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 { ifDefined } from "lit-html/directives/if-defined"; import "../../elements/forms/HorizontalFormElement"; import "../../elements/CodeMirror"; import YAML from "yaml"; import { first } from "../../utils"; import { ModelForm } from "../../elements/forms/ModelForm"; @customElement("ak-user-form") export class UserForm extends ModelForm { loadInstance(pk: number): Promise { return new CoreApi(DEFAULT_CONFIG).coreUsersRead({ id: pk }); } getSuccessMessage(): string { if (this.instance) { return t`Successfully updated user.`; } else { return t`Successfully created user.`; } } send = (data: User): Promise => { if (this.instance) { return new CoreApi(DEFAULT_CONFIG).coreUsersUpdate({ id: this.instance.pk || 0, data: data }); } else { return new CoreApi(DEFAULT_CONFIG).coreUsersCreate({ data: data }); } }; renderForm(): TemplateResult { return html`

${t`Required. 150 characters or fewer. Letters, digits and @/./+/-/_ only.`}

${t`User's display name.`}

${t`Designates whether this user should be treated as active. Unselect this instead of deleting accounts.`}

${t`Set custom attributes using YAML or JSON.`}

`; } }