Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

propagating-hammerjs

josdejong963.8kMIT3.0.0

Extend hammer.js with event propagation

hammerjs, touch, gestures, event, propagation

readme

propagating-hammerjs

Extend hammer.js (v2) with event propagation.

We use the @egjs/hammerjs fork because hammer.js is not maintained anymore.

Features

  • Events emitted by hammer will propagate in order from child to parent elements.
  • Events are extended with a function event.stopPropagation() to stop propagation to parent elements.
  • Events are extended with a property event.firstTarget containing the element where a gesture started.
  • Supports changing and rearranging the HTML DOM on the fly.
  • Load via commonjs, AMD, or as a plain old JavaScript file.

Install

npm install @egjs/hammerjs propagating-hammerjs

Load

Browser

<!DOCTYPE html>
<html>
<head>
  <script src="https://unpkg.com/@egjs/hammerjs@latest/dist/hammer.js"></script>
  <script src="https://unpkg.com/propagating-hammerjs@latest/propagating.js"></script>
  <script>
    function init() {
      var hammer = propagating(new Hammer(element));
    }
  </script>
</head>
<body>
</body>
</html>

Commonjs (e.g. Node.js, Browserify)

var Hammer = require('@egjs/hammerjs');
var propagating = require('propagating-hammerjs');

function init() {
  var hammer = propagating(new Hammer(element));
}

ESM (e.g. ES6, typescript)

import Hammer from '@egjs/hammerjs';
import propagating from 'propagating-hammerjs';

function init() {
  const hammer = propagating(new Hammer(element));
}

Use

To extend individual hammer.js instances with event propagation:

var hammer = propagating(new Hammer(element));

To extend the global hammer.js constructor

Hammer = propagating(Hammer);

Examples

Here a basic usage example. More examples are available in the folder /examples.

<!DOCTYPE html>
<html>
<head>
  <script src="node_modules/@egjs/hammerjs/dist/hammer.js"></script>
  <script src="node_muludes/propagating-hammerjs/propagating.js"></script>
  <style>
    div     {border: 1px solid black;}
    #parent {width: 400px; height: 400px; background: lightgreen;}
    #child  {width: 200px; height: 200px; background: yellow; margin: 10px;}
  </style>
</head>
<body>

<div id="parent">
  parent
  <div id="child">
    child
  </div>
</div>

<script>
  var parent = document.getElementById('parent');
  var hammer1 = propagating(new Hammer(parent))
      .on('tap', function (event) {
        alert('tap on parent');
      });

  var child = document.getElementById('child');
  var hammer2 = propagating(new Hammer(child))
      .on('tap', function (event) {
        alert('tap on child');

        // stop propagation from child to parent
        event.stopPropagation();
      });
</script>
</body>
</html>

API

Construction:

propagating(hammer: Hammer.Manager, options?: {
  preventDefault?: true | 'mouse' | 'touch' | 'pen'
}): Hammer.Manager

parameters

  • hammer: Hammer.Manager An hammer instance or the global hammer constructor.

  • options: Object An optional object with options. Available options:

    • preventDefault: true | 'mouse' | 'touch' | 'pen'. Optional. Enforce preventing the default browser behavior. Cannot be set to false.

returns

Returns the same hammer instance with extended functionality.

events

The emitted hammer.js events are extended with:

  • event.stopPropagation()

    If called, the event will not further propagate the elements parents.

  • event.firstTarget

    Contains the HTML element where a gesture started (where as event.target contains the element where the pointer is right now).

Develop

To generate the UMD bundle for commonjs and browser, run:

npm run build

License

MIT

changelog

History

2024-01-25, version 3.0.0

  • Breaking: Dropped support for IE 11
  • Fix: Use event.target in cases where the target has been removed from the DOM (#17). Thanks @sgparrish.

2020-10-14, version 2.0.1

  • Fix broken urls to hammerjs in examples.

2020-10-14, version 2.0.0

  • Switched from hammerjs to @egjs/hammerjs because the former is not actively maintained. Thanks @mojoaxel.
  • Change from having hammemrjs as dependency of this library to having it as peerDependency. Thanks @mojoaxel.

2020-10-14, version 1.5.0

  • Add ESM support. Thanks @mojoaxel.

2019-07-27, version 1.4.7

2016-03-05, version 1.4.6

  • Fixed #6: stopPropagation not binding to the original event.

2016-01-13, version 1.4.5

  • Made propagating-hammerjs more robust against removing/attaching a DOM element in the DOM whilst executing a touch event of the DOM element itself.

2016-01-04, version 1.4.4

  • Upgraded to Hammer.js v2.0.6.
    • Replaced usage of Hammer.extend with Hammer.assign.
  • Fixed not working in case of multiple instances of propagating-hammerjs on the same DOM element. Thanks @jsdw.

2015-06-04, version 1.4.3

  • Fixed dragend events not being emitted correctly in case of multiple nested handlers.

2015-06-02, version 1.4.2

  • Fixed not being able to overload options when having overridden the global Hammer instance.

2015-04-20, version 1.4.1

  • Fixed not being able to handle both a tap and double tap.

2015-04-17, version 1.4.0

  • Extended the option preventDefault with values 'mouse', 'touch', and 'pen' to prevent default behavior for a specific type of device.

2015-04-14, version 1.3.0

  • Created an option preventDefault to enforce preventing the default browser behavior.
  • Fixed propagation not being handled correctly when the mouse pointer is being dragged outside the parent div.

2015-02-09, version 1.2.2

  • Fixed #2, the emit method not working.

2015-01-29, version 1.2.1

  • Removed using top level this, attaching propagating immediately to window instead.

2015-01-05, version 1.2.0

  • Added an event property event.firstTarget, always containing the element where a gesture started.
  • Fixed the hammer.input event blocking the emit of real events.
  • Fixed panend not being emitted when pan was used too.

2015-01-02, version 1.1.1

  • Fixed the module not working via commonjs.

2014-12-30, version 1.1.0

  • Added support for applying propagating to the Hammer constructor.

2014-12-30, version 1.0.0

  • Initial, fully functional release.