ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
372 lines • 30.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Directive, Input, Output, EventEmitter, HostListener, ViewContainerRef, ElementRef, Injector, ComponentFactoryResolver, Renderer2, TemplateRef } from '@angular/core';
import { PopoverComponent } from './popover.component';
import { PopoverOptions } from './popover-options.provider';
import { PopoverComponentOptions } from './popover-component-options.provider';
import * as Positioning from '../core/util/position';
var PopoverDirective = /** @class */ (function () {
function PopoverDirective(_viewContainerRef, _elm, _defaultOptions, _cfr, _renderer) {
this._viewContainerRef = _viewContainerRef;
this._elm = _elm;
this._defaultOptions = _defaultOptions;
this._cfr = _cfr;
this._renderer = _renderer;
this._eventListeners = [];
this.onVisibleChange = new EventEmitter(true);
this.onSelect = new EventEmitter();
}
/**
* @return {?}
*/
PopoverDirective.prototype.togglePopover = /**
* @return {?}
*/
function () {
if (!this.popover) {
this.showPopover();
}
else {
this.hidePopover();
}
};
/**
* @param {?} placement
* @return {?}
*/
PopoverDirective.prototype.positionMap = /**
* @param {?} placement
* @return {?}
*/
function (placement) {
switch (placement) {
case 'topLeft':
return 'top-left';
case 'topRight':
return 'top-right';
case 'bottomLeft':
return 'bottom-left';
case 'bottomRight':
return 'bottom-right';
case 'leftTop':
return 'left-top';
case 'leftBottom':
return 'left-bottom';
case 'rightTop':
return 'right-top';
case 'rightBottom':
return 'right-bottom';
case 'fullScreen':
case 'landScape':
return 'bottom';
default:
return placement;
}
};
/**
* @return {?}
*/
PopoverDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () { };
/**
* @param {?} changes
* @return {?}
*/
PopoverDirective.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
var _this = this;
if (changes.visible && changes.visible.currentValue) {
setTimeout((/**
* @return {?}
*/
function () {
_this.showPopover();
}), 0);
}
else {
setTimeout((/**
* @return {?}
*/
function () {
_this.hidePopover();
}), 0);
}
};
/**
* @return {?}
*/
PopoverDirective.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.hidePopover();
};
/**
* @private
* @param {?} event
* @return {?}
*/
PopoverDirective.prototype.onDocumentClick = /**
* @private
* @param {?} event
* @return {?}
*/
function (event) {
if (this.popover &&
!this._elm.nativeElement.contains(event.target) &&
!this.popover.location.nativeElement.contains(event.target)) {
this.hidePopover();
}
};
/**
* @private
* @return {?}
*/
PopoverDirective.prototype.showPopover = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (!this.popover) {
setTimeout((/**
* @return {?}
*/
function () {
_this._eventListeners = [
_this._renderer.listen('document', 'click', (/**
* @param {?} event
* @return {?}
*/
function (event) { return _this.onDocumentClick(event); })),
_this._renderer.listen('document', 'touchend', (/**
* @param {?} event
* @return {?}
*/
function (event) { return _this.onDocumentClick(event); })),
_this._renderer.listen('window', 'resize', (/**
* @return {?}
*/
function () { return _this.positionPopover(); }))
];
}));
/** @type {?} */
var options_1 = new PopoverComponentOptions();
options_1.placement = this.placement;
Object.assign(options_1, this._defaultOptions, {
hidePopover: (/**
* @param {?} event
* @return {?}
*/
function (event) {
_this.hidePopover();
}),
onAfterViewInit: (/**
* @return {?}
*/
function () {
_this.positionPopover();
/** @type {?} */
var children = document.getElementsByClassName('am-popover-inner-wrapper')[0].children;
if (children.length > 0) {
var _loop_1 = function (i) {
children[i].id = "" + i;
children[i].addEventListener('click', (/**
* @return {?}
*/
function () {
if (_this.onSelect) {
_this.onSelect.emit(children[i]);
if (options_1.autoClose) {
_this.hidePopover();
}
}
}), false);
};
// 首先我们检查它是否包含子节点
for (var i = 0; i < children.length; i++) {
_loop_1(i);
}
}
})
});
/** @type {?} */
var optionalParams = [
'mask',
'showArrow',
'placement',
'appendToBody',
'overlay',
'className',
'autoClose'
];
optionalParams.forEach((/**
* @param {?} param
* @return {?}
*/
function (param) {
if (typeof _this[param] !== 'undefined') {
((/** @type {?} */ (options_1)))[param] = _this[param];
}
}));
/** @type {?} */
var componentFactory = this._cfr.resolveComponentFactory(PopoverComponent);
/** @type {?} */
var childInjector = Injector.create([
{
provide: PopoverComponentOptions,
useValue: options_1
}
], this._viewContainerRef.parentInjector);
this.popover = this._viewContainerRef.createComponent(componentFactory, this._viewContainerRef.length, childInjector);
if (options_1.appendToBody) {
document.body.appendChild(this.popover.location.nativeElement);
}
this.onVisibleChange.emit(true);
}
};
/**
* @private
* @return {?}
*/
PopoverDirective.prototype.positionPopover = /**
* @private
* @return {?}
*/
function () {
if (this.popover) {
/** @type {?} */
var popoverElement = this.popover.location.nativeElement.children[1];
/** @type {?} */
var popoverPosition = Positioning.getPositionElements(this._elm.nativeElement, popoverElement, this.positionMap(this.placement) || this._defaultOptions.placement, this.appendToBody || this._defaultOptions.appendToBody);
if (this.placement === 'landScape') {
this._renderer.setStyle(popoverElement, 'top', popoverPosition.top + "px");
this._renderer.setStyle(popoverElement, 'left', "0px");
this._renderer.setStyle(popoverElement, 'width', window.innerWidth + "px");
this._renderer.setStyle(popoverElement, 'max-height', window.innerHeight - popoverPosition.height + "px");
}
else if (this.placement === 'fullScreen') {
this._renderer.setStyle(popoverElement, 'top', 0 + "px");
this._renderer.setStyle(popoverElement, 'left', "0px");
this._renderer.setStyle(popoverElement, 'width', window.innerWidth + "px");
this._renderer.setStyle(popoverElement, 'max-height', window.innerHeight - popoverPosition.height + "px");
}
else {
this._renderer.setStyle(popoverElement, 'top', popoverPosition.top + "px");
this._renderer.setStyle(popoverElement, 'left', popoverPosition.left + "px");
}
}
};
/**
* @private
* @return {?}
*/
PopoverDirective.prototype.hidePopover = /**
* @private
* @return {?}
*/
function () {
if (this.popover) {
this.popover.destroy();
delete this.popover;
this.onVisibleChange.emit(false);
this._eventListeners.forEach((/**
* @param {?} fn
* @return {?}
*/
function (fn) { return fn(); }));
this._eventListeners = [];
}
};
PopoverDirective.decorators = [
{ type: Directive, args: [{
selector: '[Popover], [nzm-popover]',
providers: [PopoverOptions]
},] }
];
/** @nocollapse */
PopoverDirective.ctorParameters = function () { return [
{ type: ViewContainerRef },
{ type: ElementRef },
{ type: PopoverOptions },
{ type: ComponentFactoryResolver },
{ type: Renderer2 }
]; };
PopoverDirective.propDecorators = {
mask: [{ type: Input }],
showArrow: [{ type: Input }],
visible: [{ type: Input }],
placement: [{ type: Input }],
overlay: [{ type: Input }],
onVisibleChange: [{ type: Output }],
onSelect: [{ type: Output }],
appendToBody: [{ type: Input }],
className: [{ type: Input }],
autoClose: [{ type: Input }],
togglePopover: [{ type: HostListener, args: ['click',] }]
};
return PopoverDirective;
}());
export { PopoverDirective };
if (false) {
/** @type {?} */
PopoverDirective.prototype.popover;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype._eventListeners;
/** @type {?} */
PopoverDirective.prototype.mask;
/** @type {?} */
PopoverDirective.prototype.showArrow;
/** @type {?} */
PopoverDirective.prototype.visible;
/** @type {?} */
PopoverDirective.prototype.placement;
/** @type {?} */
PopoverDirective.prototype.overlay;
/** @type {?} */
PopoverDirective.prototype.onVisibleChange;
/** @type {?} */
PopoverDirective.prototype.onSelect;
/** @type {?} */
PopoverDirective.prototype.appendToBody;
/** @type {?} */
PopoverDirective.prototype.className;
/** @type {?} */
PopoverDirective.prototype.autoClose;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype._viewContainerRef;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype._elm;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype._defaultOptions;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype._cfr;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype._renderer;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.directive.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["popover/popover.directive.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EACZ,YAAY,EACZ,gBAAgB,EAGhB,UAAU,EAEV,QAAQ,EACR,wBAAwB,EACxB,SAAS,EACT,WAAW,EAIZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,uBAAuB,EAAE,MAAM,sCAAsC,CAAC;AAC/E,OAAO,KAAK,WAAW,MAAM,uBAAuB,CAAC;AAErD;IAuCE,0BACU,iBAAmC,EACnC,IAAgB,EAChB,eAA+B,EAC/B,IAA8B,EAC9B,SAAoB;QAJpB,sBAAiB,GAAjB,iBAAiB,CAAkB;QACnC,SAAI,GAAJ,IAAI,CAAY;QAChB,oBAAe,GAAf,eAAe,CAAgB;QAC/B,SAAI,GAAJ,IAAI,CAA0B;QAC9B,cAAS,GAAT,SAAS,CAAW;QArCtB,oBAAe,GAAsB,EAAE,CAAC;QAahD,oBAAe,GAA0B,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC;QAEhE,aAAQ,GAAsB,IAAI,YAAY,EAAE,CAAC;IAuB9C,CAAC;;;;IAdJ,wCAAa;;;IADb;QAEE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;aAAM;YACL,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;IACH,CAAC;;;;;IAUD,sCAAW;;;;IAAX,UAAY,SAAS;QACnB,QAAQ,SAAS,EAAE;YACjB,KAAK,SAAS;gBACZ,OAAO,UAAU,CAAC;YACpB,KAAK,UAAU;gBACb,OAAO,WAAW,CAAC;YACrB,KAAK,YAAY;gBACf,OAAO,aAAa,CAAC;YACvB,KAAK,aAAa;gBAChB,OAAO,cAAc,CAAC;YACxB,KAAK,SAAS;gBACZ,OAAO,UAAU,CAAC;YACpB,KAAK,YAAY;gBACf,OAAO,aAAa,CAAC;YACvB,KAAK,UAAU;gBACb,OAAO,WAAW,CAAC;YACrB,KAAK,aAAa;gBAChB,OAAO,cAAc,CAAC;YACxB,KAAK,YAAY,CAAC;YAClB,KAAK,WAAW;gBACd,OAAO,QAAQ,CAAC;YAClB;gBACE,OAAO,SAAS,CAAC;SACpB;IACH,CAAC;;;;IAED,mCAAQ;;;IAAR,cAAkB,CAAC;;;;;IAEnB,sCAAW;;;;IAAX,UAAY,OAAsB;QAAlC,iBAUC;QATC,IAAI,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,YAAY,EAAE;YACnD,UAAU;;;YAAC;gBACT,KAAI,CAAC,WAAW,EAAE,CAAC;YACrB,CAAC,GAAE,CAAC,CAAC,CAAC;SACP;aAAM;YACL,UAAU;;;YAAC;gBACT,KAAI,CAAC,WAAW,EAAE,CAAC;YACrB,CAAC,GAAE,CAAC,CAAC,CAAC;SACP;IACH,CAAC;;;;IAED,sCAAW;;;IAAX;QACE,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;;;;;;IAEO,0CAAe;;;;;IAAvB,UAAwB,KAAY;QAClC,IACE,IAAI,CAAC,OAAO;YACZ,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC;YAC/C,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAC3D;YACA,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;IACH,CAAC;;;;;IAEO,sCAAW;;;;IAAnB;QAAA,iBA2EC;QA1EC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,UAAU;;;YAAC;gBACT,KAAI,CAAC,eAAe,GAAG;oBACrB,KAAI,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE,OAAO;;;;oBAAE,UAAC,KAAY,IAAK,OAAA,KAAI,CAAC,eAAe,CAAC,KAAK,CAAC,EAA3B,CAA2B,EAAC;oBACzF,KAAI,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE,UAAU;;;;oBAAE,UAAC,KAAY,IAAK,OAAA,KAAI,CAAC,eAAe,CAAC,KAAK,CAAC,EAA3B,CAA2B,EAAC;oBAC5F,KAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,EAAE,QAAQ;;;oBAAE,cAAM,OAAA,KAAI,CAAC,eAAe,EAAE,EAAtB,CAAsB,EAAC;iBACxE,CAAC;YACJ,CAAC,EAAC,CAAC;;gBAEG,SAAO,GAAG,IAAI,uBAAuB,EAAE;YAC7C,SAAO,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;YACnC,MAAM,CAAC,MAAM,CAAC,SAAO,EAAE,IAAI,CAAC,eAAe,EAAE;gBAC3C,WAAW;;;;gBAAE,UAAC,KAAK;oBACjB,KAAI,CAAC,WAAW,EAAE,CAAC;gBACrB,CAAC,CAAA;gBACD,eAAe;;;gBAAE;oBACf,KAAI,CAAC,eAAe,EAAE,CAAC;;wBACjB,QAAQ,GAAG,QAAQ,CAAC,sBAAsB,CAAC,0BAA0B,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ;oBACxF,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;gDAEd,CAAC;4BACR,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,KAAG,CAAG,CAAC;4BACxB,QAAQ,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAC1B,OAAO;;;4BACP;gCACE,IAAI,KAAI,CAAC,QAAQ,EAAE;oCACjB,KAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;oCAChC,IAAI,SAAO,CAAC,SAAS,EAAE;wCACrB,KAAI,CAAC,WAAW,EAAE,CAAC;qCACpB;iCACF;4BACH,CAAC,GACD,KAAK,CACN,CAAC;;wBAdJ,iBAAiB;wBACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE;oCAA/B,CAAC;yBAcT;qBACF;gBACH,CAAC,CAAA;aACF,CAAC,CAAC;;gBAEG,cAAc,GAAkC;gBACpD,MAAM;gBACN,WAAW;gBACX,WAAW;gBACX,cAAc;gBACd,SAAS;gBACT,WAAW;gBACX,WAAW;aACZ;YACD,cAAc,CAAC,OAAO;;;;YAAC,UAAA,KAAK;gBAC1B,IAAI,OAAO,KAAI,CAAC,KAAK,CAAC,KAAK,WAAW,EAAE;oBACtC,CAAC,mBAAA,SAAO,EAAO,CAAC,CAAC,KAAK,CAAC,GAAG,KAAI,CAAC,KAAK,CAAC,CAAC;iBACvC;YACH,CAAC,EAAC,CAAC;;gBAEG,gBAAgB,GAAuC,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAAC,gBAAgB,CAAC;;gBAC1G,aAAa,GAAG,QAAQ,CAAC,MAAM,CACnC;gBACE;oBACE,OAAO,EAAE,uBAAuB;oBAChC,QAAQ,EAAE,SAAO;iBAClB;aACF,EACD,IAAI,CAAC,iBAAiB,CAAC,cAAc,CACtC;YACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,eAAe,CACnD,gBAAgB,EAChB,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAC7B,aAAa,CACd,CAAC;YACF,IAAI,SAAO,CAAC,YAAY,EAAE;gBACxB,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;aAChE;YACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACjC;IACH,CAAC;;;;;IAEO,0CAAe;;;;IAAvB;QACE,IAAI,IAAI,CAAC,OAAO,EAAE;;gBACV,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC;;gBAChE,eAAe,GAAG,WAAW,CAAC,mBAAmB,CACrD,IAAI,CAAC,IAAI,CAAC,aAAa,EACvB,cAAc,EACd,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,eAAe,CAAC,SAAS,EAClE,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,eAAe,CAAC,YAAY,CACvD;YACD,IAAI,IAAI,CAAC,SAAS,KAAK,WAAW,EAAE;gBAClC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,KAAK,EAAK,eAAe,CAAC,GAAG,OAAI,CAAC,CAAC;gBAC3E,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;gBACvD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,OAAO,EAAK,MAAM,CAAC,UAAU,OAAI,CAAC,CAAC;gBAC3E,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,YAAY,EAAK,MAAM,CAAC,WAAW,GAAG,eAAe,CAAC,MAAM,OAAI,CAAC,CAAC;aAC3G;iBAAM,IAAI,IAAI,CAAC,SAAS,KAAK,YAAY,EAAE;gBAC1C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,KAAK,EAAK,CAAC,OAAI,CAAC,CAAC;gBACzD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;gBACvD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,OAAO,EAAK,MAAM,CAAC,UAAU,OAAI,CAAC,CAAC;gBAC3E,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,YAAY,EAAK,MAAM,CAAC,WAAW,GAAG,eAAe,CAAC,MAAM,OAAI,CAAC,CAAC;aAC3G;iBAAM;gBACL,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,KAAK,EAAK,eAAe,CAAC,GAAG,OAAI,CAAC,CAAC;gBAC3E,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,EAAK,eAAe,CAAC,IAAI,OAAI,CAAC,CAAC;aAC9E;SACF;IACH,CAAC;;;;;IAEO,sCAAW;;;;IAAnB;QACE,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvB,OAAO,IAAI,CAAC,OAAO,CAAC;YACpB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACjC,IAAI,CAAC,eAAe,CAAC,OAAO;;;;YAAC,UAAA,EAAE,IAAI,OAAA,EAAE,EAAE,EAAJ,CAAI,EAAC,CAAC;YACzC,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;SAC3B;IACH,CAAC;;gBApNF,SAAS,SAAC;oBACT,QAAQ,EAAE,0BAA0B;oBACpC,SAAS,EAAE,CAAC,cAAc,CAAC;iBAC5B;;;;gBArBC,gBAAgB;gBAGhB,UAAU;gBAWH,cAAc;gBARrB,wBAAwB;gBACxB,SAAS;;;uBAoBR,KAAK;4BAEL,KAAK;0BAEL,KAAK;4BAEL,KAAK;0BAEL,KAAK;kCAEL,MAAM;2BAEN,MAAM;+BAEN,KAAK;4BAEL,KAAK;4BAEL,KAAK;gCAGL,YAAY,SAAC,OAAO;;IAuLvB,uBAAC;CAAA,AArND,IAqNC;SAjNY,gBAAgB;;;IAC3B,mCAAwC;;;;;IAExC,2CAAgD;;IAEhD,gCACc;;IACd,qCACmB;;IACnB,mCACiB;;IACjB,qCACkB;;IAClB,mCAC0B;;IAC1B,2CACgE;;IAChE,oCACiD;;IACjD,wCACsB;;IACtB,qCACkB;;IAClB,qCACmB;;;;;IAYjB,6CAA2C;;;;;IAC3C,gCAAwB;;;;;IACxB,2CAAuC;;;;;IACvC,gCAAsC;;;;;IACtC,qCAA4B","sourcesContent":["import {\n  Directive,\n  Input,\n  Output,\n  EventEmitter,\n  HostListener,\n  ViewContainerRef,\n  ComponentRef,\n  OnDestroy,\n  ElementRef,\n  OnInit,\n  Injector,\n  ComponentFactoryResolver,\n  Renderer2,\n  TemplateRef,\n  ComponentFactory,\n  OnChanges,\n  SimpleChanges\n} from '@angular/core';\nimport { PopoverComponent } from './popover.component';\nimport { PopoverOptions } from './popover-options.provider';\nimport { PopoverComponentOptions } from './popover-component-options.provider';\nimport * as Positioning from '../core/util/position';\n\n@Directive({\n  selector: '[Popover], [nzm-popover]',\n  providers: [PopoverOptions]\n})\nexport class PopoverDirective implements OnInit, OnChanges, OnDestroy {\n  popover: ComponentRef<PopoverComponent>;\n\n  private _eventListeners: Array<() => void> = [];\n\n  @Input()\n  mask: boolean;\n  @Input()\n  showArrow: boolean;\n  @Input()\n  visible: boolean;\n  @Input()\n  placement: string;\n  @Input()\n  overlay: TemplateRef<any>;\n  @Output()\n  onVisibleChange: EventEmitter<boolean> = new EventEmitter(true);\n  @Output()\n  onSelect: EventEmitter<any> = new EventEmitter();\n  @Input()\n  appendToBody: boolean;\n  @Input()\n  className: string;\n  @Input()\n  autoClose: boolean;\n\n  @HostListener('click')\n  togglePopover(): void {\n    if (!this.popover) {\n      this.showPopover();\n    } else {\n      this.hidePopover();\n    }\n  }\n\n  constructor(\n    private _viewContainerRef: ViewContainerRef,\n    private _elm: ElementRef,\n    private _defaultOptions: PopoverOptions,\n    private _cfr: ComponentFactoryResolver,\n    private _renderer: Renderer2\n  ) {}\n\n  positionMap(placement): string {\n    switch (placement) {\n      case 'topLeft':\n        return 'top-left';\n      case 'topRight':\n        return 'top-right';\n      case 'bottomLeft':\n        return 'bottom-left';\n      case 'bottomRight':\n        return 'bottom-right';\n      case 'leftTop':\n        return 'left-top';\n      case 'leftBottom':\n        return 'left-bottom';\n      case 'rightTop':\n        return 'right-top';\n      case 'rightBottom':\n        return 'right-bottom';\n      case 'fullScreen':\n      case 'landScape':\n        return 'bottom';\n      default:\n        return placement;\n    }\n  }\n\n  ngOnInit(): void {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.visible && changes.visible.currentValue) {\n      setTimeout(() => {\n        this.showPopover();\n      }, 0);\n    } else {\n      setTimeout(() => {\n        this.hidePopover();\n      }, 0);\n    }\n  }\n\n  ngOnDestroy() {\n    this.hidePopover();\n  }\n\n  private onDocumentClick(event: Event): void {\n    if (\n      this.popover &&\n      !this._elm.nativeElement.contains(event.target) &&\n      !this.popover.location.nativeElement.contains(event.target)\n    ) {\n      this.hidePopover();\n    }\n  }\n\n  private showPopover(): void {\n    if (!this.popover) {\n      setTimeout(() => {\n        this._eventListeners = [\n          this._renderer.listen('document', 'click', (event: Event) => this.onDocumentClick(event)),\n          this._renderer.listen('document', 'touchend', (event: Event) => this.onDocumentClick(event)),\n          this._renderer.listen('window', 'resize', () => this.positionPopover())\n        ];\n      });\n\n      const options = new PopoverComponentOptions();\n      options.placement = this.placement;\n      Object.assign(options, this._defaultOptions, {\n        hidePopover: (event): void => {\n          this.hidePopover();\n        },\n        onAfterViewInit: (): void => {\n          this.positionPopover();\n          const children = document.getElementsByClassName('am-popover-inner-wrapper')[0].children;\n          if (children.length > 0) {\n            // 首先我们检查它是否包含子节点\n            for (let i = 0; i < children.length; i++) {\n              children[i].id = `${i}`;\n              children[i].addEventListener(\n                'click',\n                () => {\n                  if (this.onSelect) {\n                    this.onSelect.emit(children[i]);\n                    if (options.autoClose) {\n                      this.hidePopover();\n                    }\n                  }\n                },\n                false\n              );\n            }\n          }\n        }\n      });\n\n      const optionalParams: Array<keyof PopoverDirective> = [\n        'mask',\n        'showArrow',\n        'placement',\n        'appendToBody',\n        'overlay',\n        'className',\n        'autoClose'\n      ];\n      optionalParams.forEach(param => {\n        if (typeof this[param] !== 'undefined') {\n          (options as any)[param] = this[param];\n        }\n      });\n\n      const componentFactory: ComponentFactory<PopoverComponent> = this._cfr.resolveComponentFactory(PopoverComponent);\n      const childInjector = Injector.create(\n        [\n          {\n            provide: PopoverComponentOptions,\n            useValue: options\n          }\n        ],\n        this._viewContainerRef.parentInjector\n      );\n      this.popover = this._viewContainerRef.createComponent(\n        componentFactory,\n        this._viewContainerRef.length,\n        childInjector\n      );\n      if (options.appendToBody) {\n        document.body.appendChild(this.popover.location.nativeElement);\n      }\n      this.onVisibleChange.emit(true);\n    }\n  }\n\n  private positionPopover(): void {\n    if (this.popover) {\n      const popoverElement = this.popover.location.nativeElement.children[1];\n      const popoverPosition = Positioning.getPositionElements(\n        this._elm.nativeElement,\n        popoverElement,\n        this.positionMap(this.placement) || this._defaultOptions.placement,\n        this.appendToBody || this._defaultOptions.appendToBody\n      );\n      if (this.placement === 'landScape') {\n        this._renderer.setStyle(popoverElement, 'top', `${popoverPosition.top}px`);\n        this._renderer.setStyle(popoverElement, 'left', `0px`);\n        this._renderer.setStyle(popoverElement, 'width', `${window.innerWidth}px`);\n        this._renderer.setStyle(popoverElement, 'max-height', `${window.innerHeight - popoverPosition.height}px`);\n      } else if (this.placement === 'fullScreen') {\n        this._renderer.setStyle(popoverElement, 'top', `${0}px`);\n        this._renderer.setStyle(popoverElement, 'left', `0px`);\n        this._renderer.setStyle(popoverElement, 'width', `${window.innerWidth}px`);\n        this._renderer.setStyle(popoverElement, 'max-height', `${window.innerHeight - popoverPosition.height}px`);\n      } else {\n        this._renderer.setStyle(popoverElement, 'top', `${popoverPosition.top}px`);\n        this._renderer.setStyle(popoverElement, 'left', `${popoverPosition.left}px`);\n      }\n    }\n  }\n\n  private hidePopover(): void {\n    if (this.popover) {\n      this.popover.destroy();\n      delete this.popover;\n      this.onVisibleChange.emit(false);\n      this._eventListeners.forEach(fn => fn());\n      this._eventListeners = [];\n    }\n  }\n}\n"]}