MapComplete/UI/CenterMessageBox.ts

49 lines
1.5 KiB
TypeScript
Raw Normal View History

2020-07-20 23:43:42 +02:00
import Translations from "./i18n/Translations";
import State from "../State";
2021-06-12 02:58:32 +02:00
import {VariableUiElement} from "./Base/VariableUIElement";
2020-06-24 00:35:19 +02:00
2021-06-12 02:58:32 +02:00
export default class CenterMessageBox extends VariableUiElement {
2020-06-24 00:35:19 +02:00
constructor() {
2021-06-12 02:58:32 +02:00
const state = State.state;
const updater = State.state.layerUpdater;
const t = Translations.t.centerMessage;
const message = updater.runningQuery.map(
isRunning => {
if (isRunning) {
return {el: t.loadingData};
}
if (!updater.sufficientlyZoomed.data) {
return {el: t.zoomIn}
}
if (updater.timeout.data > 0) {
return {el: t.retrying.Subs({count: "" + updater.timeout.data})}
}
return {el: t.ready, isDone: true}
},
[updater.timeout, updater.sufficientlyZoomed, state.locationControl]
)
2021-06-12 02:58:32 +02:00
super(message.map(toShow => toShow.el))
2021-06-12 02:58:32 +02:00
this.SetClass("block " +
"rounded-3xl bg-white text-xl font-bold text-center pointer-events-none p-4")
this.SetStyle("transition: opacity 750ms linear")
message.addCallbackAndRun(toShow => {
const isDone = toShow.isDone ?? false;
if (isDone) {
this.SetStyle("transition: opacity 750ms linear; opacity: 0")
} else {
this.SetStyle("transition: opacity 750ms linear; opacity: 0.75")
}
})
2020-06-24 00:35:19 +02:00
}
}