MapComplete/UI/Base/CheckBox.ts

34 lines
1,023 B
TypeScript
Raw Normal View History

2020-07-20 13:30:58 +02:00
import {UIElement} from "../UIElement";
import {UIEventSource} from "../UIEventSource";
2020-07-20 16:57:46 +02:00
import { FilteredLayer } from "../../Logic/FilteredLayer";
2020-07-22 11:49:01 +02:00
import Translations from "../../UI/i18n/Translations";
2020-07-20 13:30:58 +02:00
export class CheckBox extends UIElement{
2020-07-20 13:37:33 +02:00
private data: UIEventSource<boolean>;
2020-07-20 13:30:58 +02:00
2020-07-22 11:01:25 +02:00
private readonly _data: UIEventSource<boolean>;
private readonly _showEnabled: string|UIElement;
private readonly _showDisabled: string|UIElement;
constructor(data: UIEventSource<boolean>, showEnabled: string|UIElement, showDisabled: string|UIElement) {
2020-07-20 13:30:58 +02:00
super(data);
2020-07-22 11:01:25 +02:00
this._data = data;
this._showEnabled = showEnabled;
this._showDisabled = showDisabled;
this.onClick(() => {
data.setData(!data.data);
})
2020-07-20 13:30:58 +02:00
}
2020-07-22 11:05:04 +02:00
InnerRender(): string {
2020-07-22 11:01:25 +02:00
if (this._data.data) {
2020-07-22 11:49:01 +02:00
return Translations.W(this._showEnabled).Render();
2020-07-22 11:01:25 +02:00
} else {
2020-07-22 11:49:01 +02:00
return Translations.W(this._showDisabled).Render();
2020-07-22 11:01:25 +02:00
}
2020-07-20 13:30:58 +02:00
}
}