forked from MapComplete/MapComplete
75 lines
2.6 KiB
TypeScript
75 lines
2.6 KiB
TypeScript
import { FixedUiElement } from "./UI/Base/FixedUiElement"
|
|
import Combine from "./UI/Base/Combine"
|
|
import MinimapImplementation from "./UI/Base/MinimapImplementation"
|
|
import { Utils } from "./Utils"
|
|
import AllThemesGui from "./UI/AllThemesGui"
|
|
import DetermineLayout from "./Logic/DetermineLayout"
|
|
import LayoutConfig from "./Models/ThemeConfig/LayoutConfig"
|
|
import DefaultGUI from "./UI/DefaultGUI"
|
|
import State from "./State"
|
|
import ShowOverlayLayerImplementation from "./UI/ShowDataLayer/ShowOverlayLayerImplementation"
|
|
import { DefaultGuiState } from "./UI/DefaultGuiState"
|
|
import { QueryParameters } from "./Logic/Web/QueryParameters"
|
|
import DashboardGui from "./UI/DashboardGui"
|
|
|
|
// Workaround for a stupid crash: inject some functions which would give stupid circular dependencies or crash the other nodejs scripts running from console
|
|
MinimapImplementation.initialize()
|
|
ShowOverlayLayerImplementation.Implement()
|
|
// Miscelleanous
|
|
Utils.DisableLongPresses()
|
|
|
|
class Init {
|
|
public static Init(layoutToUse: LayoutConfig) {
|
|
if (layoutToUse === null) {
|
|
// Something went wrong, error message is already on screen
|
|
return
|
|
}
|
|
|
|
if (layoutToUse === undefined) {
|
|
// No layout found
|
|
new AllThemesGui().setup()
|
|
return
|
|
}
|
|
|
|
const guiState = new DefaultGuiState()
|
|
State.state = new State(layoutToUse)
|
|
DefaultGuiState.state = guiState
|
|
// This 'leaks' the global state via the window object, useful for debugging
|
|
// @ts-ignore
|
|
window.mapcomplete_state = State.state
|
|
|
|
const mode = QueryParameters.GetQueryParameter(
|
|
"mode",
|
|
"map",
|
|
"The mode the application starts in, e.g. 'map', 'dashboard' or 'statistics'"
|
|
)
|
|
if (mode.data === "dashboard") {
|
|
new DashboardGui(State.state, guiState).setup()
|
|
} else {
|
|
new DefaultGUI(State.state, guiState).setup()
|
|
}
|
|
}
|
|
}
|
|
|
|
document.getElementById("decoration-desktop").remove()
|
|
new Combine([
|
|
"Initializing... <br/>",
|
|
new FixedUiElement(
|
|
"<a>If this message persist, something went wrong - click here to try again</a>"
|
|
)
|
|
.SetClass("link-underline small")
|
|
.onClick(() => {
|
|
localStorage.clear()
|
|
window.location.reload()
|
|
}),
|
|
]).AttachTo("centermessage") // Add an initialization and reset button if something goes wrong
|
|
|
|
// @ts-ignore
|
|
DetermineLayout.GetLayout()
|
|
.then((value) => {
|
|
console.log("Got ", value)
|
|
Init.Init(value)
|
|
})
|
|
.catch((err) => {
|
|
console.error("Error while initializing: ", err, err.stack)
|
|
})
|