mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2026-03-13 10:22:08 +08:00
Closes #2336. Closes #2317. Closes #2290. Closes #2228. Closes #2067. Closes #1890. Closes #1865. Closes #1850. Closes #1755. Closes #1688. Closes #1578. Closes #1501. Closes #1353. Closes #1342. Closes #782. Closes #416. Closes #2288. BREAKING CHANGE: The slideBox's API has undergone many changes. - **`<ion-slide-box>`** attributes have changed (see [documentation](http://ionicframework.com/docs/api/directive/ionSlideBox)): * `active-slide` has changed to `selected`. Change your code from this: ```html <ion-slide-box active-slide="activeSlideIndex"></ion-slide-box> ``` To this: ```html <ion-slide-box selected="activeSlideIndex"></ion-slide-box> ``` * `does-continue` has changed to `loop`. Change your code from this: ```html <ion-slide-box does-continue="shouldLoop"></ion-slide-box> ``` To this: ```html <ion-slide-box loop="shouldLoop"></ion-slide-box> ``` * `auto-play` and `slide-interval` have been merged into `auto-play`. Change your code from this: ```html <!-- autoPlay is on --> <ion-slide-box auto-play="true" slide-interval="1000"> </ion-slide-box> <!-- autoPlay is off --> <ion-slide-box auto-play="false" slide-interval="1000"> </ion-slide-box> ``` To this: ```html <!-- autoPlay is on --> <ion-slide-box auto-play="1000"></ion-slide-box> <!-- autoPlay is off --> <ion-slide-box auto-play="false"></ion-slide-box> ``` * `show-pager` and `pager-click` have been removed. Use a child `<ion-slide-pager>` element. See the [`ion-slide-pager` documentation](http://ionicframework.com/docs/api/directive/ionSlidePager). Change your code from this: ```html <!-- pager using default click action --> <ion-slide-box show-pager="true"> </ion-slide-box> <!-- pager with custom click action --> <ion-slide-box show-pager="true" pager-click="doSomething(index)"> </ion-slide-box> ``` To this: ```html <ion-slide-box> <!-- pager using default click action --> <ion-slide-pager></ion-slide-pager> </ion-slide-box> <ion-slide-box> <!-- pager with custom click action --> <ion-slide-pager ng-click="doSomething(index)"></ion-slide-pager> </ion-slide-box> ``` - **`$ionicSlideBoxDelegate`** methods have changed (see [documentation](http://ionicframework.com/docs/api/service/$ionicSlideBoxDelegate)): - `update()` has been removed. slideBox updates on its own now. - `stop()` has been removed. See `autoPlay()` below. - `start()` hass been removed. See `autoPlay()` below. - `slide(newIndex[, speed])` has been renamed to `select(newIndex[, speed]); - `currentIndex()` has been renamed to `selected()`. - `slidesCount()` has been renamed to `count()`. - New method `$ionicSlideBoxDelegate.autoPlay()`. Change your code from this: ```js // stop auto sliding $ionicSlideBoxDelegate.stop(); // later... start auto sliding $ionicSlideBoxDelegate.start(); ``` To this: ```js var autoPlaySpeed = 3000; //wait 3000 seconds between changing slide // stop auto sliding $ionicSlideBoxDelegate.autoPlay(false); // later... start auto sliding $ionicSlideBoxDelegate.autoPlay(autoPlaySpeed); ``` - `previous()` now returns the index of the previous slide and does not select. Change your code from this: ```js // select previous slide $ionicSlideBoxDelegate.previous(); ``` To this: ```js // select previous slide $ionicSlideBoxDelegate.select( $ionicSlideBoxDelegate.previous() ); ``` - `next()` now returns the index of the next slide and does not select. Change your code from this: ```js // select next slide $ionicSlideBoxDelegate.next(); ``` To this: ```js // select next slide $ionicSlideBoxDelegate.select( $ionicSlideBoxDelegate.next() ); ```
145 lines
4.5 KiB
JavaScript
145 lines
4.5 KiB
JavaScript
/**
|
|
* @ngdoc directive
|
|
* @name ionInfiniteScroll
|
|
* @module ionic
|
|
* @parent ionic.directive:ionContent, ionic.directive:ionScroll
|
|
* @restrict E
|
|
*
|
|
* @description
|
|
* The ionInfiniteScroll directive allows you to call a function whenever
|
|
* the user gets to the bottom of the page or near the bottom of the page.
|
|
*
|
|
* The expression you pass in for `on-infinite` is called when the user scrolls
|
|
* greater than `distance` away from the bottom of the content. Once `on-infinite`
|
|
* is done loading new data, it should broadcast the `scroll.infiniteScrollComplete`
|
|
* event from your controller (see below example).
|
|
*
|
|
* @param {expression} on-infinite What to call when the scroller reaches the
|
|
* bottom.
|
|
* @param {string=} distance The distance from the bottom that the scroll must
|
|
* reach to trigger the on-infinite expression. Default: 1%.
|
|
* @param {string=} icon The icon to show while loading. Default: 'ion-loading-d'.
|
|
*
|
|
* @usage
|
|
* ```html
|
|
* <ion-content ng-controller="MyController">
|
|
* <ion-list>
|
|
* ....
|
|
* ....
|
|
* </ion-list>
|
|
*
|
|
* <ion-infinite-scroll
|
|
* on-infinite="loadMore()"
|
|
* distance="1%">
|
|
* </ion-infinite-scroll>
|
|
* </ion-content>
|
|
* ```
|
|
* ```js
|
|
* function MyController($scope, $http) {
|
|
* $scope.items = [];
|
|
* $scope.loadMore = function() {
|
|
* $http.get('/more-items').success(function(items) {
|
|
* useItems(items);
|
|
* $scope.$broadcast('scroll.infiniteScrollComplete');
|
|
* });
|
|
* };
|
|
*
|
|
* $scope.$on('$stateChangeSuccess', function() {
|
|
* $scope.loadMore();
|
|
* });
|
|
* }
|
|
* ```
|
|
*
|
|
* An easy to way to stop infinite scroll once there is no more data to load
|
|
* is to use angular's `ng-if` directive:
|
|
*
|
|
* ```html
|
|
* <ion-infinite-scroll
|
|
* ng-if="moreDataCanBeLoaded()"
|
|
* icon="ion-loading-c"
|
|
* on-infinite="loadMoreData()">
|
|
* </ion-infinite-scroll>
|
|
* ```
|
|
*/
|
|
IonicModule
|
|
.directive('ionInfiniteScroll', ['$timeout', function($timeout) {
|
|
function calculateMaxValue(distance, maximum, isPercent) {
|
|
return isPercent ?
|
|
maximum * (1 - parseFloat(distance,10) / 100) :
|
|
maximum - parseFloat(distance, 10);
|
|
}
|
|
return {
|
|
restrict: 'E',
|
|
require: ['^$ionicScroll', 'ionInfiniteScroll'],
|
|
template: '<i class="icon {{icon()}} icon-refreshing"></i>',
|
|
scope: true,
|
|
controller: ['$scope', '$attrs', function($scope, $attrs) {
|
|
this.isLoading = false;
|
|
this.scrollView = null; //given by link function
|
|
this.getMaxScroll = function() {
|
|
var distance = ($attrs.distance || '2.5%').trim();
|
|
var isPercent = distance.indexOf('%') !== -1;
|
|
var maxValues = this.scrollView.getScrollMax();
|
|
return {
|
|
left: this.scrollView.options.scrollingX ?
|
|
calculateMaxValue(distance, maxValues.left, isPercent) :
|
|
-1,
|
|
top: this.scrollView.options.scrollingY ?
|
|
calculateMaxValue(distance, maxValues.top, isPercent) :
|
|
-1
|
|
};
|
|
};
|
|
}],
|
|
link: function($scope, $element, $attrs, ctrls) {
|
|
var scrollCtrl = ctrls[0];
|
|
var infiniteScrollCtrl = ctrls[1];
|
|
var scrollView = infiniteScrollCtrl.scrollView = scrollCtrl.scrollView;
|
|
|
|
$scope.icon = function() {
|
|
return angular.isDefined($attrs.icon) ? $attrs.icon : 'ion-loading-d';
|
|
};
|
|
|
|
var onInfinite = function() {
|
|
$element[0].classList.add('active');
|
|
infiniteScrollCtrl.isLoading = true;
|
|
$scope.$parent && $scope.$parent.$apply($attrs.onInfinite || '');
|
|
};
|
|
|
|
var finishInfiniteScroll = function() {
|
|
$element[0].classList.remove('active');
|
|
$timeout(function() {
|
|
scrollView.resize();
|
|
checkBounds();
|
|
}, 0, false);
|
|
infiniteScrollCtrl.isLoading = false;
|
|
};
|
|
|
|
$scope.$on('scroll.infiniteScrollComplete', function() {
|
|
finishInfiniteScroll();
|
|
});
|
|
|
|
$scope.$on('$destroy', function() {
|
|
if(scrollCtrl && scrollCtrl.$element)scrollCtrl.$element.off('scroll', checkBounds);
|
|
});
|
|
|
|
var checkBounds = ionic.animationFrameThrottle(checkInfiniteBounds);
|
|
|
|
//Check bounds on start, after scrollView is fully rendered
|
|
setTimeout(checkBounds);
|
|
scrollCtrl.$element.on('scroll', checkBounds);
|
|
|
|
function checkInfiniteBounds() {
|
|
if (infiniteScrollCtrl.isLoading) return;
|
|
|
|
var scrollValues = scrollView.getValues();
|
|
var maxScroll = infiniteScrollCtrl.getMaxScroll();
|
|
|
|
if ((maxScroll.left !== -1 && scrollValues.left >= maxScroll.left) ||
|
|
(maxScroll.top !== -1 && scrollValues.top >= maxScroll.top)) {
|
|
onInfinite();
|
|
}
|
|
}
|
|
}
|
|
};
|
|
}]);
|