blob: 84421c9afe817c3ca5f3db003848df8237346f86 [file] [log] [blame]
Steven Burrowsaf3159d2016-08-25 14:54:30 +01001/*
2 * Copyright 2016-present 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 -- Topology Breadcrumb Module.
19 Module that renders the breadcrumbs for regions
20 */
21
Steven Burrowsdfa52b02016-09-02 13:50:43 +010022(function () {
23
Steven Burrowsaf3159d2016-08-25 14:54:30 +010024 'use strict';
25
26 var $log, wss;
27
Steven Burrowsdfa52b02016-09-02 13:50:43 +010028 // Internal
Steven Burrowsaf3159d2016-08-25 14:54:30 +010029 var breadcrumbContainer,
Steven Burrowsaf96a212016-12-28 12:57:02 +000030 breadcrumbs,
31 layout;
Steven Burrowsaf3159d2016-08-25 14:54:30 +010032
33 function init() {
Steven Burrowsdfa52b02016-09-02 13:50:43 +010034 $log.debug("Topo2BreadcrumbService Initiated");
Steven Burrowsaf3159d2016-08-25 14:54:30 +010035 breadcrumbs = [];
Steven Burrows8ea5dea2016-12-27 13:28:41 +000036 breadcrumbContainer = d3.select('#breadcrumbs');
37
38 breadcrumbContainer
39 .append('span')
Steven Burrowsd8e6c332016-09-27 10:40:53 -070040 .text('Regions: ');
Steven Burrows8ea5dea2016-12-27 13:28:41 +000041
Steven Burrowsaf3159d2016-08-25 14:54:30 +010042 render();
43 }
44
45 function addBreadcrumb(crumbs) {
Steven Burrowsdfa52b02016-09-02 13:50:43 +010046 breadcrumbContainer.selectAll('.breadcrumb').remove();
47 breadcrumbs = crumbs.reverse();
Steven Burrowsaf3159d2016-08-25 14:54:30 +010048 render();
49 }
50
51 function navigateToRegion(data, index) {
52
53 if (index === breadcrumbs.length - 1) {
54 return;
55 }
56
57 // Remove breadcrumbs after index;
58 breadcrumbs.splice(index + 1);
59
60 wss.sendEvent('topo2navRegion', {
61 dir: 'up',
62 rid: data.id
63 });
64
Steven Burrowsaf96a212016-12-28 12:57:02 +000065 layout.createForceElements();
66 layout.transitionDownRegion();
67
Steven Burrowsaf3159d2016-08-25 14:54:30 +010068 render();
69 }
70
71 function render() {
72
73 var selection = breadcrumbContainer.selectAll('.breadcrumb')
74 .data(breadcrumbs);
75
76 selection.enter()
77 .append('div')
78 .attr('class', 'breadcrumb')
79 .on('click', navigateToRegion)
Steven Burrowsd8e6c332016-09-27 10:40:53 -070080 .append('a')
Steven Burrowsaf3159d2016-08-25 14:54:30 +010081 .text(function (d) {
82 return d.name;
83 });
84
85 selection.exit()
86 .transition()
87 .duration(200)
88 .style('opacity', 0)
89 .remove();
90 }
91
Steven Burrows8ea5dea2016-12-27 13:28:41 +000092 function hide() {
93
94 var view = d3.select('body');
95 view.classed('breadcrumb--hidden', true);
96
97 var startTranslateState = 'translate(0px,0%)',
98 endTranslateState = 'translate(0px,-100%)',
99 translateInterpolator = d3.interpolateString(startTranslateState, endTranslateState);
100
101 breadcrumbContainer
102 .transition()
103 .duration(600)
104 .style('opacity', 0)
105 .styleTween('transform', function (d) {
106 return translateInterpolator;
107 });
Steven Burrowsaf96a212016-12-28 12:57:02 +0000108 }
Steven Burrows8ea5dea2016-12-27 13:28:41 +0000109
Steven Burrowsaf96a212016-12-28 12:57:02 +0000110 function addLayout(_layout_) {
111 layout = _layout_;
Steven Burrows8ea5dea2016-12-27 13:28:41 +0000112 }
113
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100114 angular.module('ovTopo2')
Steven Burrowsaf96a212016-12-28 12:57:02 +0000115 .factory('Topo2BreadcrumbService', [
116 '$log', 'WebSocketService',
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100117 function (_$log_, _wss_) {
118
119 $log = _$log_;
120 wss = _wss_;
121
122 return {
123 init: init,
Steven Burrows8ea5dea2016-12-27 13:28:41 +0000124 addBreadcrumb: addBreadcrumb,
Steven Burrowsaf96a212016-12-28 12:57:02 +0000125 addLayout: addLayout,
Steven Burrows8ea5dea2016-12-27 13:28:41 +0000126 hide: hide
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100127 };
Steven Burrowsaf96a212016-12-28 12:57:02 +0000128 }
129 ]);
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100130})();