angular-ui-tree
Version:
An AngularJS UI component that can sort nested lists, provides drag & drop support and doesn't depend on jQuery
78 lines (71 loc) • 3.17 kB
HTML
<!-- Nested node template -->
<script type="text/ng-template" id="nodes_renderer1.html">
<div ui-tree-handle class="tree-node tree-node-content">
<a class="btn btn-success btn-xs" data-nodrag ng-click="toggle(this)"><span class="glyphicon" ng-class="{'glyphicon-chevron-right': collapsed, 'glyphicon-chevron-down': !collapsed}"></span></a>
<input type="text" ng-model="node.title">
<a class="pull-right btn btn-danger btn-xs" data-nodrag ng-click="remove(this)"><span class="glyphicon glyphicon-remove"></span></a>
<a class="pull-right btn btn-primary btn-xs" data-nodrag ng-click="newSubItem(this)" style="margin-right: 8px;"><span class="glyphicon glyphicon-plus"></span></a>
</div>
<ol ui-tree-nodes="" ng-model="node.nodes" ng-class="{hidden: collapsed}">
<li ng-repeat="node in node.nodes" ui-tree-node ng-include="'nodes_renderer1.html'">
</li>
</ol>
</script>
<script type="text/ng-template" id="nodes_renderer2.html">
<div class="tree-node">
<div class="pull-left tree-handle" ui-tree-handle>
<span class="glyphicon glyphicon-list"></span>
</div>
<div class="tree-node-content">
<a class="btn btn-success btn-xs" data-nodrag ng-click="toggle(this)">
<span class="glyphicon" ng-class="{
'glyphicon-chevron-right': collapsed,
'glyphicon-chevron-down': !collapsed
}">
</span>
</a>
<input type="text" ng-model="node.title">
<a class="pull-right btn btn-danger btn-xs" data-nodrag ng-click="remove(this)"><span class="glyphicon glyphicon-remove"></span></a>
<a class="pull-right btn btn-primary btn-xs" data-nodrag ng-click="newSubItem(this)" style="margin-right: 8px;"><span class="glyphicon glyphicon-plus"></span></a>
</div>
</div>
<ol ui-tree-nodes="" ng-model="node.nodes" ng-class="{hidden: collapsed}">
<li ng-repeat="node in node.nodes" ui-tree-node ng-include="'nodes_renderer2.html'">
</li>
</ol>
</script>
<div class="row">
<div class="col-sm-12">
<h3>Connected Trees Cloning</h3>
<p>
The <code>data-clone-enabled</code> attribute can be added to a ui-tree element to allow nodes to be copied to another ui-tree rather than moved. Add <code>data-nodrop-enabled</code> to the source tree to leave the node in the tree while cloning.
</p>
</div>
</div>
<div class="row">
<div class="col-sm-6">
<h3>Tree 1 - Source</h3>
<div ui-tree id="tree1-root" data-clone-enabled="true" data-nodrop-enabled="true">
<ol ui-tree-nodes="" ng-model="tree1">
<li ng-repeat="node in tree1" ui-tree-node ng-include="'nodes_renderer1.html'"></li>
</ol>
</div>
</div>
<div class="col-sm-6">
<h3>Tree 2 - Destination</h3>
<div ui-tree id="tree2-root" data-clone-enabled="true">
<ol ui-tree-nodes="" ng-model="tree2">
<li ng-repeat="node in tree2" ui-tree-node ng-include="'nodes_renderer2.html'"></li>
</ol>
</div>
</div>
</div>
<h3>Data binding</h3>
<div class="row">
<div class="col-sm-6">
<pre class="code">{{ tree1 | json }}</pre>
</div>
<div class="col-sm-6">
<pre class="code">{{ tree2 | json }}</pre>
</div>
</div>