Another step forward with the UI.
- Added hosts to test data. - Messed with colors and icons. - Added more internal configuration values.
Showing
5 changed files
with
275 additions
and
83 deletions
| ... | @@ -10,17 +10,33 @@ | ... | @@ -10,17 +10,33 @@ |
| 10 | var api = onos.api; | 10 | var api = onos.api; |
| 11 | 11 | ||
| 12 | var config = { | 12 | var config = { |
| 13 | + options: { | ||
| 13 | layering: false, | 14 | layering: false, |
| 15 | + collisionPrevention: true | ||
| 16 | + }, | ||
| 14 | jsonUrl: 'network.json', | 17 | jsonUrl: 'network.json', |
| 15 | iconUrl: { | 18 | iconUrl: { |
| 16 | - pkt: 'pkt.png', | 19 | + logo: 'img/onos-logo.tiff', |
| 17 | - opt: 'opt.png' | 20 | + device: 'img/device.png', |
| 21 | + host: 'img/host.png', | ||
| 22 | + pkt: 'img/pkt.png', | ||
| 23 | + opt: 'img/opt.png' | ||
| 18 | }, | 24 | }, |
| 19 | mastHeight: 32, | 25 | mastHeight: 32, |
| 20 | force: { | 26 | force: { |
| 21 | - linkDistance: 240, | 27 | + note: 'node.class or link.class is used to differentiate', |
| 22 | - linkStrength: 0.8, | 28 | + linkDistance: { |
| 23 | - charge: -400, | 29 | + infra: 240, |
| 30 | + host: 100 | ||
| 31 | + }, | ||
| 32 | + linkStrength: { | ||
| 33 | + infra: 1.0, | ||
| 34 | + host: 0.4 | ||
| 35 | + }, | ||
| 36 | + charge: { | ||
| 37 | + device: -800, | ||
| 38 | + host: -400 | ||
| 39 | + }, | ||
| 24 | ticksWithoutCollisions: 50, | 40 | ticksWithoutCollisions: 50, |
| 25 | marginLR: 20, | 41 | marginLR: 20, |
| 26 | marginTB: 20, | 42 | marginTB: 20, |
| ... | @@ -37,13 +53,22 @@ | ... | @@ -37,13 +53,22 @@ |
| 37 | marginLR: 3, | 53 | marginLR: 3, |
| 38 | marginTB: 2 | 54 | marginTB: 2 |
| 39 | }, | 55 | }, |
| 56 | + icons: { | ||
| 57 | + w: 32, | ||
| 58 | + h: 32, | ||
| 59 | + xoff: -12, | ||
| 60 | + yoff: -10 | ||
| 61 | + }, | ||
| 40 | constraints: { | 62 | constraints: { |
| 41 | ypos: { | 63 | ypos: { |
| 42 | - pkt: 0.3, | 64 | + host: 0.15, |
| 43 | - opt: 0.7 | 65 | + switch: 0.3, |
| 44 | - } | 66 | + roadm: 0.7 |
| 45 | } | 67 | } |
| 46 | }, | 68 | }, |
| 69 | + hostLinkWidth: 1.0, | ||
| 70 | + mouseOutTimerDelayMs: 120 | ||
| 71 | + }, | ||
| 47 | view = {}, | 72 | view = {}, |
| 48 | network = {}, | 73 | network = {}, |
| 49 | selected = {}, | 74 | selected = {}, |
| ... | @@ -104,14 +129,23 @@ | ... | @@ -104,14 +129,23 @@ |
| 104 | var nw = network.forceWidth, | 129 | var nw = network.forceWidth, |
| 105 | nh = network.forceHeight; | 130 | nh = network.forceHeight; |
| 106 | 131 | ||
| 107 | - network.data.nodes.forEach(function(n) { | 132 | + function yPosConstraintForNode(n) { |
| 133 | + return config.constraints.ypos[n.type || 'host']; | ||
| 134 | + } | ||
| 135 | + | ||
| 136 | + // Note that both 'devices' and 'hosts' get mapped into the nodes array | ||
| 137 | + | ||
| 138 | + // first, the devices... | ||
| 139 | + network.data.devices.forEach(function(n) { | ||
| 108 | var ypc = yPosConstraintForNode(n), | 140 | var ypc = yPosConstraintForNode(n), |
| 109 | ix = Math.random() * 0.6 * nw + 0.2 * nw, | 141 | ix = Math.random() * 0.6 * nw + 0.2 * nw, |
| 110 | iy = ypc * nh, | 142 | iy = ypc * nh, |
| 111 | node = { | 143 | node = { |
| 112 | id: n.id, | 144 | id: n.id, |
| 145 | + labels: n.labels, | ||
| 146 | + class: 'device', | ||
| 147 | + icon: 'device', | ||
| 113 | type: n.type, | 148 | type: n.type, |
| 114 | - status: n.status, | ||
| 115 | x: ix, | 149 | x: ix, |
| 116 | y: iy, | 150 | y: iy, |
| 117 | constraint: { | 151 | constraint: { |
| ... | @@ -123,21 +157,61 @@ | ... | @@ -123,21 +157,61 @@ |
| 123 | network.nodes.push(node); | 157 | network.nodes.push(node); |
| 124 | }); | 158 | }); |
| 125 | 159 | ||
| 126 | - function yPosConstraintForNode(n) { | 160 | + // then, the hosts... |
| 127 | - return config.constraints.ypos[n.type] || 0.5; | 161 | + network.data.hosts.forEach(function(n) { |
| 162 | + var ypc = yPosConstraintForNode(n), | ||
| 163 | + ix = Math.random() * 0.6 * nw + 0.2 * nw, | ||
| 164 | + iy = ypc * nh, | ||
| 165 | + node = { | ||
| 166 | + id: n.id, | ||
| 167 | + labels: n.labels, | ||
| 168 | + class: 'host', | ||
| 169 | + icon: 'host', | ||
| 170 | + type: n.type, | ||
| 171 | + x: ix, | ||
| 172 | + y: iy, | ||
| 173 | + constraint: { | ||
| 174 | + weight: 0.7, | ||
| 175 | + y: iy | ||
| 128 | } | 176 | } |
| 177 | + }; | ||
| 178 | + network.lookup[n.id] = node; | ||
| 179 | + network.nodes.push(node); | ||
| 180 | + }); | ||
| 129 | 181 | ||
| 130 | 182 | ||
| 183 | + // now, process the explicit links... | ||
| 131 | network.data.links.forEach(function(n) { | 184 | network.data.links.forEach(function(n) { |
| 132 | var src = network.lookup[n.src], | 185 | var src = network.lookup[n.src], |
| 133 | dst = network.lookup[n.dst], | 186 | dst = network.lookup[n.dst], |
| 134 | id = src.id + "~" + dst.id; | 187 | id = src.id + "~" + dst.id; |
| 135 | 188 | ||
| 136 | var link = { | 189 | var link = { |
| 190 | + class: 'infra', | ||
| 191 | + id: id, | ||
| 192 | + type: n.type, | ||
| 193 | + width: n.linkWidth, | ||
| 194 | + source: src, | ||
| 195 | + target: dst, | ||
| 196 | + strength: config.force.linkStrength.infra | ||
| 197 | + }; | ||
| 198 | + network.links.push(link); | ||
| 199 | + }); | ||
| 200 | + | ||
| 201 | + // finally, infer host links... | ||
| 202 | + network.data.hosts.forEach(function(n) { | ||
| 203 | + var src = network.lookup[n.id], | ||
| 204 | + dst = network.lookup[n.cp.device], | ||
| 205 | + id = src.id + "~" + dst.id; | ||
| 206 | + | ||
| 207 | + var link = { | ||
| 208 | + class: 'host', | ||
| 137 | id: id, | 209 | id: id, |
| 210 | + type: 'hostLink', | ||
| 211 | + width: config.hostLinkWidth, | ||
| 138 | source: src, | 212 | source: src, |
| 139 | target: dst, | 213 | target: dst, |
| 140 | - strength: config.force.linkStrength | 214 | + strength: config.force.linkStrength.host |
| 141 | }; | 215 | }; |
| 142 | network.links.push(link); | 216 | network.links.push(link); |
| 143 | }); | 217 | }); |
| ... | @@ -145,13 +219,15 @@ | ... | @@ -145,13 +219,15 @@ |
| 145 | 219 | ||
| 146 | function createLayout() { | 220 | function createLayout() { |
| 147 | 221 | ||
| 222 | + var cfg = config.force; | ||
| 223 | + | ||
| 148 | network.force = d3.layout.force() | 224 | network.force = d3.layout.force() |
| 225 | + .size([network.forceWidth, network.forceHeight]) | ||
| 149 | .nodes(network.nodes) | 226 | .nodes(network.nodes) |
| 150 | .links(network.links) | 227 | .links(network.links) |
| 151 | - .linkStrength(function(d) { return d.strength; }) | 228 | + .linkStrength(function(d) { return cfg.linkStrength[d.class]; }) |
| 152 | - .size([network.forceWidth, network.forceHeight]) | 229 | + .linkDistance(function(d) { return cfg.linkDistance[d.class]; }) |
| 153 | - .linkDistance(config.force.linkDistance) | 230 | + .charge(function(d) { return cfg.charge[d.class]; }) |
| 154 | - .charge(config.force.charge) | ||
| 155 | .on('tick', tick); | 231 | .on('tick', tick); |
| 156 | 232 | ||
| 157 | network.svg = d3.select('#view').append('svg') | 233 | network.svg = d3.select('#view').append('svg') |
| ... | @@ -205,9 +281,10 @@ | ... | @@ -205,9 +281,10 @@ |
| 205 | network.link = network.svg.append('g').selectAll('.link') | 281 | network.link = network.svg.append('g').selectAll('.link') |
| 206 | .data(network.force.links(), function(d) {return d.id}) | 282 | .data(network.force.links(), function(d) {return d.id}) |
| 207 | .enter().append('line') | 283 | .enter().append('line') |
| 208 | - .attr('class', 'link'); | 284 | + .attr('class', function(d) {return 'link ' + d.class}); |
| 285 | + | ||
| 209 | 286 | ||
| 210 | - // TODO: drag behavior | 287 | + // == define node drag behavior... |
| 211 | network.draggedThreshold = d3.scale.linear() | 288 | network.draggedThreshold = d3.scale.linear() |
| 212 | .domain([0, 0.1]) | 289 | .domain([0, 0.1]) |
| 213 | .range([5, 20]) | 290 | .range([5, 20]) |
| ... | @@ -258,7 +335,11 @@ | ... | @@ -258,7 +335,11 @@ |
| 258 | .data(network.force.nodes(), function(d) {return d.id}) | 335 | .data(network.force.nodes(), function(d) {return d.id}) |
| 259 | .enter().append('g') | 336 | .enter().append('g') |
| 260 | .attr('class', function(d) { | 337 | .attr('class', function(d) { |
| 261 | - return 'node ' + d.type; | 338 | + var cls = 'node ' + d.class; |
| 339 | + if (d.type) { | ||
| 340 | + cls += ' ' + d.type; | ||
| 341 | + } | ||
| 342 | + return cls; | ||
| 262 | }) | 343 | }) |
| 263 | .attr('transform', function(d) { | 344 | .attr('transform', function(d) { |
| 264 | return translate(d.x, d.y); | 345 | return translate(d.x, d.y); |
| ... | @@ -281,29 +362,32 @@ | ... | @@ -281,29 +362,32 @@ |
| 281 | } | 362 | } |
| 282 | network.mouseoutTimeout = setTimeout(function() { | 363 | network.mouseoutTimeout = setTimeout(function() { |
| 283 | highlightObject(null); | 364 | highlightObject(null); |
| 284 | - }, 160); | 365 | + }, config.mouseOutTimerDelayMs); |
| 285 | } | 366 | } |
| 286 | }); | 367 | }); |
| 287 | 368 | ||
| 288 | network.nodeRect = network.node.append('rect') | 369 | network.nodeRect = network.node.append('rect') |
| 289 | .attr('rx', 5) | 370 | .attr('rx', 5) |
| 290 | - .attr('ry', 5) | 371 | + .attr('ry', 5); |
| 291 | - .attr('width', 126) | 372 | + // note that width/height are adjusted to fit the label text |
| 292 | - .attr('height', 40); | ||
| 293 | 373 | ||
| 294 | network.node.each(function(d) { | 374 | network.node.each(function(d) { |
| 295 | var node = d3.select(this), | 375 | var node = d3.select(this), |
| 296 | rect = node.select('rect'), | 376 | rect = node.select('rect'), |
| 297 | - img = node.append('svg:image') | 377 | + icon = iconUrl(d), |
| 298 | - .attr('x', -16) | ||
| 299 | - .attr('y', -16) | ||
| 300 | - .attr('width', 32) | ||
| 301 | - .attr('height', 32) | ||
| 302 | - .attr('xlink:href', iconUrl(d)), | ||
| 303 | text = node.append('text') | 378 | text = node.append('text') |
| 304 | .text(d.id) | 379 | .text(d.id) |
| 305 | - .attr('dy', '1.1em'), | 380 | + .attr('dy', '1.1em'); |
| 306 | - dummy; | 381 | + |
| 382 | + if (icon) { | ||
| 383 | + var cfg = config.icons; | ||
| 384 | + node.append('svg:image') | ||
| 385 | + .attr('width', cfg.w) | ||
| 386 | + .attr('height', cfg.h) | ||
| 387 | + .attr('xlink:href', icon); | ||
| 388 | + // note, icon relative positioning (x,y) is done after we have | ||
| 389 | + // adjusted the bounds of the rectangle... | ||
| 390 | + } | ||
| 307 | 391 | ||
| 308 | }); | 392 | }); |
| 309 | 393 | ||
| ... | @@ -352,7 +436,8 @@ | ... | @@ -352,7 +436,8 @@ |
| 352 | .attr('height', bounds.y2 - bounds.y1); | 436 | .attr('height', bounds.y2 - bounds.y1); |
| 353 | 437 | ||
| 354 | node.select('image') | 438 | node.select('image') |
| 355 | - .attr('x', bounds.x1); | 439 | + .attr('x', bounds.x1 + config.icons.xoff) |
| 440 | + .attr('y', bounds.y1 + config.icons.yoff); | ||
| 356 | 441 | ||
| 357 | d.extent = { | 442 | d.extent = { |
| 358 | left: bounds.x1 - lab.marginLR, | 443 | left: bounds.x1 - lab.marginLR, |
| ... | @@ -384,7 +469,7 @@ | ... | @@ -384,7 +469,7 @@ |
| 384 | } | 469 | } |
| 385 | 470 | ||
| 386 | function iconUrl(d) { | 471 | function iconUrl(d) { |
| 387 | - return config.iconUrl[d.type]; | 472 | + return config.iconUrl[d.icon]; |
| 388 | } | 473 | } |
| 389 | 474 | ||
| 390 | function translate(x, y) { | 475 | function translate(x, y) { |
| ... | @@ -440,7 +525,7 @@ | ... | @@ -440,7 +525,7 @@ |
| 440 | function tick(e) { | 525 | function tick(e) { |
| 441 | network.numTicks++; | 526 | network.numTicks++; |
| 442 | 527 | ||
| 443 | - if (config.layering) { | 528 | + if (config.options.layering) { |
| 444 | // adjust the y-coord of each node, based on y-pos constraints | 529 | // adjust the y-coord of each node, based on y-pos constraints |
| 445 | network.nodes.forEach(function (n) { | 530 | network.nodes.forEach(function (n) { |
| 446 | var z = e.alpha * n.constraint.weight; | 531 | var z = e.alpha * n.constraint.weight; |
| ... | @@ -450,7 +535,7 @@ | ... | @@ -450,7 +535,7 @@ |
| 450 | }); | 535 | }); |
| 451 | } | 536 | } |
| 452 | 537 | ||
| 453 | - if (network.preventCollisions) { | 538 | + if (config.options.collisionPrevention && network.preventCollisions) { |
| 454 | preventCollisions(); | 539 | preventCollisions(); |
| 455 | } | 540 | } |
| 456 | 541 | ... | ... |
| 1 | { | 1 | { |
| 2 | - "id": "network-v1", | ||
| 3 | "meta": { | 2 | "meta": { |
| 4 | - "__comment_1__": "This is sample data for developing the ONOS UI", | 3 | + "comments": [ |
| 5 | - "foo": "bar", | 4 | + "This is sample data for developing the ONOS UI (network view)", |
| 6 | - "zoo": "goo" | 5 | + " in a standalone mode (no server required).", |
| 6 | + " Eventually, we will wire this up to live data", | ||
| 7 | + " from the server, via a websocket.", | ||
| 8 | + "", | ||
| 9 | + "Note that this is just a first-draft of the data --", | ||
| 10 | + " additional fields will be added when they are needed." | ||
| 11 | + ], | ||
| 12 | + "otherMetaData": "can go here..." | ||
| 7 | }, | 13 | }, |
| 8 | - "nodes": [ | 14 | + "devices": [ |
| 9 | { | 15 | { |
| 10 | - "id": "sample1", | 16 | + "id": "of:0000000000000001", |
| 11 | - "type": "opt", | 17 | + "labels": ["00:00:00:00:00:00:00:01", "of/::01", "opt-1"], |
| 12 | - "status": "good" | 18 | + "type": "roadm" |
| 13 | }, | 19 | }, |
| 14 | { | 20 | { |
| 15 | - "id": "00:00:00:00:00:00:00:02", | 21 | + "id": "of:0000000000000002", |
| 16 | - "type": "opt", | 22 | + "labels": ["00:00:00:00:00:00:00:02", "of/::02", "opt-2"], |
| 17 | - "status": "good" | 23 | + "type": "roadm" |
| 18 | }, | 24 | }, |
| 19 | { | 25 | { |
| 20 | - "id": "00:00:00:00:00:00:00:03", | 26 | + "id": "of:0000000000000003", |
| 21 | - "type": "opt", | 27 | + "labels": ["00:00:00:00:00:00:00:03", "of/::03", "opt-3"], |
| 22 | - "status": "good" | 28 | + "type": "roadm" |
| 23 | }, | 29 | }, |
| 24 | { | 30 | { |
| 25 | - "id": "00:00:00:00:00:00:00:04", | 31 | + "id": "of:0000000000000004", |
| 26 | - "type": "opt", | 32 | + "labels": ["00:00:00:00:00:00:00:04", "of/::04", "opt-4"], |
| 27 | - "status": "good" | 33 | + "type": "roadm" |
| 28 | }, | 34 | }, |
| 29 | { | 35 | { |
| 30 | - "id": "00:00:00:00:00:00:00:11", | 36 | + "id": "of:0000000000000011", |
| 31 | - "type": "pkt", | 37 | + "labels": ["00:00:00:00:00:00:00:11", "of/::11", "pkt-11"], |
| 32 | - "status": "good" | 38 | + "type": "switch" |
| 33 | }, | 39 | }, |
| 34 | { | 40 | { |
| 35 | - "id": "00:00:00:00:00:00:00:12", | 41 | + "id": "of:0000000000000012", |
| 36 | - "type": "pkt", | 42 | + "labels": ["00:00:00:00:00:00:00:12", "of/::12", "pkt-12"], |
| 37 | - "status": "good" | 43 | + "type": "switch" |
| 38 | }, | 44 | }, |
| 39 | { | 45 | { |
| 40 | - "id": "00:00:00:00:00:00:00:13", | 46 | + "id": "of:0000000000000013", |
| 41 | - "type": "pkt", | 47 | + "labels": ["00:00:00:00:00:00:00:13", "of/::13", "pkt-13"], |
| 42 | - "status": "good" | 48 | + "type": "switch" |
| 43 | } | 49 | } |
| 44 | ], | 50 | ], |
| 51 | + "linkNotes": [ | ||
| 52 | + "even though we have 'directionality' (src/dst), each link is", | ||
| 53 | + " considered to be bi-directional. Note that links between hosts", | ||
| 54 | + " and edge switches are inferred from host information, and not", | ||
| 55 | + " explicitly represented here." | ||
| 56 | + ], | ||
| 45 | "links": [ | 57 | "links": [ |
| 46 | - { "src": "sample1", "dst": "00:00:00:00:00:00:00:02" }, | 58 | + { |
| 47 | - { "src": "sample1", "dst": "00:00:00:00:00:00:00:03" }, | 59 | + "src": "of:0000000000000001", |
| 48 | - { "src": "sample1", "dst": "00:00:00:00:00:00:00:04" }, | 60 | + "dst": "of:0000000000000002", |
| 49 | - { "src": "00:00:00:00:00:00:00:02", "dst": "00:00:00:00:00:00:00:03" }, | 61 | + "type": "optical", |
| 50 | - { "src": "00:00:00:00:00:00:00:02", "dst": "00:00:00:00:00:00:00:04" }, | 62 | + "linkWidth": 1.5 |
| 51 | - { "src": "00:00:00:00:00:00:00:03", "dst": "00:00:00:00:00:00:00:04" }, | 63 | + }, |
| 52 | - { "src": "00:00:00:00:00:00:00:13", "dst": "00:00:00:00:00:00:00:03" }, | 64 | + { |
| 53 | - { "src": "00:00:00:00:00:00:00:12", "dst": "00:00:00:00:00:00:00:02" }, | 65 | + "src": "of:0000000000000001", |
| 54 | - { "src": "00:00:00:00:00:00:00:11", "dst": "sample1" } | 66 | + "dst": "of:0000000000000003", |
| 67 | + "type": "optical", | ||
| 68 | + "linkWidth": 1.5 | ||
| 69 | + }, | ||
| 70 | + { | ||
| 71 | + "src": "of:0000000000000001", | ||
| 72 | + "dst": "of:0000000000000004", | ||
| 73 | + "type": "optical", | ||
| 74 | + "linkWidth": 1.5 | ||
| 75 | + }, | ||
| 76 | + { | ||
| 77 | + "src": "of:0000000000000002", | ||
| 78 | + "dst": "of:0000000000000003", | ||
| 79 | + "type": "optical", | ||
| 80 | + "linkWidth": 1.5 | ||
| 81 | + }, | ||
| 82 | + { | ||
| 83 | + "src": "of:0000000000000002", | ||
| 84 | + "dst": "of:0000000000000004", | ||
| 85 | + "type": "optical", | ||
| 86 | + "linkWidth": 1.5 | ||
| 87 | + }, | ||
| 88 | + { | ||
| 89 | + "src": "of:0000000000000003", | ||
| 90 | + "dst": "of:0000000000000004", | ||
| 91 | + "type": "optical", | ||
| 92 | + "linkWidth": 1.5 | ||
| 93 | + }, | ||
| 94 | + { | ||
| 95 | + "src": "of:0000000000000013", | ||
| 96 | + "dst": "of:0000000000000003", | ||
| 97 | + "type": "direct", | ||
| 98 | + "linkWidth": 1.0 | ||
| 99 | + }, | ||
| 100 | + { | ||
| 101 | + "src": "of:0000000000000012", | ||
| 102 | + "dst": "of:0000000000000002", | ||
| 103 | + "type": "direct", | ||
| 104 | + "linkWidth": 1.0 | ||
| 105 | + }, | ||
| 106 | + { | ||
| 107 | + "src": "of:0000000000000011", | ||
| 108 | + "dst": "of:0000000000000001", | ||
| 109 | + "type": "direct", | ||
| 110 | + "linkWidth": 1.0 | ||
| 111 | + } | ||
| 112 | + ], | ||
| 113 | + "hosts": [ | ||
| 114 | + { | ||
| 115 | + "id": "00:60:d3:00:11:01/7", | ||
| 116 | + "labels": ["00:60:d3:00:11:01/7", "Host-11-A"], | ||
| 117 | + "cp" : { | ||
| 118 | + "device": "of:0000000000000011", | ||
| 119 | + "port": 6 | ||
| 120 | + } | ||
| 121 | + }, | ||
| 122 | + { | ||
| 123 | + "id": "00:60:d3:00:11:02/7", | ||
| 124 | + "labels": ["00:60:d3:00:11:02/7", "Host-11-B"], | ||
| 125 | + "cp" : { | ||
| 126 | + "device": "of:0000000000000011", | ||
| 127 | + "port": 8 | ||
| 128 | + } | ||
| 129 | + }, | ||
| 130 | + { | ||
| 131 | + "id": "00:60:d3:00:12:01/4", | ||
| 132 | + "labels": ["00:60:d3:00:12:01/4", "Host-12-C"], | ||
| 133 | + "cp" : { | ||
| 134 | + "device": "of:0000000000000012", | ||
| 135 | + "port": 12 | ||
| 136 | + } | ||
| 137 | + }, | ||
| 138 | + { | ||
| 139 | + "id": "00:60:d3:00:12:02/4", | ||
| 140 | + "labels": ["00:60:d3:00:12:02/4", "Host-12-D"], | ||
| 141 | + "cp" : { | ||
| 142 | + "device": "of:0000000000000012", | ||
| 143 | + "port": 13 | ||
| 144 | + } | ||
| 145 | + }, | ||
| 146 | + { | ||
| 147 | + "id": "00:60:d3:00:13:01/19", | ||
| 148 | + "labels": ["00:60:d3:00:13:01/19", "Host-13-E"], | ||
| 149 | + "cp" : { | ||
| 150 | + "device": "of:0000000000000013", | ||
| 151 | + "port": 7 | ||
| 152 | + } | ||
| 153 | + }, | ||
| 154 | + { | ||
| 155 | + "id": "00:60:d3:00:13:02/19", | ||
| 156 | + "labels": ["00:60:d3:00:13:02/19", "Host-13-F"], | ||
| 157 | + "cp" : { | ||
| 158 | + "device": "of:0000000000000013", | ||
| 159 | + "port": 8 | ||
| 160 | + } | ||
| 161 | + } | ||
| 55 | ] | 162 | ] |
| 56 | } | 163 | } | ... | ... |
| ... | @@ -38,7 +38,7 @@ svg { | ... | @@ -38,7 +38,7 @@ svg { |
| 38 | * Network Graph elements ====================================== | 38 | * Network Graph elements ====================================== |
| 39 | */ | 39 | */ |
| 40 | 40 | ||
| 41 | -.link { | 41 | +svg .link { |
| 42 | fill: none; | 42 | fill: none; |
| 43 | stroke: #666; | 43 | stroke: #666; |
| 44 | stroke-width: 1.5px; | 44 | stroke-width: 1.5px; |
| ... | @@ -56,7 +56,7 @@ marker#end { | ... | @@ -56,7 +56,7 @@ marker#end { |
| 56 | stroke-width: 1.5px; | 56 | stroke-width: 1.5px; |
| 57 | } | 57 | } |
| 58 | 58 | ||
| 59 | -.node rect { | 59 | +svg .node rect { |
| 60 | stroke-width: 1.5px; | 60 | stroke-width: 1.5px; |
| 61 | 61 | ||
| 62 | transition: opacity 250ms; | 62 | transition: opacity 250ms; |
| ... | @@ -64,13 +64,15 @@ marker#end { | ... | @@ -64,13 +64,15 @@ marker#end { |
| 64 | -moz-transition: opacity 250ms; | 64 | -moz-transition: opacity 250ms; |
| 65 | } | 65 | } |
| 66 | 66 | ||
| 67 | -/*differentiate between packet and optical nodes*/ | 67 | +svg .node.device.roadm rect { |
| 68 | -svg .node.pkt rect { | 68 | + fill: #229; |
| 69 | - fill: #77a; | 69 | +} |
| 70 | +svg .node.device.switch rect { | ||
| 71 | + fill: #55f; | ||
| 70 | } | 72 | } |
| 71 | 73 | ||
| 72 | -svg .node.opt rect { | 74 | +svg .node.host rect { |
| 73 | - fill: #7a7; | 75 | + fill: #787; |
| 74 | } | 76 | } |
| 75 | 77 | ||
| 76 | svg .node text { | 78 | svg .node text { |
| ... | @@ -121,15 +123,13 @@ svg .legend .category text { | ... | @@ -121,15 +123,13 @@ svg .legend .category text { |
| 121 | #frame { | 123 | #frame { |
| 122 | width: 100%; | 124 | width: 100%; |
| 123 | height: 100%; | 125 | height: 100%; |
| 124 | - background-color: #cdf; | 126 | + background-color: #fff; |
| 125 | } | 127 | } |
| 126 | 128 | ||
| 127 | #mast { | 129 | #mast { |
| 128 | height: 32px; | 130 | height: 32px; |
| 129 | - background-color: #abe; | 131 | + padding: 6px; |
| 132 | + background-color: #ccc; | ||
| 130 | vertical-align: baseline; | 133 | vertical-align: baseline; |
| 131 | } | 134 | } |
| 132 | 135 | ||
| 133 | -#main { | ||
| 134 | - background-color: #99c; | ||
| 135 | -} | ... | ... |
web/gui/src/main/webapp/opt.png
deleted
100644 → 0
1.48 KB
web/gui/src/main/webapp/pkt.png
deleted
100644 → 0
2.07 KB
-
Please register or login to post a comment