ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
276 lines • 21.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: nz-context-menu.service.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @license
* Copyright Alibaba.com All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE
*/
/** keep track https://github.com/angular/material2/issues/5007 **/
import { ConnectionPositionPair, Overlay, OverlayConfig } from '@angular/cdk/overlay';
import { TemplatePortal } from '@angular/cdk/portal';
import { Injectable } from '@angular/core';
import { fromEvent, Subscription } from 'rxjs';
import { filter, take } from 'rxjs/operators';
import { NzContextMenuServiceModule } from './nz-context-menu.service.module';
import * as i0 from "@angular/core";
import * as i1 from "@angular/cdk/overlay";
import * as i2 from "./nz-context-menu.service.module";
var NzContextMenuService = /** @class */ (function () {
function NzContextMenuService(overlay) {
this.overlay = overlay;
this.clickOutsideSubscription = Subscription.EMPTY;
this.clickMenuSubscription = Subscription.EMPTY;
this.positionSubscription = Subscription.EMPTY;
}
/**
* @param {?} $event
* @param {?} nzDropdownMenuComponent
* @return {?}
*/
NzContextMenuService.prototype.create = /**
* @param {?} $event
* @param {?} nzDropdownMenuComponent
* @return {?}
*/
function ($event, nzDropdownMenuComponent) {
$event.preventDefault();
/** @type {?} */
var overlayRef = this.createOverlay($event);
if (overlayRef.hasAttached()) {
this.close();
}
this.attachTemplatePortal(overlayRef, nzDropdownMenuComponent);
this.handleClickOutside();
};
/**
* @return {?}
*/
NzContextMenuService.prototype.close = /**
* @return {?}
*/
function () {
if (this.overlayRef) {
this.overlayRef.detach();
this.setOpenState(false);
this.clickOutsideSubscription.unsubscribe();
this.clickMenuSubscription.unsubscribe();
this.positionSubscription.unsubscribe();
}
};
/**
* @private
* @return {?}
*/
NzContextMenuService.prototype.handleClickOutside = /**
* @private
* @return {?}
*/
function () {
var _this = this;
this.clickOutsideSubscription.unsubscribe();
this.clickOutsideSubscription = fromEvent(document, 'click')
.pipe(filter((/**
* @param {?} event
* @return {?}
*/
function (event) { return !!_this.overlayRef && !_this.overlayRef.overlayElement.contains((/** @type {?} */ (event.target))); })),
// handle firefox contextmenu event
filter((/**
* @param {?} event
* @return {?}
*/
function (event) { return event.button !== 2; })), take(1))
.subscribe((/**
* @return {?}
*/
function () {
_this.close();
}));
};
/**
* @private
* @param {?} overlayRef
* @param {?} nzDropdownMenuComponent
* @return {?}
*/
NzContextMenuService.prototype.attachTemplatePortal = /**
* @private
* @param {?} overlayRef
* @param {?} nzDropdownMenuComponent
* @return {?}
*/
function (overlayRef, nzDropdownMenuComponent) {
var _this = this;
this.nzDropdownMenuComponent = nzDropdownMenuComponent;
nzDropdownMenuComponent.setValue('nzTrigger', 'click');
this.clickMenuSubscription.unsubscribe();
this.clickMenuSubscription = nzDropdownMenuComponent.nzMenuDropdownService.menuItemClick$.subscribe((/**
* @return {?}
*/
function () {
_this.close();
}));
overlayRef.attach(new TemplatePortal(nzDropdownMenuComponent.templateRef, nzDropdownMenuComponent.viewContainerRef));
this.setOpenState(true);
};
/**
* @private
* @param {?} state
* @return {?}
*/
NzContextMenuService.prototype.setOpenState = /**
* @private
* @param {?} state
* @return {?}
*/
function (state) {
this.nzDropdownMenuComponent.setValue('open', state);
};
/**
* @private
* @param {?} $event
* @return {?}
*/
NzContextMenuService.prototype.getOverlayConfig = /**
* @private
* @param {?} $event
* @return {?}
*/
function ($event) {
return new OverlayConfig({
panelClass: 'nz-dropdown-panel',
positionStrategy: this.generatePositionStrategy($event),
scrollStrategy: this.overlay.scrollStrategies.close()
});
};
/**
* @private
* @param {?} $event
* @return {?}
*/
NzContextMenuService.prototype.generatePositionStrategy = /**
* @private
* @param {?} $event
* @return {?}
*/
function ($event) {
return this.overlay
.position()
.flexibleConnectedTo({ x: $event.x, y: $event.y })
.withPositions([
new ConnectionPositionPair({ originX: 'start', originY: 'top' }, { overlayX: 'start', overlayY: 'top' }),
new ConnectionPositionPair({ originX: 'start', originY: 'top' }, { overlayX: 'start', overlayY: 'bottom' }),
new ConnectionPositionPair({ originX: 'start', originY: 'top' }, { overlayX: 'end', overlayY: 'bottom' }),
new ConnectionPositionPair({ originX: 'start', originY: 'top' }, { overlayX: 'end', overlayY: 'top' })
]);
};
/**
* @private
* @param {?} position
* @return {?}
*/
NzContextMenuService.prototype.subscribeToPositions = /**
* @private
* @param {?} position
* @return {?}
*/
function (position) {
var _this = this;
this.positionSubscription.unsubscribe();
this.positionSubscription = position.positionChanges.subscribe((/**
* @param {?} change
* @return {?}
*/
function (change) {
// TODO: positionChanges won't trigger if not dispose
_this.nzDropdownMenuComponent.setValue('dropDownPosition', change.connectionPair.overlayY === 'bottom' ? 'top' : 'bottom');
}));
};
/**
* @private
* @param {?} $event
* @return {?}
*/
NzContextMenuService.prototype.createOverlay = /**
* @private
* @param {?} $event
* @return {?}
*/
function ($event) {
/** @type {?} */
var config = this.getOverlayConfig($event);
if (!this.overlayRef) {
this.overlayRef = this.overlay.create(config);
}
else {
this.updatePosition(this.overlayRef, $event);
}
this.subscribeToPositions((/** @type {?} */ (config.positionStrategy)));
return this.overlayRef;
};
/**
* @private
* @param {?} overlayRef
* @param {?} $event
* @return {?}
*/
NzContextMenuService.prototype.updatePosition = /**
* @private
* @param {?} overlayRef
* @param {?} $event
* @return {?}
*/
function (overlayRef, $event) {
overlayRef.updatePositionStrategy(this.generatePositionStrategy($event));
};
NzContextMenuService.decorators = [
{ type: Injectable, args: [{
providedIn: NzContextMenuServiceModule
},] }
];
/** @nocollapse */
NzContextMenuService.ctorParameters = function () { return [
{ type: Overlay }
]; };
/** @nocollapse */ NzContextMenuService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function NzContextMenuService_Factory() { return new NzContextMenuService(i0.ɵɵinject(i1.Overlay)); }, token: NzContextMenuService, providedIn: i2.NzContextMenuServiceModule });
return NzContextMenuService;
}());
export { NzContextMenuService };
if (false) {
/**
* @type {?}
* @private
*/
NzContextMenuService.prototype.overlayRef;
/**
* @type {?}
* @private
*/
NzContextMenuService.prototype.nzDropdownMenuComponent;
/**
* @type {?}
* @private
*/
NzContextMenuService.prototype.clickOutsideSubscription;
/**
* @type {?}
* @private
*/
NzContextMenuService.prototype.clickMenuSubscription;
/**
* @type {?}
* @private
*/
NzContextMenuService.prototype.positionSubscription;
/**
* @type {?}
* @private
*/
NzContextMenuService.prototype.overlay;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-context-menu.service.js","sourceRoot":"ng://ng-zorro-antd/dropdown/","sources":["nz-context-menu.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\n/** keep track https://github.com/angular/material2/issues/5007 **/\nimport {\n  ConnectionPositionPair,\n  FlexibleConnectedPositionStrategy,\n  Overlay,\n  OverlayConfig,\n  OverlayRef\n} from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Injectable } from '@angular/core';\nimport { fromEvent, Subscription } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { NzContextMenuServiceModule } from './nz-context-menu.service.module';\nimport { NzDropdownMenuComponent } from './nz-dropdown-menu.component';\n\n@Injectable({\n  providedIn: NzContextMenuServiceModule\n})\nexport class NzContextMenuService {\n  private overlayRef: OverlayRef;\n  private nzDropdownMenuComponent: NzDropdownMenuComponent;\n  private clickOutsideSubscription = Subscription.EMPTY;\n  private clickMenuSubscription = Subscription.EMPTY;\n  private positionSubscription = Subscription.EMPTY;\n\n  constructor(private overlay: Overlay) {}\n\n  create($event: MouseEvent, nzDropdownMenuComponent: NzDropdownMenuComponent): void {\n    $event.preventDefault();\n    const overlayRef = this.createOverlay($event);\n    if (overlayRef.hasAttached()) {\n      this.close();\n    }\n    this.attachTemplatePortal(overlayRef, nzDropdownMenuComponent);\n    this.handleClickOutside();\n  }\n\n  close(): void {\n    if (this.overlayRef) {\n      this.overlayRef.detach();\n      this.setOpenState(false);\n      this.clickOutsideSubscription.unsubscribe();\n      this.clickMenuSubscription.unsubscribe();\n      this.positionSubscription.unsubscribe();\n    }\n  }\n\n  private handleClickOutside(): void {\n    this.clickOutsideSubscription.unsubscribe();\n    this.clickOutsideSubscription = fromEvent<MouseEvent>(document, 'click')\n      .pipe(\n        filter(event => !!this.overlayRef && !this.overlayRef.overlayElement.contains(event.target as HTMLElement)),\n        // handle firefox contextmenu event\n        filter(event => event.button !== 2),\n        take(1)\n      )\n      .subscribe(() => {\n        this.close();\n      });\n  }\n\n  private attachTemplatePortal(overlayRef: OverlayRef, nzDropdownMenuComponent: NzDropdownMenuComponent): void {\n    this.nzDropdownMenuComponent = nzDropdownMenuComponent;\n    nzDropdownMenuComponent.setValue('nzTrigger', 'click');\n    this.clickMenuSubscription.unsubscribe();\n    this.clickMenuSubscription = nzDropdownMenuComponent.nzMenuDropdownService.menuItemClick$.subscribe(() => {\n      this.close();\n    });\n    overlayRef.attach(\n      new TemplatePortal(nzDropdownMenuComponent.templateRef, nzDropdownMenuComponent.viewContainerRef)\n    );\n    this.setOpenState(true);\n  }\n\n  private setOpenState(state: boolean): void {\n    this.nzDropdownMenuComponent.setValue('open', state);\n  }\n\n  private getOverlayConfig($event: MouseEvent): OverlayConfig {\n    return new OverlayConfig({\n      panelClass: 'nz-dropdown-panel',\n      positionStrategy: this.generatePositionStrategy($event),\n      scrollStrategy: this.overlay.scrollStrategies.close()\n    });\n  }\n\n  private generatePositionStrategy($event: MouseEvent): FlexibleConnectedPositionStrategy {\n    return this.overlay\n      .position()\n      .flexibleConnectedTo({ x: $event.x, y: $event.y })\n      .withPositions([\n        new ConnectionPositionPair({ originX: 'start', originY: 'top' }, { overlayX: 'start', overlayY: 'top' }),\n        new ConnectionPositionPair({ originX: 'start', originY: 'top' }, { overlayX: 'start', overlayY: 'bottom' }),\n        new ConnectionPositionPair({ originX: 'start', originY: 'top' }, { overlayX: 'end', overlayY: 'bottom' }),\n        new ConnectionPositionPair({ originX: 'start', originY: 'top' }, { overlayX: 'end', overlayY: 'top' })\n      ]);\n  }\n\n  private subscribeToPositions(position: FlexibleConnectedPositionStrategy): void {\n    this.positionSubscription.unsubscribe();\n    this.positionSubscription = position.positionChanges.subscribe(change => {\n      // TODO: positionChanges won't trigger if not dispose\n      this.nzDropdownMenuComponent.setValue(\n        'dropDownPosition',\n        change.connectionPair.overlayY === 'bottom' ? 'top' : 'bottom'\n      );\n    });\n  }\n\n  private createOverlay($event: MouseEvent): OverlayRef {\n    const config = this.getOverlayConfig($event);\n    if (!this.overlayRef) {\n      this.overlayRef = this.overlay.create(config);\n    } else {\n      this.updatePosition(this.overlayRef, $event);\n    }\n    this.subscribeToPositions(config.positionStrategy as FlexibleConnectedPositionStrategy);\n    return this.overlayRef;\n  }\n\n  private updatePosition(overlayRef: OverlayRef, $event: MouseEvent): void {\n    overlayRef.updatePositionStrategy(this.generatePositionStrategy($event));\n  }\n}\n"]}