forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			54 lines
		
	
	
		
			No EOL
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			No EOL
		
	
	
		
			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);
 | |
|       
 | |
|     }
 | |
| 
 | |
|     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>";
 | |
|     }
 | |
| 
 | |
| 
 | |
| } |