| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  | import Combine from "../Base/Combine"; | 
					
						
							|  |  |  | import Toggle from "../Input/Toggle"; | 
					
						
							|  |  |  | import LanguagePicker from "../LanguagePicker"; | 
					
						
							|  |  |  | import BackToIndex from "../BigComponents/BackToIndex"; | 
					
						
							|  |  |  | import UserRelatedState from "../../Logic/State/UserRelatedState"; | 
					
						
							|  |  |  | import BaseUIElement from "../BaseUIElement"; | 
					
						
							|  |  |  | import MinimapImplementation from "../Base/MinimapImplementation"; | 
					
						
							|  |  |  | import Translations from "../i18n/Translations"; | 
					
						
							| 
									
										
										
										
											2022-01-21 01:57:16 +01:00
										 |  |  | import {FlowPanelFactory} from "./FlowStep"; | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  | import {RequestFile} from "./RequestFile"; | 
					
						
							| 
									
										
										
										
											2022-01-22 02:56:35 +01:00
										 |  |  | import {PreviewPanel} from "./PreviewPanel"; | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  | import ConflationChecker from "./ConflationChecker"; | 
					
						
							| 
									
										
										
										
											2022-01-21 01:57:16 +01:00
										 |  |  | import {AskMetadata} from "./AskMetadata"; | 
					
						
							|  |  |  | import LayerConfig from "../../Models/ThemeConfig/LayerConfig"; | 
					
						
							|  |  |  | import {ConfirmProcess} from "./ConfirmProcess"; | 
					
						
							|  |  |  | import {CreateNotes} from "./CreateNotes"; | 
					
						
							|  |  |  | import {FixedUiElement} from "../Base/FixedUiElement"; | 
					
						
							|  |  |  | import {VariableUiElement} from "../Base/VariableUIElement"; | 
					
						
							|  |  |  | import List from "../Base/List"; | 
					
						
							|  |  |  | import {CompareToAlreadyExistingNotes} from "./CompareToAlreadyExistingNotes"; | 
					
						
							| 
									
										
										
										
											2022-01-22 02:56:35 +01:00
										 |  |  | import Introdution from "./Introdution"; | 
					
						
							|  |  |  | import LoginToImport from "./LoginToImport"; | 
					
						
							|  |  |  | import {MapPreview} from "./MapPreview"; | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-22 02:56:35 +01:00
										 |  |  | export default class ImportHelperGui extends Combine { | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  |     constructor() { | 
					
						
							|  |  |  |         const t = Translations.t.importHelper; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const state = new UserRelatedState(undefined) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // We disable the userbadge, as various 'showData'-layers will give a read-only view in this case
 | 
					
						
							|  |  |  |         state.featureSwitchUserbadge.setData(false) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-21 01:57:16 +01:00
										 |  |  |         const {flow, furthestStep, titles} = | 
					
						
							|  |  |  |             FlowPanelFactory | 
					
						
							| 
									
										
										
										
											2022-01-22 02:56:35 +01:00
										 |  |  |                 .start("Introduction", new Introdution()) | 
					
						
							|  |  |  |                 .then("Login", _ => new LoginToImport(state)) | 
					
						
							|  |  |  |                 .then("Select file", _ => new RequestFile()) | 
					
						
							|  |  |  |                 .then("Inspect attributes", geojson => new PreviewPanel(state, geojson)) | 
					
						
							|  |  |  |                 .then("Inspect data", geojson => new MapPreview(state, geojson)) | 
					
						
							| 
									
										
										
										
											2022-01-21 01:57:16 +01:00
										 |  |  |                 .then("Compare with open notes", v => new CompareToAlreadyExistingNotes(state, v)) | 
					
						
							|  |  |  |                 .then("Compare with existing data", v => new ConflationChecker(state, v)) | 
					
						
							|  |  |  |                 .then("License and community check", v => new ConfirmProcess(v)) | 
					
						
							|  |  |  |                 .then("Metadata", (v:{features:any[], layer: LayerConfig}) => new AskMetadata(v)) | 
					
						
							|  |  |  |                 .finish("Note creation", v => new CreateNotes(state, v)); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         const toc = new List( | 
					
						
							|  |  |  |             titles.map((title, i) => new VariableUiElement(furthestStep.map(currentStep => { | 
					
						
							|  |  |  |                 if(i > currentStep){ | 
					
						
							|  |  |  |                     return new Combine([title]).SetClass("subtle"); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 if(i == currentStep){ | 
					
						
							|  |  |  |                     return new Combine([title]).SetClass("font-bold"); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 if(i < currentStep){ | 
					
						
							|  |  |  |                     return title | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                  | 
					
						
							|  |  |  |                  | 
					
						
							|  |  |  |             }))) | 
					
						
							|  |  |  |             , true) | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  |         const leftContents: BaseUIElement[] = [ | 
					
						
							|  |  |  |             new BackToIndex().SetClass("block pl-4"), | 
					
						
							| 
									
										
										
										
											2022-01-21 01:57:16 +01:00
										 |  |  |             toc, | 
					
						
							|  |  |  |             new Toggle(new FixedUiElement("Testmode - won't actually import notes").SetClass("alert"), undefined, state.featureSwitchIsTesting), | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  |             LanguagePicker.CreateLanguagePicker(Translations.t.importHelper.title.SupportedLanguages())?.SetClass("mt-4 self-end flex-col"), | 
					
						
							|  |  |  |         ].map(el => el?.SetClass("pl-4")) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const leftBar = new Combine([ | 
					
						
							| 
									
										
										
										
											2022-01-21 01:57:16 +01:00
										 |  |  |             new Combine(leftContents).SetClass("sticky top-4 m-4"), | 
					
						
							|  |  |  |           ]).SetClass("block w-full md:w-2/6 lg:w-1/6") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-22 02:56:35 +01:00
										 |  |  |         super([ | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  |                 new Combine([ | 
					
						
							|  |  |  |                     leftBar, | 
					
						
							| 
									
										
										
										
											2022-01-21 01:57:16 +01:00
										 |  |  |                     flow.SetClass("m-8 w-full mb-24") | 
					
						
							| 
									
										
										
										
											2022-01-22 02:56:35 +01:00
										 |  |  |                 ]).SetClass("h-full block md:flex")]) | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MinimapImplementation.initialize() | 
					
						
							|  |  |  | new ImportHelperGui().AttachTo("main") |