| 
									
										
										
										
											2018-01-17 04:34:09 +00:00
										 |  |  | <div class="virtual-list-item {{shown ? 'shown' : ''}}" | 
					
						
							|  |  |  |      virtual-list-key="{{key}}" | 
					
						
							| 
									
										
										
										
											2018-01-15 18:54:02 +00:00
										 |  |  |      ref:node | 
					
						
							| 
									
										
										
										
											2018-01-21 18:32:18 +00:00
										 |  |  |      style="transform: translateY({{offset}}px);" > | 
					
						
							| 
									
										
										
										
											2018-01-24 02:15:14 +00:00
										 |  |  |   <:Component {component} | 
					
						
							|  |  |  |               virtualProps="{{props}}" | 
					
						
							|  |  |  |               virtualIndex="{{index}}" | 
					
						
							|  |  |  |               virtualLength="{{$numItems}}" | 
					
						
							| 
									
										
										
										
											2018-01-21 18:32:18 +00:00
										 |  |  |               on:recalculateHeight="doRecalculateHeight()"/> | 
					
						
							| 
									
										
										
										
											2018-01-15 18:54:02 +00:00
										 |  |  | </div> | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  |   .virtual-list-item { | 
					
						
							|  |  |  |     position: absolute; | 
					
						
							|  |  |  |     top: 0; | 
					
						
							| 
									
										
										
										
											2018-01-17 04:34:09 +00:00
										 |  |  |     opacity: 0; | 
					
						
							|  |  |  |     pointer-events: none; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-01-20 20:35:38 +00:00
										 |  |  |   .virtual-list-item.shown { | 
					
						
							| 
									
										
										
										
											2018-01-17 04:34:09 +00:00
										 |  |  |     opacity: 1; | 
					
						
							|  |  |  |     pointer-events: auto; | 
					
						
							| 
									
										
										
										
											2018-01-15 18:54:02 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | </style> | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2018-01-25 16:23:14 +00:00
										 |  |  |   import { virtualListStore } from './virtualListStore' | 
					
						
							|  |  |  |   import { AsyncLayout } from '../../_utils/AsyncLayout' | 
					
						
							| 
									
										
										
										
											2018-01-17 04:34:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-15 18:54:02 +00:00
										 |  |  |   export default { | 
					
						
							|  |  |  |     oncreate() { | 
					
						
							| 
									
										
										
										
											2018-01-27 17:53:14 +00:00
										 |  |  |       this.doRecalculateHeight() | 
					
						
							| 
									
										
										
										
											2018-01-15 18:54:02 +00:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-01-17 04:34:09 +00:00
										 |  |  |     store: () => virtualListStore, | 
					
						
							|  |  |  |     computed: { | 
					
						
							|  |  |  |       'shown': ($itemHeights, key) => $itemHeights[key] > 0 | 
					
						
							| 
									
										
										
										
											2018-01-21 18:32:18 +00:00
										 |  |  |     }, | 
					
						
							|  |  |  |     methods: { | 
					
						
							|  |  |  |       doRecalculateHeight() { | 
					
						
							| 
									
										
										
										
											2018-01-27 17:53:14 +00:00
										 |  |  |         let asyncLayout = new AsyncLayout(node => node.getAttribute('virtual-list-key')) | 
					
						
							| 
									
										
										
										
											2018-01-21 18:32:18 +00:00
										 |  |  |         let key = this.get('key') | 
					
						
							| 
									
										
										
										
											2018-01-27 17:53:14 +00:00
										 |  |  |         asyncLayout.observe(key, this.refs.node, (rect) => { | 
					
						
							|  |  |  |           asyncLayout.disconnect() | 
					
						
							| 
									
										
										
										
											2018-01-27 17:53:33 +00:00
										 |  |  |           // update all item heights in one batch for better perf | 
					
						
							| 
									
										
										
										
											2018-01-21 18:32:18 +00:00
										 |  |  |           this.store.batchUpdate('itemHeights', key, rect.height) | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-01-17 04:34:09 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-15 18:54:02 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | </script> |