ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
459 lines • 40.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ViewEncapsulation, Input, HostBinding, Output, EventEmitter, ElementRef } from '@angular/core';
export class DrawerComponent {
/**
* @param {?} _el
*/
constructor(_el) {
this._el = _el;
this.prefixCls = 'am-drawer';
this.sidebarStyleFinal = {};
this.contentStyleFinal = {};
this.overlayStyleFinal = {};
this.sidebarWidth = 0;
this.sidebarHeight = 0;
this.sidebarTop = 0;
this.dragHandleTop = 0;
this.touchIdentifier = null;
this.touchStartX = null;
this.touchStartY = null;
this.touchCurrentX = null;
this.touchCurrentY = null;
this.touchSupported = typeof window === 'object' && 'ontouchstart' in window;
this._docked = false;
this._open = false;
this._position = 'left';
this.sidebarStyle = {};
this.contentStyle = {};
this.overlayStyle = {};
this.dragHandleStyle = {};
this.transitions = true;
this.touch = true;
this.enableDragHandle = false;
this.dragToggleDistance = 30;
this.onOpenChange = new EventEmitter();
this.am = true;
this.left = this._position === 'left';
this.right = this._position === 'right';
this.top = this._position == 'top';
this.bottom = this._position == 'bottom';
this.dockedCls = this._docked;
this.openCls = this._open;
}
/**
* @return {?}
*/
get docked() {
return this._docked;
}
/**
* @param {?} v
* @return {?}
*/
set docked(v) {
this._docked = v;
this.dockedCls = v;
}
/**
* @return {?}
*/
get open() {
return this._open;
}
/**
* @param {?} v
* @return {?}
*/
set open(v) {
this._open = v;
this.openCls = v;
}
/**
* @param {?} v
* @return {?}
*/
set position(v) {
this._position = v;
this.right = false;
this.left = false;
this.top = false;
this.bottom = false;
switch (v) {
case 'right':
this.right = true;
break;
case 'left':
this.left = true;
break;
case 'top':
this.top = true;
break;
case 'bottom':
this.bottom = true;
break;
}
}
/**
* @return {?}
*/
onOverlayClicked() {
if (this._open) {
this.onOpenChange.emit(true);
}
}
/**
* @return {?}
*/
isTouching() {
return this.touchIdentifier !== null;
}
/**
* @param {?} event
* @return {?}
*/
onTouchStart(event) {
/** @type {?} */
const touch = event.changedTouches[0];
this.touchIdentifier = touch.identifier;
this.touchStartX = touch.clientX;
this.touchStartY = touch.clientY;
this.touchCurrentX = touch.clientX;
this.touchCurrentY = touch.clientY;
}
/**
* @param {?} ev
* @return {?}
*/
onTouchMove(ev) {
for (let ind = 0; ind < ev.changedTouches.length; ind++) {
if (ev.changedTouches[ind].identifier === this.touchIdentifier) {
this.touchCurrentX = ev.changedTouches[ind].clientX;
this.touchCurrentY = ev.changedTouches[ind].clientY;
break;
}
}
this.update();
}
/**
* @return {?}
*/
onTouchEnd() {
/** @type {?} */
const touchWidth = this.touchSidebarWidth();
if (!this._open && touchWidth > this.dragToggleDistance) {
this.onOpenChange.emit(!this._open);
}
/** @type {?} */
const touchHeight = this.touchSidebarHeight();
if (!this._open && touchHeight > this.dragToggleDistance) {
this.onOpenChange.emit(!this._open);
}
this.touchIdentifier = null;
this.touchStartX = null;
this.touchStartY = null;
this.touchCurrentX = null;
this.touchCurrentY = null;
this.update();
}
/**
* @return {?}
*/
saveSidebarSize() {
/** @type {?} */
const sidebar = this._el.nativeElement.querySelector('#sidebar');
/** @type {?} */
const dragHandle = this._el.nativeElement.querySelector('#dragHandle');
/** @type {?} */
const width = sidebar.offsetWidth;
/** @type {?} */
const height = sidebar.offsetHeight;
/** @type {?} */
const sidebarTop = this.getOffset(sidebar).top;
/** @type {?} */
const dragHandleTop = this.getOffset(dragHandle).top;
if (width !== this.sidebarWidth) {
this.sidebarWidth = width;
}
if (height !== this.sidebarHeight) {
this.sidebarHeight = height;
}
if (sidebarTop !== this.sidebarTop) {
this.sidebarTop = sidebarTop;
}
if (dragHandleTop !== this.dragHandleTop) {
this.dragHandleTop = dragHandleTop;
}
}
/**
* @return {?}
*/
touchSidebarWidth() {
if (this._position === 'right') {
return Math.min(window.innerWidth - this.touchCurrentX, this.sidebarWidth);
}
if (this._position === 'left') {
return Math.min(this.touchCurrentX, this.sidebarWidth);
}
}
/**
* @return {?}
*/
touchSidebarHeight() {
if (this._position === 'bottom') {
return Math.min(this._el.nativeElement.offsetHeight - this.touchCurrentY + this._el.nativeElement.offsetTop, this.sidebarHeight);
}
if (this._position === 'top') {
return Math.min(this.touchCurrentY - this.dragHandleTop, this.sidebarHeight);
}
}
/**
* @param {?} __0
* @return {?}
*/
renderStyle({ sidebarStyle, isTouching, overlayStyle, contentStyle }) {
if (this._position === 'right' || this._position === 'left') {
sidebarStyle.transform = `translateX(0%)`;
sidebarStyle.WebkitTransform = `translateX(0%)`;
if (isTouching) {
/** @type {?} */
const percentage = this.touchSidebarWidth() / this.sidebarWidth;
// slide open to what we dragged
if (this._position === 'right') {
sidebarStyle.transform = `translateX(${(1 - percentage) * 100}%)`;
sidebarStyle.WebkitTransform = `translateX(${(1 - percentage) * 100}%)`;
}
if (this._position === 'left') {
sidebarStyle.transform = `translateX(-${(1 - percentage) * 100}%)`;
sidebarStyle.WebkitTransform = `translateX(-${(1 - percentage) * 100}%)`;
}
overlayStyle.opacity = percentage;
overlayStyle.visibility = 'visible';
}
if (contentStyle) {
contentStyle[this._position] = `${this.sidebarWidth}px`;
}
}
if (this._position === 'top' || this._position === 'bottom') {
sidebarStyle.transform = `translateY(0%)`;
sidebarStyle.WebkitTransform = `translateY(0%)`;
if (isTouching) {
/** @type {?} */
const percentage = this.touchSidebarHeight() / this.sidebarHeight;
if (this._position === 'bottom') {
sidebarStyle.transform = `translateY(${(1 - percentage) * 100}%)`;
sidebarStyle.WebkitTransform = `translateY(${(1 - percentage) * 100}%)`;
}
if (this._position === 'top') {
sidebarStyle.transform = `translateY(-${(1 - percentage) * 100}%)`;
sidebarStyle.WebkitTransform = `translateY(-${(1 - percentage) * 100}%)`;
}
overlayStyle.opacity = percentage;
overlayStyle.visibility = 'visible';
}
if (contentStyle) {
contentStyle[this._position] = `${this.sidebarHeight}px`;
}
}
}
/**
* @return {?}
*/
update() {
/** @type {?} */
const sidebarStyle = Object.assign({}, this.sidebarStyle);
/** @type {?} */
const contentStyle = Object.assign({}, this.contentStyle);
/** @type {?} */
const overlayStyle = Object.assign({}, this.overlayStyle);
if (this.isTouching()) {
this.renderStyle({
sidebarStyle: sidebarStyle,
isTouching: true,
contentStyle: undefined,
overlayStyle: overlayStyle
});
}
else if (this._docked) {
this.dockedCls = true;
this.renderStyle({
sidebarStyle: sidebarStyle,
isTouching: undefined,
contentStyle: contentStyle,
overlayStyle: undefined
});
}
else if (this._open) {
this.openCls = true;
this.renderStyle({
sidebarStyle: sidebarStyle,
isTouching: undefined,
contentStyle: undefined,
overlayStyle: undefined
});
overlayStyle.opacity = 1;
overlayStyle.visibility = 'visible';
}
if (this.isTouching() || !this.transitions) {
sidebarStyle.transition = 'none';
sidebarStyle.WebkitTransition = 'none';
contentStyle.transition = 'none';
overlayStyle.transition = 'none';
}
this.sidebarStyleFinal = sidebarStyle;
this.contentStyleFinal = contentStyle;
this.overlayStyleFinal = overlayStyle;
}
/**
* @param {?} ele
* @return {?}
*/
getOffset(ele) {
/** @type {?} */
let el = ele;
/** @type {?} */
let _x = 0;
/** @type {?} */
let _y = 0;
while (el && !isNaN(el.offsetLeft) && !isNaN(el.offsetTop)) {
_x += el.offsetLeft - el.scrollLeft;
_y += el.offsetTop - el.scrollTop;
el = el.offsetParent;
}
return { top: _y, left: _x };
}
/**
* @return {?}
*/
ngAfterViewChecked() {
if (!this.isTouching()) {
this.saveSidebarSize();
}
}
/**
* @return {?}
*/
ngOnChanges() {
this.update();
}
}
DrawerComponent.decorators = [
{ type: Component, args: [{
selector: 'Drawer, nzm-drawer',
template: "<div class=\"{{ prefixCls }}-sidebar\" [ngStyle]=\"sidebarStyleFinal\" id=\"sidebar\">\n <ng-template [ngTemplateOutlet]=\"sidebar\"></ng-template>\n</div>\n<div\n class=\"{{ prefixCls }}-overlay\"\n [ngStyle]=\"overlayStyleFinal\"\n role=\"presentation\"\n ref=\"overlay\"\n (click)=\"onOverlayClicked()\"\n></div>\n<div class=\"{{ prefixCls }}-content\" [ngStyle]=\"contentStyleFinal\" ref=\"content\">\n <div\n *ngIf=\"touch && touchSupported && !open && !docked && enableDragHandle\"\n id=\"dragHandle\"\n class=\"{{ prefixCls }}-draghandle\"\n [ngStyle]=\"dragHandleStyle\"\n (touchstart)=\"onTouchStart($event)\"\n (touchmove)=\"onTouchMove($event)\"\n (touchend)=\"onTouchEnd()\"\n (touchcancle)=\"onTouchEnd()\"\n ></div>\n <ng-content></ng-content>\n</div>\n",
encapsulation: ViewEncapsulation.None
}] }
];
/** @nocollapse */
DrawerComponent.ctorParameters = () => [
{ type: ElementRef }
];
DrawerComponent.propDecorators = {
sidebar: [{ type: Input }],
sidebarStyle: [{ type: Input }],
contentStyle: [{ type: Input }],
overlayStyle: [{ type: Input }],
dragHandleStyle: [{ type: Input }],
transitions: [{ type: Input }],
touch: [{ type: Input }],
enableDragHandle: [{ type: Input }],
dragToggleDistance: [{ type: Input }],
docked: [{ type: Input }],
open: [{ type: Input }],
position: [{ type: Input }],
onOpenChange: [{ type: Output }],
am: [{ type: HostBinding, args: ['class.am-drawer',] }],
left: [{ type: HostBinding, args: ['class.am-drawer-left',] }],
right: [{ type: HostBinding, args: ['class.am-drawer-right',] }],
top: [{ type: HostBinding, args: ['class.am-drawer-top',] }],
bottom: [{ type: HostBinding, args: ['class.am-drawer-bottom',] }],
dockedCls: [{ type: HostBinding, args: ['class.am-drawer-docked',] }],
openCls: [{ type: HostBinding, args: ['class.am-drawer-open',] }]
};
if (false) {
/** @type {?} */
DrawerComponent.prototype.prefixCls;
/** @type {?} */
DrawerComponent.prototype.sidebarStyleFinal;
/** @type {?} */
DrawerComponent.prototype.contentStyleFinal;
/** @type {?} */
DrawerComponent.prototype.overlayStyleFinal;
/** @type {?} */
DrawerComponent.prototype.sidebarWidth;
/** @type {?} */
DrawerComponent.prototype.sidebarHeight;
/** @type {?} */
DrawerComponent.prototype.sidebarTop;
/** @type {?} */
DrawerComponent.prototype.dragHandleTop;
/** @type {?} */
DrawerComponent.prototype.touchIdentifier;
/** @type {?} */
DrawerComponent.prototype.touchStartX;
/** @type {?} */
DrawerComponent.prototype.touchStartY;
/** @type {?} */
DrawerComponent.prototype.touchCurrentX;
/** @type {?} */
DrawerComponent.prototype.touchCurrentY;
/** @type {?} */
DrawerComponent.prototype.touchSupported;
/**
* @type {?}
* @private
*/
DrawerComponent.prototype._docked;
/**
* @type {?}
* @private
*/
DrawerComponent.prototype._open;
/**
* @type {?}
* @private
*/
DrawerComponent.prototype._position;
/** @type {?} */
DrawerComponent.prototype.sidebar;
/** @type {?} */
DrawerComponent.prototype.sidebarStyle;
/** @type {?} */
DrawerComponent.prototype.contentStyle;
/** @type {?} */
DrawerComponent.prototype.overlayStyle;
/** @type {?} */
DrawerComponent.prototype.dragHandleStyle;
/** @type {?} */
DrawerComponent.prototype.transitions;
/** @type {?} */
DrawerComponent.prototype.touch;
/** @type {?} */
DrawerComponent.prototype.enableDragHandle;
/** @type {?} */
DrawerComponent.prototype.dragToggleDistance;
/** @type {?} */
DrawerComponent.prototype.onOpenChange;
/** @type {?} */
DrawerComponent.prototype.am;
/** @type {?} */
DrawerComponent.prototype.left;
/** @type {?} */
DrawerComponent.prototype.right;
/** @type {?} */
DrawerComponent.prototype.top;
/** @type {?} */
DrawerComponent.prototype.bottom;
/** @type {?} */
DrawerComponent.prototype.dockedCls;
/** @type {?} */
DrawerComponent.prototype.openCls;
/**
* @type {?}
* @private
*/
DrawerComponent.prototype._el;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["drawer/drawer.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EACT,iBAAiB,EACjB,KAAK,EACL,WAAW,EACX,MAAM,EACN,YAAY,EACZ,UAAU,EAGX,MAAM,eAAe,CAAC;AAOvB,MAAM,OAAO,eAAe;;;;IA8F1B,YAAoB,GAAe;QAAf,QAAG,GAAH,GAAG,CAAY;QA7FnC,cAAS,GAAW,WAAW,CAAC;QAChC,sBAAiB,GAAyB,EAAE,CAAC;QAC7C,sBAAiB,GAAyB,EAAE,CAAC;QAC7C,sBAAiB,GAAyB,EAAE,CAAC;QAC7C,iBAAY,GAAW,CAAC,CAAC;QACzB,kBAAa,GAAW,CAAC,CAAC;QAC1B,eAAU,GAAW,CAAC,CAAC;QACvB,kBAAa,GAAW,CAAC,CAAC;QAC1B,oBAAe,GAAW,IAAI,CAAC;QAC/B,gBAAW,GAAW,IAAI,CAAC;QAC3B,gBAAW,GAAW,IAAI,CAAC;QAC3B,kBAAa,GAAW,IAAI,CAAC;QAC7B,kBAAa,GAAW,IAAI,CAAC;QAC7B,mBAAc,GAAY,OAAO,MAAM,KAAK,QAAQ,IAAI,cAAc,IAAI,MAAM,CAAC;QAEzE,YAAO,GAAY,KAAK,CAAC;QACzB,UAAK,GAAY,KAAK,CAAC;QACvB,cAAS,GAAW,MAAM,CAAC;QAKnC,iBAAY,GAAyB,EAAE,CAAC;QAExC,iBAAY,GAAyB,EAAE,CAAC;QAExC,iBAAY,GAAyB,EAAE,CAAC;QAExC,oBAAe,GAAyB,EAAE,CAAC;QAE3C,gBAAW,GAAY,IAAI,CAAC;QAE5B,UAAK,GAAY,IAAI,CAAC;QAEtB,qBAAgB,GAAY,KAAK,CAAC;QAElC,uBAAkB,GAAW,EAAE,CAAC;QAwChC,iBAAY,GAAsB,IAAI,YAAY,EAAO,CAAC;QAG1D,OAAE,GAAY,IAAI,CAAC;QAEnB,SAAI,GAAY,IAAI,CAAC,SAAS,KAAK,MAAM,CAAC;QAE1C,UAAK,GAAY,IAAI,CAAC,SAAS,KAAK,OAAO,CAAC;QAE5C,QAAG,GAAY,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC;QAEvC,WAAM,GAAY,IAAI,CAAC,SAAS,IAAI,QAAQ,CAAC;QAE7C,cAAS,GAAY,IAAI,CAAC,OAAO,CAAC;QAElC,YAAO,GAAY,IAAI,CAAC,KAAK,CAAC;IAEQ,CAAC;;;;IAxDvC,IACI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;;;;;IACD,IAAI,MAAM,CAAC,CAAC;QACV,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;QACjB,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IACrB,CAAC;;;;IACD,IACI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;;;;;IACD,IAAI,IAAI,CAAC,CAAC;QACR,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;IACnB,CAAC;;;;;IACD,IACI,QAAQ,CAAC,CAAC;QACZ,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAClB,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC;QACjB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,QAAQ,CAAC,EAAE;YACT,KAAK,OAAO;gBACV,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;gBAClB,MAAM;YACR,KAAK,MAAM;gBACT,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;gBACjB,MAAM;YACR,KAAK,KAAK;gBACR,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC;gBAChB,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;gBACnB,MAAM;SACT;IACH,CAAC;;;;IAqBD,gBAAgB;QACd,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC9B;IACH,CAAC;;;;IAED,UAAU;QACR,OAAO,IAAI,CAAC,eAAe,KAAK,IAAI,CAAC;IACvC,CAAC;;;;;IAED,YAAY,CAAC,KAAK;;cACV,KAAK,GAAG,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC;QACrC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,UAAU,CAAC;QACxC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,OAAO,CAAC;QACjC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,OAAO,CAAC;QACjC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC;QACnC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC;IACrC,CAAC;;;;;IAED,WAAW,CAAC,EAAE;QACZ,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE;YACvD,IAAI,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,UAAU,KAAK,IAAI,CAAC,eAAe,EAAE;gBAC9D,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;gBACpD,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;gBACpD,MAAM;aACP;SACF;QACD,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;;;;IAED,UAAU;;cACF,UAAU,GAAG,IAAI,CAAC,iBAAiB,EAAE;QAC3C,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,UAAU,GAAG,IAAI,CAAC,kBAAkB,EAAE;YACvD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACrC;;cAEK,WAAW,GAAG,IAAI,CAAC,kBAAkB,EAAE;QAC7C,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,WAAW,GAAG,IAAI,CAAC,kBAAkB,EAAE;YACxD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACrC;QACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;;;;IAED,eAAe;;cACP,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC;;cAC1D,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC;;cAEhE,KAAK,GAAG,OAAO,CAAC,WAAW;;cAC3B,MAAM,GAAG,OAAO,CAAC,YAAY;;cAC7B,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,GAAG;;cACxC,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,GAAG;QAEpD,IAAI,KAAK,KAAK,IAAI,CAAC,YAAY,EAAE;YAC/B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;SAC3B;QACD,IAAI,MAAM,KAAK,IAAI,CAAC,aAAa,EAAE;YACjC,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC;SAC7B;QACD,IAAI,UAAU,KAAK,IAAI,CAAC,UAAU,EAAE;YAClC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;SAC9B;QACD,IAAI,aAAa,KAAK,IAAI,CAAC,aAAa,EAAE;YACxC,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;SACpC;IACH,CAAC;;;;IAED,iBAAiB;QACf,IAAI,IAAI,CAAC,SAAS,KAAK,OAAO,EAAE;YAC9B,OAAO,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;SAC5E;QAED,IAAI,IAAI,CAAC,SAAS,KAAK,MAAM,EAAE;YAC7B,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;SACxD;IACH,CAAC;;;;IAED,kBAAkB;QAChB,IAAI,IAAI,CAAC,SAAS,KAAK,QAAQ,EAAE;YAC/B,OAAO,IAAI,CAAC,GAAG,CACb,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,SAAS,EAC3F,IAAI,CAAC,aAAa,CACnB,CAAC;SACH;QAED,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK,EAAE;YAC5B,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;SAC9E;IACH,CAAC;;;;;IAED,WAAW,CAAC,EAAE,YAAY,EAAE,UAAU,EAAE,YAAY,EAAE,YAAY,EAAE;QAClE,IAAI,IAAI,CAAC,SAAS,KAAK,OAAO,IAAI,IAAI,CAAC,SAAS,KAAK,MAAM,EAAE;YAC3D,YAAY,CAAC,SAAS,GAAG,gBAAgB,CAAC;YAC1C,YAAY,CAAC,eAAe,GAAG,gBAAgB,CAAC;YAChD,IAAI,UAAU,EAAE;;sBACR,UAAU,GAAG,IAAI,CAAC,iBAAiB,EAAE,GAAG,IAAI,CAAC,YAAY;gBAC/D,gCAAgC;gBAChC,IAAI,IAAI,CAAC,SAAS,KAAK,OAAO,EAAE;oBAC9B,YAAY,CAAC,SAAS,GAAG,cAAc,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC;oBAClE,YAAY,CAAC,eAAe,GAAG,cAAc,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC;iBACzE;gBACD,IAAI,IAAI,CAAC,SAAS,KAAK,MAAM,EAAE;oBAC7B,YAAY,CAAC,SAAS,GAAG,eAAe,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC;oBACnE,YAAY,CAAC,eAAe,GAAG,eAAe,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC;iBAC1E;gBACD,YAAY,CAAC,OAAO,GAAG,UAAU,CAAC;gBAClC,YAAY,CAAC,UAAU,GAAG,SAAS,CAAC;aACrC;YACD,IAAI,YAAY,EAAE;gBAChB,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,GAAG,IAAI,CAAC,YAAY,IAAI,CAAC;aACzD;SACF;QACD,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK,IAAI,IAAI,CAAC,SAAS,KAAK,QAAQ,EAAE;YAC3D,YAAY,CAAC,SAAS,GAAG,gBAAgB,CAAC;YAC1C,YAAY,CAAC,eAAe,GAAG,gBAAgB,CAAC;YAChD,IAAI,UAAU,EAAE;;sBACR,UAAU,GAAG,IAAI,CAAC,kBAAkB,EAAE,GAAG,IAAI,CAAC,aAAa;gBACjE,IAAI,IAAI,CAAC,SAAS,KAAK,QAAQ,EAAE;oBAC/B,YAAY,CAAC,SAAS,GAAG,cAAc,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC;oBAClE,YAAY,CAAC,eAAe,GAAG,cAAc,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC;iBACzE;gBACD,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK,EAAE;oBAC5B,YAAY,CAAC,SAAS,GAAG,eAAe,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC;oBACnE,YAAY,CAAC,eAAe,GAAG,eAAe,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC;iBAC1E;gBACD,YAAY,CAAC,OAAO,GAAG,UAAU,CAAC;gBAClC,YAAY,CAAC,UAAU,GAAG,SAAS,CAAC;aACrC;YACD,IAAI,YAAY,EAAE;gBAChB,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,GAAG,IAAI,CAAC,aAAa,IAAI,CAAC;aAC1D;SACF;IACH,CAAC;;;;IAED,MAAM;;cACE,YAAY,qBAAQ,IAAI,CAAC,YAAY,CAAE;;cACvC,YAAY,qBAAQ,IAAI,CAAC,YAAY,CAAE;;cACvC,YAAY,qBAAQ,IAAI,CAAC,YAAY,CAAE;QAE7C,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE;YACrB,IAAI,CAAC,WAAW,CAAC;gBACf,YAAY,EAAE,YAAY;gBAC1B,UAAU,EAAE,IAAI;gBAChB,YAAY,EAAE,SAAS;gBACvB,YAAY,EAAE,YAAY;aAC3B,CAAC,CAAC;SACJ;aAAM,IAAI,IAAI,CAAC,OAAO,EAAE;YACvB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,WAAW,CAAC;gBACf,YAAY,EAAE,YAAY;gBAC1B,UAAU,EAAE,SAAS;gBACrB,YAAY,EAAE,YAAY;gBAC1B,YAAY,EAAE,SAAS;aACxB,CAAC,CAAC;SACJ;aAAM,IAAI,IAAI,CAAC,KAAK,EAAE;YACrB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,WAAW,CAAC;gBACf,YAAY,EAAE,YAAY;gBAC1B,UAAU,EAAE,SAAS;gBACrB,YAAY,EAAE,SAAS;gBACvB,YAAY,EAAE,SAAS;aACxB,CAAC,CAAC;YACH,YAAY,CAAC,OAAO,GAAG,CAAC,CAAC;YACzB,YAAY,CAAC,UAAU,GAAG,SAAS,CAAC;SACrC;QAED,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YAC1C,YAAY,CAAC,UAAU,GAAG,MAAM,CAAC;YACjC,YAAY,CAAC,gBAAgB,GAAG,MAAM,CAAC;YACvC,YAAY,CAAC,UAAU,GAAG,MAAM,CAAC;YACjC,YAAY,CAAC,UAAU,GAAG,MAAM,CAAC;SAClC;QACD,IAAI,CAAC,iBAAiB,GAAG,YAAY,CAAC;QACtC,IAAI,CAAC,iBAAiB,GAAG,YAAY,CAAC;QACtC,IAAI,CAAC,iBAAiB,GAAG,YAAY,CAAC;IACxC,CAAC;;;;;IAED,SAAS,CAAC,GAAG;;YACP,EAAE,GAAG,GAAG;;YACR,EAAE,GAAG,CAAC;;YACN,EAAE,GAAG,CAAC;QACV,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE;YAC1D,EAAE,IAAI,EAAE,CAAC,UAAU,GAAG,EAAE,CAAC,UAAU,CAAC;YACpC,EAAE,IAAI,EAAE,CAAC,SAAS,GAAG,EAAE,CAAC,SAAS,CAAC;YAClC,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC;SACtB;QACD,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC;IAC/B,CAAC;;;;IAED,kBAAkB;QAChB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE;YACtB,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;IACH,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;;;YA9SF,SAAS,SAAC;gBACT,QAAQ,EAAE,oBAAoB;gBAC9B,4yBAAsC;gBACtC,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;;YATC,UAAU;;;sBA8BT,KAAK;2BAEL,KAAK;2BAEL,KAAK;2BAEL,KAAK;8BAEL,KAAK;0BAEL,KAAK;oBAEL,KAAK;+BAEL,KAAK;iCAEL,KAAK;qBAEL,KAAK;mBAQL,KAAK;uBAQL,KAAK;2BAsBL,MAAM;iBAGN,WAAW,SAAC,iBAAiB;mBAE7B,WAAW,SAAC,sBAAsB;oBAElC,WAAW,SAAC,uBAAuB;kBAEnC,WAAW,SAAC,qBAAqB;qBAEjC,WAAW,SAAC,wBAAwB;wBAEpC,WAAW,SAAC,wBAAwB;sBAEpC,WAAW,SAAC,sBAAsB;;;;IA1FnC,oCAAgC;;IAChC,4CAA6C;;IAC7C,4CAA6C;;IAC7C,4CAA6C;;IAC7C,uCAAyB;;IACzB,wCAA0B;;IAC1B,qCAAuB;;IACvB,wCAA0B;;IAC1B,0CAA+B;;IAC/B,sCAA2B;;IAC3B,sCAA2B;;IAC3B,wCAA6B;;IAC7B,wCAA6B;;IAC7B,yCAAiF;;;;;IAEjF,kCAAiC;;;;;IACjC,gCAA+B;;;;;IAC/B,oCAAmC;;IAEnC,kCACa;;IACb,uCACwC;;IACxC,uCACwC;;IACxC,uCACwC;;IACxC,0CAC2C;;IAC3C,sCAC4B;;IAC5B,gCACsB;;IACtB,2CACkC;;IAClC,6CACgC;;IAuChC,uCAC0D;;IAE1D,6BACmB;;IACnB,+BAC0C;;IAC1C,gCAC4C;;IAC5C,8BACuC;;IACvC,iCAC6C;;IAC7C,oCACkC;;IAClC,kCAC8B;;;;;IAElB,8BAAuB","sourcesContent":["import {\n  Component,\n  ViewEncapsulation,\n  Input,\n  HostBinding,\n  Output,\n  EventEmitter,\n  ElementRef,\n  OnChanges,\n  AfterViewChecked\n} from '@angular/core';\n\n@Component({\n  selector: 'Drawer, nzm-drawer',\n  templateUrl: './drawer.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class DrawerComponent implements AfterViewChecked, OnChanges {\n  prefixCls: string = 'am-drawer';\n  sidebarStyleFinal: { [k: string]: any } = {};\n  contentStyleFinal: { [k: string]: any } = {};\n  overlayStyleFinal: { [k: string]: any } = {};\n  sidebarWidth: number = 0;\n  sidebarHeight: number = 0;\n  sidebarTop: number = 0;\n  dragHandleTop: number = 0;\n  touchIdentifier: number = null;\n  touchStartX: number = null;\n  touchStartY: number = null;\n  touchCurrentX: number = null;\n  touchCurrentY: number = null;\n  touchSupported: boolean = typeof window === 'object' && 'ontouchstart' in window;\n\n  private _docked: boolean = false;\n  private _open: boolean = false;\n  private _position: string = 'left';\n\n  @Input()\n  sidebar: any;\n  @Input()\n  sidebarStyle: { [k: string]: any } = {};\n  @Input()\n  contentStyle: { [k: string]: any } = {};\n  @Input()\n  overlayStyle: { [k: string]: any } = {};\n  @Input()\n  dragHandleStyle: { [k: string]: any } = {};\n  @Input()\n  transitions: boolean = true;\n  @Input()\n  touch: boolean = true;\n  @Input()\n  enableDragHandle: boolean = false;\n  @Input()\n  dragToggleDistance: number = 30;\n  @Input()\n  get docked() {\n    return this._docked;\n  }\n  set docked(v) {\n    this._docked = v;\n    this.dockedCls = v;\n  }\n  @Input()\n  get open() {\n    return this._open;\n  }\n  set open(v) {\n    this._open = v;\n    this.openCls = v;\n  }\n  @Input()\n  set position(v) {\n    this._position = v;\n    this.right = false;\n    this.left = false;\n    this.top = false;\n    this.bottom = false;\n    switch (v) {\n      case 'right':\n        this.right = true;\n        break;\n      case 'left':\n        this.left = true;\n        break;\n      case 'top':\n        this.top = true;\n        break;\n      case 'bottom':\n        this.bottom = true;\n        break;\n    }\n  }\n  @Output()\n  onOpenChange: EventEmitter<any> = new EventEmitter<any>();\n\n  @HostBinding('class.am-drawer')\n  am: boolean = true;\n  @HostBinding('class.am-drawer-left')\n  left: boolean = this._position === 'left';\n  @HostBinding('class.am-drawer-right')\n  right: boolean = this._position === 'right';\n  @HostBinding('class.am-drawer-top')\n  top: boolean = this._position == 'top';\n  @HostBinding('class.am-drawer-bottom')\n  bottom: boolean = this._position == 'bottom';\n  @HostBinding('class.am-drawer-docked')\n  dockedCls: boolean = this._docked;\n  @HostBinding('class.am-drawer-open')\n  openCls: boolean = this._open;\n\n  constructor(private _el: ElementRef) {}\n\n  onOverlayClicked() {\n    if (this._open) {\n      this.onOpenChange.emit(true);\n    }\n  }\n\n  isTouching() {\n    return this.touchIdentifier !== null;\n  }\n\n  onTouchStart(event) {\n    const touch = event.changedTouches[0];\n    this.touchIdentifier = touch.identifier;\n    this.touchStartX = touch.clientX;\n    this.touchStartY = touch.clientY;\n    this.touchCurrentX = touch.clientX;\n    this.touchCurrentY = touch.clientY;\n  }\n\n  onTouchMove(ev) {\n    for (let ind = 0; ind < ev.changedTouches.length; ind++) {\n      if (ev.changedTouches[ind].identifier === this.touchIdentifier) {\n        this.touchCurrentX = ev.changedTouches[ind].clientX;\n        this.touchCurrentY = ev.changedTouches[ind].clientY;\n        break;\n      }\n    }\n    this.update();\n  }\n\n  onTouchEnd() {\n    const touchWidth = this.touchSidebarWidth();\n    if (!this._open && touchWidth > this.dragToggleDistance) {\n      this.onOpenChange.emit(!this._open);\n    }\n\n    const touchHeight = this.touchSidebarHeight();\n    if (!this._open && touchHeight > this.dragToggleDistance) {\n      this.onOpenChange.emit(!this._open);\n    }\n    this.touchIdentifier = null;\n    this.touchStartX = null;\n    this.touchStartY = null;\n    this.touchCurrentX = null;\n    this.touchCurrentY = null;\n    this.update();\n  }\n\n  saveSidebarSize() {\n    const sidebar = this._el.nativeElement.querySelector('#sidebar');\n    const dragHandle = this._el.nativeElement.querySelector('#dragHandle');\n\n    const width = sidebar.offsetWidth;\n    const height = sidebar.offsetHeight;\n    const sidebarTop = this.getOffset(sidebar).top;\n    const dragHandleTop = this.getOffset(dragHandle).top;\n\n    if (width !== this.sidebarWidth) {\n      this.sidebarWidth = width;\n    }\n    if (height !== this.sidebarHeight) {\n      this.sidebarHeight = height;\n    }\n    if (sidebarTop !== this.sidebarTop) {\n      this.sidebarTop = sidebarTop;\n    }\n    if (dragHandleTop !== this.dragHandleTop) {\n      this.dragHandleTop = dragHandleTop;\n    }\n  }\n\n  touchSidebarWidth() {\n    if (this._position === 'right') {\n      return Math.min(window.innerWidth - this.touchCurrentX, this.sidebarWidth);\n    }\n\n    if (this._position === 'left') {\n      return Math.min(this.touchCurrentX, this.sidebarWidth);\n    }\n  }\n\n  touchSidebarHeight() {\n    if (this._position === 'bottom') {\n      return Math.min(\n        this._el.nativeElement.offsetHeight - this.touchCurrentY + this._el.nativeElement.offsetTop,\n        this.sidebarHeight\n      );\n    }\n\n    if (this._position === 'top') {\n      return Math.min(this.touchCurrentY - this.dragHandleTop, this.sidebarHeight);\n    }\n  }\n\n  renderStyle({ sidebarStyle, isTouching, overlayStyle, contentStyle }) {\n    if (this._position === 'right' || this._position === 'left') {\n      sidebarStyle.transform = `translateX(0%)`;\n      sidebarStyle.WebkitTransform = `translateX(0%)`;\n      if (isTouching) {\n        const percentage = this.touchSidebarWidth() / this.sidebarWidth;\n        // slide open to what we dragged\n        if (this._position === 'right') {\n          sidebarStyle.transform = `translateX(${(1 - percentage) * 100}%)`;\n          sidebarStyle.WebkitTransform = `translateX(${(1 - percentage) * 100}%)`;\n        }\n        if (this._position === 'left') {\n          sidebarStyle.transform = `translateX(-${(1 - percentage) * 100}%)`;\n          sidebarStyle.WebkitTransform = `translateX(-${(1 - percentage) * 100}%)`;\n        }\n        overlayStyle.opacity = percentage;\n        overlayStyle.visibility = 'visible';\n      }\n      if (contentStyle) {\n        contentStyle[this._position] = `${this.sidebarWidth}px`;\n      }\n    }\n    if (this._position === 'top' || this._position === 'bottom') {\n      sidebarStyle.transform = `translateY(0%)`;\n      sidebarStyle.WebkitTransform = `translateY(0%)`;\n      if (isTouching) {\n        const percentage = this.touchSidebarHeight() / this.sidebarHeight;\n        if (this._position === 'bottom') {\n          sidebarStyle.transform = `translateY(${(1 - percentage) * 100}%)`;\n          sidebarStyle.WebkitTransform = `translateY(${(1 - percentage) * 100}%)`;\n        }\n        if (this._position === 'top') {\n          sidebarStyle.transform = `translateY(-${(1 - percentage) * 100}%)`;\n          sidebarStyle.WebkitTransform = `translateY(-${(1 - percentage) * 100}%)`;\n        }\n        overlayStyle.opacity = percentage;\n        overlayStyle.visibility = 'visible';\n      }\n      if (contentStyle) {\n        contentStyle[this._position] = `${this.sidebarHeight}px`;\n      }\n    }\n  }\n\n  update() {\n    const sidebarStyle = { ...this.sidebarStyle };\n    const contentStyle = { ...this.contentStyle };\n    const overlayStyle = { ...this.overlayStyle };\n\n    if (this.isTouching()) {\n      this.renderStyle({\n        sidebarStyle: sidebarStyle,\n        isTouching: true,\n        contentStyle: undefined,\n        overlayStyle: overlayStyle\n      });\n    } else if (this._docked) {\n      this.dockedCls = true;\n      this.renderStyle({\n        sidebarStyle: sidebarStyle,\n        isTouching: undefined,\n        contentStyle: contentStyle,\n        overlayStyle: undefined\n      });\n    } else if (this._open) {\n      this.openCls = true;\n      this.renderStyle({\n        sidebarStyle: sidebarStyle,\n        isTouching: undefined,\n        contentStyle: undefined,\n        overlayStyle: undefined\n      });\n      overlayStyle.opacity = 1;\n      overlayStyle.visibility = 'visible';\n    }\n\n    if (this.isTouching() || !this.transitions) {\n      sidebarStyle.transition = 'none';\n      sidebarStyle.WebkitTransition = 'none';\n      contentStyle.transition = 'none';\n      overlayStyle.transition = 'none';\n    }\n    this.sidebarStyleFinal = sidebarStyle;\n    this.contentStyleFinal = contentStyle;\n    this.overlayStyleFinal = overlayStyle;\n  }\n\n  getOffset(ele) {\n    let el = ele;\n    let _x = 0;\n    let _y = 0;\n    while (el && !isNaN(el.offsetLeft) && !isNaN(el.offsetTop)) {\n      _x += el.offsetLeft - el.scrollLeft;\n      _y += el.offsetTop - el.scrollTop;\n      el = el.offsetParent;\n    }\n    return { top: _y, left: _x };\n  }\n\n  ngAfterViewChecked() {\n    if (!this.isTouching()) {\n      this.saveSidebarSize();\n    }\n  }\n\n  ngOnChanges() {\n    this.update();\n  }\n}\n"]}