forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			43 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import Translations from "./i18n/Translations"
 | |
| import { VariableUiElement } from "./Base/VariableUIElement"
 | |
| import FeaturePipelineState from "../Logic/State/FeaturePipelineState"
 | |
| import Loading from "./Base/Loading"
 | |
| 
 | |
| export default class CenterMessageBox extends VariableUiElement {
 | |
|     constructor(state: FeaturePipelineState) {
 | |
|         const updater = state.featurePipeline
 | |
|         const t = Translations.t.centerMessage
 | |
|         const message = updater.runningQuery.map(
 | |
|             (isRunning) => {
 | |
|                 if (isRunning) {
 | |
|                     return { el: new Loading(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]
 | |
|         )
 | |
| 
 | |
|         super(message.map((toShow) => toShow.el))
 | |
| 
 | |
|         this.SetClass(
 | |
|             "flex justify-center " +
 | |
|                 "rounded-3xl bg-white text-xl font-bold 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")
 | |
|             }
 | |
|         })
 | |
|     }
 | |
| }
 |