forked from MapComplete/MapComplete
140 lines
5.4 KiB
TypeScript
140 lines
5.4 KiB
TypeScript
import ThemeIntroductionPanel from "./ThemeIntroductionPanel"
|
|
import Svg from "../../Svg"
|
|
import Translations from "../i18n/Translations"
|
|
import ShareScreen from "./ShareScreen"
|
|
import MoreScreen from "./MoreScreen"
|
|
import Constants from "../../Models/Constants"
|
|
import Combine from "../Base/Combine"
|
|
import { TabbedComponent } from "../Base/TabbedComponent"
|
|
import { UIEventSource } from "../../Logic/UIEventSource"
|
|
import UserDetails, { OsmConnection } from "../../Logic/Osm/OsmConnection"
|
|
import ScrollableFullScreen from "../Base/ScrollableFullScreen"
|
|
import BaseUIElement from "../BaseUIElement"
|
|
import Toggle from "../Input/Toggle"
|
|
import LayoutConfig from "../../Models/ThemeConfig/LayoutConfig"
|
|
import { Utils } from "../../Utils"
|
|
import UserRelatedState from "../../Logic/State/UserRelatedState"
|
|
import Loc from "../../Models/Loc"
|
|
import BaseLayer from "../../Models/BaseLayer"
|
|
import FilteredLayer from "../../Models/FilteredLayer"
|
|
import FeaturePipeline from "../../Logic/FeatureSource/FeaturePipeline"
|
|
import PrivacyPolicy from "./PrivacyPolicy"
|
|
import Hotkeys from "../Base/Hotkeys"
|
|
|
|
export default class FullWelcomePaneWithTabs extends ScrollableFullScreen {
|
|
public static MoreThemesTabIndex = 1
|
|
|
|
constructor(
|
|
isShown: UIEventSource<boolean>,
|
|
currentTab: UIEventSource<number>,
|
|
state: {
|
|
layoutToUse: LayoutConfig
|
|
osmConnection: OsmConnection
|
|
featureSwitchShareScreen: UIEventSource<boolean>
|
|
featureSwitchMoreQuests: UIEventSource<boolean>
|
|
locationControl: UIEventSource<Loc>
|
|
featurePipeline: FeaturePipeline
|
|
backgroundLayer: UIEventSource<BaseLayer>
|
|
filteredLayers: UIEventSource<FilteredLayer[]>
|
|
} & UserRelatedState,
|
|
guistate?: { userInfoIsOpened: UIEventSource<boolean> }
|
|
) {
|
|
const layoutToUse = state.layoutToUse
|
|
super(
|
|
() => layoutToUse.title.Clone(),
|
|
() => FullWelcomePaneWithTabs.GenerateContents(state, currentTab, isShown, guistate),
|
|
"welcome",
|
|
isShown
|
|
)
|
|
}
|
|
|
|
private static ConstructBaseTabs(
|
|
state: {
|
|
layoutToUse: LayoutConfig
|
|
osmConnection: OsmConnection
|
|
featureSwitchShareScreen: UIEventSource<boolean>
|
|
featureSwitchMoreQuests: UIEventSource<boolean>
|
|
featurePipeline: FeaturePipeline
|
|
locationControl: UIEventSource<Loc>
|
|
backgroundLayer: UIEventSource<BaseLayer>
|
|
filteredLayers: UIEventSource<FilteredLayer[]>
|
|
} & UserRelatedState,
|
|
isShown: UIEventSource<boolean>,
|
|
currentTab: UIEventSource<number>,
|
|
guistate?: { userInfoIsOpened: UIEventSource<boolean> }
|
|
): { header: string | BaseUIElement; content: BaseUIElement }[] {
|
|
const tabs: { header: string | BaseUIElement; content: BaseUIElement }[] = [
|
|
{
|
|
header: `<img src='${state.layoutToUse.icon}'>`,
|
|
content: new ThemeIntroductionPanel(isShown, currentTab, state, guistate),
|
|
},
|
|
]
|
|
|
|
if (state.featureSwitchMoreQuests.data) {
|
|
tabs.push({
|
|
header: Svg.add_img,
|
|
content: new Combine([
|
|
Translations.t.general.morescreen.intro,
|
|
new MoreScreen(state),
|
|
]).SetClass("flex flex-col"),
|
|
})
|
|
}
|
|
|
|
if (state.featureSwitchShareScreen.data) {
|
|
tabs.push({ header: Svg.share_img, content: new ShareScreen(state) })
|
|
}
|
|
|
|
const privacy = {
|
|
header: Svg.eye_svg(),
|
|
content: new PrivacyPolicy(),
|
|
}
|
|
tabs.push(privacy)
|
|
|
|
return tabs
|
|
}
|
|
|
|
private static GenerateContents(
|
|
state: {
|
|
layoutToUse: LayoutConfig
|
|
osmConnection: OsmConnection
|
|
featureSwitchShareScreen: UIEventSource<boolean>
|
|
featureSwitchMoreQuests: UIEventSource<boolean>
|
|
featurePipeline: FeaturePipeline
|
|
locationControl: UIEventSource<Loc>
|
|
backgroundLayer: UIEventSource<BaseLayer>
|
|
filteredLayers: UIEventSource<FilteredLayer[]>
|
|
} & UserRelatedState,
|
|
currentTab: UIEventSource<number>,
|
|
isShown: UIEventSource<boolean>,
|
|
guistate?: { userInfoIsOpened: UIEventSource<boolean> }
|
|
) {
|
|
const tabs = FullWelcomePaneWithTabs.ConstructBaseTabs(state, isShown, currentTab, guistate)
|
|
const tabsWithAboutMc = [
|
|
...FullWelcomePaneWithTabs.ConstructBaseTabs(state, isShown, currentTab, guistate),
|
|
]
|
|
|
|
tabsWithAboutMc.push({
|
|
header: Svg.help,
|
|
content: new Combine([
|
|
Translations.t.general.aboutMapcomplete.Subs({
|
|
osmcha_link: Utils.OsmChaLinkFor(7),
|
|
}),
|
|
"<br/>Version " + Constants.vNumber,
|
|
Hotkeys.generateDocumentationDynamic(),
|
|
]).SetClass("link-underline"),
|
|
})
|
|
|
|
tabs.forEach((c) => c.content.SetClass("p-4"))
|
|
tabsWithAboutMc.forEach((c) => c.content.SetClass("p-4"))
|
|
|
|
return new Toggle(
|
|
new TabbedComponent(tabsWithAboutMc, currentTab),
|
|
new TabbedComponent(tabs, currentTab),
|
|
state.osmConnection.userDetails.map(
|
|
(userdetails: UserDetails) =>
|
|
userdetails.loggedIn &&
|
|
userdetails.csCount >= Constants.userJourney.mapCompleteHelpUnlock
|
|
)
|
|
)
|
|
}
|
|
}
|