| 
									
										
										
										
											2018-03-13 23:07:30 -07:00
										 |  |  | <div class="lazy-image" | 
					
						
							|  |  |  |      style="width: {{width}}px; height: {{height}}px; background: {{background}};"> | 
					
						
							|  |  |  |   {{#if displaySrc}} | 
					
						
							|  |  |  |     <img | 
					
						
							|  |  |  |       class="{{hidden ? 'hidden' : ''}} {{className || ''}}" | 
					
						
							| 
									
										
										
										
											2018-04-29 17:45:03 -07:00
										 |  |  |       aria-hidden={{ariaHidden || ''}} | 
					
						
							|  |  |  |       alt={{alt || ''}} | 
					
						
							|  |  |  |       title={{alt || ''}} | 
					
						
							|  |  |  |       src={{displaySrc}} | 
					
						
							| 
									
										
										
										
											2018-03-13 23:07:30 -07:00
										 |  |  |       :width | 
					
						
							|  |  |  |       :height | 
					
						
							|  |  |  |     /> | 
					
						
							|  |  |  |   {{/if}} | 
					
						
							|  |  |  | </div> | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  |   .lazy-image { | 
					
						
							|  |  |  |     overflow: hidden; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .lazy-image img { | 
					
						
							|  |  |  |     transition: opacity 0.2s linear; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | </style> | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2018-03-14 07:24:16 -07:00
										 |  |  |   import { mark, stop } from '../_utils/marks' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-13 23:07:30 -07:00
										 |  |  |   export default { | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |     oncreate () { | 
					
						
							| 
									
										
										
										
											2018-03-14 07:24:16 -07:00
										 |  |  |       mark('LazyImage oncreate()') | 
					
						
							|  |  |  |       let img = new Image() | 
					
						
							| 
									
										
										
										
											2018-04-19 09:37:05 -07:00
										 |  |  |       let { src } = this.get() | 
					
						
							|  |  |  |       let { fallback } = this.get() | 
					
						
							| 
									
										
										
										
											2018-03-14 07:24:16 -07:00
										 |  |  |       img.onload = () => { | 
					
						
							|  |  |  |         requestAnimationFrame(() => { | 
					
						
							|  |  |  |           this.set({ | 
					
						
							|  |  |  |             displaySrc: src, | 
					
						
							|  |  |  |             hidden: true | 
					
						
							|  |  |  |           }) | 
					
						
							| 
									
										
										
										
											2018-03-13 23:07:30 -07:00
										 |  |  |           requestAnimationFrame(() => { | 
					
						
							| 
									
										
										
										
											2018-03-14 07:24:16 -07:00
										 |  |  |             this.set({hidden: false}) | 
					
						
							| 
									
										
										
										
											2018-03-13 23:07:30 -07:00
										 |  |  |           }) | 
					
						
							| 
									
										
										
										
											2018-03-14 07:24:16 -07:00
										 |  |  |         }) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       img.onerror = () => { | 
					
						
							|  |  |  |         this.set({displaySrc: fallback}) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       img.src = src | 
					
						
							|  |  |  |       stop('LazyImage oncreate()') | 
					
						
							| 
									
										
										
										
											2018-03-13 23:07:30 -07:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | </script> |