forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			43 lines
		
	
	
		
			No EOL
		
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			No EOL
		
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {UIEventSource} from "../UIEventSource";
 | |
| import {Imgur} from "./Imgur";
 | |
| 
 | |
| export default class ImgurUploader {
 | |
| 
 | |
|     public readonly queue: UIEventSource<string[]> = new UIEventSource<string[]>([]);
 | |
|     public readonly failed: UIEventSource<string[]> = new UIEventSource<string[]>([]);
 | |
|     public readonly success: UIEventSource<string[]> = new UIEventSource<string[]>([]);
 | |
|     public maxFileSizeInMegabytes = 10;
 | |
|     private readonly _handleSuccessUrl: (string) => void;
 | |
| 
 | |
|     constructor(handleSuccessUrl: (string) => void) {
 | |
|         this._handleSuccessUrl = handleSuccessUrl;
 | |
|     }
 | |
| 
 | |
|     public uploadMany(title: string, description: string, files: FileList): void {
 | |
|         for (let i = 0; i < files.length; i++) {
 | |
|             this.queue.data.push(files.item(i).name)
 | |
|         }
 | |
|         this.queue.ping()
 | |
| 
 | |
|         const self = this;
 | |
|         this.queue.setData([...self.queue.data])
 | |
|         Imgur.uploadMultiple(title,
 | |
|             description,
 | |
|             files,
 | |
|             function (url) {
 | |
|                 console.log("File saved at", url);
 | |
|                 self.success.data.push(url)
 | |
|                 self.success.ping();
 | |
|                 self._handleSuccessUrl(url);
 | |
|             },
 | |
|             function () {
 | |
|                 console.log("All uploads completed");
 | |
|             },
 | |
| 
 | |
|             function (failReason) {
 | |
|                 console.log("Upload failed due to ", failReason)
 | |
|                 self.failed.setData([...self.failed.data, failReason])
 | |
|             }
 | |
|         );
 | |
|     }
 | |
| } |