diff options
| author | Vojta Jina | 2012-01-12 03:00:34 -0800 |
|---|---|---|
| committer | Vojta Jina | 2012-01-13 01:07:12 -0800 |
| commit | 15fd735793cffe89fdf9662275409cdcdb3e801a (patch) | |
| tree | ce5699ab3375d41cfcffb88ed93236b7ff96a366 /src/service | |
| parent | 985d3d75586a16020d78564753f9b46ec9091929 (diff) | |
| download | angular.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; }]; |
