| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  | <div class="timeline"> | 
					
						
							|  |  |  |   <VirtualList component="{{StatusListItem}}" items="{{statuses}}" /> | 
					
						
							| 
									
										
										
										
											2018-01-15 12:23:28 -08:00
										 |  |  |   <button type="button" on:click="addMoreItems()">Add more items</button> | 
					
						
							| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  | </div> | 
					
						
							| 
									
										
										
										
											2018-01-08 18:14:21 -08:00
										 |  |  | <script> | 
					
						
							|  |  |  |   import { store } from '../_utils/store' | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |   import { getHomeTimeline } from '../_utils/mastodon/oauth' | 
					
						
							| 
									
										
										
										
											2018-01-10 20:45:02 -08:00
										 |  |  |   import fixture from '../_utils/fixture.json' | 
					
						
							| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  |   import StatusListItem from './StatusListItem.html' | 
					
						
							|  |  |  |   import VirtualList from './VirtualList.html' | 
					
						
							| 
									
										
										
										
											2018-01-15 12:23:28 -08:00
										 |  |  |   import { splice } from 'svelte-extras' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   let i = -1 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-15 16:12:07 -08:00
										 |  |  |   const createData = () => fixture.slice(0, 20).map(_ => ({ | 
					
						
							| 
									
										
										
										
											2018-01-15 12:23:28 -08:00
										 |  |  |     key: `${++i}`, | 
					
						
							|  |  |  |     props: _ | 
					
						
							|  |  |  |   })) | 
					
						
							| 
									
										
										
										
											2018-01-08 18:14:21 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   export default { | 
					
						
							|  |  |  |     data: () => ({ | 
					
						
							|  |  |  |       target: 'home', | 
					
						
							| 
									
										
										
										
											2018-01-15 12:23:28 -08:00
										 |  |  |       statuses: createData(), | 
					
						
							| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  |       StatusListItem: StatusListItem | 
					
						
							| 
									
										
										
										
											2018-01-08 18:14:21 -08:00
										 |  |  |     }), | 
					
						
							| 
									
										
										
										
											2018-01-10 20:45:02 -08:00
										 |  |  |     store: () => store, | 
					
						
							|  |  |  |     components: { | 
					
						
							| 
									
										
										
										
											2018-01-15 10:54:02 -08:00
										 |  |  |       VirtualList | 
					
						
							| 
									
										
										
										
											2018-01-15 12:23:28 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     methods: { | 
					
						
							|  |  |  |       splice: splice, | 
					
						
							|  |  |  |       addMoreItems() { | 
					
						
							|  |  |  |         this.splice('statuses', this.get('statuses').length, 0, ...createData()) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-01-10 20:45:02 -08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-08 18:14:21 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | </script> |