MapComplete/UI/AllThemesGui.ts

71 lines
3.1 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import UserRelatedState from "../Logic/State/UserRelatedState"
import { FixedUiElement } from "./Base/FixedUiElement"
import Combine from "./Base/Combine"
import MoreScreen from "./BigComponents/MoreScreen"
import Translations from "./i18n/Translations"
import Constants from "../Models/Constants"
import { Utils } from "../Utils"
import LanguagePicker1 from "./LanguagePicker"
import IndexText from "./BigComponents/IndexText"
import FeaturedMessage from "./BigComponents/FeaturedMessage"
import Toggle from "./Input/Toggle"
import { SubtleButton } from "./Base/SubtleButton"
import { VariableUiElement } from "./Base/VariableUIElement"
import Svg from "../Svg"
export default class AllThemesGui {
2022-04-08 04:36:00 +02:00
setup() {
2021-11-07 16:34:51 +01:00
try {
new FixedUiElement("").AttachTo("centermessage")
2022-09-08 21:40:48 +02:00
const state = new UserRelatedState(undefined)
2021-11-07 16:34:51 +01:00
const intro = new Combine([
2022-09-08 21:40:48 +02:00
new LanguagePicker1(Translations.t.index.title.SupportedLanguages(), "").SetClass(
"flex absolute top-2 right-3"
),
new IndexText(),
])
2021-11-07 16:34:51 +01:00
new Combine([
intro,
2022-01-25 21:55:51 +01:00
new FeaturedMessage().SetClass("mb-4 block"),
2021-11-07 16:34:51 +01:00
new MoreScreen(state, true),
new Toggle(
undefined,
2022-09-08 21:40:48 +02:00
new SubtleButton(undefined, Translations.t.index.logIn)
.SetStyle("height:min-content")
.onClick(() => state.osmConnection.AttemptLogin()),
state.osmConnection.isLoggedIn
),
new VariableUiElement(
state.osmConnection.userDetails.map((ud) => {
if (ud.csCount < Constants.userJourney.importHelperUnlock) {
return undefined
}
return new Combine([
new SubtleButton(undefined, Translations.t.importHelper.title, {
url: "import_helper.html",
}),
new SubtleButton(Svg.note_svg(), Translations.t.importInspector.title, {
url: "import_viewer.html",
}),
]).SetClass("p-4 border-2 border-gray-500 m-4 block")
})
),
2021-11-07 16:34:51 +01:00
Translations.t.general.aboutMapcomplete
2022-09-08 21:40:48 +02:00
.Subs({ osmcha_link: Utils.OsmChaLinkFor(7) })
2021-11-07 16:34:51 +01:00
.SetClass("link-underline"),
2022-09-08 21:40:48 +02:00
new FixedUiElement("v" + Constants.vNumber),
])
.SetClass("block m-5 lg:w-3/4 lg:ml-40")
2021-11-07 16:34:51 +01:00
.SetStyle("pointer-events: all;")
2022-09-08 21:40:48 +02:00
.AttachTo("topleft-tools")
2021-11-07 16:34:51 +01:00
} catch (e) {
2021-12-21 18:35:31 +01:00
console.error(">>>> CRITICAL", e)
2022-09-08 21:40:48 +02:00
new FixedUiElement(
"Seems like no layers are compiled - check the output of `npm run generate:layeroverview`. Is this visible online? Contact pietervdvn immediately!"
)
.SetClass("alert")
.AttachTo("centermessage")
}
}
}