Как настроить QTip, чтобы всегда показывать подсказки в Cytoscape.js - PullRequest
0 голосов
/ 02 ноября 2018

Я ищу способ заставить QTip одновременно отображать всплывающие подсказки для каждого узла на графике Cytoscape.js, чтобы они всегда отображались и привязывались к узлам на графике без необходимости нажимать или перемещать мышь над кнопкой мыши. узел.

Я подошел ближе с кодом ниже:

$(document).ready(function(){
            cy.nodes().qtip({
                content: function(){ return 'Station: ' + this.id() +
                                       '</br> Next Train: ' + this.data('nextTrain') +
                                       '</br> Connections: ' + this.degree();
                        },
                hide: false,
                show: {
                    when: false,
                    ready: true
                 }
            })
        })

Приведенный выше код отображает всплывающие подсказки в $ (document) .ready, но все они расположены в одном узле на графике Cytoscape и исчезают, когда я вообще увеличиваю или панорамирую.

Цель состоит в том, чтобы всплывающие подсказки были привязаны к каждому узлу в моем графике таким образом, чтобы при увеличении и перемещении они оставались фиксированными на этом узле. Я не уверен, есть ли более простой способ сделать это, просто используя Cytoscape (то есть, многофункциональную маркировку).

Я использую Qtip2, jQuery-2.0.3 и самый последний выпуск cytoscape.js

Любая помощь очень ценится.

1 Ответ

0 голосов
/ 02 ноября 2018

РЕДАКТИРОВАТЬ: Если вы хотите создать эти элементы автоматически, используйте функцию и цикл для итерации по cy.nodes ():

var makeTippy = function (nodeTemp, node) {
    return tippy(node.popperRef(), {
        html: (function () {
            let div = document.createElement('div');
            // do things in div
            return div;
        })(),
        trigger: 'manual',
        arrow: true,
        placement: 'right',
        hideOnClick: false,
        multiple: true,
        sticky: true
    }).tooltips[0];
};
var nodes = cy.nodes();
for (var i = 0; i < nodes.length; i++) {
    var tippy = makeTippy(nodes[i]);
    tippy.show();
}

Если вы хотите прикрепить qTip, я бы порекомендовал расширение cytoscape для popper.js и, в частности, tippy версия (липкие div):

document.addEventListener('DOMContentLoaded', function() {
  var cy = window.cy = cytoscape({
    container: document.getElementById('cy'),
    style: [{
        selector: 'node',
        style: {
          'content': 'data(id)'
        }
      },
      {
        selector: 'edge',
        style: {
          'curve-style': 'bezier',
          'target-arrow-shape': 'triangle'
        }
      }
    ],
    elements: {
      nodes: [{
          data: {
            id: 'a'
          }
        },
        {
          data: {
            id: 'b'
          }
        }
      ],
      edges: [{
        data: {
          source: 'a',
          target: 'b'
        }
      }]
    },
    layout: {
      name: 'grid'
    }
  });
  var a = cy.getElementById('a');
  var b = cy.getElementById('b');
  var makeTippy = function(node, text) {
    return tippy(node.popperRef(), {
      html: (function() {
        var div = document.createElement('div');
        div.innerHTML = text;
        return div;
      })(),
      trigger: 'manual',
      arrow: true,
      placement: 'bottom',
      hideOnClick: false,
      multiple: true,
      sticky: true
    }).tooltips[0];
  };
  var tippyA = makeTippy(a, 'foo');
  tippyA.show();
  var tippyB = makeTippy(b, 'bar');
  tippyB.show();
});
body {
  font-family: helvetica neue, helvetica, liberation sans, arial, sans-serif;
  font-size: 14px
}

#cy {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  z-index: 1;
}

h1 {
  opacity: 0.5;
  font-size: 1em;
  font-weight: bold;
}


/* makes sticky faster; disable if you want animated tippies */

.tippy-popper {
  transition: none !important;
}
<!DOCTYPE>
<html>

<head>
  <title>Tippy > qTip</title>
  <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1, maximum-scale=1">
  <script src="https://unpkg.com/cytoscape/dist/cytoscape.min.js"></script>
  <script src="https://unpkg.com/popper.js"></script>
  <script src="cytoscape-popper.js"></script>
  <script src="https://unpkg.com/tippy.js@2.0.9/dist/tippy.all.js"></script>
  <link rel="stylesheet" href="https://unpkg.com/tippy.js@2.0.9/dist/tippy.css" />
  <script src="https://cdn.jsdelivr.net/npm/cytoscape-popper@1.0.2/cytoscape-popper.js"></script>
</head>

<body>
  <h1>cytoscape-popper tippy demo</h1>
  <div id="cy"></div>
</body>

</html>

Я думаю, что с поппером легче справиться, если div'ы "держатся"

...