forked from cornflourblue/angu-fixed-header-table
-
Notifications
You must be signed in to change notification settings - Fork 0
/
angu-fixed-header-table.js
83 lines (71 loc) · 3.23 KB
/
angu-fixed-header-table.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
/**
* AngularJS fixed header scrollable table directive
* @author Jason Watmore <[email protected]> (http://jasonwatmore.com)
* @version 1.2.6
*/
(function () {
angular
.module('anguFixedHeaderTable', [])
.directive('fixedHeader', fixedHeader);
fixedHeader.$inject = ['$timeout'];
function fixedHeader($timeout) {
return {
restrict: 'A',
link: link
};
function link($scope, $elem, $attrs, $ctrl) {
var elem = $elem[0];
// wait for data to load and then transform the table
$scope.$watch(tableDataLoaded, function(isTableDataLoaded) {
if (isTableDataLoaded) {
transformTable();
}
});
function tableDataLoaded() {
// first cell in the tbody exists when data is loaded but doesn't have a width
// until after the table is transformed
var firstCell = elem.querySelector('tbody tr:first-child td:first-child');
return firstCell && !firstCell.style.width;
}
function transformTable() {
// reset display styles so column widths are correct when measured below
angular.element(elem.querySelectorAll('thead, tbody, tfoot')).css('display', '');
// wrap in $timeout to give table a chance to finish rendering
$timeout(function () {
// set widths of columns
angular.forEach(elem.querySelectorAll('tr:first-child th'), function (thElem, i) {
var tdElems = elem.querySelector('tbody tr:first-child td:nth-child(' + (i + 1) + ')');
var tfElems = elem.querySelector('tfoot tr:first-child td:nth-child(' + (i + 1) + ')');
var columnWidth = thElem.offsetWidth;
if(tdElems.offsetWidth > thElem.offsetWidth) columnWidth = tdElems.offsetWidth;
if(thElem) thElem.style.minWidth = columnWidth + 'px';
if(thElem) thElem.style.maxWidth = columnWidth + 'px';
if(thElem) thElem.style.width = columnWidth + 'px';
if(tdElems) tdElems.style.minWidth = columnWidth + 'px';
if(tdElems) tdElems.style.maxWidth = columnWidth + 'px';
if(tdElems) tdElems.style.width = columnWidth + 'px';
if(tfElems) tfElems.style.minWidth = columnWidth + 'px';
if(tfElems) tfElems.style.maxWidth = columnWidth + 'px';
if(tfElems) tfElems.style.width = columnWidth + 'px';
});
// set css styles on thead and tbody
angular.element(elem.querySelectorAll('thead, tfoot')).css('display', 'block');
angular.element(elem.querySelectorAll('tbody')).css({
'display': 'block',
'height': $attrs.tableHeight || 'inherit',
'overflow': 'auto'
});
// reduce width of last column by width of scrollbar
var tbody = elem.querySelector('tbody');
var scrollBarWidth = tbody.offsetWidth - tbody.clientWidth;
if (scrollBarWidth > 0) {
// for some reason trimming the width by 2px lines everything up better
scrollBarWidth -= 2;
var lastColumn = elem.querySelector('tbody tr:first-child td:last-child');
lastColumn.style.width = (lastColumn.offsetWidth - scrollBarWidth) + 'px';
}
});
}
}
}
})();