-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreactive-datatable-template.js
88 lines (65 loc) · 2.82 KB
/
reactive-datatable-template.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
Template.reactiveDatatable.rendered = function() {
var data = this.data;
if (typeof data.tableData !== 'function') {
throw new Meteor.Error('Your tableData must be a function that returns an array via Cursor.fetch(), .map() or another (hopefully reactive) means');
}
var reactiveDataTable = new ReactiveDatatable(data.options);
// Help Blaze cleanly remove entire datatable when changing template / route by
// wrapping table in existing element (#datatable_wrap) defined in the template.
var table = document.createElement('table');
var tableClasses = data.options.tableClasses || '';
table.className = 'table dataTable ' + tableClasses;
table.id = data.options.id;
// Render the table element and turn it into a DataTable
this.$('.datatable_wrapper').append(table);
var dt = $(table).DataTable(data.options);
dt.on('page.dt', function(e, settings) {
var info = dt.page.info();
reactiveDataTable.page = info.page;
});
dt.on('stateLoaded.dt', function(e, settings, data) {
console.log('state loaded', settings, data);
});
dt.on('stateLoadParams.dt', function(e, settings, data) {
console.log('stateLoadParams event fired', settings, data);
});
reactiveDataTable.datatable = dt;
// reactiveDataTable.difference = function(array) {
// var rest = Array.prototype.concat.apply(Array.prototype, Array.prototype.slice.call(arguments, 1));
// var containsEquals = function(obj, target) {
// if (obj == null) return false;
// return _.some(obj, function(value) {
// return _.isEqual(value, target);
// });
// };
// var arr1 = _.pluck(array, "_id");
// var arr2 = _.pluck(rest, "_id");
// var diff = _.difference(arr1, arr2);
// console.log('diff', diff);
// return {
// incremental: _.filter(array, function(value) { return !containsEquals(rest, value); }),
// decremental: diff
// };
// };
reactiveDataTable.difference = function(existingData, newData) {
var targetData = [],
existingDataIdArr = _.pluck(existingData, "_id"),
newDataIdArr = _.pluck(newData, "_id"),
diffIdArr = [];
if (existingData.length > newData.length) {
// remove
diffIdArr = _.difference(existingDataIdArr, newDataIdArr);
targetData = existingData;
} else {
// add
diffIdArr = _.difference(newDataIdArr, existingDataIdArr);
targetData = newData;
}
return _.filter(targetData, function(item) {
return _.contains(diffIdArr, item._id);
});
}
this.autorun(function() {
reactiveDataTable.update(data.tableData(), data.options);
});
};