2020-05-29 14:28:12 +02:00
|
|
|
<script>
|
2020-11-18 23:04:18 +01:00
|
|
|
import { onMount } from "svelte"
|
2020-12-05 13:09:58 +01:00
|
|
|
import { goto, params, url } from "@sveltech/routify"
|
2020-12-09 19:18:47 +01:00
|
|
|
import {
|
|
|
|
store,
|
|
|
|
currentAsset,
|
|
|
|
backendUiStore,
|
|
|
|
selectedAccessRole,
|
|
|
|
} from "builderStore"
|
2020-12-05 13:09:58 +01:00
|
|
|
import { FrontendTypes } from "constants"
|
2020-11-19 17:41:29 +01:00
|
|
|
import ComponentNavigationTree from "components/userInterface/ComponentNavigationTree/index.svelte"
|
2020-11-25 18:56:09 +01:00
|
|
|
import Layout from "components/userInterface/Layout.svelte"
|
2020-10-08 10:35:11 +02:00
|
|
|
import NewScreenModal from "components/userInterface/NewScreenModal.svelte"
|
2020-12-05 00:16:07 +01:00
|
|
|
import NewLayoutModal from "components/userInterface/NewLayoutModal.svelte"
|
2020-12-09 19:18:47 +01:00
|
|
|
import { Modal, Switcher, Select } from "@budibase/bbui"
|
2020-05-29 19:32:52 +02:00
|
|
|
|
2020-12-01 17:22:06 +01:00
|
|
|
const tabs = [
|
|
|
|
{
|
|
|
|
title: "Screens",
|
2020-12-05 13:09:58 +01:00
|
|
|
key: "screen",
|
2020-12-01 17:22:06 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "Layouts",
|
2020-12-05 13:09:58 +01:00
|
|
|
key: "layout",
|
2020-12-01 17:22:06 +01:00
|
|
|
},
|
|
|
|
]
|
2020-11-18 23:04:18 +01:00
|
|
|
|
2020-12-01 17:22:06 +01:00
|
|
|
let modal
|
2020-11-18 23:04:18 +01:00
|
|
|
let routes = {}
|
2020-12-05 13:09:58 +01:00
|
|
|
let tab = $params.assetType
|
2020-12-02 14:41:00 +01:00
|
|
|
|
2020-12-03 16:15:14 +01:00
|
|
|
function navigate({ detail }) {
|
2020-12-02 14:41:00 +01:00
|
|
|
if (!detail) return
|
2020-12-07 17:06:20 +01:00
|
|
|
$goto(`../${detail.heading.key}`)
|
2020-12-02 14:41:00 +01:00
|
|
|
}
|
2020-11-18 23:04:18 +01:00
|
|
|
|
|
|
|
onMount(() => {
|
2020-11-19 22:07:25 +01:00
|
|
|
store.actions.routing.fetch()
|
2020-11-18 23:04:18 +01:00
|
|
|
})
|
2020-05-29 14:28:12 +02:00
|
|
|
</script>
|
|
|
|
|
2020-10-22 19:12:40 +02:00
|
|
|
<div class="title">
|
2020-12-03 16:15:14 +01:00
|
|
|
<Switcher headings={tabs} bind:value={tab} on:change={navigate}>
|
2020-12-05 13:09:58 +01:00
|
|
|
{#if tab === FrontendTypes.SCREEN}
|
2020-12-01 17:22:06 +01:00
|
|
|
<i
|
|
|
|
on:click={modal.show}
|
|
|
|
data-cy="new-screen"
|
|
|
|
class="ri-add-circle-fill" />
|
2020-12-09 19:18:47 +01:00
|
|
|
|
|
|
|
<div class="role-select">
|
|
|
|
<Select
|
|
|
|
extraThin
|
|
|
|
secondary
|
|
|
|
bind:value={$selectedAccessRole}
|
|
|
|
label="Filter by Access">
|
|
|
|
{#each $backendUiStore.roles as role}
|
|
|
|
<option value={role._id}>{role.name}</option>
|
|
|
|
{/each}
|
|
|
|
</Select>
|
|
|
|
</div>
|
|
|
|
|
2020-12-01 17:22:06 +01:00
|
|
|
{#if $currentAsset}
|
|
|
|
<div class="nav-items-container">
|
|
|
|
<ComponentNavigationTree />
|
|
|
|
</div>
|
|
|
|
{/if}
|
|
|
|
<Modal bind:this={modal}>
|
|
|
|
<NewScreenModal />
|
|
|
|
</Modal>
|
2020-12-05 13:09:58 +01:00
|
|
|
{:else if tab === FrontendTypes.LAYOUT}
|
2020-12-05 00:16:07 +01:00
|
|
|
<i
|
|
|
|
on:click={modal.show}
|
|
|
|
data-cy="new-layout"
|
|
|
|
class="ri-add-circle-fill" />
|
2020-12-09 19:18:47 +01:00
|
|
|
{#each $store.layouts as layout, idx (layout._id)}
|
|
|
|
<Layout {layout} border={idx > 0} />
|
2020-12-02 15:49:43 +01:00
|
|
|
{/each}
|
2020-12-05 00:16:07 +01:00
|
|
|
<Modal bind:this={modal}>
|
|
|
|
<NewLayoutModal />
|
|
|
|
</Modal>
|
2020-12-01 17:22:06 +01:00
|
|
|
{/if}
|
|
|
|
</Switcher>
|
2020-05-29 14:28:12 +02:00
|
|
|
</div>
|
2020-12-01 17:22:06 +01:00
|
|
|
|
2020-10-22 19:12:40 +02:00
|
|
|
<style>
|
|
|
|
.title {
|
|
|
|
display: flex;
|
2020-12-04 15:07:56 +01:00
|
|
|
flex-direction: column;
|
|
|
|
justify-content: flex-start;
|
|
|
|
align-items: stretch;
|
2020-12-04 15:52:40 +01:00
|
|
|
position: relative;
|
2020-10-22 19:12:40 +02:00
|
|
|
}
|
|
|
|
.title i {
|
|
|
|
font-size: 20px;
|
2020-12-04 15:52:40 +01:00
|
|
|
position: absolute;
|
|
|
|
top: 0;
|
|
|
|
right: 0;
|
2020-10-22 19:12:40 +02:00
|
|
|
}
|
|
|
|
.title i:hover {
|
|
|
|
cursor: pointer;
|
|
|
|
color: var(--blue);
|
|
|
|
}
|
2020-12-09 19:18:47 +01:00
|
|
|
|
|
|
|
.role-select {
|
|
|
|
margin-bottom: var(--spacing-m);
|
|
|
|
}
|
2020-10-22 19:12:40 +02:00
|
|
|
</style>
|