web/elements: fix click propagation from modal into table
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
This commit is contained in:
parent
b3323c5d00
commit
1919a9dd77
|
@ -107,7 +107,12 @@ export class ModalButton extends AKElement {
|
|||
}
|
||||
|
||||
renderModal(): TemplateResult {
|
||||
return html`<div class="pf-c-backdrop">
|
||||
return html`<div
|
||||
class="pf-c-backdrop"
|
||||
@click=${(e: PointerEvent) => {
|
||||
e.stopPropagation();
|
||||
}}
|
||||
>
|
||||
<div class="pf-l-bullseye">
|
||||
<div
|
||||
class="pf-c-modal-box ${this.size} ${this.locked ? "locked" : ""}"
|
||||
|
|
|
@ -294,17 +294,9 @@ export abstract class Table<T> extends AKElement {
|
|||
return items.map((item) => {
|
||||
const itemSelectHandler = (ev?: InputEvent | PointerEvent) => {
|
||||
let checked = false;
|
||||
if (ev) {
|
||||
// Only register click events on a table row
|
||||
if (ev instanceof PointerEvent) {
|
||||
if ((ev.target as HTMLInputElement).tagName.toLowerCase() != "tr") {
|
||||
return;
|
||||
}
|
||||
} else if (ev instanceof InputEvent) {
|
||||
checked = (ev.target as HTMLInputElement).checked;
|
||||
}
|
||||
} else {
|
||||
// If we have no event, toggle the state
|
||||
if (ev instanceof InputEvent) {
|
||||
checked = (ev.target as HTMLInputElement).checked;
|
||||
} else if (ev instanceof PointerEvent) {
|
||||
checked = this.selectedElements.indexOf(item) === -1;
|
||||
}
|
||||
if (checked) {
|
||||
|
|
|
@ -67,7 +67,12 @@ export abstract class TableModal<T> extends Table<T> {
|
|||
}
|
||||
|
||||
renderModal(): TemplateResult {
|
||||
return html`<div class="pf-c-backdrop">
|
||||
return html`<div
|
||||
class="pf-c-backdrop"
|
||||
@click=${(e: PointerEvent) => {
|
||||
e.stopPropagation();
|
||||
}}
|
||||
>
|
||||
<div class="pf-l-bullseye">
|
||||
<div class="pf-c-modal-box ${this.size}" role="dialog" aria-modal="true">
|
||||
<button
|
||||
|
|
Reference in a new issue