| 
									
										
										
										
											2018-05-22 11:25:43 -07:00
										 |  |  | import Component from '@ember/component'; | 
					
						
							| 
									
										
										
										
											2019-08-31 20:51:14 -07:00
										 |  |  | import { action, computed } from '@ember/object'; | 
					
						
							|  |  |  | import { classNames } from '@ember-decorators/component'; | 
					
						
							| 
									
										
										
										
											2018-05-22 11:25:43 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-31 20:51:14 -07:00
										 |  |  | @classNames('nacho-uploader') | 
					
						
							| 
									
										
										
										
											2018-05-22 11:25:43 -07:00
										 |  |  | export default class JsonUpload extends Component { | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * External action to receive json text resource | 
					
						
							|  |  |  |    * @memberof JsonUpload | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   receiveJsonFile: (textBlob: string) => void; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Handles the change event on the json-upload DOM element | 
					
						
							|  |  |  |    * @param {FileList} files extracts a FileList object from the event object | 
					
						
							|  |  |  |    * @return {void | null} | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2019-08-31 20:51:14 -07:00
										 |  |  |   change({ target }: Event): void { | 
					
						
							|  |  |  |     const { files } = target as HTMLInputElement; | 
					
						
							|  |  |  |     files && files.length ? this.sendFileAsText(Array.from(files).shift()) : null; | 
					
						
							| 
									
										
										
										
											2018-05-22 11:25:43 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Caches a unique id for this instances HTML Element for file upload | 
					
						
							|  |  |  |    * @type {ComputedProperty<string>} | 
					
						
							|  |  |  |    * @memberof JsonUpload | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2019-08-31 20:51:14 -07:00
										 |  |  |   @computed() | 
					
						
							|  |  |  |   get uploadInputId(): string { | 
					
						
							|  |  |  |     return `${this.elementId}-uploader`; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-05-22 11:25:43 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Reads a file as a text string and passes the output to the closure action | 
					
						
							|  |  |  |    * @param {File} [fileBlob] | 
					
						
							|  |  |  |    * @memberof JsonUpload | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2019-08-31 20:51:14 -07:00
										 |  |  |   sendFileAsText(fileBlob?: File): void { | 
					
						
							|  |  |  |     const { receiveJsonFile } = this; | 
					
						
							| 
									
										
										
										
											2018-05-22 11:25:43 -07:00
										 |  |  |     const reader = new FileReader(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-31 20:51:14 -07:00
										 |  |  |     if (typeof receiveJsonFile === 'function' && fileBlob) { | 
					
						
							|  |  |  |       reader.onload = ({ target }: ProgressEvent & { target: FileReader }): unknown => | 
					
						
							|  |  |  |         target && receiveJsonFile(String(target.result)); | 
					
						
							| 
									
										
										
										
											2018-05-22 11:25:43 -07:00
										 |  |  |       reader.readAsText(fileBlob); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Proxies the user's click interaction on the styled upload button to the file input element | 
					
						
							|  |  |  |    * @memberof JsonUpload | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   @action | 
					
						
							| 
									
										
										
										
											2019-08-31 20:51:14 -07:00
										 |  |  |   onUpload(): void { | 
					
						
							|  |  |  |     const input = this.element.querySelector<HTMLInputElement>(`#${this.uploadInputId}`); | 
					
						
							|  |  |  |     input && input.click(); | 
					
						
							| 
									
										
										
										
											2018-05-22 11:25:43 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | } |