2020-06-24 00:35:19 +02:00
|
|
|
import {UIElement} from "./UIElement";
|
2020-07-20 23:43:42 +02:00
|
|
|
import Translations from "./i18n/Translations";
|
2020-10-02 19:00:24 +02:00
|
|
|
import State from "../State";
|
2020-06-24 00:35:19 +02:00
|
|
|
|
2021-01-04 04:06:21 +01:00
|
|
|
export default class CenterMessageBox extends UIElement {
|
2020-06-24 00:35:19 +02:00
|
|
|
|
2021-01-04 04:06:21 +01:00
|
|
|
constructor() {
|
2020-07-31 01:45:54 +02:00
|
|
|
super(State.state.centerMessage);
|
2020-06-24 00:35:19 +02:00
|
|
|
|
2020-07-31 01:45:54 +02:00
|
|
|
this.ListenTo(State.state.locationControl);
|
2021-02-20 01:45:51 +01:00
|
|
|
this.ListenTo(State.state.layerUpdater.timeout);
|
2020-07-31 16:17:16 +02:00
|
|
|
this.ListenTo(State.state.layerUpdater.runningQuery);
|
2021-01-02 16:04:16 +01:00
|
|
|
this.ListenTo(State.state.layerUpdater.sufficientlyZoomed);
|
2020-06-24 00:35:19 +02:00
|
|
|
}
|
|
|
|
|
2021-06-10 01:36:20 +02:00
|
|
|
private static prep(): { innerHtml: string | UIElement, done: boolean } {
|
2020-07-31 01:45:54 +02:00
|
|
|
if (State.state.centerMessage.data != "") {
|
|
|
|
return {innerHtml: State.state.centerMessage.data, done: false};
|
2020-06-24 00:35:19 +02:00
|
|
|
}
|
2020-07-31 16:17:16 +02:00
|
|
|
const lu = State.state.layerUpdater;
|
2021-02-20 01:45:51 +01:00
|
|
|
if (lu.timeout.data > 0) {
|
2021-01-04 04:06:21 +01:00
|
|
|
return {
|
2021-06-10 01:36:20 +02:00
|
|
|
innerHtml: Translations.t.centerMessage.retrying.Subs({count: "" + lu.timeout.data}),
|
2021-01-04 04:06:21 +01:00
|
|
|
done: false
|
|
|
|
};
|
2020-07-31 16:17:16 +02:00
|
|
|
}
|
2021-01-04 04:06:21 +01:00
|
|
|
|
2020-07-31 16:17:16 +02:00
|
|
|
if (lu.runningQuery.data) {
|
2021-06-10 01:36:20 +02:00
|
|
|
return {innerHtml: Translations.t.centerMessage.loadingData, done: false};
|
2021-01-04 04:06:21 +01:00
|
|
|
|
|
|
|
}
|
2021-01-02 16:04:16 +01:00
|
|
|
if (!lu.sufficientlyZoomed.data) {
|
2021-06-10 01:36:20 +02:00
|
|
|
return {innerHtml: Translations.t.centerMessage.zoomIn, done: false};
|
2020-07-31 01:45:54 +02:00
|
|
|
} else {
|
2021-06-10 01:36:20 +02:00
|
|
|
return {innerHtml: Translations.t.centerMessage.ready, done: true};
|
2020-06-24 00:35:19 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-10 01:36:20 +02:00
|
|
|
InnerRender(): string | UIElement {
|
2020-09-25 12:44:04 +02:00
|
|
|
return CenterMessageBox.prep().innerHtml;
|
2020-06-24 00:35:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
InnerUpdate(htmlElement: HTMLElement) {
|
2021-06-10 01:36:20 +02:00
|
|
|
if(htmlElement.parentElement === null){
|
|
|
|
return;
|
|
|
|
}
|
2020-06-24 00:35:19 +02:00
|
|
|
const pstyle = htmlElement.parentElement.style;
|
2020-07-31 01:45:54 +02:00
|
|
|
if (State.state.centerMessage.data != "") {
|
2020-06-24 00:35:19 +02:00
|
|
|
pstyle.opacity = "1";
|
|
|
|
pstyle.pointerEvents = "all";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
pstyle.pointerEvents = "none";
|
|
|
|
|
2020-09-25 12:44:04 +02:00
|
|
|
if (CenterMessageBox.prep().done) {
|
2020-06-24 00:35:19 +02:00
|
|
|
pstyle.opacity = "0";
|
2020-07-31 01:45:54 +02:00
|
|
|
} else {
|
|
|
|
pstyle.opacity = "0.5";
|
2020-06-24 00:35:19 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|