forked from MapComplete/MapComplete
		
	
		
			
	
	
		
			53 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			53 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| 
								 | 
							
								import {UIEventSource} from "../Logic/UIEventSource";
							 | 
						||
| 
								 | 
							
								import {VariableUiElement} from "./Base/VariableUIElement";
							 | 
						||
| 
								 | 
							
								import Wikipedia from "../Logic/Web/Wikipedia";
							 | 
						||
| 
								 | 
							
								import Loading from "./Base/Loading";
							 | 
						||
| 
								 | 
							
								import {FixedUiElement} from "./Base/FixedUiElement";
							 | 
						||
| 
								 | 
							
								import Combine from "./Base/Combine";
							 | 
						||
| 
								 | 
							
								import BaseUIElement from "./BaseUIElement";
							 | 
						||
| 
								 | 
							
								import Title from "./Base/Title";
							 | 
						||
| 
								 | 
							
								import Translations from "./i18n/Translations";
							 | 
						||
| 
								 | 
							
								import Svg from "../Svg";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								export default class WikipediaBox extends Combine{
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    constructor(options: {
							 | 
						||
| 
								 | 
							
								        pagename: string,
							 | 
						||
| 
								 | 
							
								        language: string
							 | 
						||
| 
								 | 
							
								    }) {
							 | 
						||
| 
								 | 
							
								        
							 | 
						||
| 
								 | 
							
								        const htmlContent = UIEventSource.FromPromiseWithErr(Wikipedia.GetArticle({
							 | 
						||
| 
								 | 
							
								            pageName: options.pagename,
							 | 
						||
| 
								 | 
							
								            language: options.language,
							 | 
						||
| 
								 | 
							
								            removeInfoBoxes: true
							 | 
						||
| 
								 | 
							
								        }))
							 | 
						||
| 
								 | 
							
								        
							 | 
						||
| 
								 | 
							
								        const contents : UIEventSource<string | BaseUIElement> = htmlContent.map(htmlContent => {
							 | 
						||
| 
								 | 
							
								            if(htmlContent === undefined){
							 | 
						||
| 
								 | 
							
								                // Still loading
							 | 
						||
| 
								 | 
							
								                return new Loading("Loading wikipedia page").SetClass("p-4")
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								            if(htmlContent["success"] !== undefined){
							 | 
						||
| 
								 | 
							
								                return new FixedUiElement(htmlContent["success"]).SetClass("wikipedia-article")
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								            if(htmlContent["error"]){
							 | 
						||
| 
								 | 
							
								                return new FixedUiElement(htmlContent["error"]).SetClass("alert p-4")
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								            
							 | 
						||
| 
								 | 
							
								            return undefined
							 | 
						||
| 
								 | 
							
								            
							 | 
						||
| 
								 | 
							
								        })
							 | 
						||
| 
								 | 
							
								        
							 | 
						||
| 
								 | 
							
								        const scrollable = new Combine([new VariableUiElement(contents).SetClass("block pl-6 pt-2")])
							 | 
						||
| 
								 | 
							
								            .SetClass("block overflow-auto normal-background rounded-lg")
							 | 
						||
| 
								 | 
							
								        super([
							 | 
						||
| 
								 | 
							
								            new Combine([Svg.wikipedia_svg().SetStyle("width: 1.5rem").SetClass("mr-3"), 
							 | 
						||
| 
								 | 
							
								                new Title(Translations.t.general.wikipedia.wikipediaboxTitle, 2)]).SetClass("flex"),
							 | 
						||
| 
								 | 
							
								            scrollable])
							 | 
						||
| 
								 | 
							
								        
							 | 
						||
| 
								 | 
							
								        this
							 | 
						||
| 
								 | 
							
								            .SetClass("block rounded-xl subtle-background m-1 p-2 flex flex-col")
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								}
							 |