@fivethree/core
Version:
Fivethree Core Components
538 lines • 42 kB
JavaScript
/**
* @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"]}