forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			124 lines
		
	
	
		
			No EOL
		
	
	
		
			4.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			No EOL
		
	
	
		
			4.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {FixedUiElement} from "./Base/FixedUiElement";
 | |
| import Translations from "./i18n/Translations";
 | |
| import Combine from "./Base/Combine";
 | |
| import Title from "./Base/Title";
 | |
| import Toggleable, {Accordeon} from "./Base/Toggleable";
 | |
| import List from "./Base/List";
 | |
| import BaseUIElement from "./BaseUIElement";
 | |
| import LanguagePicker from "./LanguagePicker";
 | |
| import {SubtleButton} from "./Base/SubtleButton";
 | |
| import Svg from "../Svg";
 | |
| import TableOfContents from "./Base/TableOfContents";
 | |
| 
 | |
| class Snippet extends Toggleable {
 | |
|     constructor(translations, ...extraContent: BaseUIElement[]) {
 | |
|         super(
 | |
|             new Title(translations.title, 3),
 | |
|             new SnippetContent(translations, ...extraContent)
 | |
|         )
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| class SnippetContent extends Combine {
 | |
|     constructor(translations:any, ...extras: BaseUIElement[]) {
 | |
|            super([
 | |
|                 translations.intro,
 | |
|                 new List([
 | |
|                     translations.li0,
 | |
|                     translations.li1,
 | |
|                     translations.li2,
 | |
|                     translations.li3,
 | |
|                     translations.li4,
 | |
|                     translations.li5,
 | |
|                     translations.li6,
 | |
|                 ]),
 | |
|                 translations.outro,
 | |
|                 ...extras
 | |
|             ])
 | |
|             this.SetClass("flex flex-col")
 | |
|     }
 | |
| }
 | |
| 
 | |
| export default class ProfessionalGui {
 | |
| 
 | |
| 
 | |
|     constructor() {
 | |
|         const t = Translations.t.professional
 | |
| 
 | |
| 
 | |
|         const header = new Combine([
 | |
|             new FixedUiElement(`<img class="w-12 h-12 sm:h-24 sm:w-24" src="./assets/svg/logo.svg" alt="MapComplete Logo">`)
 | |
|                 .SetClass("flex-none m-3"),
 | |
|             new Combine([
 | |
|                 new Title(t.title, 1),
 | |
|                 t.intro
 | |
|             ]).SetClass("flex flex-col")
 | |
|         ]).SetClass("flex")
 | |
| 
 | |
|         const content = new Combine([
 | |
|             header,
 | |
|             new Title(t.osmTitle, 2),
 | |
|             t.text0,
 | |
|             t.text1,
 | |
|             new Accordeon([
 | |
|                 new Snippet(t.aboutOsm.aboutOsm),
 | |
|                 new Snippet(t.aboutOsm.benefits),
 | |
|                 new Snippet(t.aboutOsm.license),
 | |
|                 new Snippet(t.aboutOsm.vandalism),
 | |
|             ]).SetClass("flex flex-col"),
 | |
| 
 | |
|             new Title(t.aboutMc.title, 2),
 | |
|             t.aboutMc.text0,
 | |
|             t.aboutMc.text1,
 | |
|             t.aboutMc.text2,
 | |
|             new Accordeon([
 | |
|                 new Snippet(t.aboutMc.layers),
 | |
|                 new Snippet(t.aboutMc.survey),
 | |
|                 new Snippet(t.aboutMc.internalUse),
 | |
|                 new Snippet(t.services)
 | |
|             ]),
 | |
|             new Title(t.drawbacks.title, 2).SetClass("text-2xl"),
 | |
|             t.drawbacks.intro,
 | |
|             new Accordeon([
 | |
|                 new Snippet(t.drawbacks.unsuitedData),
 | |
|                 new Snippet(t.drawbacks.licenseNuances,
 | |
|                    new Title( t.drawbacks.licenseNuances.usecaseMapDifferentSources.title, 4),
 | |
|                     new SnippetContent(t.drawbacks.licenseNuances.usecaseMapDifferentSources),
 | |
|                     new Title( t.drawbacks.licenseNuances.usecaseGatheringOpenData.title, 4),
 | |
|                     new SnippetContent(t.drawbacks.licenseNuances.usecaseGatheringOpenData)
 | |
|                     )
 | |
|             ]),
 | |
| 
 | |
|         ]).SetClass("flex flex-col pb-12 m-3 lg:w-3/4 lg:ml-10 link-underline")
 | |
| 
 | |
| 
 | |
|         const backToIndex = new Combine([new SubtleButton(
 | |
|             Svg.back_svg().SetStyle("height: 1.5rem;"),
 | |
|             t.backToMapcomplete,
 | |
|             {
 | |
|                 url: window.location.host + "/index.html"
 | |
|             }
 | |
|         )]).SetClass("block")
 | |
| 
 | |
|         const leftContents: BaseUIElement[] = [
 | |
|             backToIndex,
 | |
|             new TableOfContents(content, {
 | |
|                 noTopLevel: true,
 | |
|                 maxDepth: 2
 | |
|             }).SetClass("subtle"),
 | |
|             
 | |
|             LanguagePicker.CreateLanguagePicker(Translations.t.professional.title.SupportedLanguages())?.SetClass("mt-4 self-end flex-col"),
 | |
|         ].map(el => el?.SetClass("pl-4"))
 | |
|         const leftBar = new Combine([
 | |
|             new Combine(leftContents).SetClass("sticky top-4 m-4")
 | |
|         ]).SetClass("block w-full md:w-2/6 lg:w-1/6")
 | |
|         new Combine([leftBar, content]).SetClass("block md:flex").AttachTo("main")
 | |
| 
 | |
|     }
 | |
| 
 | |
| 
 | |
| }
 | |
| 
 | |
| new FixedUiElement("").AttachTo("decoration-desktop")
 | |
| new ProfessionalGui() |