Fix listbox didn't have correct sub-element. Fixes placeholder dialogs in Collabora.

This commit is contained in:
nathan 2024-03-06 16:05:02 -07:00
parent 018083dc0e
commit 7112b6a2ba

View File

@ -4,6 +4,8 @@ import shoelace from "../Styles/shoelace";
import {css, html, LitElement, TemplateResult} from "lit";
import {SelectOption} from "./FindSelectOptions";
import {repeat} from "lit/directives/repeat.js";
import {property} from "lit/decorators/property.js";
import {SlMenuItem} from "@shoelace-style/shoelace";
/**
* A selectbox that shows more than one row at a time
@ -56,19 +58,7 @@ export class Et2Listbox extends RowLimitedMixin(Et2WidgetWithSelectMixin(LitElem
];
}
static get properties()
{
return {
...super.properties,
/**
* Toggle between single and multiple selection
*/
multiple: {
type: Boolean,
reflect: true,
}
}
}
@property({type: Boolean, reflect: true}) multiple = false;
private __value : String[] | null;
@ -90,6 +80,11 @@ export class Et2Listbox extends RowLimitedMixin(Et2WidgetWithSelectMixin(LitElem
});
}
private getAllItems() : SlMenuItem[]
{
return <SlMenuItem[]>Array.from(this.shadowRoot?.querySelectorAll('sl-menu-item')) ?? [];
}
/**
* Handle an item was selected
*
@ -118,15 +113,12 @@ export class Et2Listbox extends RowLimitedMixin(Et2WidgetWithSelectMixin(LitElem
this.dispatchEvent(new Event("change"));
}
@property()
get value()
{
let value = [];
if(this.defaultSlot)
{
value = this.getAllItems()
let value = this.hasUpdated ? this.getAllItems()
.filter((item) => item.checked)
.map((item) => item.value);
}
.map((item) => item.value) : this.__value ?? []
return this.multiple ? value : value.pop();
}
@ -154,15 +146,16 @@ export class Et2Listbox extends RowLimitedMixin(Et2WidgetWithSelectMixin(LitElem
// Tag used must match this.optionTag, but you can't use the variable directly.
// Pass option along so SearchMixin can grab it if needed
return html`
<sl-option
<sl-menu-item
value="${option.value}"
title="${!option.title || this.noLang ? option.title : this.egw().lang(option.title)}"
class="${option.class}" .option=${option}
.selected=${checked}
type="checkbox"
?checked=${checked}
>
${icon}
${this.noLang ? option.label : this.egw().lang(option.label)}
</sl-option>`;
</sl-menu-item>`;
}
render()