mirror of
https://github.com/koalyptus/TableFilter.git
synced 2024-06-17 05:06:49 +02:00
310 lines
7.8 KiB
JavaScript
310 lines
7.8 KiB
JavaScript
(function(win, TableFilter){
|
|
// TODO: add sort to test it with different column types
|
|
var tf = new TableFilter('demo', {
|
|
base_path: '../dist/tablefilter/',
|
|
col_types: [
|
|
null, null, null,
|
|
{ type: 'formatted-number', decimal: ',', thousands: ','},
|
|
'formatted-number', null,
|
|
{ type: 'date', locale: 'fr', },
|
|
{ type: 'date', locale: 'en', format: '{dd}-{MM}-{yyyy|yy}' },
|
|
{ type: 'date', locale: 'en', format: ['{dd}-{months}-{yyyy|yy}'] },
|
|
'IpAddress',
|
|
{
|
|
type: 'date', locale: 'en',
|
|
format: ['{yyyy|yy}-{MM}-{dd} {HH}:{mm}:{ss}']
|
|
}
|
|
]
|
|
});
|
|
tf.init();
|
|
window.tf = tf;
|
|
|
|
module('Sanity checks');
|
|
test('Data types', function() {
|
|
deepEqual(tf instanceof TableFilter, true, 'TableFilter instanciated');
|
|
deepEqual(
|
|
tf.hasType(3, ['formatted-number']) &&
|
|
tf.hasType(4, ['formatted-number']),
|
|
true, 'Has number column types'
|
|
);
|
|
deepEqual(
|
|
tf.hasType(6, ['date']) &&
|
|
tf.hasType(7, ['date']) &&
|
|
tf.hasType(8, ['date']),
|
|
true, 'Has date column types'
|
|
);
|
|
});
|
|
|
|
module('Data types filtering');
|
|
test('Can filter a column with a string', function() {
|
|
// act
|
|
tf.setFilterValue(0, 'carl');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [14, 18], 'Expected rows');
|
|
|
|
});
|
|
|
|
test('Can filter a EU formatted number', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(3, '1.836,09');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [6], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a EU formatted number column with a number', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(3, 3876);
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [14], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a EU formatted number column with a number without ' +
|
|
'thousands separator', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(3, '1393,52');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [13], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a EU formatted number column with a number without ' +
|
|
'decimals', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(3, '2.805');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [7], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a formatted number', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(4, '1,836.09');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [6], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a number', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(4, 1836.09);
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [6], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a formatted number column with a number', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(4, 3876);
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [14], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a formatted number column with a number without ' +
|
|
'thousands separator', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(4, '1393.52');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [13], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a formatted number column with a number without ' +
|
|
'decimals', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(4, '2,805');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [7], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a EU formatted date column', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(6, '14/7/1994');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [16], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a EU formatted date column with different date separator',
|
|
function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(6, '20-10-97');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [17], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a formatted date column', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(7, '7/14/1994');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [16], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a formatted date column with different date separator',
|
|
function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(7, '10-20-97');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [17], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a dd-MMM-yyy formatted date column', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(8, '3-Jul-2002');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [8], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter a dd-MMM-yyy formatted date column with different date ' +
|
|
'separator', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(8, '25.Mar.2000');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [4], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter an IP address column', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(9, '219.115.156.145');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [8], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter an IP address column with a truncated IP address',
|
|
function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(9, '219.115.15');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [4, 8, 14], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter datetime format', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(10, '2006-06-03 11:59:48');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows(), [8], 'Expected rows');
|
|
});
|
|
|
|
test('Can filter datetime format with operator', function() {
|
|
// setup
|
|
tf.clearFilters();
|
|
|
|
// act
|
|
tf.setFilterValue(10, '>2006-06-03 11:59:48');
|
|
tf.filter();
|
|
|
|
// assert
|
|
deepEqual(tf.getValidRows().length, 7, 'Expected rows');
|
|
});
|
|
|
|
module('Locale helpers');
|
|
test('Can get decimal separator for given column from config', function() {
|
|
// act
|
|
var result = tf.getDecimal(3);
|
|
|
|
// assert
|
|
deepEqual(result, ',', 'Decimal separator for given column');
|
|
});
|
|
|
|
test('Can get decimal separator for given column from global setting',
|
|
function() {
|
|
// act
|
|
var result = tf.getDecimal(1);
|
|
|
|
// assert
|
|
deepEqual(result, '.', 'Decimal separator for given column');
|
|
});
|
|
|
|
module('Tear-down');
|
|
test('can destroy TableFilter DOM elements', function() {
|
|
tf.destroy();
|
|
deepEqual(tf.isInitialized(), false, 'Filters removed');
|
|
});
|
|
|
|
})(window, TableFilter);
|