| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  | import { IgniteElement } from "../ignite-html/ignite-element.js"; | 
					
						
							|  |  |  | import { IgniteTemplate, button, div, img, input } from "../ignite-html/ignite-template.js"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class EditableImage extends IgniteElement { | 
					
						
							|  |  |  |     constructor() { | 
					
						
							|  |  |  |         super(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     get styles() { | 
					
						
							|  |  |  |         return `
 | 
					
						
							|  |  |  |             mt-editable-image { | 
					
						
							|  |  |  |                 position: relative; | 
					
						
							|  |  |  |                 display: flex; | 
					
						
							|  |  |  |                 flex-direction: column; | 
					
						
							|  |  |  |                 align-items: center; | 
					
						
							|  |  |  |                 justify-content: center; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             mt-editable-image > img { | 
					
						
							|  |  |  |                 width: 100%; | 
					
						
							|  |  |  |                 max-width: 100%; | 
					
						
							|  |  |  |                 max-height: 100%; | 
					
						
							|  |  |  |                 height: auto; | 
					
						
							|  |  |  |                 flex: 1; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-14 14:31:54 -07:00
										 |  |  |             mt-editable-image.source:hover:after { | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |                 position: absolute; | 
					
						
							| 
									
										
										
										
											2020-10-07 08:28:10 -07:00
										 |  |  |                 font-family: 'Font Awesome 5 Pro'; | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |                 font-weight: 900; | 
					
						
							|  |  |  |                 content: '\\f332'; | 
					
						
							| 
									
										
										
										
											2020-10-07 08:28:10 -07:00
										 |  |  |                 color: #fff; | 
					
						
							|  |  |  |                 font-size: 2.2em; | 
					
						
							|  |  |  |                 display: flex; | 
					
						
							|  |  |  |                 align-items: center; | 
					
						
							|  |  |  |                 justify-content: center; | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-14 14:31:54 -07:00
										 |  |  |             mt-editable-image.source:hover { | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |                 cursor: pointer; | 
					
						
							| 
									
										
										
										
											2020-10-07 08:28:10 -07:00
										 |  |  |                 filter: brightness(0.9); | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |             } | 
					
						
							|  |  |  |         `;
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     get properties() { | 
					
						
							|  |  |  |         return { | 
					
						
							|  |  |  |             source: null, | 
					
						
							|  |  |  |             fileInput: null, | 
					
						
							|  |  |  |             objectFit: "contain", | 
					
						
							| 
									
										
										
										
											2020-10-14 14:31:54 -07:00
										 |  |  |             objectPosition: "center", | 
					
						
							|  |  |  |             width: null, | 
					
						
							|  |  |  |             maxWidth: null, | 
					
						
							|  |  |  |             height: null, | 
					
						
							|  |  |  |             maxHeight: null, | 
					
						
							|  |  |  |             placeholder: null | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |         }; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     render() { | 
					
						
							|  |  |  |         return this.template | 
					
						
							|  |  |  |             .onClick(() => this.onClick()) | 
					
						
							| 
									
										
										
										
											2020-10-14 14:31:54 -07:00
										 |  |  |             .class(this.source, value => { return value != null ? "source" : null; }) | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |             .child( | 
					
						
							| 
									
										
										
										
											2020-10-14 14:31:54 -07:00
										 |  |  |                 new div() | 
					
						
							|  |  |  |                     .hide(this.source, value => { return value != null; }) | 
					
						
							|  |  |  |                     .child(this.placeholder), | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |                 new img() | 
					
						
							|  |  |  |                     .src(this.source) | 
					
						
							|  |  |  |                     .style("object-fit", this.objectFit) | 
					
						
							| 
									
										
										
										
											2020-10-07 08:28:10 -07:00
										 |  |  |                     .style("object-position", this.objectPosition) | 
					
						
							| 
									
										
										
										
											2020-10-14 14:31:54 -07:00
										 |  |  |                     .style("width", this.width) | 
					
						
							|  |  |  |                     .style("max-width", this.maxWidth) | 
					
						
							|  |  |  |                     .style("height", this.height) | 
					
						
							|  |  |  |                     .style("max-height", this.maxHeight) | 
					
						
							| 
									
										
										
										
											2020-11-14 11:34:35 -08:00
										 |  |  |                     .hide(this.source, value => { return value == null; }) | 
					
						
							| 
									
										
										
										
											2020-11-17 19:56:27 -08:00
										 |  |  |                     .on("load", () => this.dispatchEvent(new Event("load"))), | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |                 new input() | 
					
						
							|  |  |  |                     .type("file") | 
					
						
							|  |  |  |                     .style("display", "none", true) | 
					
						
							|  |  |  |                     .attribute("accept", "image/*") | 
					
						
							|  |  |  |                     .onChange((event) => this.onFileChange(event)).ref(this.fileInput) | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onFileChange(event) { | 
					
						
							| 
									
										
										
										
											2020-11-17 19:56:27 -08:00
										 |  |  |         //Prevent this event from bubbling up since we haven't
 | 
					
						
							|  |  |  |         //actually changed anything yet, just the inner input changed.
 | 
					
						
							|  |  |  |         event.stopPropagation(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |         //Get the uploaded file from the file input.
 | 
					
						
							|  |  |  |         var file = this.fileInput.files[0]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //Create a reader to read in the file.
 | 
					
						
							|  |  |  |         var reader = new FileReader(); | 
					
						
							|  |  |  |         reader.onload = (event) => { | 
					
						
							|  |  |  |             this.source = event.target.result; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-17 19:56:27 -08:00
										 |  |  |             //Invoke a native change event now that we have
 | 
					
						
							|  |  |  |             //the image file ready.
 | 
					
						
							|  |  |  |             this.dispatchEvent(new Event("change")); | 
					
						
							| 
									
										
										
										
											2020-10-06 22:45:45 -07:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         //Read it.
 | 
					
						
							|  |  |  |         reader.readAsDataURL(file); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onClick() { | 
					
						
							|  |  |  |         this.fileInput.click(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class EditableImageTemplate extends IgniteTemplate { | 
					
						
							|  |  |  |     constructor(...children) { | 
					
						
							|  |  |  |         super("mt-editable-image", children); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | customElements.define("mt-editable-image", EditableImage); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export { | 
					
						
							|  |  |  |     EditableImageTemplate as EditableImage | 
					
						
							|  |  |  | }; |