import { Directive } from '@angular/core'; import { Observable, fromEvent, merge, map, switchMap, takeUntil, tap } from 'rxjs'; import { stopPropagation } from './scrollbar/common'; import * as i0 from "@angular/core"; export class ScrollViewport { // Get viewport size, clientHeight or clientWidth get clientHeight() { return this.nativeElement.clientHeight; } get clientWidth() { return this.nativeElement.clientWidth; } get scrollHeight() { return this.nativeElement.scrollHeight; } get scrollWidth() { return this.nativeElement.scrollWidth; } // Get viewport scroll offset, scrollTop or scrollLeft get scrollTop() { return this.nativeElement.scrollTop; } get scrollLeft() { return this.nativeElement.scrollLeft; } // Get the available scrollable size get scrollMaxX() { return this.scrollWidth - this.clientWidth; } get scrollMaxY() { return this.scrollHeight - this.clientHeight; } get contentHeight() { return this.contentWrapperElement?.clientHeight || 0; } get contentWidth() { return this.contentWrapperElement?.clientWidth || 0; } constructor(viewPort) { this.viewPort = viewPort; this.nativeElement = viewPort.nativeElement; } /** * Activate viewport pointer events such as 'hovered' and 'clicked' events */ activatePointerEvents(propagate, destroyed) { this.hovered = new Observable((subscriber) => { // Stream that emits when pointer is moved over the viewport (used to set the hovered state) const mouseMoveStream = fromEvent(this.nativeElement, 'mousemove', { passive: true }); const mouseMove = propagate ? mouseMoveStream : mouseMoveStream.pipe(stopPropagation()); // Stream that emits when pointer leaves the viewport (used to remove the hovered state) const mouseLeave = fromEvent(this.nativeElement, 'mouseleave', { passive: true }).pipe(map(() => false)); merge(mouseMove, mouseLeave).pipe(tap((e) => subscriber.next(e)), takeUntil(destroyed)).subscribe(); }); this.clicked = new Observable((subscriber) => { const mouseDown = fromEvent(this.nativeElement, 'mousedown', { passive: true }).pipe(tap((e) => subscriber.next(e))); const mouseUp = fromEvent(this.nativeElement, 'mouseup', { passive: true }).pipe(tap(() => subscriber.next(false))); mouseDown.pipe(switchMap(() => mouseUp), takeUntil(destroyed)).subscribe(); }); } /** * Set this directive as a non-functional wrapper, called when a custom viewport is used */ setAsWrapper() { // In this case the default viewport and the default content wrapper will act as a mask this.nativeElement.className = 'ng-native-scrollbar-hider ng-scroll-layer'; if (this.nativeElement.firstElementChild) { this.nativeElement.firstElementChild.className = 'ng-scroll-layer'; } } /** * Set this directive as the viewport, called when no custom viewport is used */ setAsViewport(customClassName) { this.nativeElement.className += ` ng-native-scrollbar-hider ng-scroll-viewport ${customClassName}`; // Check if the custom viewport has only one child and set it as the content wrapper if (this.nativeElement.firstElementChild) { this.contentWrapperElement = this.nativeElement.firstElementChild; this.contentWrapperElement.classList.add('ng-scroll-content'); } } /** * Scroll viewport vertically */ scrollYTo(value) { this.nativeElement.scrollTop = value; } /** * Scroll viewport horizontally */ scrollXTo(value) { this.nativeElement.scrollLeft = value; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: ScrollViewport, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.5", type: ScrollViewport, isStandalone: true, selector: "[scrollViewport]", ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: ScrollViewport, decorators: [{ type: Directive, args: [{ selector: '[scrollViewport]', standalone: true }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroll-viewport.js","sourceRoot":"","sources":["../../../../projects/ngx-scrollbar/src/lib/scroll-viewport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,UAAU,EAAc,SAAS,EAAE,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAChG,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;;AAMrD,MAAM,OAAO,cAAc;IAWzB,iDAAiD;IACjD,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC;IACzC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;IACxC,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC;IACzC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;IACxC,CAAC;IAED,sDAAsD;IACtD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC;IACtC,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC;IACvC,CAAC;IAED,oCAAoC;IACpC,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;IAC7C,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;IAC/C,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,qBAAqB,EAAE,YAAY,IAAI,CAAC,CAAC;IACvD,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,qBAAqB,EAAE,WAAW,IAAI,CAAC,CAAC;IACtD,CAAC;IAED,YAAmB,QAAoB;QAApB,aAAQ,GAAR,QAAQ,CAAY;QACrC,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC;IAC9C,CAAC;IAED;;OAEG;IACH,qBAAqB,CAAC,SAAkB,EAAE,SAA2B;QACnE,IAAI,CAAC,OAAO,GAAG,IAAI,UAAU,CAAC,CAAC,UAA0C,EAAE,EAAE;YAC3E,4FAA4F;YAC5F,MAAM,eAAe,GAAG,SAAS,CAAa,IAAI,CAAC,aAAa,EAAE,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;YAClG,MAAM,SAAS,GAAG,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;YACxF,wFAAwF;YACxF,MAAM,UAAU,GAAG,SAAS,CAAQ,IAAI,CAAC,aAAa,EAAE,YAAY,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;YAChH,KAAK,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,IAAI,CAC/B,GAAG,CAAC,CAAC,CAAqB,EAAE,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAClD,SAAS,CAAC,SAAS,CAAC,CACrB,CAAC,SAAS,EAAE,CAAC;QAChB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,GAAG,IAAI,UAAU,CAAC,CAAC,UAA0C,EAAE,EAAE;YAC3E,MAAM,SAAS,GAAG,SAAS,CAAa,IAAI,CAAC,aAAa,EAAE,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAC9F,GAAG,CAAC,CAAC,CAAa,EAAE,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAC3C,CAAC;YACF,MAAM,OAAO,GAAG,SAAS,CAAQ,IAAI,CAAC,aAAa,EAAE,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CACrF,GAAG,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAClC,CAAC;YACF,SAAS,CAAC,IAAI,CACZ,SAAS,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,EACxB,SAAS,CAAC,SAAS,CAAC,CACrB,CAAC,SAAS,EAAE,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,YAAY;QACV,uFAAuF;QACvF,IAAI,CAAC,aAAa,CAAC,SAAS,GAAG,2CAA2C,CAAC;QAC3E,IAAI,IAAI,CAAC,aAAa,CAAC,iBAAiB,EAAE;YACxC,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,SAAS,GAAG,iBAAiB,CAAC;SACpE;IACH,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,eAAuB;QACnC,IAAI,CAAC,aAAa,CAAC,SAAS,IAAI,iDAAkD,eAAgB,EAAE,CAAC;QACrG,oFAAoF;QACpF,IAAI,IAAI,CAAC,aAAa,CAAC,iBAAiB,EAAE;YACxC,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAgC,CAAC;YACjF,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;SAC/D;IACH,CAAC;IAED;;OAEG;IACH,SAAS,CAAC,KAAa;QACrB,IAAI,CAAC,aAAa,CAAC,SAAS,GAAG,KAAK,CAAC;IACvC,CAAC;IAED;;OAEG;IACH,SAAS,CAAC,KAAa;QACrB,IAAI,CAAC,aAAa,CAAC,UAAU,GAAG,KAAK,CAAC;IACxC,CAAC;8GA3HU,cAAc;kGAAd,cAAc;;2FAAd,cAAc;kBAJ1B,SAAS;mBAAC;oBACT,QAAQ,EAAE,kBAAkB;oBAC5B,UAAU,EAAE,IAAI;iBACjB","sourcesContent":["import { Directive, ElementRef } from '@angular/core';\r\nimport { Observable, Subscriber, fromEvent, merge, map, switchMap, takeUntil, tap } from 'rxjs';\r\nimport { stopPropagation } from './scrollbar/common';\r\n\r\n@Directive({\r\n  selector: '[scrollViewport]',\r\n  standalone: true\r\n})\r\nexport class ScrollViewport {\r\n  // Viewport element\r\n  readonly nativeElement: HTMLElement;\r\n  // Content wrapper element\r\n  contentWrapperElement!: HTMLElement;\r\n\r\n  // Stream that emits when pointer event when the viewport is hovered and emits false value when isn't hovered\r\n  hovered!: Observable<MouseEvent | false>;\r\n  // Stream that emits when viewport is clicked\r\n  clicked!: Observable<MouseEvent | false>;\r\n\r\n  // Get viewport size, clientHeight or clientWidth\r\n  get clientHeight(): number {\r\n    return this.nativeElement.clientHeight;\r\n  }\r\n\r\n  get clientWidth(): number {\r\n    return this.nativeElement.clientWidth;\r\n  }\r\n\r\n  get scrollHeight(): number {\r\n    return this.nativeElement.scrollHeight;\r\n  }\r\n\r\n  get scrollWidth(): number {\r\n    return this.nativeElement.scrollWidth;\r\n  }\r\n\r\n  // Get viewport scroll offset, scrollTop or scrollLeft\r\n  get scrollTop(): number {\r\n    return this.nativeElement.scrollTop;\r\n  }\r\n\r\n  get scrollLeft(): number {\r\n    return this.nativeElement.scrollLeft;\r\n  }\r\n\r\n  // Get the available scrollable size\r\n  get scrollMaxX(): number {\r\n    return this.scrollWidth - this.clientWidth;\r\n  }\r\n\r\n  get scrollMaxY(): number {\r\n    return this.scrollHeight - this.clientHeight;\r\n  }\r\n\r\n  get contentHeight(): number {\r\n    return this.contentWrapperElement?.clientHeight || 0;\r\n  }\r\n\r\n  get contentWidth(): number {\r\n    return this.contentWrapperElement?.clientWidth || 0;\r\n  }\r\n\r\n  constructor(public viewPort: ElementRef) {\r\n    this.nativeElement = viewPort.nativeElement;\r\n  }\r\n\r\n  /**\r\n   * Activate viewport pointer events such as 'hovered' and 'clicked' events\r\n   */\r\n  activatePointerEvents(propagate: boolean, destroyed: Observable<void>): void {\r\n    this.hovered = new Observable((subscriber: Subscriber<MouseEvent | false>) => {\r\n      // Stream that emits when pointer is moved over the viewport (used to set the hovered state)\r\n      const mouseMoveStream = fromEvent<MouseEvent>(this.nativeElement, 'mousemove', { passive: true });\r\n      const mouseMove = propagate ? mouseMoveStream : mouseMoveStream.pipe(stopPropagation());\r\n      // Stream that emits when pointer leaves the viewport (used to remove the hovered state)\r\n      const mouseLeave = fromEvent<false>(this.nativeElement, 'mouseleave', { passive: true }).pipe(map(() => false));\r\n      merge(mouseMove, mouseLeave).pipe(\r\n        tap((e: MouseEvent | false) => subscriber.next(e)),\r\n        takeUntil(destroyed)\r\n      ).subscribe();\r\n    });\r\n\r\n    this.clicked = new Observable((subscriber: Subscriber<MouseEvent | false>) => {\r\n      const mouseDown = fromEvent<MouseEvent>(this.nativeElement, 'mousedown', { passive: true }).pipe(\r\n        tap((e: MouseEvent) => subscriber.next(e))\r\n      );\r\n      const mouseUp = fromEvent<false>(this.nativeElement, 'mouseup', { passive: true }).pipe(\r\n        tap(() => subscriber.next(false))\r\n      );\r\n      mouseDown.pipe(\r\n        switchMap(() => mouseUp),\r\n        takeUntil(destroyed)\r\n      ).subscribe();\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Set this directive as a non-functional wrapper, called when a custom viewport is used\r\n   */\r\n  setAsWrapper(): void {\r\n    // In this case the default viewport and the default content wrapper will act as a mask\r\n    this.nativeElement.className = 'ng-native-scrollbar-hider ng-scroll-layer';\r\n    if (this.nativeElement.firstElementChild) {\r\n      this.nativeElement.firstElementChild.className = 'ng-scroll-layer';\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set this directive as  the viewport, called when no custom viewport is used\r\n   */\r\n  setAsViewport(customClassName: string): void {\r\n    this.nativeElement.className += ` ng-native-scrollbar-hider ng-scroll-viewport ${ customClassName }`;\r\n    // Check if the custom viewport has only one child and set it as the content wrapper\r\n    if (this.nativeElement.firstElementChild) {\r\n      this.contentWrapperElement = this.nativeElement.firstElementChild as HTMLElement;\r\n      this.contentWrapperElement.classList.add('ng-scroll-content');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Scroll viewport vertically\r\n   */\r\n  scrollYTo(value: number): void {\r\n    this.nativeElement.scrollTop = value;\r\n  }\r\n\r\n  /**\r\n   * Scroll viewport horizontally\r\n   */\r\n  scrollXTo(value: number): void {\r\n    this.nativeElement.scrollLeft = value;\r\n  }\r\n}\r\n"]}