2018-01-19 08:51:51 +00:00
|
|
|
<div class="lazy-timeline">
|
2018-01-31 06:21:31 +00:00
|
|
|
{{#await importTimeline}}
|
2018-01-19 08:51:51 +00:00
|
|
|
{{then constructor}}
|
2018-01-27 18:46:52 +00:00
|
|
|
<:Component {constructor} :timeline />
|
2018-01-19 08:51:51 +00:00
|
|
|
{{catch error}}
|
2018-01-31 05:57:41 +00:00
|
|
|
<div>Component failed to load. Try refreshing! {{error}}</div>
|
2018-01-19 08:51:51 +00:00
|
|
|
{{/await}}
|
2018-01-15 07:24:27 +00:00
|
|
|
</div>
|
|
|
|
<style>
|
2018-01-19 08:51:51 +00:00
|
|
|
.lazy-timeline {
|
2018-01-15 07:24:27 +00:00
|
|
|
width: 100%;
|
2018-01-19 08:51:51 +00:00
|
|
|
min-height: 60vh;
|
|
|
|
}
|
2018-01-15 07:24:27 +00:00
|
|
|
</style>
|
|
|
|
<script>
|
2018-01-28 00:35:44 +00:00
|
|
|
import { importTimeline } from '../../_utils/asyncModules'
|
2018-01-28 21:09:39 +00:00
|
|
|
import { store } from '../../_store/store'
|
2018-03-13 03:58:45 +00:00
|
|
|
import { scheduleIdleTask } from '../../_utils/scheduleIdleTask'
|
2018-01-15 07:24:27 +00:00
|
|
|
|
|
|
|
export default {
|
2018-01-27 18:46:52 +00:00
|
|
|
oncreate() {
|
|
|
|
let instanceName = this.store.get('currentInstance')
|
|
|
|
let timeline = this.get('timeline')
|
|
|
|
this.store.set({currentTimeline: timeline})
|
|
|
|
this.store.setForTimeline(instanceName, timeline, {runningUpdate: false})
|
|
|
|
},
|
|
|
|
store: () => store,
|
2018-01-15 07:24:27 +00:00
|
|
|
data: () => ({
|
2018-03-13 03:58:45 +00:00
|
|
|
importTimeline: importTimeline().then(timeline => {
|
|
|
|
return new Promise((resolve) => {
|
|
|
|
// make column-switching more responsive by delaying this load
|
|
|
|
scheduleIdleTask(() => resolve(timeline))
|
|
|
|
})
|
|
|
|
})
|
2018-01-31 06:21:31 +00:00
|
|
|
})
|
2018-01-15 07:24:27 +00:00
|
|
|
}
|
|
|
|
</script>
|