2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								import  { UIElement }  from  "./UIElement" ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  { UIEventSource }  from  "./UIEventSource" ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  $  from  "jquery"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  { Imgur }  from  "../Logic/Imgur" ;  
						 
					
						
							
								
									
										
										
										
											2020-06-27 03:06:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  { UserDetails }  from  "../Logic/OsmConnection" ;  
						 
					
						
							
								
									
										
										
										
											2020-07-20 15:54:50 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  { DropDown }  from  "./Input/DropDown" ;  
						 
					
						
							
								
									
										
										
										
											2020-06-29 03:16:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  { VariableUiElement }  from  "./Base/VariableUIElement" ;  
						 
					
						
							
								
									
										
										
										
											2020-07-21 00:07:04 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  Translations  from  "./i18n/Translations" ;  
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export  class  ImageUploadFlow  extends  UIElement  {  
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    private  _licensePicker : UIElement ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    private  _selectedLicence : UIEventSource < string > ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    private  _isUploading : UIEventSource < number >  =  new  UIEventSource < number > ( 0 ) 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 22:50:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    private  _didFail : UIEventSource < boolean >  =  new  UIEventSource < boolean > ( false ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    private  _uploadOptions :  ( license : string )  = >  {  title : string ;  description : string ;  handleURL :  ( url : string )  = >  void ;  allDone :  ( ( )  = >  void )  } ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-27 03:06:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    private  _userdetails : UIEventSource < UserDetails > ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-27 03:06:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    constructor ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        userInfo : UIEventSource < UserDetails > , 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 22:50:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        preferedLicense : UIEventSource < string > , 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-27 03:06:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        uploadOptions :  ( ( license : string )  = > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                title : string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                description : string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                handleURL :  ( ( url : string )  = >  void ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                allDone :  ( ( )  = >  void ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            } ) 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        super ( undefined ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-27 03:06:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        this . _userdetails  =  userInfo ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        this . ListenTo ( userInfo ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        this . _uploadOptions  =  uploadOptions ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        this . ListenTo ( this . _isUploading ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 22:50:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        this . ListenTo ( this . _didFail ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 01:13:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        const  licensePicker  =  new  DropDown ( Translations . t . image . willBePublished , 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								            [ 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 01:13:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                { value :  "CC0" ,  shown : Translations.t.image.cco } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                { value :  "CC-BY-SA 4.0" ,  shown : Translations.t.image.ccbs } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                { value :  "CC-BY 4.0" ,  shown : Translations.t.image.ccb } 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-01 17:38:48 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            preferedLicense 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        this . _licensePicker  =  licensePicker ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-20 21:39:07 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        this . _selectedLicence  =  licensePicker . GetValue ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-07-20 21:39:07 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    InnerRender ( ) :  string  { 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-27 03:06:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  ( ! this . _userdetails . data . loggedIn )  { 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-20 23:43:42 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return  ` <div class='activate-osm-authentication'> ${ Translations . t . image . pleaseLogin . Render ( ) } </div> ` ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-27 03:06:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-20 17:30:02 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        let  uploadingMessage  =  "" ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  ( this . _isUploading . data  ==  1 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-20 23:43:42 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return  ` <b> ${ Translations . t . image . uploadingPicture . Render ( ) } </b> ` 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        if  ( this . _isUploading . data  >  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-20 17:30:02 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            uploadingMessage  =  "<b>Uploading multiple pictures, "  +  this . _isUploading . data  +  " left...</b>" 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 22:50:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if ( this . _didFail . data ) { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            uploadingMessage  +=  "<b>Some images failed to upload. Imgur migth be down or you might block third-party API's (e.g. by using Brave or UMatrix)</b><br/>" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  ""  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            "<div class='imageflow'>"  + 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-20 17:30:02 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            "<label for='fileselector-"  +  this . id  +  "'>"  + 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-20 17:30:02 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            "<div class='imageflow-file-input-wrapper'>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            "<img src='./assets/camera-plus.svg' alt='upload image'/> "  + 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 01:13:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            ` <span class='imageflow-add-picture'> ${ Translations . t . image . addPicture . R ( ) } </span> `  + 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 22:50:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            "<div class='break'></div>"  + 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            "</div>"  + 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-20 17:30:02 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            this . _licensePicker . Render ( )  +  "<br/>"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            uploadingMessage  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            "</label>"  + 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 22:50:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            "<input id='fileselector-"  +  this . id  +  "' "  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            "type='file' "  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            "class='imageflow-file-input' "  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            "accept='image/*' name='picField' size='24' multiple='multiple' alt=''"  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            "/>"  + 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 22:50:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            "</div>" 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								            ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    InnerUpdate ( htmlElement : HTMLElement )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        super . InnerUpdate ( htmlElement ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-27 03:06:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        const  user  =  this . _userdetails . data ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        htmlElement . onclick  =  function  ( )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  ( ! user . loggedIn )  { 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-27 03:06:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                user . osmConnection . AttemptLogin ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        this . _licensePicker . Update ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        const  selector  =  document . getElementById ( 'fileselector-'  +  this . id ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        const  self  =  this ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( selector  !=  null )  { 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            selector . onchange  =  function  ( )  { 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                const  files  =  $ ( this ) . get ( 0 ) . files ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                self . _isUploading . setData ( files . length ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-28 00:06:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                const  opts  =  self . _uploadOptions ( self . _selectedLicence . data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                Imgur . uploadMultiple ( opts . title ,  opts . description ,  files , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    function  ( url )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        console . log ( "File saved at" ,  url ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        self . _isUploading . setData ( self . _isUploading . data  -  1 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        opts . handleURL ( url ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    function  ( )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        console . log ( "All uploads completed" ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        opts . allDone ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-21 22:50:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    function ( failReason )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    
							 
						 
					
						
							
								
									
										
										
										
											2020-07-25 18:00:08 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    } , 0 
							 
						 
					
						
							
								
									
										
										
										
											2020-06-25 03:39:31 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}