2019-08-27 08:32:56 +02:00
|
|
|
<script>
|
2020-02-03 10:50:30 +01:00
|
|
|
import createApp from "./createApp"
|
2020-02-14 12:51:45 +01:00
|
|
|
import { form } from "./props"
|
2020-02-03 10:50:30 +01:00
|
|
|
let _bb
|
2020-02-14 12:51:45 +01:00
|
|
|
let currentComponent
|
|
|
|
let _appPromise
|
2019-09-19 05:35:40 +02:00
|
|
|
|
2020-02-25 16:21:23 +01:00
|
|
|
const autoAssignIds = (props, count = 0) => {
|
|
|
|
if (!props._id) {
|
|
|
|
props._id = `auto_id_${count}`
|
|
|
|
}
|
|
|
|
if (props._children) {
|
|
|
|
for (let child of props._children) {
|
|
|
|
count += 1
|
|
|
|
autoAssignIds(child, count)
|
|
|
|
}
|
2020-02-14 12:51:45 +01:00
|
|
|
}
|
|
|
|
}
|
2019-09-19 05:35:40 +02:00
|
|
|
|
2020-02-14 12:51:45 +01:00
|
|
|
$: {
|
|
|
|
if (currentComponent) {
|
|
|
|
const _appPromise = createApp()
|
|
|
|
const page = {
|
|
|
|
props: form,
|
|
|
|
}
|
2019-09-19 05:35:40 +02:00
|
|
|
|
2020-02-14 12:51:45 +01:00
|
|
|
autoAssignIds(page.props)
|
2019-09-19 05:35:40 +02:00
|
|
|
|
2020-02-14 12:51:45 +01:00
|
|
|
_appPromise.then(initialise => {
|
|
|
|
initialise(page, currentComponent, "")
|
|
|
|
})
|
2019-09-19 05:35:40 +02:00
|
|
|
}
|
2020-02-03 10:50:30 +01:00
|
|
|
}
|
2019-08-27 08:32:56 +02:00
|
|
|
</script>
|
|
|
|
|
2019-09-19 05:35:40 +02:00
|
|
|
{#await _appPromise}
|
2020-02-03 10:50:30 +01:00
|
|
|
loading
|
2019-09-27 18:03:31 +02:00
|
|
|
{:then _bb}
|
2020-02-03 10:50:30 +01:00
|
|
|
<div id="current_component" bind:this={currentComponent} />
|
2019-09-19 05:35:40 +02:00
|
|
|
{/await}
|
|
|
|
|
2019-08-27 08:32:56 +02:00
|
|
|
<style>
|
2020-02-03 10:50:30 +01:00
|
|
|
#current_component {
|
2019-08-27 08:32:56 +02:00
|
|
|
height: 100%;
|
|
|
|
width: 100%;
|
2020-02-03 10:50:30 +01:00
|
|
|
}
|
2019-08-27 08:32:56 +02:00
|
|
|
</style>
|