forked from MapComplete/MapComplete
		
	
		
			
	
	
		
			54 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			54 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
|  | import {UIEventSource} from "../UIEventSource"; | ||
|  | import {UIElement} from "../UIElement"; | ||
|  | import {LicenseInfo} from "../../Logic/Wikimedia"; | ||
|  | import {Imgur} from "../../Logic/Imgur"; | ||
|  | 
 | ||
|  | 
 | ||
|  | export class ImgurImage extends UIElement { | ||
|  | 
 | ||
|  | 
 | ||
|  |     /*** | ||
|  |      * Dictionary from url to alreayd known license info | ||
|  |      */ | ||
|  |     static allLicenseInfos: any = {}; | ||
|  |     private _imageMeta: UIEventSource<LicenseInfo>; | ||
|  |     private _imageLocation: string; | ||
|  | 
 | ||
|  |     constructor(source: string) { | ||
|  |         super(undefined) | ||
|  |         this._imageLocation = source; | ||
|  |         if (ImgurImage.allLicenseInfos[source] !== undefined) { | ||
|  |             this._imageMeta = ImgurImage.allLicenseInfos[source]; | ||
|  |         } else { | ||
|  |             this._imageMeta = new UIEventSource<LicenseInfo>(null); | ||
|  |             ImgurImage.allLicenseInfos[source] = this._imageMeta; | ||
|  |             const self = this; | ||
|  |             Imgur.getDescriptionOfImage(source, (license) => { | ||
|  |                 self._imageMeta.setData(license) | ||
|  |             }) | ||
|  |         } | ||
|  |          | ||
|  |         this.ListenTo(this._imageMeta); | ||
|  |        | ||
|  |     } | ||
|  | 
 | ||
|  |     protected InnerRender(): string { | ||
|  |         const image = "<img src='" + this._imageLocation + "' " + "alt='' >"; | ||
|  |          | ||
|  |         if(this._imageMeta.data === null){ | ||
|  |             return image; | ||
|  |         } | ||
|  | 
 | ||
|  |         const attribution = | ||
|  |             "<span class='attribution-author'><b>" + (this._imageMeta.data.artist ?? "") + "</b></span>" + " <span class='license'>" + (this._imageMeta.data.licenseShortName ?? "") + "</span>"; | ||
|  | 
 | ||
|  |         return "<div class='imgWithAttr'>" + | ||
|  |             image + | ||
|  |             "<div class='attribution'>" + | ||
|  |             attribution + | ||
|  |             "</div>" + | ||
|  |             "</div>"; | ||
|  |     } | ||
|  | 
 | ||
|  | 
 | ||
|  | } |