2022-09-14 22:05:21 +00:00
|
|
|
import { AKElement } from "@goauthentik/elements/Base";
|
|
|
|
import { PFSize } from "@goauthentik/elements/Spinner";
|
2022-06-25 15:44:17 +00:00
|
|
|
|
web: laying the groundwork for future expansion (#7045)
* web: laying the groundwork for future expansion
This commit is a hodge-podge of updates and changes to the web. Functional changes:
- Makefile: Fixed a bug in the `help` section that prevented the WIDTH from being accurately
calculated if `help` was included rather than in-lined.
- ESLint: Modified the "unused vars" rule so that variables starting with an underline are not
considered by the rule. This allows for elided variables in event handlers. It's not a perfect
solution-- a better one would be to use Typescript's function-specialization typing, but there are
too many places where we elide or ignore some variables in a function's usage that switching over
to specialization would be a huge lift.
- locale: It turns out, lit-locale does its own context management. We don't need to have a context
at all in this space, and that's one less listener we need to attach t othe DOM.
- ModalButton: A small thing, but using `nothing` instead of "html``" allows lit better control over
rendering and reduces the number of actual renders of the page.
- FormGroup: Provided a means to modify the aria-label, rather than stick with the just the word
"Details." Specializing this field will both help users of screen readers in the future, and will
allow test suites to find specific form groups now.
- RadioButton: provide a more consistent interface to the RadioButton. First, we dispatch the
events to the outside world, and we set the value locally so that the current `Form.ts` continues
to behave as expected. We also prevent the "button lost value" event from propagating; this
presents a unified select-like interface to users of the RadioButtonGroup. The current value
semantics are preserved; other clients of the RadioButton do not see a change in behavior.
- EventEmitter: If the custom event detail is *not* an object, do not use the object-like semantics
for forwarding it; just send it as-is.
- Comments: In the course of laying the groundwork for the application wizard, I throw a LOT of
comments into the code, describing APIs, interfaces, class and function signatures, to better
document the behavior inside and as signposts for future work.
* web: permit arrays to be sent in custom events without interpolation.
* actually use assignValue or rather serializeFieldRecursive
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
---------
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
Co-authored-by: Jens Langhammer <jens@goauthentik.io>
2023-10-02 20:33:27 +00:00
|
|
|
import { CSSResult, TemplateResult, css, html, nothing } from "lit";
|
2021-11-04 21:34:48 +00:00
|
|
|
import { customElement, property } from "lit/decorators.js";
|
2021-09-21 09:31:37 +00:00
|
|
|
|
|
|
|
import PFBackdrop from "@patternfly/patternfly/components/Backdrop/backdrop.css";
|
2021-03-17 16:11:39 +00:00
|
|
|
import PFButton from "@patternfly/patternfly/components/Button/button.css";
|
2021-09-21 09:31:37 +00:00
|
|
|
import PFCard from "@patternfly/patternfly/components/Card/card.css";
|
|
|
|
import PFContent from "@patternfly/patternfly/components/Content/content.css";
|
2021-03-17 16:11:39 +00:00
|
|
|
import PFForm from "@patternfly/patternfly/components/Form/form.css";
|
|
|
|
import PFFormControl from "@patternfly/patternfly/components/FormControl/form-control.css";
|
2021-09-21 09:31:37 +00:00
|
|
|
import PFModalBox from "@patternfly/patternfly/components/ModalBox/modal-box.css";
|
2021-03-17 16:11:39 +00:00
|
|
|
import PFPage from "@patternfly/patternfly/components/Page/page.css";
|
2021-04-10 21:27:57 +00:00
|
|
|
import PFTitle from "@patternfly/patternfly/components/Title/title.css";
|
2021-09-21 09:31:37 +00:00
|
|
|
import PFBullseye from "@patternfly/patternfly/layouts/Bullseye/bullseye.css";
|
|
|
|
import PFBase from "@patternfly/patternfly/patternfly-base.css";
|
|
|
|
|
2021-04-10 18:13:35 +00:00
|
|
|
export const MODAL_BUTTON_STYLES = css`
|
|
|
|
:host {
|
|
|
|
text-align: left;
|
|
|
|
font-size: var(--pf-global--FontSize--md);
|
|
|
|
}
|
|
|
|
.pf-c-modal-box > .pf-c-button + * {
|
|
|
|
margin-right: 0;
|
|
|
|
}
|
|
|
|
/* fix multiple selects height */
|
|
|
|
select[multiple] {
|
|
|
|
height: 15em;
|
|
|
|
}
|
|
|
|
`;
|
|
|
|
|
2020-12-05 21:08:42 +00:00
|
|
|
@customElement("ak-modal-button")
|
2022-09-14 22:05:21 +00:00
|
|
|
export class ModalButton extends AKElement {
|
2020-11-20 21:08:00 +00:00
|
|
|
@property()
|
2021-04-04 20:04:46 +00:00
|
|
|
size: PFSize = PFSize.Large;
|
2020-11-20 21:08:00 +00:00
|
|
|
|
2021-08-03 15:52:21 +00:00
|
|
|
@property({ type: Boolean })
|
2020-12-01 08:15:41 +00:00
|
|
|
open = false;
|
2020-11-21 10:28:00 +00:00
|
|
|
|
2021-08-21 17:19:23 +00:00
|
|
|
@property({ type: Boolean })
|
|
|
|
locked = false;
|
|
|
|
|
2021-08-10 21:26:17 +00:00
|
|
|
handlerBound = false;
|
|
|
|
|
2020-12-01 16:27:19 +00:00
|
|
|
static get styles(): CSSResult[] {
|
2021-08-03 15:52:21 +00:00
|
|
|
return [
|
|
|
|
PFBase,
|
|
|
|
PFButton,
|
|
|
|
PFModalBox,
|
|
|
|
PFForm,
|
|
|
|
PFTitle,
|
|
|
|
PFFormControl,
|
|
|
|
PFBullseye,
|
|
|
|
PFBackdrop,
|
|
|
|
PFPage,
|
|
|
|
PFCard,
|
|
|
|
PFContent,
|
|
|
|
MODAL_BUTTON_STYLES,
|
2021-08-21 17:19:23 +00:00
|
|
|
css`
|
|
|
|
.locked {
|
|
|
|
overflow-y: hidden !important;
|
|
|
|
}
|
|
|
|
`,
|
2021-08-03 15:52:21 +00:00
|
|
|
];
|
2020-11-20 21:08:00 +00:00
|
|
|
}
|
|
|
|
|
2021-08-10 22:00:07 +00:00
|
|
|
firstUpdated(): void {
|
2021-08-10 21:26:17 +00:00
|
|
|
if (this.handlerBound) return;
|
2021-08-10 21:22:13 +00:00
|
|
|
window.addEventListener("keyup", this.keyUpHandler);
|
2021-08-10 21:26:17 +00:00
|
|
|
this.handlerBound = true;
|
2021-08-10 21:22:13 +00:00
|
|
|
}
|
|
|
|
|
2021-08-10 21:26:17 +00:00
|
|
|
keyUpHandler = (e: KeyboardEvent): void => {
|
2021-08-10 21:22:13 +00:00
|
|
|
if (e.code === "Escape") {
|
|
|
|
this.resetForms();
|
|
|
|
this.open = false;
|
|
|
|
}
|
2021-08-10 21:26:17 +00:00
|
|
|
};
|
2021-08-10 21:22:13 +00:00
|
|
|
|
|
|
|
disconnectedCallback(): void {
|
2021-08-10 21:26:17 +00:00
|
|
|
super.disconnectedCallback();
|
|
|
|
window.removeEventListener("keyup", this.keyUpHandler);
|
2020-11-21 14:24:45 +00:00
|
|
|
}
|
|
|
|
|
2021-03-29 19:29:27 +00:00
|
|
|
resetForms(): void {
|
2021-08-03 15:52:21 +00:00
|
|
|
this.querySelectorAll<HTMLFormElement>("[slot=form]").forEach((form) => {
|
2021-06-21 20:48:47 +00:00
|
|
|
if ("resetForm" in form) {
|
|
|
|
form?.resetForm();
|
|
|
|
}
|
2021-03-29 19:29:27 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2021-04-03 12:34:46 +00:00
|
|
|
onClick(): void {
|
|
|
|
this.open = true;
|
2021-08-03 15:52:21 +00:00
|
|
|
this.querySelectorAll("*").forEach((child) => {
|
2021-04-03 12:34:46 +00:00
|
|
|
if ("requestUpdate" in child) {
|
2022-09-14 22:05:21 +00:00
|
|
|
(child as AKElement).requestUpdate();
|
2020-12-12 22:45:47 +00:00
|
|
|
}
|
2020-11-26 22:35:59 +00:00
|
|
|
});
|
2020-11-21 10:28:00 +00:00
|
|
|
}
|
|
|
|
|
web: laying the groundwork for future expansion (#7045)
* web: laying the groundwork for future expansion
This commit is a hodge-podge of updates and changes to the web. Functional changes:
- Makefile: Fixed a bug in the `help` section that prevented the WIDTH from being accurately
calculated if `help` was included rather than in-lined.
- ESLint: Modified the "unused vars" rule so that variables starting with an underline are not
considered by the rule. This allows for elided variables in event handlers. It's not a perfect
solution-- a better one would be to use Typescript's function-specialization typing, but there are
too many places where we elide or ignore some variables in a function's usage that switching over
to specialization would be a huge lift.
- locale: It turns out, lit-locale does its own context management. We don't need to have a context
at all in this space, and that's one less listener we need to attach t othe DOM.
- ModalButton: A small thing, but using `nothing` instead of "html``" allows lit better control over
rendering and reduces the number of actual renders of the page.
- FormGroup: Provided a means to modify the aria-label, rather than stick with the just the word
"Details." Specializing this field will both help users of screen readers in the future, and will
allow test suites to find specific form groups now.
- RadioButton: provide a more consistent interface to the RadioButton. First, we dispatch the
events to the outside world, and we set the value locally so that the current `Form.ts` continues
to behave as expected. We also prevent the "button lost value" event from propagating; this
presents a unified select-like interface to users of the RadioButtonGroup. The current value
semantics are preserved; other clients of the RadioButton do not see a change in behavior.
- EventEmitter: If the custom event detail is *not* an object, do not use the object-like semantics
for forwarding it; just send it as-is.
- Comments: In the course of laying the groundwork for the application wizard, I throw a LOT of
comments into the code, describing APIs, interfaces, class and function signatures, to better
document the behavior inside and as signposts for future work.
* web: permit arrays to be sent in custom events without interpolation.
* actually use assignValue or rather serializeFieldRecursive
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
---------
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
Co-authored-by: Jens Langhammer <jens@goauthentik.io>
2023-10-02 20:33:27 +00:00
|
|
|
renderModalInner(): TemplateResult | typeof nothing {
|
2021-08-03 15:52:21 +00:00
|
|
|
return html`<slot name="modal"></slot>`;
|
2021-03-18 00:43:12 +00:00
|
|
|
}
|
|
|
|
|
2020-12-01 16:27:19 +00:00
|
|
|
renderModal(): TemplateResult {
|
2023-02-06 15:47:46 +00:00
|
|
|
return html`<div
|
|
|
|
class="pf-c-backdrop"
|
|
|
|
@click=${(e: PointerEvent) => {
|
|
|
|
e.stopPropagation();
|
|
|
|
}}
|
|
|
|
>
|
2020-11-20 21:08:00 +00:00
|
|
|
<div class="pf-l-bullseye">
|
2021-08-21 17:19:23 +00:00
|
|
|
<div
|
|
|
|
class="pf-c-modal-box ${this.size} ${this.locked ? "locked" : ""}"
|
|
|
|
role="dialog"
|
|
|
|
aria-modal="true"
|
|
|
|
>
|
2020-11-21 19:48:49 +00:00
|
|
|
<button
|
2022-05-31 17:28:18 +00:00
|
|
|
@click=${() => {
|
|
|
|
this.resetForms();
|
|
|
|
this.open = false;
|
|
|
|
}}
|
2020-11-21 19:48:49 +00:00
|
|
|
class="pf-c-button pf-m-plain"
|
|
|
|
type="button"
|
|
|
|
aria-label="Close dialog"
|
|
|
|
>
|
2020-11-21 10:28:00 +00:00
|
|
|
<i class="fas fa-times" aria-hidden="true"></i>
|
|
|
|
</button>
|
2021-03-18 00:43:12 +00:00
|
|
|
${this.renderModalInner()}
|
2020-11-20 21:08:00 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>`;
|
|
|
|
}
|
|
|
|
|
2020-12-01 16:27:19 +00:00
|
|
|
render(): TemplateResult {
|
|
|
|
return html` <slot name="trigger" @click=${() => this.onClick()}></slot>
|
web: laying the groundwork for future expansion (#7045)
* web: laying the groundwork for future expansion
This commit is a hodge-podge of updates and changes to the web. Functional changes:
- Makefile: Fixed a bug in the `help` section that prevented the WIDTH from being accurately
calculated if `help` was included rather than in-lined.
- ESLint: Modified the "unused vars" rule so that variables starting with an underline are not
considered by the rule. This allows for elided variables in event handlers. It's not a perfect
solution-- a better one would be to use Typescript's function-specialization typing, but there are
too many places where we elide or ignore some variables in a function's usage that switching over
to specialization would be a huge lift.
- locale: It turns out, lit-locale does its own context management. We don't need to have a context
at all in this space, and that's one less listener we need to attach t othe DOM.
- ModalButton: A small thing, but using `nothing` instead of "html``" allows lit better control over
rendering and reduces the number of actual renders of the page.
- FormGroup: Provided a means to modify the aria-label, rather than stick with the just the word
"Details." Specializing this field will both help users of screen readers in the future, and will
allow test suites to find specific form groups now.
- RadioButton: provide a more consistent interface to the RadioButton. First, we dispatch the
events to the outside world, and we set the value locally so that the current `Form.ts` continues
to behave as expected. We also prevent the "button lost value" event from propagating; this
presents a unified select-like interface to users of the RadioButtonGroup. The current value
semantics are preserved; other clients of the RadioButton do not see a change in behavior.
- EventEmitter: If the custom event detail is *not* an object, do not use the object-like semantics
for forwarding it; just send it as-is.
- Comments: In the course of laying the groundwork for the application wizard, I throw a LOT of
comments into the code, describing APIs, interfaces, class and function signatures, to better
document the behavior inside and as signposts for future work.
* web: permit arrays to be sent in custom events without interpolation.
* actually use assignValue or rather serializeFieldRecursive
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
---------
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
Co-authored-by: Jens Langhammer <jens@goauthentik.io>
2023-10-02 20:33:27 +00:00
|
|
|
${this.open ? this.renderModal() : nothing}`;
|
2020-11-20 21:08:00 +00:00
|
|
|
}
|
|
|
|
}
|