UNPKG

@fivethree/core

Version:
538 lines 42 kB
/** * @fileoverview added by tsickle * Generated from: lib/bottom-sheet/bottom-sheet.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { FivBottomSheetContent } from './bottom-sheet-content/bottom-sheet-content.component'; import { Component, Input, Output, EventEmitter, ElementRef, Renderer2, ContentChild } from '@angular/core'; import { DomController, Platform } from '@ionic/angular'; import { DrawerState } from './drawer-state'; import { merge, Subject, fromEvent, from } from 'rxjs'; import { takeUntil, map, tap, flatMap, repeat, withLatestFrom, filter, first, take, repeatWhen } from 'rxjs/operators'; /** * @record */ export function PanEvent() { } if (false) { /** @type {?} */ PanEvent.prototype.currentOffset; /** @type {?} */ PanEvent.prototype.startOffset; /** @type {?} */ PanEvent.prototype.currentTop; /** @type {?} */ PanEvent.prototype.startTop; /** @type {?} */ PanEvent.prototype.distance; /** @type {?} */ PanEvent.prototype.touch; } var FivBottomSheet = /** @class */ (function () { function FivBottomSheet(_element, _renderer, _domCtrl, _platform) { this._element = _element; this._renderer = _renderer; this._domCtrl = _domCtrl; this._platform = _platform; this.dockedHeight = 80; this.shouldBounce = true; this.distanceTop = 56; this.transition = '0.25s'; this.state = DrawerState.Bottom; this.bounceThreshold = 40; this.panThreshold = 20; this.panEnabled = true; this.stateChange = new EventEmitter(); this.fivOpen = new EventEmitter(); this.fivDocked = new EventEmitter(); this.fivClose = new EventEmitter(); this.fivProgress = new EventEmitter(); this.scrollTop = 0; this.$onDestroy = new Subject(); } /** * @return {?} */ FivBottomSheet.prototype.ngOnDestroy = /** * @return {?} */ function () { this.$onDestroy.next(); }; /** * @return {?} */ FivBottomSheet.prototype.ngAfterViewInit = /** * @return {?} */ function () { var _this = this; this._setDrawerState(this.state); this.content.shouldBounce = this.shouldBounce; /** @type {?} */ var touchmove = fromEvent(this._element.nativeElement, 'touchmove', { passive: true }); /** @type {?} */ var touchend = merge(fromEvent(this._element.nativeElement, 'touchend', { passive: true }), fromEvent(this._element.nativeElement, 'touchcancel', { passive: true })); /** @type {?} */ var getScrollContent = from(this.content.content.getScrollElement()); /** @type {?} */ var scroll = this.content.content.ionScroll.pipe(tap((/** * @param {?} el * @return {?} */ function (el) { return (_this.scrollTop = el.detail.scrollTop); })), takeUntil(this.$onDestroy)); scroll.subscribe(); this.content.content.ionScrollEnd .pipe(filter((/** * @param {?} el * @return {?} */ function (el) { return _this.scrollTop === 0 && _this.state === DrawerState.Top; })), tap((/** * @return {?} */ function () { return _this.content.content.scrollByPoint(0, 1, 0); })), takeUntil(this.$onDestroy)) .subscribe(); /** @type {?} */ var canStart = touchmove.pipe(filter((/** * @return {?} */ function () { return _this.scrollTop === 0; }))); /** @type {?} */ var start = canStart.pipe(take(1), tap((/** * @param {?} s * @return {?} */ function (s) { return _this._handlePanStart(s); }))); /** @type {?} */ var pan = start.pipe(filter((/** * @return {?} */ function () { return _this.panEnabled; })), flatMap((/** * @return {?} */ function () { return touchmove; })), map((/** * @param {?} tm * @return {?} */ function (tm) { return _this.calculatePanEvent(tm); }))); /** @type {?} */ var handlePan = pan.pipe(filter((/** * @param {?} p * @return {?} */ function (p) { return Math.abs(p.distance) > _this.panThreshold; })), map((/** * @param {?} tm * @return {?} */ function (tm) { return _this._handlePan(tm); })), takeUntil(touchend), repeat(), takeUntil(this.$onDestroy)); /** @type {?} */ var handleBackPan = pan .pipe(filter((/** * @param {?} p * @return {?} */ function (p) { return Math.abs(p.distance) <= _this.panThreshold && _this.content.panning; })), map((/** * @param {?} tm * @return {?} */ function (tm) { return _this._handlePan(tm); })), takeUntil(touchend), repeat(), takeUntil(this.$onDestroy)) .subscribe(); handlePan .pipe(first(), tap((/** * @return {?} */ function () { return (_this.content.panning = true); })), repeatWhen((/** * @return {?} */ function () { return touchend; })), takeUntil(this.$onDestroy)) .subscribe(); handlePan .pipe(flatMap((/** * @return {?} */ function () { return touchend; })), first(), withLatestFrom(pan), tap((/** * @return {?} */ function () { return _this.content.content.scrollByPoint(0, 1, 0); })), tap((/** * @return {?} */ function () { return (_this.content.panning = false); })), map((/** * @param {?} ev * @return {?} */ function (ev) { return ev[1]; })), repeat(), takeUntil(this.$onDestroy)) .subscribe((/** * @param {?} ev * @return {?} */ function (ev) { return _this._handlePanEnd(ev); })); }; /** * @param {?} changes * @return {?} */ FivBottomSheet.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (!changes.state) { return; } this._setDrawerState(changes.state.currentValue); this.updateContent(changes.state.currentValue); }; /** * @param {?} state * @return {?} */ FivBottomSheet.prototype.updateContent = /** * @param {?} state * @return {?} */ function (state) { if (this.content) { this.content.updateState(state); } }; /** * @private * @param {?} state * @return {?} */ FivBottomSheet.prototype._setDrawerState = /** * @private * @param {?} state * @return {?} */ function (state) { this._renderer.setStyle(this._element.nativeElement, 'transition', this.transition); switch (state) { case DrawerState.Bottom: this.content.content.scrollToTop(0); this._setTranslateY(this._platform.height()); break; case DrawerState.Docked: this.content.content.scrollToTop(0); this._setTranslateY(this._platform.height() - this.dockedHeight); break; default: this._setTranslateY(this.distanceTop); } }; /** * @private * @param {?} event * @return {?} */ FivBottomSheet.prototype._handlePanStart = /** * @private * @param {?} event * @return {?} */ function (event) { this._startPositionTop = this.getCurrentTop(); this._startPositionOffset = event.touches[0].pageY; }; /** * @return {?} */ FivBottomSheet.prototype.getCurrentTop = /** * @return {?} */ function () { return this._element.nativeElement.getBoundingClientRect().top; }; /** * @private * @param {?} ev * @return {?} */ FivBottomSheet.prototype._handlePanEnd = /** * @private * @param {?} ev * @return {?} */ function (ev) { if (this.shouldBounce) { this._renderer.setStyle(this._element.nativeElement, 'transition', this.transition); switch (this.state) { case DrawerState.Docked: this._handleDockedPanEnd(ev); break; case DrawerState.Top: this._handleTopPanEnd(ev); break; default: this._handleBottomPanEnd(ev); } } this.stateChange.emit(this.state); }; /** * @private * @param {?} ev * @return {?} */ FivBottomSheet.prototype._handleTopPanEnd = /** * @private * @param {?} ev * @return {?} */ function (ev) { if (ev.distance > this.bounceThreshold) { if (this.state !== DrawerState.Docked) { this.state = DrawerState.Docked; this.fivDocked.emit(this); } } else { this._setTranslateY(this.distanceTop); } }; /** * @private * @param {?} ev * @return {?} */ FivBottomSheet.prototype._handleDockedPanEnd = /** * @private * @param {?} ev * @return {?} */ function (ev) { /** @type {?} */ var absDeltaY = Math.abs(ev.distance); if (absDeltaY > this.bounceThreshold && ev.distance < 0) { if (this.state !== DrawerState.Top) { this.state = DrawerState.Top; this.fivOpen.emit(); } } else if (absDeltaY > this.bounceThreshold && ev.distance > 0) { if (this.state !== DrawerState.Bottom) { this.close(); } } else { this._setTranslateY(this._platform.height() - this.dockedHeight); } }; /** * @private * @param {?} ev * @return {?} */ FivBottomSheet.prototype._handleBottomPanEnd = /** * @private * @param {?} ev * @return {?} */ function (ev) { if (-ev.distance > this.bounceThreshold) { if (this.state !== DrawerState.Docked) { this.state = DrawerState.Docked; this.fivDocked.emit(); } } else { this._setTranslateY('100vh'); } }; /** * @param {?} ev * @return {?} */ FivBottomSheet.prototype.calculatePanEvent = /** * @param {?} ev * @return {?} */ function (ev) { return { currentOffset: ev.touches[0].pageY, startOffset: this._startPositionOffset, startTop: this._startPositionTop, currentTop: this.getCurrentTop(), distance: ev.touches[0].pageY - this._startPositionOffset, touch: ev }; }; /** * @private * @param {?} event * @return {?} */ FivBottomSheet.prototype._handlePan = /** * @private * @param {?} event * @return {?} */ function (event) { this._renderer.setStyle(this._element.nativeElement, 'transition', 'none'); if (event.currentTop >= 0 && event.currentTop <= this._platform.height()) { /** @type {?} */ var newTop = this._startPositionTop + event.distance; if (newTop >= this.distanceTop) { this._setTranslateY(newTop); } else if (newTop <= this.distanceTop && this.content.panning) { this._setTranslateY(this.distanceTop); this.content.content.scrollToPoint(0, 0 - newTop, 0); } return event; } }; /** * @private * @param {?} value * @return {?} */ FivBottomSheet.prototype._setTranslateY = /** * @private * @param {?} value * @return {?} */ function (value) { var _this = this; this.fivProgress.emit(1 - value / (this._platform.height() - this.dockedHeight)); this._domCtrl.write((/** * @return {?} */ function () { _this._renderer.setStyle(_this._element.nativeElement, 'transform', 'translateY(' + value + 'px)'); })); }; /** * @return {?} */ FivBottomSheet.prototype.open = /** * @return {?} */ function () { this.state = DrawerState.Top; this._setDrawerState(this.state); this.updateContent(this.state); }; /** * @return {?} */ FivBottomSheet.prototype.close = /** * @return {?} */ function () { this.state = DrawerState.Bottom; this._setDrawerState(this.state); this.updateContent(this.state); this.fivClose.emit(); }; /** * @return {?} */ FivBottomSheet.prototype.dock = /** * @return {?} */ function () { this.state = DrawerState.Docked; this._setDrawerState(this.state); this.updateContent(this.state); }; FivBottomSheet.decorators = [ { type: Component, args: [{ selector: 'fiv-bottom-sheet', template: "<div class=\"fiv-bottom-drawer-scrollable-content\" no-bounce>\n <ng-content></ng-content>\n</div>", styles: [":host{width:100%;height:100%;position:absolute;left:0;z-index:11!important;background-color:rgba(0,0,0,0);transform:translateY(100vh)}.fiv-bottom-drawer-scrollable-content{width:100%;height:100%}"] }] } ]; /** @nocollapse */ FivBottomSheet.ctorParameters = function () { return [ { type: ElementRef }, { type: Renderer2 }, { type: DomController }, { type: Platform } ]; }; FivBottomSheet.propDecorators = { dockedHeight: [{ type: Input }], shouldBounce: [{ type: Input }], distanceTop: [{ type: Input }], transition: [{ type: Input }], state: [{ type: Input }], bounceThreshold: [{ type: Input }], panThreshold: [{ type: Input }], panEnabled: [{ type: Input }], stateChange: [{ type: Output }], fivOpen: [{ type: Output }], fivDocked: [{ type: Output }], fivClose: [{ type: Output }], fivProgress: [{ type: Output }], content: [{ type: ContentChild, args: [FivBottomSheetContent, { static: true },] }] }; return FivBottomSheet; }()); export { FivBottomSheet }; if (false) { /** @type {?} */ FivBottomSheet.prototype.dockedHeight; /** @type {?} */ FivBottomSheet.prototype.shouldBounce; /** @type {?} */ FivBottomSheet.prototype.distanceTop; /** @type {?} */ FivBottomSheet.prototype.transition; /** @type {?} */ FivBottomSheet.prototype.state; /** @type {?} */ FivBottomSheet.prototype.bounceThreshold; /** @type {?} */ FivBottomSheet.prototype.panThreshold; /** @type {?} */ FivBottomSheet.prototype.panEnabled; /** @type {?} */ FivBottomSheet.prototype.stateChange; /** @type {?} */ FivBottomSheet.prototype.fivOpen; /** @type {?} */ FivBottomSheet.prototype.fivDocked; /** @type {?} */ FivBottomSheet.prototype.fivClose; /** @type {?} */ FivBottomSheet.prototype.fivProgress; /** @type {?} */ FivBottomSheet.prototype.content; /** * @type {?} * @private */ FivBottomSheet.prototype._startPositionTop; /** @type {?} */ FivBottomSheet.prototype._startPositionOffset; /** @type {?} */ FivBottomSheet.prototype.scrollTop; /** @type {?} */ FivBottomSheet.prototype.$onDestroy; /** * @type {?} * @private */ FivBottomSheet.prototype._element; /** * @type {?} * @private */ FivBottomSheet.prototype._renderer; /** * @type {?} * @private */ FivBottomSheet.prototype._domCtrl; /** * @type {?} * @private */ FivBottomSheet.prototype._platform; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bottom-sheet.component.js","sourceRoot":"ng://@fivethree/core/","sources":["lib/bottom-sheet/bottom-sheet.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { FivBottomSheetContent } from './bottom-sheet-content/bottom-sheet-content.component';\nimport {\n  Component,\n  AfterViewInit,\n  OnChanges,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef,\n  Renderer2,\n  SimpleChanges,\n  ContentChild,\n  OnDestroy\n} from '@angular/core';\nimport { DomController, Platform } from '@ionic/angular';\nimport { DrawerState } from './drawer-state';\nimport { merge, Subject, fromEvent, from } from 'rxjs';\nimport {\n  takeUntil,\n  map,\n  tap,\n  flatMap,\n  repeat,\n  withLatestFrom,\n  filter,\n  first,\n  take,\n  repeatWhen,\n  skipWhile\n} from 'rxjs/operators';\n\nexport interface PanEvent {\n  currentOffset: number;\n  startOffset: number;\n  currentTop: number;\n  startTop: number;\n  distance: number;\n  touch: TouchEvent;\n}\n\n@Component({\n  selector: 'fiv-bottom-sheet',\n  templateUrl: './bottom-sheet.component.html',\n  styleUrls: ['./bottom-sheet.component.scss']\n})\nexport class FivBottomSheet implements AfterViewInit, OnChanges, OnDestroy {\n  @Input() dockedHeight = 80;\n\n  @Input() shouldBounce = true;\n\n  @Input() distanceTop = 56;\n\n  @Input() transition = '0.25s';\n\n  @Input() state: DrawerState = DrawerState.Bottom;\n\n  @Input() bounceThreshold = 40;\n  @Input() panThreshold = 20;\n\n  @Input() panEnabled = true;\n\n  @Output() stateChange: EventEmitter<DrawerState> = new EventEmitter<\n    DrawerState\n  >();\n  @Output() fivOpen: EventEmitter<FivBottomSheet> = new EventEmitter<\n    FivBottomSheet\n  >();\n  @Output() fivDocked: EventEmitter<FivBottomSheet> = new EventEmitter<\n    FivBottomSheet\n  >();\n  @Output() fivClose: EventEmitter<FivBottomSheet> = new EventEmitter<\n    FivBottomSheet\n  >();\n  @Output() fivProgress: EventEmitter<number> = new EventEmitter<number>();\n\n  @ContentChild(FivBottomSheetContent, { static: true })\n  content: FivBottomSheetContent;\n\n  private _startPositionTop: number;\n  _startPositionOffset: number;\n  scrollTop = 0;\n\n  $onDestroy = new Subject();\n\n  constructor(\n    private _element: ElementRef,\n    private _renderer: Renderer2,\n    private _domCtrl: DomController,\n    private _platform: Platform\n  ) {}\n\n  ngOnDestroy(): void {\n    this.$onDestroy.next();\n  }\n\n  ngAfterViewInit() {\n    this._setDrawerState(this.state);\n    this.content.shouldBounce = this.shouldBounce;\n\n    const touchmove = fromEvent<TouchEvent>(\n      this._element.nativeElement,\n      'touchmove',\n      {\n        passive: true\n      }\n    );\n    const touchend = merge(\n      fromEvent<TouchEvent>(this._element.nativeElement, 'touchend', {\n        passive: true\n      }),\n      fromEvent<TouchEvent>(this._element.nativeElement, 'touchcancel', {\n        passive: true\n      })\n    );\n\n    const getScrollContent = from(this.content.content.getScrollElement());\n\n    const scroll = this.content.content.ionScroll.pipe(\n      tap(el => (this.scrollTop = el.detail.scrollTop)),\n      takeUntil(this.$onDestroy)\n    );\n    scroll.subscribe();\n\n    this.content.content.ionScrollEnd\n      .pipe(\n        filter(el => this.scrollTop === 0 && this.state === DrawerState.Top),\n        tap(() => this.content.content.scrollByPoint(0, 1, 0)),\n        takeUntil(this.$onDestroy)\n      )\n      .subscribe();\n\n    const canStart = touchmove.pipe(filter(() => this.scrollTop === 0));\n\n    const start = canStart.pipe(\n      take(1),\n      tap((s: TouchEvent) => this._handlePanStart(s))\n    );\n\n    const pan = start.pipe(\n      filter(() => this.panEnabled),\n      flatMap(() => touchmove),\n      map((tm: TouchEvent) => this.calculatePanEvent(tm))\n    );\n\n    const handlePan = pan.pipe(\n      filter(p => Math.abs(p.distance) > this.panThreshold),\n      map(tm => this._handlePan(tm)),\n      takeUntil(touchend),\n      repeat(),\n      takeUntil(this.$onDestroy)\n    );\n\n    const handleBackPan = pan\n      .pipe(\n        filter(\n          p => Math.abs(p.distance) <= this.panThreshold && this.content.panning\n        ),\n        map(tm => this._handlePan(tm)),\n        takeUntil(touchend),\n        repeat(),\n        takeUntil(this.$onDestroy)\n      )\n      .subscribe();\n\n    handlePan\n      .pipe(\n        first(),\n        tap(() => (this.content.panning = true)),\n        repeatWhen(() => touchend),\n        takeUntil(this.$onDestroy)\n      )\n      .subscribe();\n\n    handlePan\n      .pipe(\n        flatMap(() => touchend),\n        first(),\n        withLatestFrom<TouchEvent, PanEvent>(pan),\n        tap(() => this.content.content.scrollByPoint(0, 1, 0)),\n        tap(() => (this.content.panning = false)),\n        map(ev => ev[1]),\n        repeat(),\n        takeUntil<PanEvent>(this.$onDestroy)\n      )\n      .subscribe(ev => this._handlePanEnd(ev));\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!changes.state) {\n      return;\n    }\n    this._setDrawerState(changes.state.currentValue);\n    this.updateContent(changes.state.currentValue);\n  }\n\n  updateContent(state: DrawerState) {\n    if (this.content) {\n      this.content.updateState(state);\n    }\n  }\n\n  private _setDrawerState(state: DrawerState) {\n    this._renderer.setStyle(\n      this._element.nativeElement,\n      'transition',\n      this.transition\n    );\n    switch (state) {\n      case DrawerState.Bottom:\n        this.content.content.scrollToTop(0);\n        this._setTranslateY(this._platform.height());\n        break;\n      case DrawerState.Docked:\n        this.content.content.scrollToTop(0);\n        this._setTranslateY(this._platform.height() - this.dockedHeight);\n        break;\n      default:\n        this._setTranslateY(this.distanceTop);\n    }\n  }\n\n  private _handlePanStart(event: TouchEvent) {\n    this._startPositionTop = this.getCurrentTop();\n    this._startPositionOffset = event.touches[0].pageY;\n  }\n\n  getCurrentTop() {\n    return this._element.nativeElement.getBoundingClientRect().top;\n  }\n\n  private _handlePanEnd(ev: PanEvent) {\n    if (this.shouldBounce) {\n      this._renderer.setStyle(\n        this._element.nativeElement,\n        'transition',\n        this.transition\n      );\n\n      switch (this.state) {\n        case DrawerState.Docked:\n          this._handleDockedPanEnd(ev);\n          break;\n        case DrawerState.Top:\n          this._handleTopPanEnd(ev);\n          break;\n        default:\n          this._handleBottomPanEnd(ev);\n      }\n    }\n    this.stateChange.emit(this.state);\n  }\n\n  private _handleTopPanEnd(ev: PanEvent) {\n    if (ev.distance > this.bounceThreshold) {\n      if (this.state !== DrawerState.Docked) {\n        this.state = DrawerState.Docked;\n        this.fivDocked.emit(this);\n      }\n    } else {\n      this._setTranslateY(this.distanceTop);\n    }\n  }\n\n  private _handleDockedPanEnd(ev: PanEvent) {\n    const absDeltaY = Math.abs(ev.distance);\n    if (absDeltaY > this.bounceThreshold && ev.distance < 0) {\n      if (this.state !== DrawerState.Top) {\n        this.state = DrawerState.Top;\n        this.fivOpen.emit();\n      }\n    } else if (absDeltaY > this.bounceThreshold && ev.distance > 0) {\n      if (this.state !== DrawerState.Bottom) {\n        this.close();\n      }\n    } else {\n      this._setTranslateY(this._platform.height() - this.dockedHeight);\n    }\n  }\n\n  private _handleBottomPanEnd(ev: PanEvent) {\n    if (-ev.distance > this.bounceThreshold) {\n      if (this.state !== DrawerState.Docked) {\n        this.state = DrawerState.Docked;\n        this.fivDocked.emit();\n      }\n    } else {\n      this._setTranslateY('100vh');\n    }\n  }\n\n  calculatePanEvent(ev: TouchEvent): PanEvent {\n    return {\n      currentOffset: ev.touches[0].pageY,\n      startOffset: this._startPositionOffset,\n      startTop: this._startPositionTop,\n      currentTop: this.getCurrentTop(),\n      distance: ev.touches[0].pageY - this._startPositionOffset,\n      touch: ev\n    };\n  }\n\n  private _handlePan(event: PanEvent) {\n    this._renderer.setStyle(this._element.nativeElement, 'transition', 'none');\n    if (event.currentTop >= 0 && event.currentTop <= this._platform.height()) {\n      const newTop = this._startPositionTop + event.distance;\n      if (newTop >= this.distanceTop) {\n        this._setTranslateY(newTop);\n      } else if (newTop <= this.distanceTop && this.content.panning) {\n        this._setTranslateY(this.distanceTop);\n        this.content.content.scrollToPoint(0, 0 - newTop, 0);\n      }\n      return event;\n    }\n  }\n\n  private _setTranslateY(value) {\n    this.fivProgress.emit(\n      1 - value / (this._platform.height() - this.dockedHeight)\n    );\n    this._domCtrl.write(() => {\n      this._renderer.setStyle(\n        this._element.nativeElement,\n        'transform',\n        'translateY(' + value + 'px)'\n      );\n    });\n  }\n\n  open() {\n    this.state = DrawerState.Top;\n    this._setDrawerState(this.state);\n    this.updateContent(this.state);\n  }\n\n  close() {\n    this.state = DrawerState.Bottom;\n    this._setDrawerState(this.state);\n    this.updateContent(this.state);\n    this.fivClose.emit();\n  }\n\n  dock() {\n    this.state = DrawerState.Docked;\n    this._setDrawerState(this.state);\n    this.updateContent(this.state);\n  }\n}\n"]}