web: add button to create application on provider page
This commit is contained in:
parent
0b75a0028b
commit
416d949d80
|
@ -4,11 +4,15 @@ export const SLUG_REGEX = "[-a-zA-Z0-9_]+";
|
||||||
export const ID_REGEX = "\\d+";
|
export const ID_REGEX = "\\d+";
|
||||||
export const UUID_REGEX = "[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}";
|
export const UUID_REGEX = "[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}";
|
||||||
|
|
||||||
|
export interface RouteArgs {
|
||||||
|
[key: string]: string;
|
||||||
|
}
|
||||||
|
|
||||||
export class Route {
|
export class Route {
|
||||||
url: RegExp;
|
url: RegExp;
|
||||||
|
|
||||||
private element?: TemplateResult;
|
private element?: TemplateResult;
|
||||||
private callback?: (args: { [key: string]: string }) => TemplateResult;
|
private callback?: (args: RouteArgs) => TemplateResult;
|
||||||
|
|
||||||
constructor(url: RegExp, element?: TemplateResult) {
|
constructor(url: RegExp, element?: TemplateResult) {
|
||||||
this.url = url;
|
this.url = url;
|
||||||
|
@ -24,12 +28,12 @@ export class Route {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
then(render: (args: { [key: string]: string }) => TemplateResult): Route {
|
then(render: (args: RouteArgs) => TemplateResult): Route {
|
||||||
this.callback = render;
|
this.callback = render;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
render(args: { [key: string]: string }): TemplateResult {
|
render(args: RouteArgs): TemplateResult {
|
||||||
if (this.callback) {
|
if (this.callback) {
|
||||||
return this.callback(args);
|
return this.callback(args);
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,11 +10,12 @@ import "../../elements/CodeMirror";
|
||||||
import "../../elements/Tabs";
|
import "../../elements/Tabs";
|
||||||
import { Page } from "../../elements/Page";
|
import { Page } from "../../elements/Page";
|
||||||
import { convertToTitle } from "../../utils";
|
import { convertToTitle } from "../../utils";
|
||||||
|
import "./RelatedApplicationButton";
|
||||||
|
|
||||||
@customElement("ak-provider-oauth2-view")
|
@customElement("ak-provider-oauth2-view")
|
||||||
export class OAuth2ProviderViewPage extends Page {
|
export class OAuth2ProviderViewPage extends Page {
|
||||||
pageTitle(): string {
|
pageTitle(): string {
|
||||||
return gettext(`OAuth Provider ${this.provider?.name}`);
|
return gettext(`OAuth Provider ${this.provider?.name || ""}`);
|
||||||
}
|
}
|
||||||
pageDescription(): string | undefined {
|
pageDescription(): string | undefined {
|
||||||
return;
|
return;
|
||||||
|
@ -72,12 +73,7 @@ export class OAuth2ProviderViewPage extends Page {
|
||||||
</dt>
|
</dt>
|
||||||
<dd class="pf-c-description-list__description">
|
<dd class="pf-c-description-list__description">
|
||||||
<div class="pf-c-description-list__text">
|
<div class="pf-c-description-list__text">
|
||||||
${this.provider.assigned_application_slug ?
|
<ak-provider-related-application .provider=${this.provider}></ak-provider-related-application>
|
||||||
html`<a href="#/applications/${this.provider.assigned_application_slug}">
|
|
||||||
${this.provider.assigned_application_name}
|
|
||||||
</a>`:
|
|
||||||
html`-`
|
|
||||||
}
|
|
||||||
</div>
|
</div>
|
||||||
</dd>
|
</dd>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -12,10 +12,6 @@ import "./ProxyProviderViewPage";
|
||||||
|
|
||||||
@customElement("ak-provider-view")
|
@customElement("ak-provider-view")
|
||||||
export class ProviderViewPage extends LitElement {
|
export class ProviderViewPage extends LitElement {
|
||||||
@property()
|
|
||||||
set args(value: { [key: string]: number }) {
|
|
||||||
this.providerID = value.id;
|
|
||||||
}
|
|
||||||
|
|
||||||
@property({type: Number})
|
@property({type: Number})
|
||||||
set providerID(value: number) {
|
set providerID(value: number) {
|
||||||
|
|
|
@ -9,11 +9,12 @@ import "../../elements/buttons/SpinnerButton";
|
||||||
import "../../elements/CodeMirror";
|
import "../../elements/CodeMirror";
|
||||||
import "../../elements/Tabs";
|
import "../../elements/Tabs";
|
||||||
import { Page } from "../../elements/Page";
|
import { Page } from "../../elements/Page";
|
||||||
|
import "./RelatedApplicationButton";
|
||||||
|
|
||||||
@customElement("ak-provider-proxy-view")
|
@customElement("ak-provider-proxy-view")
|
||||||
export class ProxyProviderViewPage extends Page {
|
export class ProxyProviderViewPage extends Page {
|
||||||
pageTitle(): string {
|
pageTitle(): string {
|
||||||
return gettext(`Proxy Provider ${this.provider?.name}`);
|
return gettext(`Proxy Provider ${this.provider?.name || ""}`);
|
||||||
}
|
}
|
||||||
pageDescription(): string | undefined {
|
pageDescription(): string | undefined {
|
||||||
return;
|
return;
|
||||||
|
@ -72,9 +73,7 @@ export class ProxyProviderViewPage extends Page {
|
||||||
</dt>
|
</dt>
|
||||||
<dd class="pf-c-description-list__description">
|
<dd class="pf-c-description-list__description">
|
||||||
<div class="pf-c-description-list__text">
|
<div class="pf-c-description-list__text">
|
||||||
<a href="#/applications/${this.provider.assigned_application_slug}">
|
<ak-provider-related-application .provider=${this.provider}></ak-provider-related-application>
|
||||||
${this.provider.assigned_application_name}
|
|
||||||
</a>
|
|
||||||
</div>
|
</div>
|
||||||
</dd>
|
</dd>
|
||||||
</div>
|
</div>
|
||||||
|
|
29
web/src/pages/providers/RelatedApplicationButton.ts
Normal file
29
web/src/pages/providers/RelatedApplicationButton.ts
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
import { gettext } from "django";
|
||||||
|
import { customElement, html, LitElement, property, TemplateResult } from "lit-element";
|
||||||
|
import { Application } from "../../api/Applications";
|
||||||
|
import { Provider } from "../../api/Providers";
|
||||||
|
|
||||||
|
import "../../elements/buttons/ModalButton";
|
||||||
|
import "../../elements/Spinner";
|
||||||
|
|
||||||
|
@customElement("ak-provider-related-application")
|
||||||
|
export class RelatedApplicationButton extends LitElement {
|
||||||
|
|
||||||
|
@property({attribute: false})
|
||||||
|
provider?: Provider;
|
||||||
|
|
||||||
|
render(): TemplateResult {
|
||||||
|
if (this.provider?.assigned_application_slug) {
|
||||||
|
return html`<a href="#/applications/${this.provider.assigned_application_slug}">
|
||||||
|
${this.provider.assigned_application_name}
|
||||||
|
</a>`;
|
||||||
|
}
|
||||||
|
return html`<ak-modal-button href=${Application.adminUrl(`create/?provider=${this.provider ? this.provider.pk : ""}`)}>
|
||||||
|
<ak-spinner-button slot="trigger" class="pf-m-primary">
|
||||||
|
${gettext("Create")}
|
||||||
|
</ak-spinner-button>
|
||||||
|
<div slot="modal"></div>
|
||||||
|
</ak-modal-button>`;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -10,11 +10,12 @@ import "../../elements/buttons/SpinnerButton";
|
||||||
import "../../elements/CodeMirror";
|
import "../../elements/CodeMirror";
|
||||||
import "../../elements/Tabs";
|
import "../../elements/Tabs";
|
||||||
import { Page } from "../../elements/Page";
|
import { Page } from "../../elements/Page";
|
||||||
|
import "./RelatedApplicationButton";
|
||||||
|
|
||||||
@customElement("ak-provider-saml-view")
|
@customElement("ak-provider-saml-view")
|
||||||
export class SAMLProviderViewPage extends Page {
|
export class SAMLProviderViewPage extends Page {
|
||||||
pageTitle(): string {
|
pageTitle(): string {
|
||||||
return gettext(`SAML Provider ${this.provider?.name}`);
|
return gettext(`SAML Provider ${this.provider?.name || ""}`);
|
||||||
}
|
}
|
||||||
pageDescription(): string | undefined {
|
pageDescription(): string | undefined {
|
||||||
return;
|
return;
|
||||||
|
@ -73,9 +74,7 @@ export class SAMLProviderViewPage extends Page {
|
||||||
</dt>
|
</dt>
|
||||||
<dd class="pf-c-description-list__description">
|
<dd class="pf-c-description-list__description">
|
||||||
<div class="pf-c-description-list__text">
|
<div class="pf-c-description-list__text">
|
||||||
<a href="#/applications/${this.provider.assigned_application_slug}">
|
<ak-provider-related-application .provider=${this.provider}></ak-provider-related-application>
|
||||||
${this.provider.assigned_application_name}
|
|
||||||
</a>
|
|
||||||
</div>
|
</div>
|
||||||
</dd>
|
</dd>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -25,7 +25,7 @@ export const ROUTES: Route[] = [
|
||||||
new Route(new RegExp("^/administration/overview$"), html`<ak-admin-overview></ak-admin-overview>`),
|
new Route(new RegExp("^/administration/overview$"), html`<ak-admin-overview></ak-admin-overview>`),
|
||||||
new Route(new RegExp("^/providers$"), html`<ak-provider-list></ak-provider-list>`),
|
new Route(new RegExp("^/providers$"), html`<ak-provider-list></ak-provider-list>`),
|
||||||
new Route(new RegExp(`^/providers/(?<id>${ID_REGEX})$`)).then((args) => {
|
new Route(new RegExp(`^/providers/(?<id>${ID_REGEX})$`)).then((args) => {
|
||||||
return html`<ak-provider-view .args=${args}></ak-provider-view>`;
|
return html`<ak-provider-view .providerID=${parseInt(args.id, 10)}></ak-provider-view>`;
|
||||||
}),
|
}),
|
||||||
new Route(new RegExp("^/applications$"), html`<ak-application-list></ak-application-list>`),
|
new Route(new RegExp("^/applications$"), html`<ak-application-list></ak-application-list>`),
|
||||||
new Route(new RegExp(`^/applications/(?<slug>${SLUG_REGEX})$`)).then((args) => {
|
new Route(new RegExp(`^/applications/(?<slug>${SLUG_REGEX})$`)).then((args) => {
|
||||||
|
|
Reference in a new issue