angular2-infinite-scroll
Advanced tools
Comparing version 0.1.1 to 0.1.2
{ | ||
"name": "angular2-infinite-scroll", | ||
"version": "0.1.1", | ||
"version": "0.1.2", | ||
"description": "An infinite scroll directive for angular2", | ||
@@ -5,0 +5,0 @@ "main": "angular2-infinite-scroll.js", |
@@ -7,16 +7,18 @@ # Angular 2 Infinite Scroll | ||
Currently supported attributes: | ||
* (number) "infiniteDcrollDistance" (optional, default: **2**) - should get a number | ||
* (number) "infiniteScrollThrottle" (optional, default: **300**) - should get a number of milliseconds for throttle | ||
* (function) - instead of defining a callback function on the "infinite-scroll" attribute, you should use the event binding **(scrolled)="handleScrollCallback()"** | ||
* (boolean) - "scrollWindow" (optional, default: **true**) - listens to the window scroll instead of the actual element scroll. this allows to invoke a callback function in the scope of the element while listenning to the window scroll. | ||
* (boolean) - "immediateCheck" (optional, default: **false**) - invokes the handler immediately to check if a scroll event has been already triggred when the page has been loaded (i.e. - when you refresh a page that has been scrolled). | ||
* (number) "infiniteScrollDistance" (optional, default: **2**) - should get a number | ||
* (number) "infiniteScrollUpDistance" (optional, default: **1.5**) - should get a number | ||
* (number) "infiniteScrollThrottle" (optional, default: **300**) - should get a number of milliseconds for throttle | ||
* (function) - instead of defining a callback function on the "infinite-scroll" attribute, you should use the event binding **(scrolled)="handleScrollDownCallback()"** - this will callback if the distance threshold has been reached on a scroll down. | ||
* (function) - instead of defining a callback function on the "infinite-scroll" attribute, you should use the event binding **(scrolledUp)="handleScrollUpCallback()"** - this will callback if the distance threshold has been reached on a scroll up. | ||
* (boolean) - "scrollWindow" (optional, default: **true**) - listens to the window scroll instead of the actual element scroll. this allows to invoke a callback function in the scope of the element while listenning to the window scroll. | ||
* (boolean) - "immediateCheck" (optional, default: **false**) - invokes the handler immediately to check if a scroll event has been already triggred when the page has been loaded (i.e. - when you refresh a page that has been scrolled). | ||
## Behavior | ||
By default, the directive listens to a window scroll event and invoked the callback. | ||
**To trigger the callback when the actual element is scrolled**, these settings should be configured: | ||
* [scrollWindow]="false" | ||
By default, the directive listens to a window scroll event and invoked the callback. | ||
**To trigger the callback when the actual element is scrolled**, these settings should be configured: | ||
* [scrollWindow]="false" | ||
* set an explict css "height" value to the element | ||
## Usage | ||
In this example, the **onScroll** callback will be invoked when the window is scrolled: | ||
In this example, the **onScroll** callback will be invoked when the window is scrolled down: | ||
@@ -45,3 +47,3 @@ ```typescript | ||
``` | ||
in this example, whenever the "search-results" is scrolled, the callback will be invoked: | ||
in this example, whenever the "search-results" is scrolled, the callback will be invoked: | ||
@@ -76,5 +78,36 @@ ```typescript | ||
} | ||
``` | ||
``` | ||
In this example, the **onScrollDown** callback will be invoked when the window is scrolled down and the **onScrollUp** callback will be invoked when the window is scrolled up: | ||
```typescript | ||
import { Component } from '@angular/core'; | ||
import { InfiniteScroll } from 'angular2-infinite-scroll'; | ||
@Component({ | ||
selector: 'app', | ||
directives: [ InfiniteScroll ], | ||
template: ` | ||
<div class="search-results" | ||
infinite-scroll | ||
[infiniteScrollDistance]="2" | ||
[infiniteScrollUpDistance]="1.5" | ||
[infiniteScrollThrottle]="500" | ||
(scrolled)="onScrollDown()"> | ||
(scrolledUp)="onScrollUp()"> | ||
</div> | ||
` | ||
}) | ||
export class App { | ||
onScrollDown () { | ||
console.log('scrolled down!!') | ||
} | ||
onScrollUp () { | ||
console.log('scrolled up!!') | ||
} | ||
} | ||
``` | ||
# Showcase Examples | ||
* [Echoes Player Ng2 Version](http://orizens.github.io/echoes-ng2) ([github repo for echoes player](http://github.com/orizens/echoes-ng2)) |
@@ -139,2 +139,1 @@ "use strict"; | ||
exports.Scroller = Scroller; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroller.js","sourceRoot":"","sources":["scroller.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef } from '@angular/core';\nimport { Observable, Subscription } from 'rxjs/Rx'; \n\nexport class Scroller {\n\tpublic scrollDistance: number;\n\tpublic scrollEnabled: boolean;\n\tpublic checkWhenEnabled: boolean;\n\tpublic container: Window | ElementRef | any;\n\tpublic immediateCheck: boolean;\n\tpublic useDocumentBottom: boolean;\n\tpublic checkInterval: number;\n\tprivate documentElement: Window | ElementRef | any;\n\tprivate isContainerWindow: boolean;\n\tprivate disposeScroll: Subscription;\n\n\tconstructor(\n\t\tprivate windowElement: Window | ElementRef | any,\n\t\tprivate $interval: Function,\n\t\tprivate $elementRef: ElementRef,\n\t\tprivate infiniteScrollCallback: Function,\n\t\tinfiniteScrollDistance: number,\n\t\tinfiniteScrollParent: Window | ElementRef | any,\n\t\tprivate infiniteScrollThrottle: number,\n\t\tprivate isImmediate: boolean\n\t\t) {\n\t\tthis.isContainerWindow = this.windowElement.hasOwnProperty('document');\n\t\tthis.documentElement = this.isContainerWindow ? this.windowElement.document.documentElement : null;\n\t\tthis.handleInfiniteScrollDistance(infiniteScrollDistance);\n\n\t\t// if (attrs.infiniteScrollParent != null) {\n\t\t// \tattachEvent(angular.element(elem.parent()));\n\t\t// }\n\t\tthis.handleInfiniteScrollDisabled(false);\n\t\tthis.defineContainer();\n    this.createInterval();\n\t}\n\n\tdefineContainer () {\n\t\tif (this.isContainerWindow) {\n\t\t\tthis.attachEvent(this.windowElement);\n\t\t} else {\n\t\t\tthis.container = this.windowElement.nativeElement;\n\t\t}\n\t}\n\n\tcreateInterval () {\n\t\tthis.checkInterval = this.$interval(() => {\n\t\t\tif (this.isImmediate) {\n\t\t\t\treturn this.handler();\n\t\t\t}\n\t\t}, 0);\n\t}\n\n\theight (elem: any) {\n\t\t// elem = elem.nativeElement;\n\t\tif (isNaN(elem.offsetHeight)) {\n\t\t\treturn this.documentElement.clientHeight;\n\t\t} else {\n\t\t\treturn elem.offsetHeight;\n\t\t}\n\t}\n\n\toffsetTop (elem: any) {\n\t\t// elem = elem.nativeElement;\n\t\tif (!elem.getBoundingClientRect) { // || elem.css('none')) {\n\t\t\treturn;\n\t\t}\n\t\treturn elem.getBoundingClientRect().top + this.pageYOffset(elem);\n\t}\n\n\tpageYOffset (elem: any) {\n\t\t// elem = elem.nativeElement;\n\t\tif (isNaN(window.pageYOffset)) {\n\t\t\treturn this.documentElement.scrollTop;\n\t\t} else if (elem.ownerDocument) {\n\t\t\treturn elem.ownerDocument.defaultView.pageYOffset;\n\t\t} else {\n\t\t\telem.offsetTop;\n\t\t}\n\t}\n\n\thandler () {\n\t\tconst container = this.calculatePoints();\n\t\tconst remaining: number = container.totalToScroll - container.scrolledUntilNow;\n\t\tconst containerBreakpoint: number = container.height * this.scrollDistance + 1;\n\t\tconst shouldScroll: boolean = remaining <= containerBreakpoint;\n\t\tconst triggerCallback: boolean = shouldScroll && this.scrollEnabled;\n\t\tconst shouldClearInterval = shouldScroll && this.checkInterval;\n\t\t// if (this.useDocumentBottom) {\n\t\t// \tcontainer.totalToScroll = this.height(this.$elementRef.nativeElement.ownerDocument);\n\t\t// }\n\t\tthis.checkWhenEnabled = shouldScroll;\n\t\tif (triggerCallback) {\n\t\t\tthis.infiniteScrollCallback();\n\t\t}\n\t\tif (shouldClearInterval) {\n\t\t\tclearInterval(this.checkInterval);\n\t\t}\n\t}\n\n\tcalculatePoints() {\n\t\treturn this.isContainerWindow\n\t\t\t? this.calculatePointsForWindow()\n\t\t\t: this.calculatePointsForElement();\n\t}\n\n\tcalculatePointsForWindow () {\n\t\t// container's height\n\t\tconst height = this.height(this.container);\n\t\t// scrolled until now / current y point\n\t\tconst scrolledUntilNow = height + this.pageYOffset(this.documentElement);\n\t\t// total height / most bottom y point\n\t\tconst totalToScroll = this.offsetTop(this.$elementRef.nativeElement) + this.height(this.$elementRef.nativeElement);\n\t\treturn { height, scrolledUntilNow, totalToScroll };\n\t}\n\n\tcalculatePointsForElement () {\n\t\tconst height = this.height(this.container);\n\t\t// perhaps use this.container.offsetTop instead of 'scrollTop'\n\t\tconst scrolledUntilNow = this.container.scrollTop;\n\t\tlet containerTopOffset = 0;\n\t\tconst offsetTop = this.offsetTop(this.container)\n\t\tif (offsetTop !== void 0) {\n\t\t\tcontainerTopOffset = offsetTop;\n\t\t}\n\t\tconst totalToScroll = this.container.scrollHeight;\n\t\t// const totalToScroll = this.offsetTop(this.$elementRef.nativeElement) - containerTopOffset + this.height(this.$elementRef.nativeElement);\n\t\treturn { height, scrolledUntilNow, totalToScroll };\n\t}\n\n\thandleInfiniteScrollDistance (scrollDistance: number | any) {\n\t\treturn this.scrollDistance = parseFloat(scrollDistance) || 0;\n\t}\n\n\tattachEvent (newContainer: Window | ElementRef | any) {\n\t\tthis.clean();\n\t\tthis.container = newContainer;\n\t\tif (newContainer) {\n\t\t\tconst throttle: number = this.infiniteScrollThrottle;\n\t\t\tthis.disposeScroll = Observable.fromEvent(this.container, 'scroll')\n\t\t\t\t.debounce(ev => Observable.timer(throttle))\n\t\t\t\t.subscribe(ev => this.handler())\n\t\t}\n\t}\n\n\tclean () {\n\t\tif (this.disposeScroll) {\n      this.disposeScroll.unsubscribe();\n\t\t}\n\t}\n\n\thandleInfiniteScrollDisabled (enableScroll: boolean) {\n\t\tthis.scrollEnabled = !enableScroll;\n\t\t// if (this.scrollEnabled && checkWhenEnabled) {\n\t\t// \tcheckWhenEnabled = false;\n\t\t// \treturn handler();\n\t\t// }\n\t}\n}"]} |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
111
30607