adds backbutton and second level handling

This commit is contained in:
kevmodrome 2020-04-20 14:40:29 +02:00
parent 33fc0b1ba8
commit 63b85185f5
4 changed files with 47 additions and 16 deletions

View File

@ -18,7 +18,7 @@
{/each} {/each}
</ul> </ul>
<div class="panel"> <div class="panel">
<Tab components={selectedCategory.components} /> <Tab list={selectedCategory} />
</div> </div>
</div> </div>

View File

@ -1,17 +1,15 @@
<script> <script>
export let icon = "" export let component
export let name = ""
export let description = ""
</script> </script>
<div class="component-item"> <div class="component-item" on:click>
<div class="component-icon"> <div class="component-icon">
<i class={icon} /> <i class={component.icon} />
</div> </div>
<div class="component-text"> <div class="component-text">
<div class="component-name">{name}</div> <div class="component-name">{component.name}</div>
<div class="component-description"> <div class="component-description">
<p>{description}</p> <p>{component.description}</p>
</div> </div>
</div> </div>
</div> </div>

View File

@ -1,10 +1,39 @@
<script> <script>
import Item from "./Item.svelte" import Item from "./Item.svelte"
export let components export let list
let category = list
console.log("Components: ", components) const handleClick = component => {
if (component.type && component.type.length > 0) {
list = component
} else {
console.log("Here be dragons that add the component! 🐉")
}
}
const goBack = () => {
list = category
}
</script> </script>
{#each components as { icon, name, description }} {#if !list.isCategory}
<Item {icon} {name} {description} /> <button class="back-button" on:click={() => (list = category)}>Back</button>
{/if}
{#each list.type as component}
<Item {component} on:click={() => handleClick(component)} />
{/each} {/each}
<style>
.back-button {
font-size: 16px;
width: 100%;
text-align: center;
height: 40px;
border-radius: 3px;
border: solid 1px #e8e8ef;
background: white;
margin-bottom: 20px;
}
</style>

View File

@ -2,7 +2,8 @@ export default {
categories: [ categories: [
{ {
name: 'Basic', name: 'Basic',
components: [ isCategory: true,
type: [
{ {
name: 'Container', name: 'Container',
description: 'This component contains things within itself', description: 'This component contains things within itself',
@ -71,7 +72,8 @@ export default {
}, },
{ {
name: 'Form', name: 'Form',
components: [ isCategory: true,
type: [
{ {
name: 'Button', name: 'Button',
description: 'A basic html button that is ready for styling', description: 'A basic html button that is ready for styling',
@ -104,7 +106,8 @@ export default {
}, },
{ {
name: 'Blocks', name: 'Blocks',
components: [ isCategory: true,
type: [
{ {
name: 'Container', name: 'Container',
description: 'This component contains things within itself', description: 'This component contains things within itself',
@ -173,7 +176,8 @@ export default {
}, },
{ {
name: 'Data', name: 'Data',
components: [ isCategory: true,
type: [
{ {
name: 'Container', name: 'Container',
description: 'This component contains things within itself', description: 'This component contains things within itself',