Bri Prebilic Cole
Committed by Gerrit Code Review

GUI -- Device table now scrolls with a fixed height.

Created a table scrolling test page to try out having a fixed table header. - WIP

Change-Id: Ia957173d0cb46c526af3da311b441802ac5cb292
1 +<!DOCTYPE html>
2 +<!--
3 + ~ Copyright 2015 Open Networking Laboratory
4 + ~
5 + ~ Licensed under the Apache License, Version 2.0 (the "License");
6 + ~ you may not use this file except in compliance with the License.
7 + ~ You may obtain a copy of the License at
8 + ~
9 + ~ http://www.apache.org/licenses/LICENSE-2.0
10 + ~
11 + ~ Unless required by applicable law or agreed to in writing, software
12 + ~ distributed under the License is distributed on an "AS IS" BASIS,
13 + ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 + ~ See the License for the specific language governing permissions and
15 + ~ limitations under the License.
16 + -->
17 +
18 +<!--
19 + ONOS -- Displaying icons with Angular test page
20 + -->
21 +
22 +<html>
23 +<head lang="en">
24 + <meta charset="UTF-8">
25 + <title>Practice Table Formatting</title>
26 +
27 + <script type="text/javascript" src="../tp/angular.js"></script>
28 + <script type="text/javascript" src="../tp/angular-route.js"></script>
29 +
30 + <script type="text/javascript" src="../tp/d3.js"></script>
31 + <script type="text/javascript" src="../tp/jquery-2.1.1.min.js"></script>
32 +
33 + <script type="text/javascript" src="practice-table.js"></script>
34 +
35 + <style>
36 + html,
37 + body {
38 + background-color: #ddf;
39 + font-family: Arial, Helvetica, sans-serif;
40 + font-size: 9pt;
41 + }
42 +
43 + h2 {
44 + color: darkred;
45 + }
46 +
47 + </style>
48 +
49 +</head>
50 +<!-- outline for using a controller in Angular -->
51 +<body ng-app="practiceTable">
52 + <h2>Scrolling Table Practice</h2>
53 + <div>
54 + <table fixed-header>
55 + <thead>
56 + <tr>
57 + <th>URI</th>
58 + <th>Vendor</th>
59 + <th>Hardware Version</th>
60 + <th>Software Version</th>
61 + <th>Serial Number</th>
62 + <th>Protocol</th>
63 + </tr>
64 + </thead>
65 + <tbody>
66 + <tr>
67 + <td>id</td>
68 + <td>mfr</td>
69 + <td>hw</td>
70 + <td>sw</td>
71 + <td>serial</td>
72 + <td>protocol</td>
73 + </tr>
74 + <tr>
75 + <td>id</td>
76 + <td>mfr</td>
77 + <td>hw</td>
78 + <td>sw</td>
79 + <td>serial</td>
80 + <td>protocol</td>
81 + </tr>
82 + <tr>
83 + <td>id</td>
84 + <td>mfr</td>
85 + <td>hw</td>
86 + <td>sw</td>
87 + <td>serial</td>
88 + <td>protocol</td>
89 + </tr>
90 + <tr>
91 + <td>id</td>
92 + <td>mfr</td>
93 + <td>hw</td>
94 + <td>sw</td>
95 + <td>serial</td>
96 + <td>protocol</td>
97 + </tr>
98 + </tbody>
99 + </table>
100 + </div>
101 +
102 +</body>
103 +</html>
...\ No newline at end of file ...\ No newline at end of file
1 +/*
2 + * Copyright 2015 Open Networking Laboratory
3 + *
4 + * Licensed under the Apache License, Version 2.0 (the "License");
5 + * you may not use this file except in compliance with the License.
6 + * You may obtain a copy of the License at
7 + *
8 + * http://www.apache.org/licenses/LICENSE-2.0
9 + *
10 + * Unless required by applicable law or agreed to in writing, software
11 + * distributed under the License is distributed on an "AS IS" BASIS,
12 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 + * See the License for the specific language governing permissions and
14 + * limitations under the License.
15 + */
16 +
17 +/*
18 + ONOS GUI -- Showing Icons Test Module
19 + */
20 +
21 +(function () {
22 + 'use strict';
23 +
24 + function setColWidth($log, t) {
25 + var tHeaders, tdElement;
26 +
27 + // for each th, set its width to td's width
28 + // do this by looping through each td in the first row
29 + // and finding its column width
30 + tHeaders = t.selectAll('th');
31 + //loop through selectAll array
32 + tHeaders.forEach(function(thElement){
33 + tdElement = t.filter('nth-child()');
34 + $log.log(thElement);
35 + });
36 + }
37 +
38 + function setCSS(thead, tbody) {
39 +
40 + }
41 +
42 + function trimTable(tbody) {
43 +
44 + }
45 +
46 + function fixTable($log, t, th, tb) {
47 + setColWidth($log, t);
48 + setCSS(th, tb);
49 + trimTable(tb);
50 + }
51 +
52 + angular.module('practiceTable', [])
53 +
54 + .directive('fixedHeader', ['$log', '$timeout', function ($log, $timeout) {
55 + return {
56 + restrict: 'A',
57 +
58 + link: function (scope, element, attrs) {
59 + var table = d3.select(element[0]),
60 + thead = table.select('thead'),
61 + tbody = table.select('tbody');
62 +
63 + // wait until the table is visible
64 + scope.$watch(
65 + function () { return (!(table.offsetParent === null)); },
66 + function (newValue, oldValue) {
67 + if (newValue === true) {
68 + $log.log('table is visible');
69 +
70 + // ensure thead and tbody have no display
71 + thead.style('display', null);
72 + tbody.style('display', null);
73 +
74 + $timeout(function() {
75 + $log.log('timeout is over');
76 + fixTable($log, table, thead, tbody);
77 + }, 200);
78 + }
79 + });
80 + $log.log('fixedHeader directive has been created');
81 + }
82 + };
83 + }]);
84 +}());
85 +
86 +$scope.$watch(function () { return $elem.find("tbody").is(':visible') },
87 + function (newValue, oldValue) {
88 + if (newValue === true) {
89 + // reset display styles so column widths are correct when measured below
90 + $elem.find('thead, tbody, tfoot').css('display', '');
91 +
92 + // wrap in $timeout to give table a chance to finish rendering
93 + $timeout(function () {
94 + // set widths of columns
95 + $elem.find('th').each(function (i, thElem) {
96 + thElem = $(thElem);
97 + var tdElems = $elem.find('tbody tr:first td:nth-child(' + (i + 1) + ')');
98 + var tfElems = $elem.find('tfoot tr:first td:nth-child(' + (i + 1) + ')');
99 +
100 + var columnWidth = tdElems.width();
101 + thElem.width(columnWidth);
102 + tdElems.width(columnWidth);
103 + tfElems.width(columnWidth);
104 + });
105 +
106 + // set css styles on thead and tbody
107 + $elem.find('thead, tfoot').css({
108 + 'display': 'block',
109 + });
110 +
111 + $elem.find('tbody').css({
112 + 'display': 'block',
113 + 'height': $scope.tableHeight || '400px',
114 + 'overflow': 'auto'
115 + });
116 +
117 + // reduce width of last column by width of scrollbar
118 + var scrollBarWidth = $elem.find('thead').width() - $elem.find('tbody')[0].clientWidth;
119 + if (scrollBarWidth > 0) {
120 + // for some reason trimming the width by 2px lines everything up better
121 + scrollBarWidth -= 2;
122 + $elem.find('tbody tr:first td:last-child').each(function (i, elem) {
123 + $(elem).width($(elem).width() - scrollBarWidth);
124 + });
125 + }
126 + });
127 + }
128 + });
129 +}
...\ No newline at end of file ...\ No newline at end of file
...@@ -25,11 +25,11 @@ table.summary-list { ...@@ -25,11 +25,11 @@ table.summary-list {
25 25
26 /* TODO: uncomment following lines for scrollable table */ 26 /* TODO: uncomment following lines for scrollable table */
27 /* Possible CSS style for creating a scrollable table */ 27 /* Possible CSS style for creating a scrollable table */
28 -/*table.summary-list tbody {*/ 28 +table.summary-list tbody {
29 - /*height: 100px;*/ 29 + height: 500px;
30 - /*overflow: auto;*/ 30 + overflow: auto;
31 - /*display: block;*/ 31 + display: block;
32 -/*}*/ 32 +}
33 33
34 table.summary-list th { 34 table.summary-list th {
35 padding: 5px; 35 padding: 5px;
......
...@@ -3,26 +3,27 @@ ...@@ -3,26 +3,27 @@
3 <h2>Device View</h2> 3 <h2>Device View</h2>
4 <!-- TODO: uncomment and test the thead and tbody tags for CSS styling --> 4 <!-- TODO: uncomment and test the thead and tbody tags for CSS styling -->
5 <table class="summary-list"> 5 <table class="summary-list">
6 - <!-- <thead> --> 6 + <tbody>
7 <tr> 7 <tr>
8 <th></th> 8 <th></th>
9 - <th>ID</th> 9 + <th>URI</th>
10 - <th>Manufacturer</th> 10 + <th>Vendor</th>
11 <th>Hardware Version</th> 11 <th>Hardware Version</th>
12 <th>Software Version</th> 12 <th>Software Version</th>
13 + <th>Serial Number</th>
14 + <th>Protocol</th>
13 </tr> 15 </tr>
14 - <!-- </thead> -->
15 16
16 - <!-- <tbody> -->
17 <tr ng-repeat="dev in ctrl.deviceData"> 17 <tr ng-repeat="dev in ctrl.deviceData">
18 <td><div icon icon-id="{{dev._iconid_available}}"></div></td> 18 <td><div icon icon-id="{{dev._iconid_available}}"></div></td>
19 <td>{{dev.id}}</td> 19 <td>{{dev.id}}</td>
20 <td>{{dev.mfr}}</td> 20 <td>{{dev.mfr}}</td>
21 <td>{{dev.hw}}</td> 21 <td>{{dev.hw}}</td>
22 <td>{{dev.sw}}</td> 22 <td>{{dev.sw}}</td>
23 - <!-- add more property fields for table from device data --> 23 + <td>{{dev.serial}}</td>
24 + <td>{{dev.annotations.protocol}}</td>
24 </tr> 25 </tr>
25 - <!-- </tbody> --> 26 + </tbody>
26 </table> 27 </table>
27 28
28 </div> 29 </div>
......