Commit e6371cf7ae9bb272161ddb84f2fa7510fae2b494
1 parent
6dd6f3aad2
Exists in
develop
Agregada nueva directiva.
Showing
1 changed file
with
34 additions
and
0 deletions
Show diff stats
src/js/onMouseHold-directive.js
| File was created | 1 | angular.module('focaDirectivas') | |
| 2 | .directive('onMouseHold', function ($parse, $interval) { | ||
| 3 | var stop; | ||
| 4 | |||
| 5 | var dirDefObj = { | ||
| 6 | restrict: 'A', | ||
| 7 | scope: { method: '&onMouseHold' }, | ||
| 8 | link: function (scope, element, attrs) { | ||
| 9 | |||
| 10 | var expressionHandler = scope.method(); | ||
| 11 | var actionInterval = (attrs.mouseHoldRepeat) ? attrs.mouseHoldRepeat : 500; | ||
| 12 | |||
| 13 | var startAction = function () { | ||
| 14 | expressionHandler(); | ||
| 15 | stop = $interval(function () { | ||
| 16 | expressionHandler(); | ||
| 17 | }, actionInterval); | ||
| 18 | }; | ||
| 19 | |||
| 20 | var stopAction = function () { | ||
| 21 | if (stop) { | ||
| 22 | $interval.cancel(stop); | ||
| 23 | stop = undefined; | ||
| 24 | } | ||
| 25 | }; | ||
| 26 | |||
| 27 | element.bind('mousedown', startAction); | ||
| 28 | element.bind('mouseup', stopAction); | ||
| 29 | element.bind('mouseout', stopAction); | ||
| 30 | } | ||
| 31 | }; | ||
| 32 | |||
| 33 | return dirDefObj; | ||
| 34 | }); |