aboutsummaryrefslogtreecommitdiffstats
path: root/src/service
diff options
context:
space:
mode:
authorVojta Jina2012-01-12 03:00:34 -0800
committerVojta Jina2012-01-13 01:07:12 -0800
commit15fd735793cffe89fdf9662275409cdcdb3e801a (patch)
treece5699ab3375d41cfcffb88ed93236b7ff96a366 /src/service
parent985d3d75586a16020d78564753f9b46ec9091929 (diff)
downloadangular.js-15fd735793cffe89fdf9662275409cdcdb3e801a.tar.bz2
refactor($autoScroll): rename to $anchorScroll and allow disabling auto scrolling (links)
Now, that we have autoscroll attribute on ng:include, there is no reason to disable the service completely, so $anchorScrollProvider.disableAutoScrolling() means it won't be scrolling when $location.hash() changes. And then, it's not $autoScroll at all, it actually scrolls to anchor when it's called, so I renamed it to $anchorScroll.
Diffstat (limited to 'src/service')
-rw-r--r--src/service/anchorScroll.js (renamed from src/service/autoScroll.js)22
1 files changed, 12 insertions, 10 deletions
diff --git a/src/service/autoScroll.js b/src/service/anchorScroll.js
index 223400f4..19a09498 100644
--- a/src/service/autoScroll.js
+++ b/src/service/anchorScroll.js
@@ -1,6 +1,6 @@
/**
* @ngdoc function
- * @name angular.module.ng.$autoScroll
+ * @name angular.module.ng.$anchorScroll
* @requires $window
* @requires $location
* @requires $rootScope
@@ -11,14 +11,14 @@
* {@link http://dev.w3.org/html5/spec/Overview.html#the-indicated-part-of-the-document Html5 spec}.
*
* It also watches the `$location.hash()` and scroll whenever it changes to match any anchor.
- *
- * You can disable `$autoScroll` service by calling `disable()` on `$autoScrollProvider`.
- * Note: disabling is only possible before the service is instantiated !
+ * This can be disabled by calling `$anchorScrollProvider.disableAutoScrolling()`.
*/
-function $AutoScrollProvider() {
+function $AnchorScrollProvider() {
+
+ var autoScrollingEnabled = true;
- this.disable = function() {
- this.$get = function() {return noop;};
+ this.disableAutoScrolling = function() {
+ autoScrollingEnabled = false;
};
this.$get = ['$window', '$location', '$rootScope', function($window, $location, $rootScope) {
@@ -54,9 +54,11 @@ function $AutoScrollProvider() {
// does not scroll when user clicks on anchor link that is currently on
// (no url change, no $locaiton.hash() change), browser native does scroll
- $rootScope.$watch(function() {return $location.hash();}, function() {
- $rootScope.$evalAsync(scroll);
- });
+ if (autoScrollingEnabled) {
+ $rootScope.$watch(function() {return $location.hash();}, function() {
+ $rootScope.$evalAsync(scroll);
+ });
+ }
return scroll;
}];