# propagating-hammerjs Extend [hammer.js](https://github.com/hammerjs/hammer.js) v2 with event propagation. ## 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 ```sh npm install propagating-hammerjs ``` ## Load ### Browser ```html
``` ### Commonjs (e.g. Node.js, Browserify) ```js var Hammer = require('hammerjs'); var propagating = require('propagating-hammerjs'); function init() { var hammer = propagating(new Hammer(element)); } ``` ### ESM (e.g. ES6, typescript) ```typescript import Hammer from 'hammerjs'; import propagating from 'propagating-hammerjs'; function init() { const hammer = propagating(new Hammer(element)); } ``` ## Use To extend individual hammer.js instances with event propagation: ```js var hammer = propagating(new Hammer(element)); ``` To extend the global hammer.js constructor ```js Hammer = propagating(Hammer); ``` ## Examples Here a basic usage example. More examples are available in the folder [/examples](./examples/). ```html