0

I have a ratchet popover and I took it from here:

<div id="popover" class="popover">
  <header class="bar bar-nav">
    <h1 class="title">Popover title</h1>
  </header>
  <ul class="table-view">
    <li class="table-view-cell">Item1</li>
    <li class="table-view-cell">Item2</li>
  </ul>
</div>

<header class="bar bar-nav">
  <a href="#popover">
    <h1 class="title">
      Tap title
      <span class="icon icon-caret"></span>
    </h1>
  </a>
</header>

and I'd like to find a way to listen to this popover closing from JS (also using jQuery)

This is the ratchet js code for popovers:

!(function () {
  'use strict';

  var popover;

  var findPopovers = function (target) {
    var i;
    var popovers = document.querySelectorAll('a');

    for (; target && target !== document; target = target.parentNode) {
      for (i = popovers.length; i--;) {
        if (popovers[i] === target) {
          return target;
        }
      }
    }
  };

  var onPopoverHidden = function () {
    popover.style.display = 'none';
    popover.removeEventListener('webkitTransitionEnd', onPopoverHidden);
  };

  var backdrop = (function () {
    var element = document.createElement('div');

    element.classList.add('backdrop');

    element.addEventListener('touchend', function () {
      popover.addEventListener('webkitTransitionEnd', onPopoverHidden);
      popover.classList.remove('visible');
      popover.parentNode.removeChild(backdrop);
    });

    return element;
  }());

  var getPopover = function (e) {
    var anchor = findPopovers(e.target);

    if (!anchor || !anchor.hash || (anchor.hash.indexOf('/') > 0)) {
      return;
    }

    try {
      popover = document.querySelector(anchor.hash);
    }
    catch (error) {
      popover = null;
    }

    if (popover === null) {
      return;
    }

    if (!popover || !popover.classList.contains('popover')) {
      return;
    }

    return popover;
  };

  var showHidePopover = function (e) {
    var popover = getPopover(e);

    if (!popover) {
      return;
    }

    popover.style.display = 'block';
    popover.offsetHeight;
    popover.classList.add('visible');

    popover.parentNode.appendChild(backdrop);
  };

  window.addEventListener('touchend', showHidePopover);

}());

How can I do that?

thanks

Community
  • 1
  • 1
Frank
  • 2,083
  • 8
  • 34
  • 52

1 Answers1

0

To trigger an event is documented here. Check it out if you want to configure your events to bubble up. Basically, trigger an event on your popover like this:

var event = new CustomEvent('pop', { "detail": { "id": popover.id, "type": "hide" }});
// Dispatch the event.
popover.dispatchEvent(event);

Inject some event triggers into popovers.js. Specifically, the methods onPopoverHidden and showHidePopover

var showHidePopover = function (e) {
    var popover = getPopover(e);

    if (!popover) {
      return;
    }

    popover.style.display = 'block';
    popover.offsetHeight;
    popover.classList.add('visible');

    popover.parentNode.appendChild(backdrop);

    //create event
    var event = new CustomEvent('pop', { "detail": { "id": popover.id, "type": "show" }});
    // Dispatch the event.
    popover.dispatchEvent(event);


  };

  var onPopoverHidden = function () {
    popover.style.display = 'none';
    popover.removeEventListener('webkitTransitionEnd', onPopoverHidden);
    //create event
    var event = new CustomEvent('pop', { "detail": { "id": popover.id, "type": "hide" }});
    // Dispatch the event.
    popover.dispatchEvent(event);
  };

Listen to a popover by attaching an event listener to the popover that is triggering events

// Listen for the event.
document.getElementById("menu-popover")
        .addEventListener('pop', function (e) {
            console.log(e.detail.id + " " + e.detail.type);
          }, false);
kindasimple
  • 2,427
  • 1
  • 16
  • 20