blob: 32d3420ccb682bca7a9e6814a7ffcbe25d922359 [file] [log] [blame]
Simon Huntb0ec1e52015-01-28 18:13:49 -08001/*
Brian O'Connor5ab426f2016-04-09 01:19:45 -07002 * Copyright 2015-present Open Networking Laboratory
Simon Huntb0ec1e52015-01-28 18:13:49 -08003 *
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 -- Topology Panel Module.
19 Defines functions for manipulating the summary, detail, and instance panels.
20 */
21
22(function () {
23 'use strict';
24
25 // injected refs
Bri Prebilic Cole17c6d0a2015-07-16 14:56:40 -070026 var $log, $window, $rootScope, fs, ps, gs, flash, wss, bns, mast, ns;
Simon Huntb0ec1e52015-01-28 18:13:49 -080027
Simon Hunt626d2102015-01-29 11:54:50 -080028 // constants
Simon Hunt08f841d02015-02-10 14:39:20 -080029 var pCls = 'topo-p',
30 idSum = 'topo-p-summary',
Simon Hunt626d2102015-01-29 11:54:50 -080031 idDet = 'topo-p-detail',
Simon Hunt626d2102015-01-29 11:54:50 -080032 panelOpts = {
Simon Hunt8f907cc2016-06-15 18:04:01 -070033 width: 260 // summary and detail panel width
Bri Prebilic Cole69d5f4e2015-05-19 15:59:55 -070034 },
Simon Hunt8f907cc2016-06-15 18:04:01 -070035 sumMax = 226, // summary panel max height
Simon Hunt8d47a5c2016-06-15 12:56:50 -070036 padTop = 16, // summary panel padding below masthead
Simon Hunt8f907cc2016-06-15 18:04:01 -070037 padding = 16, // panel internal padding
38 padFudge = padTop + 2 * padding,
Bri Prebilic Cole17c6d0a2015-07-16 14:56:40 -070039 devPath = 'device';
Simon Hunt626d2102015-01-29 11:54:50 -080040
Simon Hunt0c6b2d32015-03-26 17:46:29 -070041 // internal state
42 var useDetails = true, // should we show details if we have 'em?
Bri Prebilic Coled8745462015-06-01 16:08:57 -070043 haveDetails = false, // do we have details that we could show?
Bri Prebilic Cole0a6ffb62015-06-04 09:32:12 -070044 sumFromTop, // summary panel distance from top of screen
45 unbindWatch;
Simon Huntb0ec1e52015-01-28 18:13:49 -080046
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -070047 // panels
48 var summary, detail;
49
50 // === -----------------------------------------------------
51 // Panel API
52 function createTopoPanel(id, opts) {
53 var p = ps.createPanel(id, opts),
Bri Prebilic Cole35d29712015-05-11 16:01:32 -070054 pid = id,
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -070055 header, body, footer;
56 p.classed(pCls, true);
57
Bri Prebilic Cole35d29712015-05-11 16:01:32 -070058 function panel() {
59 return p;
60 }
61
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -070062 function hAppend(x) {
63 return header.append(x);
64 }
65
66 function bAppend(x) {
67 return body.append(x);
68 }
69
70 function fAppend(x) {
71 return footer.append(x);
72 }
73
74 function setup() {
75 p.empty();
76
77 p.append('div').classed('header', true);
78 p.append('div').classed('body', true);
79 p.append('div').classed('footer', true);
80
81 header = p.el().select('.header');
82 body = p.el().select('.body');
83 footer = p.el().select('.footer');
84 }
85
Bri Prebilic Cole35d29712015-05-11 16:01:32 -070086 function destroy() {
87 ps.destroyPanel(pid);
88 }
89
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -070090 // fromTop is how many pixels from the top of the page the panel is
91 // max is the max height of the panel in pixels
92 // only adjusts if the body content would be 10px or larger
93 function adjustHeight(fromTop, max) {
94 var totalPHeight, avSpace,
Simon Hunt8d47a5c2016-06-15 12:56:50 -070095 overflow = 0;
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -070096
97 if (!fromTop) {
98 $log.warn('adjustHeight: height from top of page not given');
99 return null;
100 } else if (!body || !p) {
Simon Hunt5b024d72016-01-29 11:02:43 -0800101 // panel contents are not defined
102 // this may happen when window is resizing but panel has
103 // been cleared or removed
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700104 return null;
105 }
106
Simon Hunt8d47a5c2016-06-15 12:56:50 -0700107 p.el().style('top', fromTop + 'px');
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700108 p.el().style('height', null);
109 body.style('height', null);
110
111 totalPHeight = fromTop + p.height();
Simon Hunt8d47a5c2016-06-15 12:56:50 -0700112 avSpace = fs.windowSize(padFudge).height;
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700113
114 if (totalPHeight >= avSpace) {
115 overflow = totalPHeight - avSpace;
116 }
117
118 function _adjustBody(height) {
119 if (height < 10) {
120 return false;
121 } else {
122 body.style('height', height + 'px');
123 }
124 return true;
125 }
126
127 if (!_adjustBody(fs.noPxStyle(body, 'height') - overflow)) {
Simon Hunt8d47a5c2016-06-15 12:56:50 -0700128 return p.height();
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700129 }
130
131 if (max && p.height() > max) {
132 _adjustBody(fs.noPxStyle(body, 'height') - (p.height() - max));
133 }
Simon Hunt8d47a5c2016-06-15 12:56:50 -0700134 return p.height();
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700135 }
136
137 return {
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700138 panel: panel,
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700139 setup: setup,
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700140 destroy: destroy,
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700141 appendHeader: hAppend,
142 appendBody: bAppend,
143 appendFooter: fAppend,
144 adjustHeight: adjustHeight
145 };
146 }
147
Simon Hunt08f841d02015-02-10 14:39:20 -0800148 // === -----------------------------------------------------
149 // Utility functions
Simon Hunt626d2102015-01-29 11:54:50 -0800150
Simon Hunt4b668592015-01-29 17:33:53 -0800151 function addSep(tbody) {
152 tbody.append('tr').append('td').attr('colspan', 2).append('hr');
153 }
154
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700155 function addBtnFooter() {
156 detail.appendFooter('hr');
157 detail.appendFooter('div').classed('actionBtns', true);
158 }
159
Simon Hunt4b668592015-01-29 17:33:53 -0800160 function addProp(tbody, label, value) {
Simon Hunte25c5a22015-04-02 14:37:12 -0700161 var tr = tbody.append('tr'),
Bri Prebilic Colef5e48b12015-04-21 14:52:36 -0700162 lab;
163 if (typeof label === 'string') {
Simon Hunte25c5a22015-04-02 14:37:12 -0700164 lab = label.replace(/_/g, ' ');
Bri Prebilic Colef5e48b12015-04-21 14:52:36 -0700165 } else {
166 lab = label;
167 }
Simon Hunt4b668592015-01-29 17:33:53 -0800168
169 function addCell(cls, txt) {
Simon Hunta36f03b2015-04-01 15:22:49 -0700170 tr.append('td').attr('class', cls).html(txt);
Simon Hunt4b668592015-01-29 17:33:53 -0800171 }
Simon Hunte25c5a22015-04-02 14:37:12 -0700172 addCell('label', lab + ' :');
Simon Hunt4b668592015-01-29 17:33:53 -0800173 addCell('value', value);
174 }
175
Simon Hunt08f841d02015-02-10 14:39:20 -0800176 function listProps(tbody, data) {
Steven Burrowscdf6b332017-05-05 11:29:29 -0400177
178 // Suppress Lat Long in details panel if null
179 if (data.props.Latitude === null ||
180 data.props.Longitude === null) {
181 var idx = data.propOrder.indexOf('Latitude');
182 data.propOrder.splice(idx, 3);
183 }
184
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700185 data.propOrder.forEach(function (p) {
Simon Hunt08f841d02015-02-10 14:39:20 -0800186 if (p === '-') {
187 addSep(tbody);
188 } else {
189 addProp(tbody, p, data.props[p]);
190 }
191 });
192 }
193
Bri Prebilic Cole69d5f4e2015-05-19 15:59:55 -0700194 function watchWindow() {
Bri Prebilic Cole0a6ffb62015-06-04 09:32:12 -0700195 unbindWatch = $rootScope.$watchCollection(
Bri Prebilic Cole69d5f4e2015-05-19 15:59:55 -0700196 function () {
197 return {
198 h: $window.innerHeight,
199 w: $window.innerWidth
200 };
201 }, function () {
Simon Hunt8d47a5c2016-06-15 12:56:50 -0700202 var h = summary.adjustHeight(sumFromTop, sumMax),
203 ss = summary.panel().isVisible(),
204 dtop = h && ss ? sumFromTop + h + padFudge : 0,
205 dy = dtop || ss ? detail.ypos.current : sumFromTop;
206 detail.adjustHeight(dy);
Bri Prebilic Cole69d5f4e2015-05-19 15:59:55 -0700207 }
208 );
209 }
210
Simon Hunt08f841d02015-02-10 14:39:20 -0800211 // === -----------------------------------------------------
212 // Functions for populating the summary panel
213
214 function populateSummary(data) {
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700215 summary.setup();
Simon Hunt08f841d02015-02-10 14:39:20 -0800216
Bri Prebilic Cole8d3de3d2015-05-15 16:02:59 -0700217 var svg = summary.appendHeader('div')
218 .classed('icon', true)
219 .append('svg'),
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700220 title = summary.appendHeader('h2'),
221 table = summary.appendBody('table'),
Simon Hunt8f907cc2016-06-15 18:04:01 -0700222 tbody = table.append('tbody');
Simon Hunt08f841d02015-02-10 14:39:20 -0800223
Simon Hunt8f907cc2016-06-15 18:04:01 -0700224 gs.addGlyph(svg, 'bird', 24, 0, [1,1]);
Simon Hunt08f841d02015-02-10 14:39:20 -0800225
Simon Hunt0af1ec32015-07-24 12:17:55 -0700226 title.text(data.title);
Simon Hunt08f841d02015-02-10 14:39:20 -0800227 listProps(tbody, data);
228 }
229
230 // === -----------------------------------------------------
231 // Functions for populating the detail panel
232
Simon Huntb745ca62015-07-28 15:37:11 -0700233 var isDevice = {
234 switch: 1,
Rimon Ashkenazy8ebfff02016-02-01 11:56:36 +0200235 roadm: 1,
236 otn:1
Simon Huntb745ca62015-07-28 15:37:11 -0700237 };
238
Simon Hunt08f841d02015-02-10 14:39:20 -0800239 function displaySingle(data) {
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700240 detail.setup();
Simon Hunt08f841d02015-02-10 14:39:20 -0800241
Bri Prebilic Cole8d3de3d2015-05-15 16:02:59 -0700242 var svg = detail.appendHeader('div')
Bri Prebilic Cole17c6d0a2015-07-16 14:56:40 -0700243 .classed('icon clickable', true)
Bri Prebilic Cole8d3de3d2015-05-15 16:02:59 -0700244 .append('svg'),
Bri Prebilic Cole17c6d0a2015-07-16 14:56:40 -0700245 title = detail.appendHeader('h2')
246 .classed('clickable', true),
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700247 table = detail.appendBody('table'),
Simon Huntb745ca62015-07-28 15:37:11 -0700248 tbody = table.append('tbody'),
249 navFn;
Simon Hunt08f841d02015-02-10 14:39:20 -0800250
Simon Hunt8f907cc2016-06-15 18:04:01 -0700251 gs.addGlyph(svg, (data.type || 'unknown'), 26);
Simon Huntb745ca62015-07-28 15:37:11 -0700252 title.text(data.title);
253
254 // only add navigation when displaying a device
255 if (isDevice[data.type]) {
256 navFn = function () {
257 ns.navTo(devPath, { devId: data.id });
258 };
259
260 svg.on('click', navFn);
261 title.on('click', navFn);
262 }
Bri Prebilic Cole17c6d0a2015-07-16 14:56:40 -0700263
Simon Hunt08f841d02015-02-10 14:39:20 -0800264 listProps(tbody, data);
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700265 addBtnFooter();
Simon Hunt08f841d02015-02-10 14:39:20 -0800266 }
267
268 function displayMulti(ids) {
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700269 detail.setup();
Simon Hunt08f841d02015-02-10 14:39:20 -0800270
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700271 var title = detail.appendHeader('h3'),
272 table = detail.appendBody('table'),
Simon Hunt08f841d02015-02-10 14:39:20 -0800273 tbody = table.append('tbody');
274
Prince Pereira46c82d42016-09-19 13:30:50 +0530275 title.text('Selected Items');
Simon Hunt08f841d02015-02-10 14:39:20 -0800276 ids.forEach(function (d, i) {
277 addProp(tbody, i+1, d);
278 });
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700279 addBtnFooter();
Simon Hunt08f841d02015-02-10 14:39:20 -0800280 }
281
Bri Prebilic Colef5e48b12015-04-21 14:52:36 -0700282 function addAction(o) {
283 var btnDiv = d3.select('#' + idDet)
284 .select('.actionBtns')
285 .append('div')
286 .classed('actionBtn', true);
Simon Hunt3a0598f2015-08-04 19:59:04 -0700287 bns.button(btnDiv, idDet + '-' + o.id, o.gid, o.cb, o.tt);
Simon Hunt08f841d02015-02-10 14:39:20 -0800288 }
289
Simon Hunta36f03b2015-04-01 15:22:49 -0700290 var friendlyIndex = {
291 device: 1,
292 host: 0
293 };
294
295 function friendly(d) {
296 var i = friendlyIndex[d.class] || 0;
297 return (d.labels && d.labels[i]) || '';
298 }
299
300 function linkSummary(d) {
301 var o = d && d.online ? 'online' : 'offline';
302 return d ? d.type + ' / ' + o : '-';
303 }
304
Simon Hunte25c5a22015-04-02 14:37:12 -0700305 // provided to change presentation of internal type name
306 var linkTypePres = {
307 hostLink: 'edge link'
308 };
309
310 function linkType(d) {
311 return linkTypePres[d.type()] || d.type();
312 }
313
Ray Milkeyb7f0f642016-01-22 16:08:14 -0800314 function linkExpected(d) {
315 return d.expected();
316 }
317
Simon Hunte25c5a22015-04-02 14:37:12 -0700318 var coreOrder = [
Ray Milkeyb7f0f642016-01-22 16:08:14 -0800319 'Type', 'Expected', '-',
Simon Hunte25c5a22015-04-02 14:37:12 -0700320 'A_type', 'A_id', 'A_label', 'A_port', '-',
Simon Hunt5c1a9382016-06-01 19:35:35 -0700321 'B_type', 'B_id', 'B_label', 'B_port'
Simon Hunte25c5a22015-04-02 14:37:12 -0700322 ],
323 edgeOrder = [
324 'Type', '-',
325 'A_type', 'A_id', 'A_label', '-',
326 'B_type', 'B_id', 'B_label', 'B_port'
327 ];
328
Simon Hunt5c1a9382016-06-01 19:35:35 -0700329 function displayLink(data, modifyCb) {
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700330 detail.setup();
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700331
Bri Prebilic Cole8d3de3d2015-05-15 16:02:59 -0700332 var svg = detail.appendHeader('div')
333 .classed('icon', true)
334 .append('svg'),
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700335 title = detail.appendHeader('h2'),
336 table = detail.appendBody('table'),
Simon Hunte25c5a22015-04-02 14:37:12 -0700337 tbody = table.append('tbody'),
338 edgeLink = data.type() === 'hostLink',
339 order = edgeLink ? edgeOrder : coreOrder;
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700340
Simon Huntf29d8e62016-06-20 11:09:25 -0700341 gs.addGlyph(svg, 'ports', 26);
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700342 title.text('Link');
Simon Hunta36f03b2015-04-01 15:22:49 -0700343
Simon Hunt5c1a9382016-06-01 19:35:35 -0700344 var linkData = {
345 propOrder: order.slice(0), // makes a copy of the array
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700346 props: {
Simon Hunte25c5a22015-04-02 14:37:12 -0700347 Type: linkType(data),
Ray Milkeyb7f0f642016-01-22 16:08:14 -0800348 Expected: linkExpected(data),
Simon Hunta36f03b2015-04-01 15:22:49 -0700349
350 A_type: data.source.class,
351 A_id: data.source.id,
352 A_label: friendly(data.source),
353 A_port: data.srcPort,
354
355 B_type: data.target.class,
356 B_id: data.target.id,
357 B_label: friendly(data.target),
358 B_port: data.tgtPort
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700359 }
Simon Hunt5c1a9382016-06-01 19:35:35 -0700360 };
361 listProps(tbody, modifyCb(linkData, data.extra));
Simon Hunta36f03b2015-04-01 15:22:49 -0700362
Simon Hunte25c5a22015-04-02 14:37:12 -0700363 if (!edgeLink) {
Simon Hunt5c1a9382016-06-01 19:35:35 -0700364 addSep(tbody);
Simon Hunte25c5a22015-04-02 14:37:12 -0700365 addProp(tbody, 'A &rarr; B', linkSummary(data.fromSource));
366 addProp(tbody, 'B &rarr; A', linkSummary(data.fromTarget));
367 }
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700368 }
369
370 function displayNothing() {
371 haveDetails = false;
372 hideDetailPanel();
373 }
374
375 function displaySomething() {
376 haveDetails = true;
377 if (useDetails) {
378 showDetailPanel();
379 }
380 }
381
Simon Hunt08f841d02015-02-10 14:39:20 -0800382 // === -----------------------------------------------------
383 // Event Handlers
384
385 function showSummary(data) {
386 populateSummary(data);
387 showSummaryPanel();
388 }
389
Simon Hunt36a58c62015-04-08 11:00:07 -0700390 function toggleSummary(x) {
Simon Huntee7a3ce2015-04-09 13:28:37 -0700391 var kev = (x === 'keyev'),
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700392 on = kev ? !summary.panel().isVisible() : !!x,
Simon Huntee7a3ce2015-04-09 13:28:37 -0700393 verb = on ? 'Show' : 'Hide';
Simon Hunt36a58c62015-04-08 11:00:07 -0700394
395 if (on) {
Simon Hunta0eb0a82015-02-11 12:30:06 -0800396 // ask server to start sending summary data.
Simon Hunt237676b52015-03-10 19:04:26 -0700397 wss.sendEvent('requestSummary');
Simon Hunta0eb0a82015-02-11 12:30:06 -0800398 // note: the summary panel will appear, once data arrives
Simon Hunt36a58c62015-04-08 11:00:07 -0700399 } else {
400 hideSummaryPanel();
Simon Hunt6036b192015-02-11 11:20:26 -0800401 }
Simon Huntee7a3ce2015-04-09 13:28:37 -0700402 flash.flash(verb + ' summary panel');
403 return on;
Simon Hunt6036b192015-02-11 11:20:26 -0800404 }
Simon Hunt08f841d02015-02-10 14:39:20 -0800405
406 // === -----------------------------------------------------
407 // === LOGIC For showing/hiding summary and detail panels...
408
Simon Hunt626d2102015-01-29 11:54:50 -0800409 function showSummaryPanel() {
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700410 function _show() {
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700411 summary.panel().show();
Bri Prebilic Cole69d5f4e2015-05-19 15:59:55 -0700412 summary.adjustHeight(sumFromTop, sumMax);
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700413 }
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700414 if (detail.panel().isVisible()) {
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700415 detail.down(_show);
Simon Hunt6036b192015-02-11 11:20:26 -0800416 } else {
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700417 _show();
Simon Hunt6036b192015-02-11 11:20:26 -0800418 }
Simon Huntc252aa62015-02-10 16:45:39 -0800419 }
420
421 function hideSummaryPanel() {
Simon Hunta0eb0a82015-02-11 12:30:06 -0800422 // instruct server to stop sending summary data
Simon Hunt237676b52015-03-10 19:04:26 -0700423 wss.sendEvent("cancelSummary");
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700424 summary.panel().hide(detail.up);
Simon Hunt4b668592015-01-29 17:33:53 -0800425 }
Simon Hunt626d2102015-01-29 11:54:50 -0800426
Simon Hunt08f841d02015-02-10 14:39:20 -0800427 function showDetailPanel() {
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700428 if (summary.panel().isVisible()) {
429 detail.down(detail.panel().show);
Simon Hunt6036b192015-02-11 11:20:26 -0800430 } else {
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700431 detail.up(detail.panel().show);
Simon Hunt6036b192015-02-11 11:20:26 -0800432 }
Simon Hunt08f841d02015-02-10 14:39:20 -0800433 }
434
435 function hideDetailPanel() {
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700436 detail.panel().hide();
Simon Hunt08f841d02015-02-10 14:39:20 -0800437 }
438
Simon Hunt6036b192015-02-11 11:20:26 -0800439 // ==========================
Simon Hunt08f841d02015-02-10 14:39:20 -0800440
Simon Hunt6036b192015-02-11 11:20:26 -0800441 function augmentDetailPanel() {
Bri Prebilic Coled8745462015-06-01 16:08:57 -0700442 var d = detail,
Simon Hunt8d47a5c2016-06-15 12:56:50 -0700443 downPos = sumFromTop + sumMax + padFudge;
Bri Prebilic Coled8745462015-06-01 16:08:57 -0700444 d.ypos = { up: sumFromTop, down: downPos, current: downPos};
Simon Hunt6036b192015-02-11 11:20:26 -0800445
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700446 d._move = function (y, cb) {
Bri Prebilic Cole69d5f4e2015-05-19 15:59:55 -0700447 var yp = d.ypos,
448 endCb;
449
450 if (fs.isF(cb)) {
451 endCb = function () {
452 cb();
453 d.adjustHeight(d.ypos.current);
454 }
455 } else {
456 endCb = function () {
457 d.adjustHeight(d.ypos.current);
458 }
459 }
Simon Hunt6036b192015-02-11 11:20:26 -0800460 if (yp.current !== y) {
461 yp.current = y;
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700462 d.panel().el().transition().duration(300)
Simon Hunt6036b192015-02-11 11:20:26 -0800463 .each('end', endCb)
464 .style('top', yp.current + 'px');
465 } else {
466 endCb();
467 }
468 };
469
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700470 d.down = function (cb) { d._move(d.ypos.down, cb); };
471 d.up = function (cb) { d._move(d.ypos.up, cb); };
Simon Hunt6036b192015-02-11 11:20:26 -0800472 }
Simon Hunt08f841d02015-02-10 14:39:20 -0800473
Simon Hunt239e5882015-04-23 15:07:04 -0700474 function toggleUseDetailsFlag(x) {
Simon Huntee7a3ce2015-04-09 13:28:37 -0700475 var kev = (x === 'keyev'),
476 verb;
477
478 useDetails = kev ? !useDetails : !!x;
479 verb = useDetails ? 'Enable' : 'Disable';
480
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700481 if (useDetails) {
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700482 if (haveDetails) {
483 showDetailPanel();
484 }
485 } else {
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700486 hideDetailPanel();
487 }
Simon Huntee7a3ce2015-04-09 13:28:37 -0700488 flash.flash(verb + ' details panel');
489 return useDetails;
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700490 }
491
Simon Hunt4b668592015-01-29 17:33:53 -0800492 // ==========================
493
Simon Hunt237676b52015-03-10 19:04:26 -0700494 function initPanels() {
Bri Prebilic Coled8745462015-06-01 16:08:57 -0700495 sumFromTop = mast.mastHeight() + padTop;
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700496 summary = createTopoPanel(idSum, panelOpts);
497 detail = createTopoPanel(idDet, panelOpts);
Simon Hunt6036b192015-02-11 11:20:26 -0800498
499 augmentDetailPanel();
Bri Prebilic Cole69d5f4e2015-05-19 15:59:55 -0700500 watchWindow();
Simon Hunt4b668592015-01-29 17:33:53 -0800501 }
502
503 function destroyPanels() {
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700504 summary.destroy();
505 summary = null;
506
507 detail.destroy();
508 detail = null;
Simon Hunt239e5882015-04-23 15:07:04 -0700509 haveDetails = false;
Bri Prebilic Cole0a6ffb62015-06-04 09:32:12 -0700510 unbindWatch();
Simon Hunt626d2102015-01-29 11:54:50 -0800511 }
512
513 // ==========================
514
Simon Huntb0ec1e52015-01-28 18:13:49 -0800515 angular.module('ovTopo')
516 .factory('TopoPanelService',
Bri Prebilic Cole69d5f4e2015-05-19 15:59:55 -0700517 ['$log', '$window', '$rootScope', 'FnService', 'PanelService', 'GlyphService',
Bri Prebilic Coled8745462015-06-01 16:08:57 -0700518 'FlashService', 'WebSocketService', 'ButtonService', 'MastService',
Bri Prebilic Cole17c6d0a2015-07-16 14:56:40 -0700519 'NavService',
Simon Huntb0ec1e52015-01-28 18:13:49 -0800520
Bri Prebilic Cole69d5f4e2015-05-19 15:59:55 -0700521 function (_$log_, _$window_, _$rootScope_,
Bri Prebilic Cole17c6d0a2015-07-16 14:56:40 -0700522 _fs_, _ps_, _gs_, _flash_, _wss_, _bns_, _mast_, _ns_) {
Simon Huntb0ec1e52015-01-28 18:13:49 -0800523 $log = _$log_;
Bri Prebilic Cole69d5f4e2015-05-19 15:59:55 -0700524 $window = _$window_;
525 $rootScope = _$rootScope_;
Simon Hunt6036b192015-02-11 11:20:26 -0800526 fs = _fs_;
Simon Huntb0ec1e52015-01-28 18:13:49 -0800527 ps = _ps_;
Simon Huntc9b73162015-01-29 14:02:15 -0800528 gs = _gs_;
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700529 flash = _flash_;
Simon Hunt237676b52015-03-10 19:04:26 -0700530 wss = _wss_;
Bri Prebilic Colef5e48b12015-04-21 14:52:36 -0700531 bns = _bns_;
Bri Prebilic Coled8745462015-06-01 16:08:57 -0700532 mast = _mast_;
Bri Prebilic Cole17c6d0a2015-07-16 14:56:40 -0700533 ns = _ns_;
Simon Huntb0ec1e52015-01-28 18:13:49 -0800534
Simon Huntb0ec1e52015-01-28 18:13:49 -0800535 return {
536 initPanels: initPanels,
Simon Hunt626d2102015-01-29 11:54:50 -0800537 destroyPanels: destroyPanels,
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700538 createTopoPanel: createTopoPanel,
Simon Hunt08f841d02015-02-10 14:39:20 -0800539
540 showSummary: showSummary,
Simon Hunt6036b192015-02-11 11:20:26 -0800541 toggleSummary: toggleSummary,
Thomas Vachuska0af26912016-03-21 21:37:30 -0700542 hideSummary: hideSummaryPanel,
Simon Hunt08f841d02015-02-10 14:39:20 -0800543
Simon Hunt239e5882015-04-23 15:07:04 -0700544 toggleUseDetailsFlag: toggleUseDetailsFlag,
Simon Hunt08f841d02015-02-10 14:39:20 -0800545 displaySingle: displaySingle,
546 displayMulti: displayMulti,
Simon Hunt0c6b2d32015-03-26 17:46:29 -0700547 displayLink: displayLink,
548 displayNothing: displayNothing,
549 displaySomething: displaySomething,
Bri Prebilic Cole684bcb72015-05-11 12:00:24 -0700550 addAction: addAction,
Simon Hunt08f841d02015-02-10 14:39:20 -0800551
Bri Prebilic Cole35d29712015-05-11 16:01:32 -0700552 detailVisible: function () { return detail.panel().isVisible(); },
553 summaryVisible: function () { return summary.panel().isVisible(); }
Simon Huntb0ec1e52015-01-28 18:13:49 -0800554 };
555 }]);
556}());