123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875 |
- /* global $, module, test, equal, ok */
- ;(function () {
- 'use strict';
- function init(options) {
- return $('#treeview').treeview(options);
- }
- function getOptions(el) {
- return el.data().treeview.options;
- }
- var data = [
- {
- text: 'Parent 1',
- nodes: [
- {
- text: 'Child 1',
- nodes: [
- {
- text: 'Grandchild 1'
- },
- {
- text: 'Grandchild 2'
- }
- ]
- },
- {
- text: 'Child 2'
- }
- ]
- },
- {
- text: 'Parent 2'
- },
- {
- text: 'Parent 3'
- },
- {
- text: 'Parent 4'
- },
- {
- text: 'Parent 5'
- }
- ];
- var json = '[' +
- '{' +
- '"text": "Parent 1",' +
- '"nodes": [' +
- '{' +
- '"text": "Child 1",' +
- '"nodes": [' +
- '{' +
- '"text": "Grandchild 1"' +
- '},' +
- '{' +
- '"text": "Grandchild 2"' +
- '}' +
- ']' +
- '},' +
- '{' +
- '"text": "Child 2"' +
- '}' +
- ']' +
- '},' +
- '{' +
- '"text": "Parent 2"' +
- '},' +
- '{' +
- '"text": "Parent 3"' +
- '},' +
- '{' +
- '"text": "Parent 4"' +
- '},' +
- '{' +
- '"text": "Parent 5"' +
- '}' +
- ']';
- module('Options');
- test('Options setup', function () {
- // First test defaults option values
- var el = init(),
- options = getOptions(el);
- ok(options, 'Defaults created ok');
- equal(options.levels, 2, 'levels default ok');
- equal(options.expandIcon, 'glyphicon glyphicon-plus', 'expandIcon default ok');
- equal(options.collapseIcon, 'glyphicon glyphicon-minus', 'collapseIcon default ok');
- equal(options.emptyIcon, 'glyphicon', 'emptyIcon default ok');
- equal(options.nodeIcon, '', 'nodeIcon default ok');
- equal(options.selectedIcon, '', 'selectedIcon default ok');
- equal(options.checkedIcon, 'glyphicon glyphicon-check', 'checkedIcon default ok');
- equal(options.uncheckedIcon, 'glyphicon glyphicon-unchecked', 'uncheckedIcon default ok');
- equal(options.color, undefined, 'color default ok');
- equal(options.backColor, undefined, 'backColor default ok');
- equal(options.borderColor, undefined, 'borderColor default ok');
- equal(options.onhoverColor, '#F5F5F5', 'onhoverColor default ok');
- equal(options.selectedColor, '#FFFFFF', 'selectedColor default ok');
- equal(options.selectedBackColor, '#428bca', 'selectedBackColor default ok');
- equal(options.searchResultColor, '#D9534F', 'searchResultColor default ok');
- equal(options.searchResultBackColor, undefined, 'searchResultBackColor default ok');
- equal(options.enableLinks, false, 'enableLinks default ok');
- equal(options.highlightSelected, true, 'highlightSelected default ok');
- equal(options.highlightSearchResults, true, 'highlightSearchResults default ok');
- equal(options.showBorder, true, 'showBorder default ok');
- equal(options.showIcon, true, 'showIcon default ok');
- equal(options.showCheckbox, false, 'showCheckbox default ok');
- equal(options.showTags, false, 'showTags default ok');
- equal(options.multiSelect, false, 'multiSelect default ok');
- equal(options.onNodeChecked, null, 'onNodeChecked default ok');
- equal(options.onNodeCollapsed, null, 'onNodeCollapsed default ok');
- equal(options.onNodeDisabled, null, 'onNodeDisabled default ok');
- equal(options.onNodeEnabled, null, 'onNodeEnabled default ok');
- equal(options.onNodeExpanded, null, 'onNodeExpanded default ok');
- equal(options.onNodeSelected, null, 'onNodeSelected default ok');
- equal(options.onNodeUnchecked, null, 'onNodeUnchecked default ok');
- equal(options.onNodeUnselected, null, 'onNodeUnselected default ok');
- equal(options.onSearchComplete, null, 'onSearchComplete default ok');
- equal(options.onSearchCleared, null, 'onSearchCleared default ok');
- // Then test user options are correctly set
- var opts = {
- levels: 99,
- expandIcon: 'glyphicon glyphicon-expand',
- collapseIcon: 'glyphicon glyphicon-collapse',
- emptyIcon: 'glyphicon',
- nodeIcon: 'glyphicon glyphicon-stop',
- selectedIcon: 'glyphicon glyphicon-selected',
- checkedIcon: 'glyphicon glyphicon-checked-icon',
- uncheckedIcon: 'glyphicon glyphicon-unchecked-icon',
- color: 'yellow',
- backColor: 'purple',
- borderColor: 'purple',
- onhoverColor: 'orange',
- selectedColor: 'yellow',
- selectedBackColor: 'darkorange',
- searchResultColor: 'yellow',
- searchResultBackColor: 'darkorange',
- enableLinks: true,
- highlightSelected: false,
- highlightSearchResults: true,
- showBorder: false,
- showIcon: false,
- showCheckbox: true,
- showTags: true,
- multiSelect: true,
- onNodeChecked: function () {},
- onNodeCollapsed: function () {},
- onNodeDisabled: function () {},
- onNodeEnabled: function () {},
- onNodeExpanded: function () {},
- onNodeSelected: function () {},
- onNodeUnchecked: function () {},
- onNodeUnselected: function () {},
- onSearchComplete: function () {},
- onSearchCleared: function () {}
- };
- options = getOptions(init(opts));
- ok(options, 'User options created ok');
- equal(options.levels, 99, 'levels set ok');
- equal(options.expandIcon, 'glyphicon glyphicon-expand', 'expandIcon set ok');
- equal(options.collapseIcon, 'glyphicon glyphicon-collapse', 'collapseIcon set ok');
- equal(options.emptyIcon, 'glyphicon', 'emptyIcon set ok');
- equal(options.nodeIcon, 'glyphicon glyphicon-stop', 'nodeIcon set ok');
- equal(options.selectedIcon, 'glyphicon glyphicon-selected', 'selectedIcon set ok');
- equal(options.checkedIcon, 'glyphicon glyphicon-checked-icon', 'checkedIcon set ok');
- equal(options.uncheckedIcon, 'glyphicon glyphicon-unchecked-icon', 'uncheckedIcon set ok');
- equal(options.color, 'yellow', 'color set ok');
- equal(options.backColor, 'purple', 'backColor set ok');
- equal(options.borderColor, 'purple', 'borderColor set ok');
- equal(options.onhoverColor, 'orange', 'onhoverColor set ok');
- equal(options.selectedColor, 'yellow', 'selectedColor set ok');
- equal(options.selectedBackColor, 'darkorange', 'selectedBackColor set ok');
- equal(options.searchResultColor, 'yellow', 'searchResultColor set ok');
- equal(options.searchResultBackColor, 'darkorange', 'searchResultBackColor set ok');
- equal(options.enableLinks, true, 'enableLinks set ok');
- equal(options.highlightSelected, false, 'highlightSelected set ok');
- equal(options.highlightSearchResults, true, 'highlightSearchResults set ok');
- equal(options.showBorder, false, 'showBorder set ok');
- equal(options.showIcon, false, 'showIcon set ok');
- equal(options.showCheckbox, true, 'showCheckbox set ok');
- equal(options.showTags, true, 'showTags set ok');
- equal(options.multiSelect, true, 'multiSelect set ok');
- equal(typeof options.onNodeChecked, 'function', 'onNodeChecked set ok');
- equal(typeof options.onNodeCollapsed, 'function', 'onNodeCollapsed set ok');
- equal(typeof options.onNodeDisabled, 'function', 'onNodeDisabled set ok');
- equal(typeof options.onNodeEnabled, 'function', 'onNodeEnabled set ok');
- equal(typeof options.onNodeExpanded, 'function', 'onNodeExpanded set ok');
- equal(typeof options.onNodeSelected, 'function', 'onNodeSelected set ok');
- equal(typeof options.onNodeUnchecked, 'function', 'onNodeUnchecked set ok');
- equal(typeof options.onNodeUnselected, 'function', 'onNodeUnselected set ok');
- equal(typeof options.onSearchComplete, 'function', 'onSearchComplete set ok');
- equal(typeof options.onSearchCleared, 'function', 'onSearchCleared set ok');
- });
- test('Links enabled', function () {
- init({enableLinks:true, data:data});
- ok($('.list-group-item:first').children('a').length, 'Links are enabled');
- });
- module('Data');
- test('Accepts JSON', function () {
- var el = init({levels:1,data:json});
- equal($(el.selector + ' ul li').length, 5, 'Correct number of root nodes');
- });
- module('Behaviour');
- test('Is chainable', function () {
- var el = init();
- equal(el.addClass('test').attr('class'), 'treeview test', 'Is chainable');
- });
- test('Correct initial levels shown', function () {
- var el = init({levels:1,data:data});
- equal($(el.selector + ' ul li').length, 5, 'Correctly display 5 root nodes when levels set to 1');
- el = init({levels:2,data:data});
- equal($(el.selector + ' ul li').length, 7, 'Correctly display 5 root and 2 child nodes when levels set to 2');
- el = init({levels:3,data:data});
- equal($(el.selector + ' ul li').length, 9, 'Correctly display 5 root, 2 children and 2 grand children nodes when levels set to 3');
- });
- test('Expanding a node', function () {
- var cbWorked, onWorked = false;
- init({
- data: data,
- levels: 1,
- onNodeExpanded: function(/*event, date*/) {
- cbWorked = true;
- }
- })
- .on('nodeExpanded', function(/*event, date*/) {
- onWorked = true;
- });
- var nodeCount = $('.list-group-item').length;
- var el = $('.expand-icon:first');
- el.trigger('click');
- ok(($('.list-group-item').length > nodeCount), 'Number of nodes are increased, so node must have expanded');
- ok(cbWorked, 'onNodeExpanded function was called');
- ok(onWorked, 'nodeExpanded was fired');
- });
- test('Collapsing a node', function () {
- var cbWorked, onWorked = false;
- init({
- data: data,
- levels: 2,
- onNodeCollapsed: function(/*event, date*/) {
- cbWorked = true;
- }
- })
- .on('nodeCollapsed', function(/*event, date*/) {
- onWorked = true;
- });
- var nodeCount = $('.list-group-item').length;
- var el = $('.expand-icon:first');
- el.trigger('click');
- ok(($('.list-group-item').length < nodeCount), 'Number of nodes has decreased, so node must have collapsed');
- ok(cbWorked, 'onNodeCollapsed function was called');
- ok(onWorked, 'nodeCollapsed was fired');
- });
- test('Selecting a node', function () {
- var cbWorked, onWorked = false;
- var $tree = init({
- data: data,
- onNodeSelected: function(/*event, date*/) {
- cbWorked = true;
- }
- })
- .on('nodeSelected', function(/*event, date*/) {
- onWorked = true;
- });
- var options = getOptions($tree);
- // Simulate click
- $('.list-group-item:first').trigger('click');
- // Has class node-selected
- ok($('.list-group-item:first').hasClass('node-selected'), 'Node is correctly selected : class "node-selected" added');
-
- // Only one can be selected
- ok(($('.node-selected').length === 1), 'There is only one selected node');
- // Has correct icon
- var iconClass = options.selectedIcon || options.nodeIcon;
- ok(!iconClass || $('.expand-icon:first').hasClass(iconClass), 'Node icon is correct');
- // Events triggered
- ok(cbWorked, 'onNodeSelected function was called');
- ok(onWorked, 'nodeSelected was fired');
- });
- test('Unselecting a node', function () {
- var cbWorked, onWorked = false;
- var $tree = init({
- data: data,
- onNodeUnselected: function(/*event, date*/) {
- cbWorked = true;
- }
- })
- .on('nodeUnselected', function(/*event, date*/) {
- onWorked = true;
- });
- var options = getOptions($tree);
- // First select a node
- $('.list-group-item:first').trigger('click');
- cbWorked = onWorked = false;
- // Simulate click
- $('.list-group-item:first').trigger('click');
- // Has class node-selected
- ok(!$('.list-group-item:first').hasClass('node-selected'), 'Node is correctly unselected : class "node-selected" removed');
-
- // Only one can be selected
- ok(($('.node-selected').length === 0), 'There are no selected nodes');
- // Has correct icon
- ok(!options.nodeIcon || $('.expand-icon:first').hasClass(options.nodeIcon), 'Node icon is correct');
-
- // Events triggered
- ok(cbWorked, 'onNodeUnselected function was called');
- ok(onWorked, 'nodeUnselected was fired');
- });
- test('Selecting multiple nodes (multiSelect true)', function () {
- init({
- data: data,
- multiSelect: true
- });
- var $firstEl = $('.list-group-item:nth-child(1)').trigger('click');
- var $secondEl = $('.list-group-item:nth-child(2)').trigger('click');
- $firstEl = $('.list-group-item:nth-child(1)');
- $secondEl = $('.list-group-item:nth-child(2)');
- ok($firstEl.hasClass('node-selected'), 'First node is correctly selected : class "node-selected" added');
- ok($secondEl.hasClass('node-selected'), 'Second node is correctly selected : class "node-selected" added');
- ok(($('.node-selected').length === 2), 'There are two selected nodes');
- });
- test('Clicking a non-selectable, collapsed node expands the node', function () {
- var testData = $.extend(true, {}, data);
- testData[0].selectable = false;
- var cbCalled, onCalled = false;
- init({
- levels: 1,
- data: testData,
- onNodeSelected: function(/*event, date*/) {
- cbCalled = true;
- }
- })
- .on('nodeSelected', function(/*event, date*/) {
- onCalled = true;
- });
- var nodeCount = $('.list-group-item').length;
- var el = $('.list-group-item:first');
- el.trigger('click');
- el = $('.list-group-item:first');
- ok(!el.hasClass('node-selected'), 'Node should not be selected');
- ok(!cbCalled, 'onNodeSelected function should not be called');
- ok(!onCalled, 'nodeSelected should not fire');
- ok(($('.list-group-item').length > nodeCount), 'Number of nodes are increased, so node must have expanded');
- });
- test('Clicking a non-selectable, expanded node collapses the node', function () {
- var testData = $.extend(true, {}, data);
- testData[0].selectable = false;
- var cbCalled, onCalled = false;
- init({
- levels: 2,
- data: testData,
- onNodeSelected: function(/*event, date*/) {
- cbCalled = true;
- }
- })
- .on('nodeSelected', function(/*event, date*/) {
- onCalled = true;
- });
- var nodeCount = $('.list-group-item').length;
- var el = $('.list-group-item:first');
- el.trigger('click');
- el = $('.list-group-item:first');
- ok(!el.hasClass('node-selected'), 'Node should not be selected');
- ok(!cbCalled, 'onNodeSelected function should not be called');
- ok(!onCalled, 'nodeSelected should not fire');
- ok(($('.list-group-item').length < nodeCount), 'Number of nodes has decreased, so node must have collapsed');
- });
- test('Checking a node', function () {
- // setup test
- var cbWorked, onWorked = false;
- var $tree = init({
- data: data,
- showCheckbox: true,
- onNodeChecked: function(/*event, date*/) {
- cbWorked = true;
- }
- })
- .on('nodeChecked', function(/*event, date*/) {
- onWorked = true;
- });
- var options = getOptions($tree);
- // simulate click event on check icon
- var $el = $('.check-icon:first');
- $el.trigger('click');
- // check state is correct
- $el = $('.check-icon:first');
- ok(($el.attr('class').indexOf(options.checkedIcon) !== -1), 'Node is checked : icon is correct');
- ok(cbWorked, 'onNodeChecked function was called');
- ok(onWorked, 'nodeChecked was fired');
- });
- test('Unchecking a node', function () {
- // setup test
- var cbWorked, onWorked = false;
- var $tree = init({
- data: data,
- showCheckbox: true,
- onNodeUnchecked: function(/*event, date*/) {
- cbWorked = true;
- }
- })
- .on('nodeUnchecked', function(/*event, date*/) {
- onWorked = true;
- });
- var options = getOptions($tree);
- // first check a node
- var $el = $('.check-icon:first');
- $el.trigger('click');
- // then simulate unchecking a node
- cbWorked = onWorked = false;
- $el = $('.check-icon:first');
- $el.trigger('click');
- // check state is correct
- $el = $('.check-icon:first');
- ok(($el.attr('class').indexOf(options.uncheckedIcon) !== -1), 'Node is unchecked : icon is correct');
- ok(cbWorked, 'onNodeUnchecked function was called');
- ok(onWorked, 'nodeUnchecked was fired');
- });
- module('Methods');
- test('getNode', function () {
- var $tree = init({ data: data });
- var nodeParent1 = $tree.treeview('getNode', 0);
- equal(nodeParent1.text, 'Parent 1', 'Correct node returned : requested "Parent 1", got "Parent 1"');
- });
- test('getParent', function () {
- var $tree = init({ data: data });
- var nodeChild1 = $tree.treeview('getNode', 1);
- var parentNode = $tree.treeview('getParent', nodeChild1);
- equal(parentNode.text, 'Parent 1', 'Correct node returned : requested parent of "Child 1", got "Parent 1"');
- });
- test('getSiblings', function () {
- var $tree = init({ data: data });
- // Test root level, internally uses the this.tree
- var nodeParent1 = $tree.treeview('getNode', 0);
- var nodeParent1Siblings = $tree.treeview('getSiblings', nodeParent1);
- var isArray = (nodeParent1Siblings instanceof Array);
- var countOK = nodeParent1Siblings.length === 4;
- var resultsOK = nodeParent1Siblings[0].text === 'Parent 2';
- resultsOK = resultsOK && nodeParent1Siblings[1].text === 'Parent 3';
- resultsOK = resultsOK && nodeParent1Siblings[2].text === 'Parent 4';
- resultsOK = resultsOK && nodeParent1Siblings[3].text === 'Parent 5';
- ok(isArray, 'Correct siblings for "Parent 1" [root] : is array');
- ok(countOK, 'Correct siblings for "Parent 1" [root] : count OK');
- ok(resultsOK, 'Correct siblings for "Parent 1" [root] : results OK');
- // Test non root level, internally uses getParent.nodes
- var nodeChild1 = $tree.treeview('getNode', 1);
- var nodeChild1Siblings = $tree.treeview('getSiblings', nodeChild1);
- var isArray = (nodeChild1Siblings instanceof Array);
- var countOK = nodeChild1Siblings.length === 1;
- var results = nodeChild1Siblings[0].text === 'Child 2'
- ok(isArray, 'Correct siblings for "Child 1" [non root] : is array');
- ok(countOK, 'Correct siblings for "Child 1" [non root] : count OK');
- ok(results, 'Correct siblings for "Child 1" [non root] : results OK');
- });
- test('getSelected', function () {
- var $tree = init({ data: data })
- .treeview('selectNode', 0);
- var selectedNodes = $tree.treeview('getSelected');
- ok((selectedNodes instanceof Array), 'Result is an array');
- equal(selectedNodes.length, 1, 'Correct number of nodes returned');
- equal(selectedNodes[0].text, 'Parent 1', 'Correct node returned');
- });
- test('getUnselected', function () {
- var $tree = init({ data: data })
- .treeview('selectNode', 0);
- var unselectedNodes = $tree.treeview('getUnselected');
- ok((unselectedNodes instanceof Array), 'Result is an array');
- equal(unselectedNodes.length, 8, 'Correct number of nodes returned');
- });
- // Assumptions:
- // Default tree + expanded to 2 levels,
- // means 1 node 'Parent 1' should be expanded and therefore returned
- test('getExpanded', function () {
- var $tree = init({ data: data });
- var expandedNodes = $tree.treeview('getExpanded');
- ok((expandedNodes instanceof Array), 'Result is an array');
- equal(expandedNodes.length, 1, 'Correct number of nodes returned');
- equal(expandedNodes[0].text, 'Parent 1', 'Correct node returned');
- });
- // Assumptions:
- // Default tree + expanded to 2 levels, means only 'Parent 1' should be expanded
- // as all other parent nodes have no children their state will be collapsed
- // which means 8 of the 9 nodes should be returned
- test('getCollapsed', function () {
- var $tree = init({ data: data });
- var collapsedNodes = $tree.treeview('getCollapsed');
- ok((collapsedNodes instanceof Array), 'Result is an array');
- equal(collapsedNodes.length, 8, 'Correct number of nodes returned');
- });
- test('getChecked', function () {
- var $tree = init({ data: data, showCheckbox: true })
- .treeview('checkNode', 0);
- var checkedNodes = $tree.treeview('getChecked');
- ok((checkedNodes instanceof Array), 'Result is an array');
- equal(checkedNodes.length, 1, 'Correct number of nodes returned');
- equal(checkedNodes[0].text, 'Parent 1', 'Correct node returned');
- });
- test('getUnchecked', function () {
- var $tree = init({ data: data })
- .treeview('checkNode', 0);
- var uncheckedNodes = $tree.treeview('getUnchecked');
- ok((uncheckedNodes instanceof Array), 'Result is an array');
- equal(uncheckedNodes.length, 8, 'Correct number of nodes returned');
- });
- test('getDisabled', function () {
- var $tree = init({ data: data })
- .treeview('disableNode', 0);
- var disabledNodes = $tree.treeview('getDisabled');
- ok((disabledNodes instanceof Array), 'Result is an array');
- equal(disabledNodes.length, 1, 'Correct number of nodes returned');
- equal(disabledNodes[0].text, 'Parent 1', 'Correct node returned');
- });
- test('getEnabled', function () {
- var $tree = init({ data: data })
- .treeview('disableNode', 0);
- var enabledNodes = $tree.treeview('getEnabled');
- ok((enabledNodes instanceof Array), 'Result is an array');
- equal(enabledNodes.length, 8, 'Correct number of nodes returned');
- });
- test('disableAll / enableAll', function () {
- var $tree = init({ data: data, levels: 1 });
- $tree.treeview('disableAll');
- equal($($tree.selector + ' ul li.node-disabled').length, 5, 'Disable all works, 9 nodes with node-disabled class');
- $tree.treeview('enableAll');
- equal($($tree.selector + ' ul li.node-disabled').length, 0, 'Check all works, 9 nodes non with node-disabled class');
- });
- test('disableNode / enableNode', function () {
- var $tree = init({ data: data, levels: 1 });
- var nodeId = 0;
- var node = $tree.treeview('getNode', 0);
- // Disable node using node id
- $tree.treeview('disableNode', nodeId);
- ok($('.list-group-item:first').hasClass('node-disabled'), 'Disable node (by id) : Node has class node-disabled');
- ok(($('.node-disabled').length === 1), 'Disable node (by id) : There is only one disabled node');
- // Enable node using node id
- $tree.treeview('enableNode', nodeId);
- ok(!$('.list-group-item:first').hasClass('node-disabled'), 'Enable node (by id) : Node does not have class node-disabled');
- ok(($('.node-checked').length === 0), 'Enable node (by id) : There are no disabled nodes');
- // Disable node using node
- $tree.treeview('disableNode', node);
- ok($('.list-group-item:first').hasClass('node-disabled'), 'Disable node (by node) : Node has class node-disabled');
- ok(($('.node-disabled').length === 1), 'Disable node (by node) : There is only one disabled node');
- // Enable node using node
- $tree.treeview('enableNode', node);
- ok(!$('.list-group-item:first').hasClass('node-disabled'), 'Enable node (by node) : Node does not have class node-disabled');
- ok(($('.node-checked').length === 0), 'Enable node (by node) : There are no disabled nodes');
- });
- test('toggleNodeDisabled', function () {
- var $tree = init({ data: data, levels: 1 });
- var nodeId = 0;
- var node = $tree.treeview('getNode', 0);
- // Toggle disabled using node id
- $tree.treeview('toggleNodeDisabled', nodeId);
- ok($('.list-group-item:first').hasClass('node-disabled'), 'Toggle node (by id) : Node has class node-disabled');
- ok(($('.node-disabled').length === 1), 'Toggle node (by id) : There is only one disabled node');
- // Toggle disabled using node
- $tree.treeview('toggleNodeDisabled', node);
- ok(!$('.list-group-item:first').hasClass('node-disabled'), 'Toggle node (by node) : Node does not have class node-disabled');
- ok(($('.node-disabled').length === 0), 'Toggle node (by node) : There are no disabled nodes');
- });
- test('checkAll / uncheckAll', function () {
- var $tree = init({ data: data, levels: 3, showCheckbox: true });
- $tree.treeview('checkAll');
- equal($($tree.selector + ' ul li.node-checked').length, 9, 'Check all works, 9 nodes with node-checked class');
- equal($($tree.selector + ' ul li .glyphicon-check').length, 9, 'Check all works, 9 nodes with glyphicon-check icon');
- $tree.treeview('uncheckAll');
- equal($($tree.selector + ' ul li.node-checked').length, 0, 'Check all works, 9 nodes non with node-checked class');
- equal($($tree.selector + ' ul li .glyphicon-unchecked').length, 9, 'Check all works, 9 nodes with glyphicon-unchecked icon');
- });
- test('checkNode / uncheckNode', function () {
- var $tree = init({ data: data, showCheckbox: true });
- var options = getOptions($tree);
- var nodeId = 0;
- var node = $tree.treeview('getNode', 0);
- // Check node using node id
- $tree.treeview('checkNode', nodeId);
- ok($('.list-group-item:first').hasClass('node-checked'), 'Check node (by id) : Node has class node-checked');
- ok(($('.node-checked').length === 1), 'Check node (by id) : There is only one checked node');
- ok($('.check-icon:first').hasClass(options.checkedIcon), 'Check node (by id) : Node icon is correct');
- // Uncheck node using node id
- $tree.treeview('uncheckNode', nodeId);
- ok(!$('.list-group-item:first').hasClass('node-checked'), 'Uncheck node (by id) : Node does not have class node-checked');
- ok(($('.node-checked').length === 0), 'Uncheck node (by id) : There are no checked nodes');
- ok($('.check-icon:first').hasClass(options.uncheckedIcon), 'Uncheck node (by id) : Node icon is correct');
- // Check node using node
- $tree.treeview('checkNode', node);
- ok($('.list-group-item:first').hasClass('node-checked'), 'Check node (by node) : Node has class node-checked');
- ok(($('.node-checked').length === 1), 'Check node (by node) : There is only one checked node');
- ok($('.check-icon:first').hasClass(options.checkedIcon), 'Check node (by node) : Node icon is correct');
- // Uncheck node using node
- $tree.treeview('uncheckNode', node);
- ok(!$('.list-group-item:first').hasClass('node-checked'), 'Uncheck node (by node) : Node does not have class node-checked');
- ok(($('.node-checked').length === 0), 'Uncheck node (by node) : There are no checked nodes');
- ok($('.check-icon:first').hasClass(options.uncheckedIcon), 'Uncheck node (by node) : Node icon is correct');
- });
- test('toggleNodeChecked', function () {
- var $tree = init({ data: data, showCheckbox: true });
- var options = getOptions($tree);
- var nodeId = 0;
- var node = $tree.treeview('getNode', 0);
- // Toggle checked using node id
- $tree.treeview('toggleNodeChecked', nodeId);
- ok($('.list-group-item:first').hasClass('node-checked'), 'Toggle node (by id) : Node has class node-checked');
- ok(($('.node-checked').length === 1), 'Toggle node (by id) : There is only one checked node');
- ok($('.check-icon:first').hasClass(options.checkedIcon), 'Toggle node (by id) : Node icon is correct');
- // Toggle checked using node
- $tree.treeview('toggleNodeChecked', node);
- ok(!$('.list-group-item:first').hasClass('node-checked'), 'Toggle node (by node) : Node does not have class node-checked');
- ok(($('.node-checked').length === 0), 'Toggle node (by node) : There are no checked nodes');
- ok($('.check-icon:first').hasClass(options.uncheckedIcon), 'Toggle node (by node) : Node icon is correct');
- });
- test('selectNode / unselectNode', function () {
- var $tree = init({ data: data, selectedIcon: 'glyphicon glyphicon-selected' });
- var nodeId = 0;
- var node = $tree.treeview('getNode', 0);
- // Select node using node id
- $tree.treeview('selectNode', nodeId);
- ok($('.list-group-item:first').hasClass('node-selected'), 'Select node (by id) : Node has class node-selected');
- ok(($('.node-selected').length === 1), 'Select node (by id) : There is only one selected node');
- // Unselect node using node id
- $tree.treeview('unselectNode', nodeId);
- ok(!$('.list-group-item:first').hasClass('node-selected'), 'Unselect node (by id) : Node does not have class node-selected');
- ok(($('.node-selected').length === 0), 'Unselect node (by id) : There are no selected nodes');
- // Select node using node
- $tree.treeview('selectNode', node);
- ok($('.list-group-item:first').hasClass('node-selected'), 'Select node (by node) : Node has class node-selected');
- ok(($('.node-selected').length === 1), 'Select node (by node) : There is only one selected node');
- // Unselect node using node id
- $tree.treeview('unselectNode', node);
- ok(!$('.list-group-item:first').hasClass('node-selected'), 'Unselect node (by node) : Node does not have class node-selected');
- ok(($('.node-selected').length === 0), 'Unselect node (by node) : There are no selected nodes');
- });
- test('toggleNodeSelected', function () {
- var $tree = init({ data: data });
- var nodeId = 0;
- var node = $tree.treeview('getNode', 0);
- // Toggle selected using node id
- $tree.treeview('toggleNodeSelected', nodeId);
- ok($('.list-group-item:first').hasClass('node-selected'), 'Toggle node (by id) : Node has class node-selected');
- ok(($('.node-selected').length === 1), 'Toggle node (by id) : There is only one selected node');
- // Toggle selected using node
- $tree.treeview('toggleNodeSelected', node);
- ok(!$('.list-group-item:first').hasClass('node-selected'), 'Toggle node (by id) : Node does not have class node-selected');
- ok(($('.node-selected').length === 0), 'Toggle node (by node) : There are no selected nodes');
- });
- test('expandAll / collapseAll', function () {
- var $tree = init({ data: data, levels: 1 });
- equal($($tree.selector + ' ul li').length, 5, 'Starts in collapsed state, 5 root nodes displayed');
- $tree.treeview('expandAll');
- equal($($tree.selector + ' ul li').length, 9, 'Expand all works, all 9 nodes displayed');
- $tree.treeview('collapseAll');
- equal($($tree.selector + ' ul li').length, 5, 'Collapse all works, 5 original root nodes displayed');
- $tree.treeview('expandAll', { levels: 1 });
- equal($($tree.selector + ' ul li').length, 7, 'Expand all (levels = 1) works, correctly displayed 7 nodes');
- });
- test('expandNode / collapseNode / toggleExpanded', function () {
- var $tree = init({ data: data, levels: 1 });
- equal($($tree.selector + ' ul li').length, 5, 'Starts in collapsed state, 5 root nodes displayed');
- $tree.treeview('expandNode', 0);
- equal($($tree.selector + ' ul li').length, 7, 'Expand node (by id) works, 7 nodes displayed');
- $tree.treeview('collapseNode', 0);
- equal($($tree.selector + ' ul li').length, 5, 'Collapse node (by id) works, 5 original nodes displayed');
- $tree.treeview('toggleNodeExpanded', 0);
- equal($($tree.selector + ' ul li').length, 7, 'Toggle node (by id) works, 7 nodes displayed');
- $tree.treeview('toggleNodeExpanded', 0);
- equal($($tree.selector + ' ul li').length, 5, 'Toggle node (by id) works, 5 original nodes displayed');
- $tree.treeview('expandNode', [ 0, { levels: 2 } ]);
- equal($($tree.selector + ' ul li').length, 9, 'Expand node (levels = 2, by id) works, 9 nodes displayed');
- $tree = init({ data: data, levels: 1 });
- equal($($tree.selector + ' ul li').length, 5, 'Reset to collapsed state, 5 root nodes displayed');
- var nodeParent1 = $tree.treeview('getNode', 0);
- $tree.treeview('expandNode', nodeParent1);
- equal($($tree.selector + ' ul li').length, 7, 'Expand node (by node) works, 7 nodes displayed');
- $tree.treeview('collapseNode', nodeParent1);
- equal($($tree.selector + ' ul li').length, 5, 'Collapse node (by node) works, 5 original nodes displayed');
- $tree.treeview('toggleNodeExpanded', nodeParent1);
- equal($($tree.selector + ' ul li').length, 7, 'Toggle node (by node) works, 7 nodes displayed');
- $tree.treeview('toggleNodeExpanded', nodeParent1);
- equal($($tree.selector + ' ul li').length, 5, 'Toggle node (by node) works, 5 original nodes displayed');
- $tree.treeview('expandNode', [ nodeParent1, { levels: 2 } ]);
- equal($($tree.selector + ' ul li').length, 9, 'Expand node (levels = 2, by node) works, 9 nodes displayed');
- });
- test('revealNode', function () {
- var $tree = init({ data: data, levels: 1 });
- $tree.treeview('revealNode', 1); // Child_1
- equal($($tree.selector + ' ul li').length, 7, 'Reveal node (by id) works, reveal Child 1 and 7 nodes displayed');
- var nodeGrandchild1 = $tree.treeview('getNode', 2); // Grandchild 1
- $tree.treeview('revealNode', nodeGrandchild1);
- equal($($tree.selector + ' ul li').length, 9, 'Reveal node (by node) works, reveal Grandchild 1 and 9 nodes displayed');
- });
- test('search', function () {
- var cbWorked, onWorked = false;
- var $tree = init({
- data: data,
- onSearchComplete: function(/*event, results*/) {
- cbWorked = true;
- }
- })
- .on('searchComplete', function(/*event, results*/) {
- onWorked = true;
- });
- // Case sensitive, exact match
- var result = $tree.treeview('search', [ 'Parent 1', { ignoreCase: false, exactMatch: true } ]);
- equal(result.length, 1, 'Search "Parent 1" case sensitive, exact match - returns 1 result');
- // Case sensitive, like
- result = $tree.treeview('search', [ 'Parent', { ignoreCase: false, exactMatch: false } ]);
- equal(result.length, 5, 'Search "Parent" case sensitive, exact match - returns 5 results');
- // Case insensitive, exact match
- result = $tree.treeview('search', [ 'parent 1', { ignoreCase: true, exactMatch: true } ]);
- equal(result.length, 1, 'Search "parent 1" case insensitive, exact match - returns 1 result');
- // Case insensitive, like
- result = $tree.treeview('search', [ 'parent', { ignoreCase: true, exactMatch: false } ]);
- equal(result.length, 5, 'Search "parent" case insensitive, exact match - returns 5 results')
- // Check events fire
- ok(cbWorked, 'onSearchComplete function was called');
- ok(onWorked, 'searchComplete was fired');
- });
- test('clearSearch', function () {
- var cbWorked, onWorked = false;
- var $tree = init({
- data: data,
- onSearchCleared: function(/*event, results*/) {
- cbWorked = true;
- }
- })
- .on('searchCleared', function(/*event, results*/) {
- onWorked = true;
- });
- // Check results are cleared
- $tree.treeview('search', [ 'Parent 1', { ignoreCase: false, exactMatch: true } ]);
- equal($tree.find('.search-result').length, 1, 'Search results highlighted');
- $tree.treeview('clearSearch');
- equal($tree.find('.search-result').length, 0, 'Search results cleared');
- // Check events fire
- ok(cbWorked, 'onSearchCleared function was called');
- ok(onWorked, 'searchCleared was fired');
- });
- }());
|