Change component bar to popovers and adjust page layout to match

This commit is contained in:
Andrew Kingston 2020-10-22 20:22:09 +01:00
parent 03582938cd
commit 601fb815e5
7 changed files with 48 additions and 87 deletions

View File

@ -26,7 +26,7 @@
<div class="content"> <div class="content">
{#if withArrow} {#if withArrow}
<div class:opened class="icon arrow"> <div class:opened class="icon arrow">
<i class="ri-arrow-right-s-fill" /> <i class="ri-arrow-right-s-line" />
</div> </div>
{/if} {/if}
{#if icon} {#if icon}
@ -81,6 +81,7 @@
} }
.icon.arrow { .icon.arrow {
margin: 0 -2px 0 -6px; margin: 0 -2px 0 -6px;
font-size: 12px;
} }
.icon.arrow.opened { .icon.arrow.opened {
transform: rotate(90deg); transform: rotate(90deg);

View File

@ -18,9 +18,13 @@
<style> <style>
.tabs { .tabs {
display: flex; display: flex;
flex-direction: row;
justify-content: flex-start;
align-items: center;
list-style: none; list-style: none;
font-size: var(--font-size-m); font-size: var(--font-size-m);
font-weight: 500; font-weight: 500;
height: 24px;
} }
li { li {

View File

@ -2,23 +2,24 @@
import { goto } from "@sveltech/routify" import { goto } from "@sveltech/routify"
import { store } from "builderStore" import { store } from "builderStore"
import components from "./temporaryPanelStructure.js" import components from "./temporaryPanelStructure.js"
import CategoryTab from "./CategoryTab.svelte" import { DropdownMenu } from "@budibase/bbui"
import { Popover } from "@budibase/bbui"
import { fade, fly } from "svelte/transition"
import Tab from "./ItemTab/Tab.svelte" import Tab from "./ItemTab/Tab.svelte"
const categories = components.categories const categories = components.categories
let selectedCategory let selectedIndex
let width let anchors = []
let popover
$: anchor = selectedIndex === -1 ? null : anchors[selectedIndex]
const close = () => { const close = () => {
selectedCategory = null selectedIndex = null
popover.hide()
} }
const onCategoryChosen = (category) => { const onCategoryChosen = (category, idx) => {
if (category.isCategory) { if (category.isCategory) {
selectedCategory = selectedCategory === category ? null : category selectedIndex = idx
popover.show()
} else { } else {
onComponentChosen(category) onComponentChosen(category)
} }
@ -26,60 +27,38 @@
const onComponentChosen = (component) => { const onComponentChosen = (component) => {
store.addChildComponent(component._component, component.presetProps) store.addChildComponent(component._component, component.presetProps)
// Get ID path
const path = store.getPathToComponent($store.currentComponentInfo) const path = store.getPathToComponent($store.currentComponentInfo)
// Go to correct URL
$goto(`./:page/:screen/${path}`) $goto(`./:page/:screen/${path}`)
close() close()
} }
</script> </script>
<div class="wrapper"> <div class="container">
<div {#each categories as category, idx}
class="container" <div
bind:clientWidth={width} bind:this={anchors[idx]}
class:open={selectedCategory != null}> class="category"
{#each categories as category, idx} on:click={() => onCategoryChosen(category, idx)}>
<div {#if category.icon}<i class={category.icon} />{/if}
class="category" <span>{category.name}</span>
on:click={() => onCategoryChosen(category)} {#if category.isCategory}<i class="ri-arrow-down-s-line arrow" />{/if}
class:active={selectedCategory === category}>
{#if category.icon}<i class={category.icon} />{/if}
<span>{category.name}</span>
{#if category.isCategory}<i class="ri-arrow-down-s-line arrow" />{/if}
</div>
{/each}
</div>
{#if selectedCategory != null}
<div class="overlay" on:click={close} />
<div class="dropdown" transition:fly={{ y: -120 }}>
<Tab
list={selectedCategory}
on:selectItem={(e) => onComponentChosen(e.detail)} />
</div> </div>
{/if} {/each}
</div> </div>
<DropdownMenu bind:this={popover} {anchor} align="left">
<Tab
list={categories[selectedIndex]}
on:selectItem={(e) => onComponentChosen(e.detail)} />
</DropdownMenu>
<style> <style>
.wrapper {
position: relative;
z-index: 1;
}
.container { .container {
padding: var(--spacing-l) 40px;
display: flex; display: flex;
flex-direction: row; flex-direction: row;
justify-content: flex-start; justify-content: flex-start;
align-items: center; align-items: center;
background-color: white;
z-index: 1; z-index: 1;
width: calc(100% - 80px); height: 24px;
overflow: hidden;
}
.container.open {
} }
.category { .category {
@ -97,31 +76,10 @@
font-weight: 500; font-weight: 500;
user-select: none; user-select: none;
} }
.category.active,
.category:hover { .category:hover {
color: var(--ink); color: var(--ink);
} }
.category i:not(:last-child) { .category i:not(:last-child) {
font-size: 16px; font-size: 16px;
} }
.overlay {
position: fixed;
top: 0;
left: 0;
z-index: -2;
width: 100vw;
height: 100vh;
}
.dropdown {
position: absolute;
z-index: -1;
top: calc(100% - var(--spacing-xl));
left: 0;
width: calc(100% - 80px);
background-color: white;
padding: var(--spacing-xl) 40px;
box-shadow: 0 0 8px 4px rgba(0, 0, 0, 0.05);
}
</style> </style>

View File

@ -12,20 +12,16 @@
<style> <style>
.item-item { .item-item {
display: flex; display: flex;
flex-direction: column; flex-direction: row;
cursor: pointer; cursor: pointer;
justify-content: center; justify-content: flex-start;
align-items: center; align-items: center;
background-color: var(--grey-1);
border-radius: 5px; border-radius: 5px;
width: 120px;
height: 80px;
color: var(--grey-7); color: var(--grey-7);
} }
.item-item:hover { .item-item:hover {
background: var(--grey-2); color: var(--ink);
transition: all 0.3s;
} }
.item-icon { .item-icon {
@ -36,16 +32,16 @@
.item-text { .item-text {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
margin-top: 5px;
} }
.item-name { .item-name {
font-size: 12px; font-size: var(--font-size-xs);
font-weight: 500; font-weight: 500;
text-align: center; text-align: center;
} }
i { i {
font-size: 24px; font-size: 16px;
margin-right: 8px;
} }
</style> </style>

View File

@ -9,7 +9,7 @@
let category = list let category = list
const handleClick = item => { const handleClick = (item) => {
if (item.children && item.children.length > 0) { if (item.children && item.children.length > 0) {
list = item list = item
} else { } else {
@ -53,10 +53,12 @@
.list { .list {
display: flex; display: flex;
flex-direction: row; flex-direction: column;
justify-content: flex-start; justify-content: flex-start;
align-items: center; align-items: stretch;
gap: var(--spacing-m); gap: var(--spacing-s);
flex-wrap: wrap; flex-wrap: wrap;
padding: var(--spacing-l);
min-width: 120px;
} }
</style> </style>

View File

@ -631,7 +631,7 @@ export default {
}, },
}, },
{ {
name: "Groupedbar", name: "Grouped Bar",
_component: "@budibase/standard-components/groupedbar", _component: "@budibase/standard-components/groupedbar",
description: "Groupedbar chart", description: "Groupedbar chart",
icon: "ri-bar-chart-grouped-fill", icon: "ri-bar-chart-grouped-fill",

View File

@ -73,7 +73,7 @@
background-color: var(--white); background-color: var(--white);
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: var(--spacing-m); gap: var(--spacing-l);
padding: var(--spacing-l) var(--spacing-xl); padding: var(--spacing-l) var(--spacing-xl);
overflow-y: auto; overflow-y: auto;
border-right: 1px solid var(--grey-2); border-right: 1px solid var(--grey-2);
@ -86,13 +86,13 @@
flex-direction: column; flex-direction: column;
justify-content: flex-start; justify-content: flex-start;
align-items: stretch; align-items: stretch;
gap: var(--spacing-m); gap: var(--spacing-l);
padding: var(--spacing-l) 40px var(--spacing-xl) 40px;
} }
.preview-content { .preview-content {
background: #fff; background: #fff;
box-shadow: 0 0 12px rgba(0, 0, 0, 0.05); box-shadow: 0 0 12px rgba(0, 0, 0, 0.05);
flex: 1 1 auto; flex: 1 1 auto;
margin: var(--spacing-xl) 40px;
} }
.components-pane { .components-pane {