blob: 6b39f3e86d0dbf02456ffb9d0f14d35515693052 [file] [log] [blame]
Steven Burrowsaf3159d2016-08-25 14:54:30 +01001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2016-present Open Networking Foundation
Steven Burrowsaf3159d2016-08-25 14:54:30 +01003 *
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 Burrows1c2a9682017-07-14 16:52:46 +010026 var 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 Burrows1c2a9682017-07-14 16:52:46 +010030 breadcrumbs;
Steven Burrowsaf3159d2016-08-25 14:54:30 +010031
32 function init() {
Steven Burrowsaf3159d2016-08-25 14:54:30 +010033 breadcrumbs = [];
Steven Burrows8ea5dea2016-12-27 13:28:41 +000034 breadcrumbContainer = d3.select('#breadcrumbs');
35
36 breadcrumbContainer
37 .append('span')
Steven Burrowsd8e6c332016-09-27 10:40:53 -070038 .text('Regions: ');
Steven Burrows8ea5dea2016-12-27 13:28:41 +000039
Steven Burrowsaf3159d2016-08-25 14:54:30 +010040 render();
41 }
42
43 function addBreadcrumb(crumbs) {
Steven Burrowsdfa52b02016-09-02 13:50:43 +010044 breadcrumbContainer.selectAll('.breadcrumb').remove();
45 breadcrumbs = crumbs.reverse();
Steven Burrowsaf3159d2016-08-25 14:54:30 +010046 render();
47 }
48
49 function navigateToRegion(data, index) {
Steven Burrowsaf3159d2016-08-25 14:54:30 +010050 if (index === breadcrumbs.length - 1) {
51 return;
52 }
53
54 // Remove breadcrumbs after index;
55 breadcrumbs.splice(index + 1);
Steven Burrows6a4febe2017-04-20 11:45:33 -040056 t2rns.navigateToRegion(data.id);
Steven Burrowsaf96a212016-12-28 12:57:02 +000057
Steven Burrowsaf3159d2016-08-25 14:54:30 +010058 render();
59 }
60
61 function render() {
Steven Burrowsaf3159d2016-08-25 14:54:30 +010062 var selection = breadcrumbContainer.selectAll('.breadcrumb')
63 .data(breadcrumbs);
64
65 selection.enter()
66 .append('div')
67 .attr('class', 'breadcrumb')
68 .on('click', navigateToRegion)
Steven Burrowsd8e6c332016-09-27 10:40:53 -070069 .append('a')
Steven Burrowsaf3159d2016-08-25 14:54:30 +010070 .text(function (d) {
71 return d.name;
72 });
73
74 selection.exit()
75 .transition()
76 .duration(200)
77 .style('opacity', 0)
78 .remove();
79 }
80
Steven Burrows8ea5dea2016-12-27 13:28:41 +000081 function hide() {
Steven Burrows8ea5dea2016-12-27 13:28:41 +000082 var view = d3.select('body');
83 view.classed('breadcrumb--hidden', true);
84
85 var startTranslateState = 'translate(0px,0%)',
86 endTranslateState = 'translate(0px,-100%)',
87 translateInterpolator = d3.interpolateString(startTranslateState, endTranslateState);
88
89 breadcrumbContainer
90 .transition()
91 .duration(600)
92 .style('opacity', 0)
93 .styleTween('transform', function (d) {
94 return translateInterpolator;
95 });
Steven Burrowsaf96a212016-12-28 12:57:02 +000096 }
Steven Burrows8ea5dea2016-12-27 13:28:41 +000097
Steven Burrows1c2a9682017-07-14 16:52:46 +010098 // TODO: Remove references
99 function addLayout(_layout_) {}
Steven Burrows8ea5dea2016-12-27 13:28:41 +0000100
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100101 angular.module('ovTopo2')
Steven Burrowsaf96a212016-12-28 12:57:02 +0000102 .factory('Topo2BreadcrumbService', [
Steven Burrows6a4febe2017-04-20 11:45:33 -0400103 'Topo2RegionNavigationService',
Steven Burrows1c2a9682017-07-14 16:52:46 +0100104 function (_t2rns_) {
Steven Burrows6a4febe2017-04-20 11:45:33 -0400105 t2rns = _t2rns_;
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100106
107 return {
108 init: init,
Steven Burrows8ea5dea2016-12-27 13:28:41 +0000109 addBreadcrumb: addBreadcrumb,
Steven Burrowsaf96a212016-12-28 12:57:02 +0000110 addLayout: addLayout,
Steven Burrows1c2a9682017-07-14 16:52:46 +0100111 hide: hide,
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100112 };
Steven Burrows1c2a9682017-07-14 16:52:46 +0100113 },
Steven Burrowsaf96a212016-12-28 12:57:02 +0000114 ]);
Steven Burrowsaf3159d2016-08-25 14:54:30 +0100115})();