UNPKG

10 kBJavaScriptView Raw
1
2var tf = new TableFilter('demo', {
3 base_path: '../dist/tablefilter/',
4 alternate_rows: true
5});
6tf.init();
7var tbl = tf.dom();
8var altRows = tf.feature('alternateRows');
9
10module('Sanity checks');
11test('AlternateRows component', function() {
12 deepEqual(typeof altRows, 'object', 'AlternateRows instanciated');
13 deepEqual(altRows.evenCss, 'even', 'Expected even css class');
14 deepEqual(altRows.oddCss, 'odd', 'Expected odd css class');
15});
16
17module('Feature interface');
18test('Properties', function() {
19 deepEqual(
20 altRows.tf instanceof TableFilter, true, 'TableFilter instance');
21 deepEqual(altRows.feature, 'alternateRows', 'Feature name');
22 deepEqual(altRows.enabled, true, 'Feature enabled');
23 deepEqual(altRows.initialized, true, 'Feature enabled');
24 deepEqual(typeof altRows.emitter, 'object', 'Feature has emitter instance');
25 deepEqual(typeof altRows.config, 'object', 'TF configuration object');
26 deepEqual(typeof altRows.init, 'function', 'Feature init method');
27 deepEqual(typeof altRows.destroy, 'function', 'Feature destroy method');
28 deepEqual(typeof altRows.reset, 'function', 'Feature reset method');
29 deepEqual(typeof altRows.enable, 'function', 'Feature enable method');
30 deepEqual(typeof altRows.disable, 'function', 'Feature enable method');
31 deepEqual(
32 typeof altRows.isEnabled, 'function', 'Feature enable method');
33});
34test('Can destroy', function() {
35 altRows.destroy();
36 deepEqual(altRows.initialized, false, 'not initialised');
37 deepEqual(
38 altRows.emitter.events['row-processed'].length,
39 0,
40 '`row-processed` event handler removed'
41 );
42 deepEqual(
43 altRows.emitter.events['row-paged'].length,
44 0,
45 '`row-paged` event handler removed'
46 );
47 deepEqual(
48 altRows.emitter.events['column-sorted'].length,
49 0,
50 '`column-sorted` event handler removed'
51 );
52 deepEqual(
53 altRows.emitter.events['rows-changed'].length,
54 0,
55 '`rows-changed` event handler removed'
56 );
57});
58test('Can reset', function() {
59 altRows.reset();
60 deepEqual(altRows.enabled, true, 'enabled');
61});
62test('Can disable', function() {
63 altRows.disable();
64 deepEqual(altRows.enabled, false, 'disabled');
65});
66test('Can enable', function() {
67 altRows.enable();
68 deepEqual(altRows.enabled, true, 'enabled');
69});
70test('Can init', function() {
71 altRows.destroy();
72 altRows.enable();
73 altRows.init();
74 deepEqual(altRows.enabled, true, 'enabled');
75});
76test('Can check is enabled', function() {
77 altRows.isEnabled();
78 deepEqual(altRows.enabled, true, 'enabled');
79});
80
81module('Actions');
82test('Filter column', function() {
83 tf.setFilterValue(2, '>1400');
84 tf.filter();
85
86 deepEqual(tbl.querySelectorAll('tr.odd').length, 2, 'Odd bgs removed');
87 deepEqual(tbl.querySelectorAll('tr.even').length, 2, 'Even bg removed');
88});
89
90test('Clear filters', function() {
91 tf.clearFilters();
92 tf.filter();
93
94 deepEqual(tbl.querySelectorAll('tr.odd').length, 4, 'Odd bgs removed');
95 deepEqual(tbl.querySelectorAll('tr.even').length, 3, 'Even bg removed');
96});
97
98test('Set background on a row', function() {
99 altRows.setRowBg(4);
100 deepEqual(tbl.rows[4].className, 'odd', 'Bg set on expected row');
101});
102
103test('Remove background on a row', function() {
104 altRows.removeRowBg(4);
105 deepEqual(tbl.rows[4].querySelectorAll('.odd').length,
106 0, 'Bg set on expected row');
107});
108
109test('Cannot init if initialised', function() {
110 // setup
111 var processAll = altRows.processAll;
112 var hit = 0;
113 altRows.processAll = function() { hit++; };
114 altRows.initialized = true;
115
116 // act
117 altRows.init();
118
119 // assert
120 deepEqual(hit, 0, 'processAll not called');
121
122 altRows.processAll = processAll;
123});
124
125test('Cannot processAll if not enabled', function() {
126 // setup
127 var setRowBg = altRows.setRowBg;
128 var hit = 0;
129 altRows.setRowBg = function() { hit++; };
130 altRows.enabled = false;
131
132 // act
133 altRows.processAll();
134
135 // assert
136 deepEqual(hit, 0, 'setRowBg not called');
137
138 altRows.setRowBg = setRowBg;
139});
140
141test('Cannot setRowBg if not enabled', function() {
142 // setup
143 var removeRowBg = altRows.removeRowBg;
144 var hit = 0;
145 altRows.removeRowBg = function() { hit++; };
146 altRows.enabled = false;
147
148 // act
149 altRows.setRowBg(3, 5);
150
151 // assert
152 deepEqual(hit, 0, 'removeRowBg not called');
153
154 altRows.removeRowBg = removeRowBg;
155});
156
157test('Cannot removeRowBg if row index is NaN', function() {
158 // setup
159 tf.clearFilters();
160 tf.filter();
161
162 // act
163 altRows.removeRowBg('hello');
164
165 // assert
166 deepEqual(tbl.querySelectorAll('tr.odd').length, 3, 'Expected odd bgs');
167 deepEqual(tbl.querySelectorAll('tr.even').length, 3, 'Expected even bgs');
168});
169
170test('Cannot destroy if not initialised', function() {
171 // setup
172 var getRowsNb = altRows.tf.getRowsNb;
173 var hit = 0;
174 altRows.tf.getRowsNb = function() { hit++; };
175 altRows.initialized = false;
176
177 // act
178 altRows.destroy();
179
180 // assert
181 deepEqual(hit, 0, 'tf.getRowsNb not called');
182
183 altRows.tf.getRowsNb = getRowsNb;
184});
185
186test('Remove alternating rows', function() {
187 // setup
188 altRows.initialized = true;
189
190 // act
191 altRows.destroy();
192
193 // assert
194 deepEqual(tbl.querySelectorAll('tr.odd').length, 0, 'Odd bgs removed');
195 deepEqual(tbl.querySelectorAll('tr.even').length, 0, 'Even bg removed');
196});
197
198module('Events');
199test('Can handle `row-processed` event', function() {
200 // setup
201 var processRow = altRows.processRow;
202 var hit = 0;
203 var args;
204 altRows.processRow = function() {
205 args = [].slice.call(arguments);
206 hit++;
207 };
208
209 // act
210 altRows.init();
211 tf.emitter.emit('row-processed', tf, 1, 0, true);
212
213 // assert
214 deepEqual(hit, 1, 'processRow called');
215 deepEqual(args[0], 1, 'processRow called with expected row index');
216 deepEqual(args[1], 0, 'processRow called with expected array index');
217 deepEqual(args[2], true, 'processRow called with expected isValid value');
218
219 altRows.processRow = processRow;
220});
221
222test('Can handle `row-paged` event', function() {
223 // setup
224 var processRow = altRows.processRow;
225 var hit = 0;
226 var args;
227 altRows.processRow = function() {
228 args = [].slice.call(arguments);
229 hit++;
230 };
231
232 // act
233 altRows.init();
234 tf.emitter.emit('row-paged', tf, 1, 0, true);
235
236 // assert
237 deepEqual(hit, 1, 'processRow called');
238 deepEqual(args[0], 1, 'processRow called with expected row index');
239 deepEqual(args[1], 0, 'processRow called with expected array index');
240 deepEqual(args[2], true, 'processRow called with expected isValid value');
241
242 altRows.processRow = processRow;
243});
244
245module('Grid layout');
246test('Grid layout: initialising alternating rows', function() {
247 tf.destroy();
248 tf = null;
249 tf = new TableFilter('demo', {
250 base_path: '../dist/tablefilter/',
251 grid_layout: true,
252 alternate_rows: true
253 });
254 tf.init();
255 tbl = tf.dom();
256 altRows = tf.feature('alternateRows');
257
258 deepEqual(
259 tbl.querySelectorAll('tr.odd').length, 4, 'Expected bg for odd rows');
260 deepEqual(
261 tbl.querySelectorAll('tr.even').length, 3, 'Expected bg for even rows');
262});
263
264test('Grid layout: filter column', function() {
265 tf.setFilterValue(3, '<2');
266 tf.filter();
267
268 deepEqual(tbl.querySelectorAll('tr.odd').length, 2, 'Odd bgs removed');
269 deepEqual(tbl.querySelectorAll('tr.even').length, 2, 'Even bg removed');
270});
271
272test('Grid layout: clear filters', function() {
273 tf.clearFilters();
274 tf.filter();
275
276 deepEqual(tbl.querySelectorAll('tr.odd').length, 4, 'Odd bgs removed');
277 deepEqual(tbl.querySelectorAll('tr.even').length, 3, 'Even bg removed');
278});
279
280test('Grid layout: set background on a row', function() {
281 altRows.setRowBg(4);
282 deepEqual(tbl.rows[4].className, 'odd', 'Bg set on expected row');
283});
284
285test('Grid layout: remove background on a row', function() {
286 altRows.removeRowBg(4);
287 deepEqual(tbl.rows[4].querySelectorAll('.odd').length,
288 0, 'Bg set on expected row');
289});
290
291test('Grid layout: remove alternating rows', function() {
292 altRows.destroy();
293 deepEqual(tbl.querySelectorAll('tr.odd').length, 0, 'Odd bgs removed');
294 deepEqual(tbl.querySelectorAll('tr.even').length, 0, 'Even bg removed');
295});
296
297module('Fixes');
298// Issue 365: alternating rows with column sorted at start
299test('Sort: alternating rows with column sorted at start', function() {
300 tf.destroy();
301 tf = null;
302 tf = new TableFilter('demo', {
303 base_path: '../dist/tablefilter/',
304 alternate_rows: true,
305 extensions:[{
306 name: 'sort',
307 sort_col_at_start: [2, true],
308 on_sort_loaded: checkAlternateRows
309 }]
310 });
311 tf.init();
312 altRows = tf.feature('alternateRows');
313
314 deepEqual(typeof altRows, 'object', 'AlternateRows instanciated');
315 deepEqual(altRows.evenCss, 'even', 'Expected even css class');
316 deepEqual(altRows.oddCss, 'odd', 'Expected odd css class');
317
318 function checkAlternateRows(tf) {
319 tbl = tf.dom();
320 altRows = tf.feature('alternateRows');
321
322 test('Alternate rows with sort column at start option', function() {
323 deepEqual(
324 tbl.rows[2].classList.contains('odd'),
325 true,
326 'Expected bg for rows[2]'
327 );
328 deepEqual(
329 tbl.rows[5].classList.contains('even'),
330 true,
331 'Expected bg for rows[5]'
332 );
333 });
334 }
335});