| 
									
										
										
										
											2018-01-16 20:34:09 -08:00
										 |  |  | <div class="virtual-list-item {{shown ? 'shown' : ''}}" | 
					
						
							| 
									
										
										
										
											2018-04-29 17:45:03 -07:00
										 |  |  |      aria-hidden={{!shown}} | 
					
						
							|  |  |  |      virtual-list-key={{key}} | 
					
						
							| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  |      ref:node | 
					
						
							| 
									
										
										
										
											2018-01-21 10:32:18 -08:00
										 |  |  |      style="transform: translateY({{offset}}px);" > | 
					
						
							| 
									
										
										
										
											2018-01-23 18:15:14 -08:00
										 |  |  |   <:Component {component} | 
					
						
							| 
									
										
										
										
											2018-04-29 17:45:03 -07:00
										 |  |  |               virtualProps={{props}} | 
					
						
							|  |  |  |               virtualIndex={{index}} | 
					
						
							|  |  |  |               virtualLength={{$length}} | 
					
						
							| 
									
										
										
										
											2018-01-21 10:32:18 -08:00
										 |  |  |               on:recalculateHeight="doRecalculateHeight()"/> | 
					
						
							| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  | </div> | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  |   .virtual-list-item { | 
					
						
							|  |  |  |     position: absolute; | 
					
						
							|  |  |  |     top: 0; | 
					
						
							| 
									
										
										
										
											2018-01-16 20:34:09 -08:00
										 |  |  |     opacity: 0; | 
					
						
							|  |  |  |     pointer-events: none; | 
					
						
							| 
									
										
										
										
											2018-02-11 16:24:14 -08:00
										 |  |  |     transition: opacity 0.333s linear; | 
					
						
							| 
									
										
										
										
											2018-01-16 20:34:09 -08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-01-20 12:35:38 -08:00
										 |  |  |   .virtual-list-item.shown { | 
					
						
							| 
									
										
										
										
											2018-01-16 20:34:09 -08:00
										 |  |  |     opacity: 1; | 
					
						
							|  |  |  |     pointer-events: auto; | 
					
						
							| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | </style> | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2018-01-25 08:23:14 -08:00
										 |  |  |   import { virtualListStore } from './virtualListStore' | 
					
						
							| 
									
										
										
										
											2018-03-31 17:42:52 -07:00
										 |  |  |   import { registerResizeListener, unregisterResizeListener } from '../../_utils/resize' | 
					
						
							| 
									
										
										
										
											2018-04-27 09:21:30 -07:00
										 |  |  |   import { mark, stop } from '../../_utils/marks' | 
					
						
							| 
									
										
										
										
											2018-01-16 20:34:09 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  |   export default { | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |     oncreate () { | 
					
						
							| 
									
										
										
										
											2018-04-19 09:37:05 -07:00
										 |  |  |       let { key } = this.get() | 
					
						
							| 
									
										
										
										
											2018-04-27 09:21:30 -07:00
										 |  |  |       requestAnimationFrame(() => { | 
					
						
							|  |  |  |         mark('VirtualListItem gBCR') | 
					
						
							|  |  |  |         let rect = this.refs.node.getBoundingClientRect() | 
					
						
							|  |  |  |         stop('VirtualListItem gBCR') | 
					
						
							| 
									
										
										
										
											2018-03-23 08:29:54 -07:00
										 |  |  |         // update all item heights in one batch for better perf | 
					
						
							|  |  |  |         this.store.batchUpdateForRealm('itemHeights', key, rect.height) | 
					
						
							|  |  |  |       }) | 
					
						
							| 
									
										
										
										
											2018-03-31 17:42:52 -07:00
										 |  |  |       this.doRecalculateHeight = this.doRecalculateHeight.bind(this) | 
					
						
							|  |  |  |       registerResizeListener(this.doRecalculateHeight) | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |     ondestroy () { | 
					
						
							| 
									
										
										
										
											2018-03-31 17:42:52 -07:00
										 |  |  |       unregisterResizeListener(this.doRecalculateHeight) | 
					
						
							| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-01-16 20:34:09 -08:00
										 |  |  |     store: () => virtualListStore, | 
					
						
							|  |  |  |     computed: { | 
					
						
							|  |  |  |       'shown': ($itemHeights, key) => $itemHeights[key] > 0 | 
					
						
							| 
									
										
										
										
											2018-01-21 10:32:18 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     methods: { | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |       doRecalculateHeight () { | 
					
						
							| 
									
										
										
										
											2018-03-23 08:29:54 -07:00
										 |  |  |         // Recalculate immediately because this is done on-demand, e.g. | 
					
						
							|  |  |  |         // when clicking the "More" button on a spoiler. | 
					
						
							|  |  |  |         let rect = this.refs.node.getBoundingClientRect() | 
					
						
							| 
									
										
										
										
											2018-04-19 09:37:05 -07:00
										 |  |  |         let { key } = this.get() | 
					
						
							|  |  |  |         let { itemHeights } = this.store.get() | 
					
						
							| 
									
										
										
										
											2018-03-23 08:29:54 -07:00
										 |  |  |         itemHeights[key] = rect.height | 
					
						
							|  |  |  |         this.store.setForRealm({itemHeights}) | 
					
						
							| 
									
										
										
										
											2018-01-21 10:32:18 -08:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-01-16 20:34:09 -08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | </script> |