| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  | import {VariableUiElement} from "../Base/VariableUIElement"; | 
					
						
							|  |  |  | import {UIEventSource} from "../../Logic/UIEventSource"; | 
					
						
							|  |  |  | import Wikidata, {WikidataResponse} from "../../Logic/Web/Wikidata"; | 
					
						
							|  |  |  | import {Translation} from "../i18n/Translation"; | 
					
						
							|  |  |  | import {FixedUiElement} from "../Base/FixedUiElement"; | 
					
						
							|  |  |  | import Loading from "../Base/Loading"; | 
					
						
							|  |  |  | import Translations from "../i18n/Translations"; | 
					
						
							|  |  |  | import Combine from "../Base/Combine"; | 
					
						
							|  |  |  | import Img from "../Base/Img"; | 
					
						
							|  |  |  | import {WikimediaImageProvider} from "../../Logic/ImageProviders/WikimediaImageProvider"; | 
					
						
							|  |  |  | import Link from "../Base/Link"; | 
					
						
							|  |  |  | import Svg from "../../Svg"; | 
					
						
							|  |  |  | import BaseUIElement from "../BaseUIElement"; | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  | import {Utils} from "../../Utils"; | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default class WikidataPreviewBox extends VariableUiElement { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |     private static isHuman = [ | 
					
						
							|  |  |  |         {p: 31/*is a*/, q: 5 /* human */}, | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |     // @ts-ignore
 | 
					
						
							|  |  |  |     private static extraProperties: { | 
					
						
							|  |  |  |         requires?: { p: number, q?: number }[], | 
					
						
							|  |  |  |         property: string, | 
					
						
							|  |  |  |         display: Translation | Map<string, string | (() => BaseUIElement) /*If translation: Subs({value: * })  */> | 
					
						
							|  |  |  |     }[] = [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             requires: WikidataPreviewBox.isHuman, | 
					
						
							|  |  |  |             property: "P21", | 
					
						
							|  |  |  |             display: new Map([ | 
					
						
							|  |  |  |                 ['Q6581097', () => Svg.gender_male_ui().SetStyle("width: 1rem; height: auto")], | 
					
						
							|  |  |  |                 ['Q6581072', () => Svg.gender_female_ui().SetStyle("width: 1rem; height: auto")], | 
					
						
							|  |  |  |                 ['Q1097630', () => Svg.gender_inter_ui().SetStyle("width: 1rem; height: auto")], | 
					
						
							|  |  |  |                 ['Q1052281', () => Svg.gender_trans_ui().SetStyle("width: 1rem; height: auto")/*'transwomen'*/], | 
					
						
							|  |  |  |                 ['Q2449503', () => Svg.gender_trans_ui().SetStyle("width: 1rem; height: auto")/*'transmen'*/], | 
					
						
							|  |  |  |                 ['Q48270', () => Svg.gender_queer_ui().SetStyle("width: 1rem; height: auto")] | 
					
						
							|  |  |  |             ]) | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             property: "P569", | 
					
						
							|  |  |  |             requires: WikidataPreviewBox.isHuman, | 
					
						
							|  |  |  |             display: new Translation({ | 
					
						
							|  |  |  |                 "*": "Born: {value}" | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             property: "P570", | 
					
						
							|  |  |  |             requires: WikidataPreviewBox.isHuman, | 
					
						
							|  |  |  |             display: new Translation({ | 
					
						
							|  |  |  |                 "*": "Died: {value}" | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |     constructor(wikidataId: UIEventSource<string>) { | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |         let inited = false; | 
					
						
							|  |  |  |         const wikidata = wikidataId | 
					
						
							|  |  |  |             .stabilized(250) | 
					
						
							|  |  |  |             .bind(id => { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |                 if (id === undefined || id === "" || id === "Q") { | 
					
						
							|  |  |  |                     return null; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 inited = true; | 
					
						
							|  |  |  |                 return Wikidata.LoadWikidataEntry(id) | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |         super(wikidata.map(maybeWikidata => { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |             if (maybeWikidata === null || !inited) { | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |                 return undefined; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             if (maybeWikidata === undefined) { | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |                 return new Loading(Translations.t.general.loading) | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |             if (maybeWikidata["error"] !== undefined) { | 
					
						
							|  |  |  |                 return new FixedUiElement(maybeWikidata["error"]).SetClass("alert") | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |             const wikidata = <WikidataResponse>maybeWikidata["success"] | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |             return WikidataPreviewBox.WikidataResponsePreview(wikidata) | 
					
						
							|  |  |  |         })) | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |     // @ts-ignore
 | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public static WikidataResponsePreview(wikidata: WikidataResponse): BaseUIElement { | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |         let link = new Link( | 
					
						
							|  |  |  |             new Combine([ | 
					
						
							|  |  |  |                 wikidata.id, | 
					
						
							|  |  |  |                 Svg.wikidata_ui().SetStyle("width: 2.5rem").SetClass("block") | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |             ]).SetClass("flex"), | 
					
						
							| 
									
										
										
										
											2021-10-18 22:34:52 +02:00
										 |  |  |             Wikidata.IdToArticle(wikidata.id), true)?.SetClass("must-link") | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         let info = new Combine([ | 
					
						
							|  |  |  |             new Combine( | 
					
						
							| 
									
										
										
										
											2021-10-18 22:34:52 +02:00
										 |  |  |                 [Translation.fromMap(wikidata.labels)?.SetClass("font-bold"), | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |                     link]).SetClass("flex justify-between"), | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |             Translation.fromMap(wikidata.descriptions), | 
					
						
							|  |  |  |             WikidataPreviewBox.QuickFacts(wikidata) | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |         ]).SetClass("flex flex-col link-underline") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         let imageUrl = undefined | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |         if (wikidata.claims.get("P18")?.size > 0) { | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |             imageUrl = Array.from(wikidata.claims.get("P18"))[0] | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |         if (imageUrl) { | 
					
						
							|  |  |  |             imageUrl = WikimediaImageProvider.singleton.PrepUrl(imageUrl).url | 
					
						
							|  |  |  |             info = new Combine([new Img(imageUrl).SetStyle("max-width: 5rem; width: unset; height: 4rem").SetClass("rounded-xl mr-2"), | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  |                 info.SetClass("w-full")]).SetClass("flex") | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         info.SetClass("p-2 w-full") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return info | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public static QuickFacts(wikidata: WikidataResponse): BaseUIElement { | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         const els: BaseUIElement[] = [] | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |         for (const extraProperty of WikidataPreviewBox.extraProperties) { | 
					
						
							| 
									
										
										
										
											2021-10-25 14:02:32 +02:00
										 |  |  |             let hasAllRequirements = true | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |             for (const requirement of extraProperty.requires) { | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |                 if (!wikidata.claims?.has("P" + requirement.p)) { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |                     hasAllRequirements = false; | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |                 if (!wikidata.claims?.get("P" + requirement.p).has("Q" + requirement.q)) { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |                     hasAllRequirements = false; | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |             if (!hasAllRequirements) { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |                 continue | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |             const key = extraProperty.property | 
					
						
							|  |  |  |             const display = extraProperty.display | 
					
						
							|  |  |  |             const value: string[] = Array.from(wikidata.claims.get(key)) | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |             if (value === undefined) { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |                 continue | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |             if (display instanceof Translation) { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |                 els.push(display.Subs({value: value.join(", ")}).SetClass("m-2")) | 
					
						
							|  |  |  |                 continue | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             const constructors = Utils.NoNull(value.map(property => display.get(property))) | 
					
						
							|  |  |  |             const elems = constructors.map(v => { | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |                 if (typeof v === "string") { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |                     return new FixedUiElement(v) | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |                 } else { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |                     return v(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |             els.push(new Combine(elems).SetClass("flex m-2")) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |         if (els.length === 0) { | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |             return undefined; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-18 20:40:24 +02:00
										 |  |  |         return new Combine(els).SetClass("flex") | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-08 04:33:39 +02:00
										 |  |  | } |