forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			55 lines
		
	
	
		
			No EOL
		
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			No EOL
		
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {UIElement} from "../UIElement";
 | |
| import {LicenseInfo, Wikimedia} from "../../Logic/Web/Wikimedia";
 | |
| import {UIEventSource} from "../../Logic/UIEventSource";
 | |
| import Svg from "../../Svg";
 | |
| import Link from "../Base/Link";
 | |
| import {FixedUiElement} from "../Base/FixedUiElement";
 | |
| import Combine from "../Base/Combine";
 | |
| 
 | |
| 
 | |
| export class WikimediaImage extends UIElement {
 | |
| 
 | |
| 
 | |
|     static allLicenseInfos: any = {};
 | |
|     private readonly _imageMeta: UIEventSource<LicenseInfo>;
 | |
|     private readonly _imageLocation: string;
 | |
| 
 | |
|     constructor(source: string) {
 | |
|         super(undefined)
 | |
|         this._imageLocation = source;
 | |
|         if (WikimediaImage.allLicenseInfos[source] !== undefined) {
 | |
|             this._imageMeta = WikimediaImage.allLicenseInfos[source];
 | |
|         } else {
 | |
|             this._imageMeta = new UIEventSource<LicenseInfo>(new LicenseInfo());
 | |
|             WikimediaImage.allLicenseInfos[source] = this._imageMeta;
 | |
|             const self = this;
 | |
|             Wikimedia.LicenseData(source, (info) => {
 | |
|                 self._imageMeta.setData(info);
 | |
|             })
 | |
|         }
 | |
| 
 | |
|         this.ListenTo(this._imageMeta);
 | |
| 
 | |
|       
 | |
|     }
 | |
| 
 | |
|     InnerRender(): string {
 | |
|         let url = Wikimedia.ImageNameToUrl(this._imageLocation, 500, 400);
 | |
|         url = url.replace(/'/g, '%27');
 | |
| 
 | |
|         const wikimediaLink = new Link(Svg.wikimedia_commons_white_img,
 | |
|             `https://commons.wikimedia.org/wiki/${this._imageLocation}`, true)
 | |
|             .SetStyle("width:2em;height: 2em");
 | |
| 
 | |
|         const attribution = new FixedUiElement(this._imageMeta.data.artist ?? "").SetClass("attribution-author");
 | |
|         const license = new FixedUiElement(this._imageMeta.data.licenseShortName ?? "").SetClass("license");
 | |
|         const image = "<img src='" + url + "' " + "alt='" + this._imageMeta.data.description + "' >";
 | |
| 
 | |
|         return "<div class='imgWithAttr'>" +
 | |
|             image +
 | |
|             new Combine([wikimediaLink, attribution]).SetClass("attribution").Render() +
 | |
|             "</div>";
 | |
|     }
 | |
| 
 | |
| 
 | |
| } |