web/admin: only show token expiry when token is set to expire (#6643)
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
This commit is contained in:
@ -8,16 +8,21 @@ import "@goauthentik/elements/forms/SearchSelect";
|
|||||||
|
|
||||||
import { msg } from "@lit/localize";
|
import { msg } from "@lit/localize";
|
||||||
import { TemplateResult, html } from "lit";
|
import { TemplateResult, html } from "lit";
|
||||||
import { customElement } from "lit/decorators.js";
|
import { customElement, state } from "lit/decorators.js";
|
||||||
|
|
||||||
import { CoreApi, CoreUsersListRequest, IntentEnum, Token, User } from "@goauthentik/api";
|
import { CoreApi, CoreUsersListRequest, IntentEnum, Token, User } from "@goauthentik/api";
|
||||||
|
|
||||||
@customElement("ak-token-form")
|
@customElement("ak-token-form")
|
||||||
export class TokenForm extends ModelForm<Token, string> {
|
export class TokenForm extends ModelForm<Token, string> {
|
||||||
loadInstance(pk: string): Promise<Token> {
|
@state()
|
||||||
return new CoreApi(DEFAULT_CONFIG).coreTokensRetrieve({
|
showExpiry = true;
|
||||||
|
|
||||||
|
async loadInstance(pk: string): Promise<Token> {
|
||||||
|
const token = await new CoreApi(DEFAULT_CONFIG).coreTokensRetrieve({
|
||||||
identifier: pk,
|
identifier: pk,
|
||||||
});
|
});
|
||||||
|
this.showExpiry = token.expiring || true;
|
||||||
|
return token;
|
||||||
}
|
}
|
||||||
|
|
||||||
getSuccessMessage(): string {
|
getSuccessMessage(): string {
|
||||||
@ -41,6 +46,17 @@ export class TokenForm extends ModelForm<Token, string> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
renderExpiry(): TemplateResult {
|
||||||
|
return html`<ak-form-element-horizontal label=${msg("Expires on")} name="expires">
|
||||||
|
<input
|
||||||
|
type="datetime-local"
|
||||||
|
data-type="datetime-local"
|
||||||
|
value="${dateTimeLocal(first(this.instance?.expires, new Date()))}"
|
||||||
|
class="pf-c-form-control"
|
||||||
|
/>
|
||||||
|
</ak-form-element-horizontal>`;
|
||||||
|
}
|
||||||
|
|
||||||
renderForm(): TemplateResult {
|
renderForm(): TemplateResult {
|
||||||
return html`<form class="pf-c-form pf-m-horizontal">
|
return html`<form class="pf-c-form pf-m-horizontal">
|
||||||
<ak-form-element-horizontal
|
<ak-form-element-horizontal
|
||||||
@ -117,6 +133,10 @@ export class TokenForm extends ModelForm<Token, string> {
|
|||||||
class="pf-c-switch__input"
|
class="pf-c-switch__input"
|
||||||
type="checkbox"
|
type="checkbox"
|
||||||
?checked=${first(this.instance?.expiring, true)}
|
?checked=${first(this.instance?.expiring, true)}
|
||||||
|
@change=${(ev: Event) => {
|
||||||
|
const el = ev.target as HTMLInputElement;
|
||||||
|
this.showExpiry = el.checked;
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
<span class="pf-c-switch__toggle">
|
<span class="pf-c-switch__toggle">
|
||||||
<span class="pf-c-switch__toggle-icon">
|
<span class="pf-c-switch__toggle-icon">
|
||||||
@ -131,14 +151,7 @@ export class TokenForm extends ModelForm<Token, string> {
|
|||||||
)}
|
)}
|
||||||
</p>
|
</p>
|
||||||
</ak-form-element-horizontal>
|
</ak-form-element-horizontal>
|
||||||
<ak-form-element-horizontal label=${msg("Expires on")} name="expires">
|
${this.showExpiry ? this.renderExpiry() : html``}
|
||||||
<input
|
|
||||||
type="datetime-local"
|
|
||||||
data-type="datetime-local"
|
|
||||||
value="${dateTimeLocal(first(this.instance?.expires, new Date()))}"
|
|
||||||
class="pf-c-form-control"
|
|
||||||
/>
|
|
||||||
</ak-form-element-horizontal>
|
|
||||||
</form>`;
|
</form>`;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user