forked from MapComplete/MapComplete
42 lines
No EOL
1.3 KiB
TypeScript
42 lines
No EOL
1.3 KiB
TypeScript
import {UIEventSource} from "../../Logic/UIEventSource";
|
|
import BaseUIElement from "../BaseUIElement";
|
|
|
|
export class SlideShow extends BaseUIElement {
|
|
|
|
|
|
private readonly embeddedElements: UIEventSource<BaseUIElement[]>;
|
|
|
|
constructor(embeddedElements: UIEventSource<BaseUIElement[]>) {
|
|
super()
|
|
this.embeddedElements = embeddedElements;
|
|
}
|
|
|
|
protected InnerConstructElement(): HTMLElement {
|
|
const el = document.createElement("div")
|
|
el.classList.add("slic-carousel")
|
|
el.style.overflowX = "auto"
|
|
el.style.width = "min-content"
|
|
el.style.minWidth = "min-content"
|
|
el.style.display = "flex"
|
|
|
|
this.embeddedElements.addCallbackAndRun(elements => {
|
|
while (el.firstChild) {
|
|
el.removeChild(el.lastChild)
|
|
}
|
|
|
|
for (const element of elements ?? []) {
|
|
element.SetClass("block ml-1")
|
|
.SetStyle("width: 300px; max-height: var(--image-carousel-height); height: var(--image-carousel-height)")
|
|
|
|
el.appendChild(element.ConstructElement())
|
|
}
|
|
});
|
|
|
|
const wrapper = document.createElement("div")
|
|
wrapper.style.maxWidth = "100%"
|
|
wrapper.style.overflowX = "auto"
|
|
wrapper.appendChild(el)
|
|
return wrapper;
|
|
}
|
|
|
|
} |