MapComplete/UI/Base/Ornament.ts

34 lines
962 B
TypeScript
Raw Normal View History

2021-01-07 04:50:12 +01:00
import {UIElement} from "../UIElement";
import {UIEventSource} from "../../Logic/UIEventSource";
import Svg from "../../Svg";
export default class Ornament extends UIElement {
private static readonly ornamentsCount = Ornament.countOrnaments();
private readonly _index = new UIEventSource<number>(0)
constructor(index = new UIEventSource<number>(0)) {
super(index);
this._index = index;
this.SetClass("ornament")
const self = this;
this.onClick(() => {
self._index.setData((self._index.data + 1) % Ornament.ornamentsCount);
})
}
private static countOrnaments() {
let ornamentCount = 0;
for (const key in Svg.All) {
if (key.startsWith("Ornament-Horiz-")) {
ornamentCount++;
}
}
return ornamentCount;
}
InnerRender(): string {
return Svg.All[`Ornament-Horiz-${this._index.data}.svg`]
}
}