|
12 | 12 | //Usage: |
13 | 13 | //<div drag-scroll>Lorem ipsum dolor sit amet</div> |
14 | 14 | var directive = { |
15 | | - scope: false, |
| 15 | + scope:{ |
| 16 | + dragScroll:'=' |
| 17 | + }, |
16 | 18 | restrict: 'A', |
17 | 19 | link: function($scope, $element, $attributes, vm) { |
18 | 20 | var allowedClickOffset = 5; |
|
53 | 55 | * @param {object} e MouseDown event |
54 | 56 | */ |
55 | 57 | function handleMouseDown (e) { |
56 | | - for (var i= 0; i<excludedClasses.length; i++) { |
57 | | - if (angular.element(e.target).hasClass(excludedClasses[i])) { |
58 | | - return false; |
| 58 | + if($scope.dragScroll){ |
| 59 | + for (var i= 0; i<excludedClasses.length; i++) { |
| 60 | + if (angular.element(e.target).hasClass(excludedClasses[i])) { |
| 61 | + return false; |
| 62 | + } |
59 | 63 | } |
60 | | - } |
61 | 64 |
|
62 | | - $scope.$apply(function() { |
63 | | - onDragStart($scope); |
64 | | - }); |
| 65 | + $scope.$apply(function() { |
| 66 | + onDragStart($scope); |
| 67 | + }); |
65 | 68 |
|
66 | | - // Set mouse drag listeners |
67 | | - setDragListeners(); |
| 69 | + // Set mouse drag listeners |
| 70 | + setDragListeners(); |
68 | 71 |
|
69 | | - // Set 'pushed' state |
70 | | - pushed = true; |
71 | | - lastClientX = startClientX = e.clientX; |
72 | | - lastClientY = startClientY = e.clientY; |
| 72 | + // Set 'pushed' state |
| 73 | + pushed = true; |
| 74 | + lastClientX = startClientX = e.clientX; |
| 75 | + lastClientY = startClientY = e.clientY; |
73 | 76 |
|
74 | | - clearSelection(); |
| 77 | + clearSelection(); |
75 | 78 |
|
76 | | - e.preventDefault(); |
77 | | - e.stopPropagation(); |
| 79 | + e.preventDefault(); |
| 80 | + e.stopPropagation(); |
| 81 | + } |
| 82 | + |
78 | 83 | } |
79 | 84 |
|
80 | 85 | /** |
81 | 86 | * Handles mouseup event |
82 | 87 | * @param {object} e MouseUp event |
83 | 88 | */ |
84 | 89 | function handleMouseUp (e) { |
85 | | - var selectable = ('drag-scroll-text' in e.target.attributes); |
86 | | - var withinXConstraints = (e.clientX >= (startClientX - allowedClickOffset) && e.clientX <= (startClientX + allowedClickOffset)); |
87 | | - var withinYConstraints = (e.clientY >= (startClientY - allowedClickOffset) && e.clientY <= (startClientY + allowedClickOffset)); |
| 90 | + if($scope.dragScroll){ |
| 91 | + var selectable = ('drag-scroll-text' in e.target.attributes); |
| 92 | + var withinXConstraints = (e.clientX >= (startClientX - allowedClickOffset) && e.clientX <= (startClientX + allowedClickOffset)); |
| 93 | + var withinYConstraints = (e.clientY >= (startClientY - allowedClickOffset) && e.clientY <= (startClientY + allowedClickOffset)); |
| 94 | + |
| 95 | + // Set 'pushed' state |
| 96 | + pushed = false; |
| 97 | + |
| 98 | + // Check if cursor falls within X and Y axis constraints |
| 99 | + if(selectable && withinXConstraints && withinYConstraints) { |
| 100 | + // If so, select the text inside the target element |
| 101 | + selectText(e.target); |
| 102 | + } |
88 | 103 |
|
89 | | - // Set 'pushed' state |
90 | | - pushed = false; |
| 104 | + $scope.$apply(function() { |
| 105 | + onDragEnd($scope); |
| 106 | + }); |
91 | 107 |
|
92 | | - // Check if cursor falls within X and Y axis constraints |
93 | | - if(selectable && withinXConstraints && withinYConstraints) { |
94 | | - // If so, select the text inside the target element |
95 | | - selectText(e.target); |
| 108 | + removeDragListeners(); |
96 | 109 | } |
97 | | - |
98 | | - $scope.$apply(function() { |
99 | | - onDragEnd($scope); |
100 | | - }); |
101 | | - |
102 | | - removeDragListeners(); |
| 110 | + |
103 | 111 | } |
104 | 112 |
|
105 | 113 | /** |
106 | 114 | * Handles mousemove event |
107 | 115 | * @param {object} e MouseMove event |
108 | 116 | */ |
109 | 117 | function handleMouseMove (e) { |
110 | | - if (pushed) { |
111 | | - if(!axis || axis === 'x') { |
112 | | - $element[0].scrollLeft -= (-lastClientX + (lastClientX = e.clientX)); |
113 | | - } |
114 | | - if(!axis || axis === 'y') { |
115 | | - $element[0].scrollTop -= (-lastClientY + (lastClientY = e.clientY)); |
| 118 | + if($scope.dragScroll){ |
| 119 | + if (pushed) { |
| 120 | + if(!axis || axis === 'x') { |
| 121 | + $element[0].scrollLeft -= (-lastClientX + (lastClientX = e.clientX)); |
| 122 | + } |
| 123 | + if(!axis || axis === 'y') { |
| 124 | + $element[0].scrollTop -= (-lastClientY + (lastClientY = e.clientY)); |
| 125 | + } |
116 | 126 | } |
117 | | - } |
118 | 127 |
|
119 | | - e.preventDefault(); |
| 128 | + e.preventDefault(); |
| 129 | + } |
120 | 130 | } |
121 | 131 |
|
122 | 132 | /** |
|
0 commit comments