TableFilter/test/test-cols-visibility-grid-l...

166 lines
5.2 KiB
JavaScript

var tf = new TableFilter('demo', {
base_path: '../dist/tablefilter/',
grid_layout: true,
extensions:[{ name: 'colsVisibility' }]
});
tf.init();
var ext;
module('Sanity checks');
test('Extension initialization', function() {
ext = tf.extension('colsVisibility');
deepEqual(tf instanceof TableFilter, true, 'TableFilter instanciated');
notEqual(ext, null, 'Extension instanciated');
deepEqual(ext.initialized, true, 'Extension initialized');
deepEqual(ext.text, 'Hide: ', 'Text setting');
deepEqual(ext.btnText, 'Columns▼', 'Button text setting');
});
module('UI checks');
test('UI elements', function() {
ext = tf.extension('colsVisibility');
var span = ext.spanEl;
var cont = ext.contEl;
var btn = ext.btnEl;
deepEqual(span.nodeName, 'SPAN', 'Container element');
deepEqual(cont.nodeName, 'DIV', 'Container element');
deepEqual(cont.getElementsByTagName('p')[0].innerHTML,
'Hide: ', 'Expected text');
deepEqual(btn.nodeName, 'A', 'Button element');
deepEqual(btn.innerHTML, 'Columns▼');
});
module('Behaviour');
test('Toggle columns list container', function() {
ext = tf.extension('colsVisibility');
ext.toggle();
deepEqual(ext.contEl.style.display, 'inline', 'columns list visible');
ext.toggle();
deepEqual(ext.contEl.style.display, 'none', 'columns list visible');
});
test('Hide columns', function() {
// setup
ext = tf.extension('colsVisibility');
var cols = tf.dom().getElementsByTagName('COL');
// act
ext.hideCol(2);
ext.hideCol(3);
// assert
deepEqual(ext.isColHidden(2), true, 'Expected column is hidden');
deepEqual(ext.isColHidden(3), true, 'Expected column is hidden');
deepEqual(cols[2].style.display, 'none', 'Column`s element display value');
deepEqual(cols[3].style.display, 'none', 'Column`s element display value');
});
test('Show columns', function() {
// setup
ext = tf.extension('colsVisibility');
var cols = tf.dom().getElementsByTagName('COL');
// act
ext.showCol(2);
ext.showCol(3);
// assert
deepEqual(ext.isColHidden(2), false, 'Expected column is displayed');
deepEqual(ext.isColHidden(3), false, 'Expected column is displayed');
deepEqual(cols[2].style.display, '', 'Column`s element display value');
deepEqual(cols[3].style.display, '', 'Column`s element display value');
});
test('Toggle column', function() {
ext = tf.extension('colsVisibility');
ext.toggleCol(2);
deepEqual(ext.isColHidden(2), true, 'Expected column is hidden');
ext.toggleCol(2);
deepEqual(ext.isColHidden(2), false, 'Expected column is displayed');
});
test('Popup container auto-closes when user clicks away', function() {
// setup
ext = tf.extension('colsVisibility');
ext.toggle();
// act
var evObj = document.createEvent('HTMLEvents');
evObj.initEvent('mouseup', true, true);
// mouseup fired from a table cell
tf.dom().rows[3].cells[2].dispatchEvent(evObj);
// assert
deepEqual(ext.contEl.style.display, 'none',
'Popup container closed after user clicks away'
);
});
test('Close button closes popup', function() {
// setup
ext = tf.extension('colsVisibility');
ext.toggle();
// act
var evObj = document.createEvent('HTMLEvents');
evObj.initEvent('click', true, true);
ext.contEl.querySelector('.colVis').dispatchEvent(evObj);
// assert
deepEqual(ext.contEl.style.display, 'none',
'Close button closes popup'
);
});
test('Button closes popup when already open', function() {
// setup
ext = tf.extension('colsVisibility');
ext.toggle();
// act
var evObj = document.createEvent('HTMLEvents');
evObj.initEvent('click', true, true);
ext.btnEl.dispatchEvent(evObj);
// assert
deepEqual(ext.contEl.style.display, 'none',
'Close button closes popup'
);
});
test('Toggle columns list container', function() {
ext = tf.extension('colsVisibility');
ext.toggle();
deepEqual(ext.contEl.style.display, 'inline', 'columns list visible');
ext.toggle();
deepEqual(ext.contEl.style.display, 'none', 'columns list visible');
});
test('Hide columns', function() {
ext = tf.extension('colsVisibility');
ext.hideCol(2);
ext.hideCol(3);
deepEqual(ext.isColHidden(2), true, 'Expected column is hidden');
deepEqual(ext.isColHidden(3), true, 'Expected column is hidden');
});
test('Show columns', function() {
ext = tf.extension('colsVisibility');
ext.showCol(2);
ext.showCol(3);
deepEqual(ext.isColHidden(2), false, 'Expected column is displayed');
deepEqual(ext.isColHidden(3), false, 'Expected column is displayed');
});
test('Toggle column', function() {
ext = tf.extension('colsVisibility');
ext.toggleCol(2);
deepEqual(ext.isColHidden(2), true, 'Expected column is hidden');
ext.toggleCol(2);
deepEqual(ext.isColHidden(2), false, 'Expected column is displayed');
});
test('Destroy extension and tablefilter', function() {
ext = tf.extension('colsVisibility');
ext.destroy();
deepEqual(ext.initialized, false, 'Extension no longer initialized');
deepEqual(ext.contEl, null, 'Columns list container removed');
deepEqual(ext.btnEl, null, 'Button removed');
tf.destroy();
});