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

102 lines
2.4 KiB
Svelte
Raw Normal View History

<script>
import { goto } from "@sveltech/routify"
import { store } from "builderStore"
import components from "./temporaryPanelStructure.js"
import { DropdownMenu } from "@budibase/bbui"
import { DropdownContainer, DropdownItem } from "components/common/Dropdowns"
const categories = components.categories
let selectedIndex
let anchors = []
let popover
$: anchor = selectedIndex === -1 ? null : anchors[selectedIndex]
const close = () => {
popover.hide()
}
const onCategoryChosen = (category, idx) => {
2020-10-22 18:46:21 +02:00
if (category.isCategory) {
selectedIndex = idx
popover.show()
2020-10-22 18:46:21 +02:00
} else {
onComponentChosen(category)
}
}
2020-10-27 16:28:13 +01:00
const onComponentChosen = component => {
2020-11-04 18:09:45 +01:00
store.actions.components.create(component._component, component.presetProps)
const path = store.actions.components.findRoute($store.currentComponentInfo)
$goto(`./:page/:screen/${path}`)
close()
}
</script>
<div class="container">
{#each categories as category, idx}
<div
bind:this={anchors[idx]}
class="category"
on:click={() => onCategoryChosen(category, idx)}
class:active={idx === selectedIndex}>
2020-11-13 11:29:54 +01:00
{#if category.icon}
<i class={category.icon} />
{/if}
<span>{category.name}</span>
2020-11-13 11:29:54 +01:00
{#if category.isCategory}
<i class="ri-arrow-down-s-line arrow" />
{/if}
</div>
{/each}
</div>
<DropdownMenu
on:close={() => (selectedIndex = null)}
bind:this={popover}
{anchor}
align="left">
<DropdownContainer>
{#each categories[selectedIndex].children as item}
{#if !item.showOnPages || item.showOnPages.includes($store.currentPageName)}
<DropdownItem
icon={item.icon}
title={item.name}
on:click={() => onComponentChosen(item)} />
{/if}
{/each}
</DropdownContainer>
</DropdownMenu>
<style>
.container {
display: flex;
flex-direction: row;
justify-content: flex-start;
align-items: center;
min-height: 24px;
flex-wrap: wrap;
gap: var(--spacing-l);
}
.category {
2020-10-22 18:46:21 +02:00
color: var(--grey-7);
cursor: pointer;
display: flex;
flex-direction: row;
justify-content: flex-start;
align-items: center;
gap: var(--spacing-xs);
2020-10-22 18:46:21 +02:00
font-size: var(--font-size-xs);
}
.category span {
font-weight: 500;
2020-10-22 18:46:21 +02:00
user-select: none;
}
.category.active,
.category:hover {
2020-10-22 18:46:21 +02:00
color: var(--ink);
}
.category i:not(:last-child) {
font-size: 16px;
}
</style>