blob: d2a1391539e234ab443992d0d09d41bf22b80122 [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
Steven Burrows6a4febe2017-04-20 11:45:33 -040026 var $log, $loc, wss, t2rns;
Steven Burrowsaf3159d2016-08-25 14:54:30 +010027
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 Burrowsaf3159d2016-08-25 14:54:30 +010034 breadcrumbs = [];
Steven Burrows8ea5dea2016-12-27 13:28:41 +000035 breadcrumbContainer = d3.select('#breadcrumbs');
36
37 breadcrumbContainer
38 .append('span')
Steven Burrowsd8e6c332016-09-27 10:40:53 -070039 .text('Regions: ');
Steven Burrows8ea5dea2016-12-27 13:28:41 +000040
Steven Burrowsaf3159d2016-08-25 14:54:30 +010041 render();
42 }
43
44 function addBreadcrumb(crumbs) {
Steven Burrowsdfa52b02016-09-02 13:50:43 +010045 breadcrumbContainer.selectAll('.breadcrumb').remove();
46 breadcrumbs = crumbs.reverse();
Steven Burrowsaf3159d2016-08-25 14:54:30 +010047 render();
48 }
49
50 function navigateToRegion(data, index) {
Steven Burrowsaf3159d2016-08-25 14:54:30 +010051 if (index === breadcrumbs.length - 1) {
52 return;
53 }
54
55 // Remove breadcrumbs after index;
56 breadcrumbs.splice(index + 1);
Steven Burrows6a4febe2017-04-20 11:45:33 -040057 t2rns.navigateToRegion(data.id);
Steven Burrowsaf96a212016-12-28 12:57:02 +000058
Steven Burrowsaf3159d2016-08-25 14:54:30 +010059 render();
60 }
61
62 function render() {
Steven Burrowsaf3159d2016-08-25 14:54:30 +010063 var selection = breadcrumbContainer.selectAll('.breadcrumb')
64 .data(breadcrumbs);
65
66 selection.enter()
67 .append('div')
68 .attr('class', 'breadcrumb')
69 .on('click', navigateToRegion)
Steven Burrowsd8e6c332016-09-27 10:40:53 -070070 .append('a')
Steven Burrowsaf3159d2016-08-25 14:54:30 +010071 .text(function (d) {
72 return d.name;
73 });
74
75 selection.exit()
76 .transition()
77 .duration(200)
78 .style('opacity', 0)
79 .remove();
80 }
81
Steven Burrows8ea5dea2016-12-27 13:28:41 +000082 function hide() {
Steven Burrows8ea5dea2016-12-27 13:28:41 +000083 var view = d3.select('body');
84 view.classed('breadcrumb--hidden', true);
85
86 var startTranslateState = 'translate(0px,0%)',
87 endTranslateState = 'translate(0px,-100%)',
88 translateInterpolator = d3.interpolateString(startTranslateState, endTranslateState);
89
90 breadcrumbContainer
91 .transition()
92 .duration(600)
93 .style('opacity', 0)
94 .styleTween('transform', function (d) {
95 return translateInterpolator;
96 });
Steven Burrowsaf96a212016-12-28 12:57:02 +000097 }
Steven Burrows8ea5dea2016-12-27 13:28:41 +000098
Steven Burrowsaf96a212016-12-28 12:57:02 +000099 function addLayout(_layout_) {
100 layout = _layout_;
Steven Burrows8ea5dea2016-12-27 13:28:41 +0000101 }
102
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100103 angular.module('ovTopo2')
Steven Burrowsaf96a212016-12-28 12:57:02 +0000104 .factory('Topo2BreadcrumbService', [
Simon Hunt9edd1722017-03-10 17:43:26 -0800105 '$log', '$location', 'WebSocketService',
Steven Burrows6a4febe2017-04-20 11:45:33 -0400106 'Topo2RegionNavigationService',
107 function (_$log_, _$loc_, _wss_, _t2rns_) {
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100108
109 $log = _$log_;
Simon Hunt9edd1722017-03-10 17:43:26 -0800110 $loc = _$loc_;
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100111 wss = _wss_;
Steven Burrows6a4febe2017-04-20 11:45:33 -0400112 t2rns = _t2rns_;
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100113
114 return {
115 init: init,
Steven Burrows8ea5dea2016-12-27 13:28:41 +0000116 addBreadcrumb: addBreadcrumb,
Steven Burrowsaf96a212016-12-28 12:57:02 +0000117 addLayout: addLayout,
Steven Burrows8ea5dea2016-12-27 13:28:41 +0000118 hide: hide
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100119 };
Steven Burrowsaf96a212016-12-28 12:57:02 +0000120 }
121 ]);
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100122})();