Skip to content

Instantly share code, notes, and snippets.

@ChadTaljaardt
Created September 26, 2016 14:45
Show Gist options
  • Save ChadTaljaardt/27146200ad6ff71e7556fde7ce6f74da to your computer and use it in GitHub Desktop.
Save ChadTaljaardt/27146200ad6ff71e7556fde7ce6f74da to your computer and use it in GitHub Desktop.
<style>
</style>
<template>
<script type="text/x-template" id="item-template">
<li>
<div :class="{bold: isFolder}" @click="toggle" @dblclick="changeType">
{{model.name}}
<span v-if="isFolder">[{{open ? '-' : '+'}}]</span>
</div>
<ul v-show="open" v-if="isFolder">
<item class="item" v-for="model in model.children" :model="model"></item>
<li @click="addChild">+</li>
</ul>
</li>
</script>
<p>(You can double click on an item to turn it into a folder.)</p>
<ul id="demo">
<item class="item" :model="treeData"></item>
</ul>
</template>
<script>
Vue.component('item', require('./Item.vue'));
var data = {
name: 'My Tree',
children: [
{ name: 'hello' },
{ name: 'wat' },
{
name: 'child folder',
children: [
{
name: 'child folder',
children: [
{ name: 'hello' },
{ name: 'wat' }
]
},
{ name: 'hello' },
{ name: 'wat' },
{
name: 'child folder',
children: [
{ name: 'hello' },
{ name: 'wat' }
]
}
]
}
]
}
export default {
data: {
treeData: data
}
}
</script>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment