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

69 lines
1.4 KiB
Svelte
Raw Normal View History

<script>
import { goto } from "@sveltech/routify"
import { splitName } from "./pagesParsing/splitRootComponentName.js"
import components from "./temporaryPanelStructure.js"
import ConfirmDialog from "components/common/ConfirmDialog.svelte"
2020-05-04 17:07:04 +02:00
import CategoryTab from "./CategoryTab.svelte"
import {
find,
sortBy,
groupBy,
values,
filter,
map,
uniqBy,
flatten,
} from "lodash/fp"
import { pipe } from "components/common/core"
import Tab from "./ItemTab/Tab.svelte"
import { store } from "builderStore"
export let toggleTab
let selectTemplateDialog
let selectedTemplateInstance
let templateInstances = []
let selectedComponent = null
const categories = components.categories
let selectedCategory = categories[0]
const onComponentChosen = component => {
2020-05-07 15:04:32 +02:00
store.addChildComponent(component._component)
2020-05-29 19:32:52 +02:00
toggleTab("Navigate")
2020-05-29 19:32:52 +02:00
// Get ID path
const path = store.getPathToComponent($store.currentComponentInfo)
// Go to correct URL
$goto(`./:page/:screen/${path}`)
}
</script>
<div class="root">
2020-05-04 17:07:04 +02:00
<CategoryTab
onClick={category => (selectedCategory = category)}
{selectedCategory}
{categories} />
<div class="panel">
<Tab
list={selectedCategory}
on:selectItem={e => onComponentChosen(e.detail)}
{toggleTab} />
2020-02-19 22:38:21 +01:00
</div>
</div>
<style>
.panel {
2020-05-27 12:11:32 +02:00
padding: 20px 0px;
display: flex;
flex-wrap: wrap;
}
</style>