budibase/packages/builder/src/components/userInterface/PageLayout.svelte

45 lines
1.2 KiB
Svelte
Raw Normal View History

2020-02-20 18:11:41 +01:00
<script>
2020-04-28 15:28:31 +02:00
import { goto } from "@sveltech/routify"
2020-11-19 17:41:29 +01:00
import ComponentTree from "./ComponentNavigationTree/ComponentTree.svelte"
import NavItem from "components/common/NavItem.svelte"
import { last } from "lodash/fp"
import { store } from "builderStore"
2020-08-13 11:15:37 +02:00
import { writable } from "svelte/store"
2020-02-20 18:11:41 +01:00
export let layout
let confirmDeleteDialog
let componentToDelete = ""
2020-08-13 11:15:37 +02:00
const dragDropStore = writable({})
2020-02-20 18:11:41 +01:00
2020-10-27 16:28:13 +01:00
const lastPartOfName = c =>
2020-02-20 18:11:41 +01:00
c && last(c.name ? c.name.split("/") : c._component.split("/"))
$: _layout = {
component: layout,
2020-05-07 11:53:34 +02:00
title: lastPartOfName(layout),
}
2020-02-20 18:11:41 +01:00
2020-04-28 15:28:31 +02:00
const setCurrentScreenToLayout = () => {
2020-11-04 18:09:45 +01:00
store.actions.selectPageOrScreen("page")
2020-04-28 15:28:31 +02:00
$goto("./:page/page-layout")
}
2020-02-20 18:11:41 +01:00
</script>
<NavItem
border={false}
icon="ri-layout-3-line"
text="Master Screen"
withArrow
selected={$store.currentComponentInfo?._id === _layout.component.props._id}
opened={$store.currentPreviewItem?.name === _layout.title}
on:click={setCurrentScreenToLayout} />
2020-06-01 23:16:55 +02:00
{#if $store.currentPreviewItem?.name === _layout.title && _layout.component.props._children}
2020-11-19 17:41:29 +01:00
<ComponentTree
2020-06-01 23:16:55 +02:00
components={_layout.component.props._children}
2020-08-13 11:15:37 +02:00
currentComponent={$store.currentComponentInfo}
{dragDropStore} />
2020-06-01 23:16:55 +02:00
{/if}