Tengo un gráfico cytoscape.js, tengo 2 tipos de nodos. Quiero diseñar los nodos según la clase.
Tengo esto hasta ahora:
cy = cytoscape({ container: document.getElementById("cy"), style: [ { selector: 'node', style: { 'background-color': 'green', 'label': 'data(_label)', 'shape': 'hexagon', } }, { selector: '.server', style: { 'background-color': 'red', 'shape': 'square' } }, { selector: '.db', style: { 'background-color': 'blue', 'shape': 'triangle' } }, { selector: 'edge', style: { 'width': 3, 'line-color': '#fff', 'target-arrow-color': '#fff', 'target-arrow-shape': 'triangle', 'curve-style': 'bezier', } } ], elements: { nodes: [ { data: { id: 'a', _label: 'zzz', type: 'node'}, classes: 'db'}, { data: { id: 'b', _label: 'b', type: 'node'}, classes: 'server'}, { data: { id: 'c', _label: 'c', type: 'node'}, classes: 'server'}, { data: { id: 'd', _label: 'd', type: 'node'}, classes: 'server'}, { data: { id: 'e', _label: 'e', type: 'node'}, classes: 'server'}, { data: { id: 'k', _label: 'k', type: 'node'}, classes: 'server'}], edges: [ { data: { id: 'ab', source: 'a', target: 'b', type: 'edge'}}, { data: { id: 'bc', source: 'b', target: 'c', type: 'edge'}}, { data: { id: 'bd', source: 'b', target: 'd', type: 'edge'}}, { data: { id: 'ae', source: 'a', target: 'e', type: 'edge'}}, { data: { id: 'ek', source: 'e', target: 'k', type: 'edge'}}] }});
Cuando se carga el gráfico, todo funciona bien. Veo 2 triángulos azules y el resto son cuadrados rojos, como esperaba.
Tengo un código que muestra un cuadro de diálogo cuando el usuario selecciona el tipo de cambio desde un menú contextual, elidí ese código, pero el controlador se ve así:
var foo = cy.$("#"+selectedNode.id); foo.removeClass(foo.classes()[0]); foo.addClass(newType); // wher newType here is either 'server' or 'db'
Esto funciona la primera vez que trato de cambiar algo. es decir, puedo cambiar un servidor a una base de datos, y cambia de un cuadrado rojo a un triángulo azul, o viceversa. Sin embargo, solo funciona una vez. Si trato de cambiar una segunda vez (ya sea el mismo nodo o un nodo diferente), obtengo un hexágono verde todo el tiempo.
¿Por qué solo funciona una vez?
Supongo que de alguna manera estoy corrompiendo el gráfico, no se registran errores en la consola.