ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
320 lines • 31.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay';
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, Host, Input, Optional, Output, QueryList, ViewChild, ViewEncapsulation } from '@angular/core';
import { combineLatest, merge, Subject } from 'rxjs';
import { flatMap, map, startWith, takeUntil } from 'rxjs/operators';
import { collapseMotion } from '../core/animation/collapse';
import { slideMotion } from '../core/animation/slide';
import { zoomBigMotion } from '../core/animation/zoom';
import { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';
import { getPlacementName, DEFAULT_SUBMENU_POSITIONS, POSITION_MAP } from '../core/overlay/overlay-position';
import { NzUpdateHostClassService } from '../core/services/update-host-class.service';
import { InputBoolean } from '../core/util/convert';
import { NzMenuItemDirective } from './nz-menu-item.directive';
import { NzMenuService } from './nz-menu.service';
import { NzSubmenuService } from './nz-submenu.service';
var NzSubMenuComponent = /** @class */ (function () {
function NzSubMenuComponent(elementRef, nzMenuService, cdr, nzSubmenuService, nzUpdateHostClassService, noAnimation) {
this.elementRef = elementRef;
this.nzMenuService = nzMenuService;
this.cdr = cdr;
this.nzSubmenuService = nzSubmenuService;
this.nzUpdateHostClassService = nzUpdateHostClassService;
this.noAnimation = noAnimation;
this.placement = 'rightTop';
this.expandState = 'collapsed';
this.overlayPositions = tslib_1.__spread(DEFAULT_SUBMENU_POSITIONS);
this.destroy$ = new Subject();
this.isChildMenuSelected = false;
this.nzOpen = false;
this.nzDisabled = false;
this.nzOpenChange = new EventEmitter();
}
/**
* @param {?} open
* @return {?}
*/
NzSubMenuComponent.prototype.setOpenState = /**
* @param {?} open
* @return {?}
*/
function (open) {
this.nzSubmenuService.setOpenState(open);
};
/**
* @return {?}
*/
NzSubMenuComponent.prototype.clickSubMenuTitle = /**
* @return {?}
*/
function () {
if (this.nzSubmenuService.mode === 'inline' && !this.nzMenuService.isInDropDown && !this.nzDisabled) {
this.setOpenState(!this.nzOpen);
}
};
/**
* @param {?} value
* @return {?}
*/
NzSubMenuComponent.prototype.setMouseEnterState = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.nzSubmenuService.setMouseEnterState(value);
};
/**
* @return {?}
*/
NzSubMenuComponent.prototype.setTriggerWidth = /**
* @return {?}
*/
function () {
if (this.nzSubmenuService.mode === 'horizontal') {
this.triggerWidth = this.cdkOverlayOrigin.nativeElement.getBoundingClientRect().width;
}
};
/**
* @param {?} position
* @return {?}
*/
NzSubMenuComponent.prototype.onPositionChange = /**
* @param {?} position
* @return {?}
*/
function (position) {
this.placement = getPlacementName(position);
this.cdr.markForCheck();
};
/**
* @return {?}
*/
NzSubMenuComponent.prototype.setClassMap = /**
* @return {?}
*/
function () {
var _a;
/** @type {?} */
var prefixName = this.nzMenuService.isInDropDown ? 'ant-dropdown-menu-submenu' : 'ant-menu-submenu';
this.nzUpdateHostClassService.updateHostClass(this.elementRef.nativeElement, (_a = {},
_a["" + prefixName] = true,
_a[prefixName + "-disabled"] = this.nzDisabled,
_a[prefixName + "-open"] = this.nzOpen,
_a[prefixName + "-selected"] = this.isChildMenuSelected,
_a[prefixName + "-" + this.nzSubmenuService.mode] = true,
_a));
};
/**
* @return {?}
*/
NzSubMenuComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
combineLatest(this.nzSubmenuService.mode$, this.nzSubmenuService.open$).pipe(takeUntil(this.destroy$)).subscribe((/**
* @param {?} data
* @return {?}
*/
function (data) {
/** @type {?} */
var mode = data[0];
/** @type {?} */
var open = data[1];
if (open && mode === 'inline') {
_this.expandState = 'expanded';
}
else if (open && mode === 'horizontal') {
_this.expandState = 'bottom';
}
else if (open && mode === 'vertical') {
_this.expandState = 'active';
}
else {
_this.expandState = 'collapsed';
}
_this.overlayPositions = mode === 'horizontal' ? [POSITION_MAP.bottomLeft] : [POSITION_MAP.rightTop, POSITION_MAP.leftTop];
if (open !== _this.nzOpen) {
_this.nzOpen = open;
_this.nzOpenChange.emit(_this.nzOpen);
}
_this.setClassMap();
_this.setTriggerWidth();
}));
this.nzSubmenuService.menuOpen$.pipe(takeUntil(this.destroy$)).subscribe((/**
* @param {?} data
* @return {?}
*/
function (data) {
_this.nzMenuService.menuOpen$.next(data);
}));
merge(this.nzMenuService.mode$, this.nzMenuService.inlineIndent$, this.nzSubmenuService.level$, this.nzSubmenuService.open$, this.nzSubmenuService.mode$).pipe(takeUntil(this.destroy$)).subscribe((/**
* @return {?}
*/
function () {
_this.cdr.markForCheck();
}));
};
/**
* @return {?}
*/
NzSubMenuComponent.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
var _this = this;
this.setTriggerWidth();
this.listOfNzMenuItemDirective.changes.pipe(startWith(true), flatMap((/**
* @return {?}
*/
function () { return merge.apply(void 0, tslib_1.__spread([_this.listOfNzMenuItemDirective.changes], _this.listOfNzMenuItemDirective.map((/**
* @param {?} menu
* @return {?}
*/
function (menu) { return menu.selected$; })))); })), map((/**
* @return {?}
*/
function () { return _this.listOfNzMenuItemDirective.some((/**
* @param {?} e
* @return {?}
*/
function (e) { return e.nzSelected; })); })), takeUntil(this.destroy$)).subscribe((/**
* @param {?} selected
* @return {?}
*/
function (selected) {
_this.isChildMenuSelected = selected;
_this.setClassMap();
}));
};
/**
* @param {?} changes
* @return {?}
*/
NzSubMenuComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes.nzOpen) {
this.nzSubmenuService.setOpenState(this.nzOpen);
}
if (changes.nzDisabled) {
this.nzSubmenuService.disabled = this.nzDisabled;
this.setClassMap();
}
};
/**
* @return {?}
*/
NzSubMenuComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.destroy$.next();
this.destroy$.complete();
};
NzSubMenuComponent.decorators = [
{ type: Component, args: [{
selector: '[nz-submenu]',
providers: [NzSubmenuService, NzUpdateHostClassService],
animations: [collapseMotion, zoomBigMotion, slideMotion],
encapsulation: ViewEncapsulation.None,
changeDetection: ChangeDetectionStrategy.OnPush,
preserveWhitespaces: false,
template: "<div cdkOverlayOrigin\n #origin=\"cdkOverlayOrigin\"\n [class.ant-dropdown-menu-submenu-title]=\"nzMenuService.isInDropDown\"\n [class.ant-menu-submenu-title]=\"!nzMenuService.isInDropDown\"\n [style.paddingLeft.px]=\"nzMenuService.mode === 'inline'? (nzPaddingLeft ? nzPaddingLeft : nzSubmenuService.level * nzMenuService.inlineIndent) : null\"\n (mouseenter)=\"setMouseEnterState(true)\"\n (mouseleave)=\"setMouseEnterState(false)\"\n (click)=\"clickSubMenuTitle()\">\n <ng-content select=\"[title]\"></ng-content>\n <span *ngIf=\"nzMenuService.isInDropDown; else notDropdownTpl\" class=\"ant-dropdown-menu-submenu-arrow\">\n <i nz-icon type=\"right\" class=\"anticon-right ant-dropdown-menu-submenu-arrow-icon\"></i>\n </span>\n <ng-template #notDropdownTpl><i class=\"ant-menu-submenu-arrow\"></i></ng-template>\n</div>\n<ul *ngIf=\"nzMenuService.mode === 'inline'\" [@collapseMotion]=\"expandState\" [nzNoAnimation]=\"noAnimation?.nzNoAnimation\" class=\"ant-menu ant-menu-inline ant-menu-sub\">\n <ng-template [ngTemplateOutlet]=\"subMenuTemplate\"></ng-template>\n</ul>\n<ng-template cdkConnectedOverlay\n (positionChange)=\"onPositionChange($event)\"\n [cdkConnectedOverlayPositions]=\"overlayPositions\"\n [cdkConnectedOverlayOrigin]=\"origin\"\n [cdkConnectedOverlayWidth]=\"triggerWidth\"\n [cdkConnectedOverlayOpen]=\"nzOpen && nzMenuService.mode !== 'inline'\">\n <div class=\"ant-menu-submenu ant-menu-submenu-popup\"\n [@slideMotion]=\"expandState\"\n [@zoomBigMotion]=\"expandState\"\n [nzNoAnimation]=\"noAnimation?.nzNoAnimation\"\n [class.ant-menu-light]=\"nzMenuService.theme === 'light'\"\n [class.ant-menu-dark]=\"nzMenuService.theme === 'dark'\"\n [class.ant-menu-submenu-placement-bottomLeft]=\"nzSubmenuService.mode === 'horizontal'\"\n [class.ant-menu-submenu-placement-rightTop]=\"nzSubmenuService.mode === 'vertical' && placement === 'rightTop'\"\n [class.ant-menu-submenu-placement-leftTop]=\"nzSubmenuService.mode === 'vertical' && placement === 'leftTop'\"\n (mouseleave)=\"setMouseEnterState(false)\"\n (mouseenter)=\"setMouseEnterState(true)\">\n <ul [class.ant-dropdown-menu]=\"nzMenuService.isInDropDown\"\n [class.ant-menu]=\"!nzMenuService.isInDropDown\"\n [class.ant-dropdown-menu-vertical]=\"nzMenuService.isInDropDown\"\n [class.ant-menu-vertical]=\"!nzMenuService.isInDropDown\"\n [class.ant-dropdown-menu-sub]=\"nzMenuService.isInDropDown\"\n [class.ant-menu-sub]=\"!nzMenuService.isInDropDown\">\n <ng-template [ngTemplateOutlet]=\"subMenuTemplate\"></ng-template>\n </ul>\n </div>\n</ng-template>\n\n<ng-template #subMenuTemplate>\n <ng-content></ng-content>\n</ng-template>",
styles: ["\n .ant-menu-submenu-placement-bottomLeft {\n top: 6px;\n position: relative;\n }\n\n .ant-menu-submenu-placement-rightTop {\n left: 4px;\n position: relative;\n }\n\n .ant-menu-submenu-placement-leftTop {\n right: 4px;\n position: relative;\n }\n "]
}] }
];
/** @nocollapse */
NzSubMenuComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: NzMenuService },
{ type: ChangeDetectorRef },
{ type: NzSubmenuService },
{ type: NzUpdateHostClassService },
{ type: NzNoAnimationDirective, decorators: [{ type: Host }, { type: Optional }] }
]; };
NzSubMenuComponent.propDecorators = {
listOfNzSubMenuComponent: [{ type: ContentChildren, args: [NzSubMenuComponent, { descendants: true },] }],
listOfNzMenuItemDirective: [{ type: ContentChildren, args: [NzMenuItemDirective, { descendants: true },] }],
cdkConnectedOverlay: [{ type: ViewChild, args: [CdkConnectedOverlay,] }],
cdkOverlayOrigin: [{ type: ViewChild, args: [CdkOverlayOrigin, { read: ElementRef },] }],
nzPaddingLeft: [{ type: Input }],
nzOpen: [{ type: Input }],
nzDisabled: [{ type: Input }],
nzOpenChange: [{ type: Output }]
};
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzSubMenuComponent.prototype, "nzOpen", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzSubMenuComponent.prototype, "nzDisabled", void 0);
return NzSubMenuComponent;
}());
export { NzSubMenuComponent };
if (false) {
/** @type {?} */
NzSubMenuComponent.prototype.placement;
/** @type {?} */
NzSubMenuComponent.prototype.triggerWidth;
/** @type {?} */
NzSubMenuComponent.prototype.expandState;
/** @type {?} */
NzSubMenuComponent.prototype.overlayPositions;
/**
* @type {?}
* @private
*/
NzSubMenuComponent.prototype.destroy$;
/**
* @type {?}
* @private
*/
NzSubMenuComponent.prototype.isChildMenuSelected;
/** @type {?} */
NzSubMenuComponent.prototype.listOfNzSubMenuComponent;
/** @type {?} */
NzSubMenuComponent.prototype.listOfNzMenuItemDirective;
/** @type {?} */
NzSubMenuComponent.prototype.cdkConnectedOverlay;
/** @type {?} */
NzSubMenuComponent.prototype.cdkOverlayOrigin;
/** @type {?} */
NzSubMenuComponent.prototype.nzPaddingLeft;
/** @type {?} */
NzSubMenuComponent.prototype.nzOpen;
/** @type {?} */
NzSubMenuComponent.prototype.nzDisabled;
/** @type {?} */
NzSubMenuComponent.prototype.nzOpenChange;
/**
* @type {?}
* @private
*/
NzSubMenuComponent.prototype.elementRef;
/** @type {?} */
NzSubMenuComponent.prototype.nzMenuService;
/**
* @type {?}
* @private
*/
NzSubMenuComponent.prototype.cdr;
/** @type {?} */
NzSubMenuComponent.prototype.nzSubmenuService;
/**
* @type {?}
* @private
*/
NzSubMenuComponent.prototype.nzUpdateHostClassService;
/** @type {?} */
NzSubMenuComponent.prototype.noAnimation;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-submenu.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["menu/nz-submenu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Host,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\n\nimport { combineLatest, merge, Subject } from 'rxjs';\nimport { flatMap, map, startWith, takeUntil } from 'rxjs/operators';\nimport { collapseMotion } from '../core/animation/collapse';\nimport { slideMotion } from '../core/animation/slide';\nimport { zoomBigMotion } from '../core/animation/zoom';\nimport { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';\nimport { getPlacementName, DEFAULT_SUBMENU_POSITIONS, POSITION_MAP } from '../core/overlay/overlay-position';\nimport { NzUpdateHostClassService } from '../core/services/update-host-class.service';\nimport { InputBoolean } from '../core/util/convert';\nimport { NzMenuItemDirective } from './nz-menu-item.directive';\nimport { NzMenuService } from './nz-menu.service';\nimport { NzSubmenuService } from './nz-submenu.service';\n\n@Component({\n  selector           : '[nz-submenu]',\n  providers          : [ NzSubmenuService, NzUpdateHostClassService ],\n  animations         : [ collapseMotion, zoomBigMotion, slideMotion ],\n  encapsulation      : ViewEncapsulation.None,\n  changeDetection    : ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n  templateUrl        : './nz-submenu.component.html',\n  styles             : [\n      `\n      .ant-menu-submenu-placement-bottomLeft {\n        top: 6px;\n        position: relative;\n      }\n\n      .ant-menu-submenu-placement-rightTop {\n        left: 4px;\n        position: relative;\n      }\n\n      .ant-menu-submenu-placement-leftTop {\n        right: 4px;\n        position: relative;\n      }\n    `\n  ]\n})\n\nexport class NzSubMenuComponent implements OnInit, OnDestroy, AfterContentInit, OnChanges {\n  placement = 'rightTop';\n  triggerWidth: number;\n  expandState = 'collapsed';\n  overlayPositions = [ ...DEFAULT_SUBMENU_POSITIONS ];\n  private destroy$ = new Subject<void>();\n  private isChildMenuSelected = false;\n  @ContentChildren(NzSubMenuComponent, { descendants: true }) listOfNzSubMenuComponent: QueryList<NzSubMenuComponent>;\n  @ContentChildren(NzMenuItemDirective, { descendants: true }) listOfNzMenuItemDirective: QueryList<NzMenuItemDirective>;\n  @ViewChild(CdkConnectedOverlay) cdkConnectedOverlay: CdkConnectedOverlay;\n  @ViewChild(CdkOverlayOrigin, { read: ElementRef }) cdkOverlayOrigin: ElementRef;\n  @Input() nzPaddingLeft: number;\n  @Input() @InputBoolean() nzOpen = false;\n  @Input() @InputBoolean() nzDisabled = false;\n  @Output() readonly nzOpenChange: EventEmitter<boolean> = new EventEmitter();\n\n  setOpenState(open: boolean): void {\n    this.nzSubmenuService.setOpenState(open);\n  }\n\n  clickSubMenuTitle(): void {\n    if (this.nzSubmenuService.mode === 'inline' && !this.nzMenuService.isInDropDown && !this.nzDisabled) {\n      this.setOpenState(!this.nzOpen);\n    }\n  }\n\n  setMouseEnterState(value: boolean): void {\n    this.nzSubmenuService.setMouseEnterState(value);\n  }\n\n  setTriggerWidth(): void {\n    if (this.nzSubmenuService.mode === 'horizontal') {\n      this.triggerWidth = this.cdkOverlayOrigin.nativeElement.getBoundingClientRect().width;\n    }\n  }\n\n  onPositionChange(position: ConnectedOverlayPositionChange): void {\n    this.placement = getPlacementName(position);\n    this.cdr.markForCheck();\n  }\n\n  setClassMap(): void {\n    const prefixName = this.nzMenuService.isInDropDown ? 'ant-dropdown-menu-submenu' : 'ant-menu-submenu';\n    this.nzUpdateHostClassService.updateHostClass(this.elementRef.nativeElement, {\n      [ `${prefixName}` ]                              : true,\n      [ `${prefixName}-disabled` ]                     : this.nzDisabled,\n      [ `${prefixName}-open` ]                         : this.nzOpen,\n      [ `${prefixName}-selected` ]                     : this.isChildMenuSelected,\n      [ `${prefixName}-${this.nzSubmenuService.mode}` ]: true\n    });\n  }\n\n  constructor(private elementRef: ElementRef,\n              public nzMenuService: NzMenuService,\n              private cdr: ChangeDetectorRef,\n              public nzSubmenuService: NzSubmenuService,\n              private nzUpdateHostClassService: NzUpdateHostClassService,\n              @Host() @Optional() public noAnimation?: NzNoAnimationDirective) {\n  }\n\n  ngOnInit(): void {\n    combineLatest(\n      this.nzSubmenuService.mode$,\n      this.nzSubmenuService.open$\n    ).pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(data => {\n      const mode = data[ 0 ];\n      const open = data[ 1 ];\n      if (open && mode === 'inline') {\n        this.expandState = 'expanded';\n      } else if (open && mode === 'horizontal') {\n        this.expandState = 'bottom';\n      } else if (open && mode === 'vertical') {\n        this.expandState = 'active';\n      } else {\n        this.expandState = 'collapsed';\n      }\n      this.overlayPositions = mode === 'horizontal' ? [ POSITION_MAP.bottomLeft ] : [ POSITION_MAP.rightTop, POSITION_MAP.leftTop ];\n      if (open !== this.nzOpen) {\n        this.nzOpen = open;\n        this.nzOpenChange.emit(this.nzOpen);\n      }\n      this.setClassMap();\n      this.setTriggerWidth();\n    });\n    this.nzSubmenuService.menuOpen$.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe((data: boolean) => {\n      this.nzMenuService.menuOpen$.next(data);\n    });\n    merge(\n      this.nzMenuService.mode$,\n      this.nzMenuService.inlineIndent$,\n      this.nzSubmenuService.level$,\n      this.nzSubmenuService.open$,\n      this.nzSubmenuService.mode$).pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(() => {\n      this.cdr.markForCheck();\n    });\n  }\n\n  ngAfterContentInit(): void {\n    this.setTriggerWidth();\n    this.listOfNzMenuItemDirective.changes.pipe(\n      startWith(true),\n      flatMap(() => merge(\n        this.listOfNzMenuItemDirective.changes,\n        ...this.listOfNzMenuItemDirective.map(menu => menu.selected$)\n      )),\n      map(() => this.listOfNzMenuItemDirective.some(e => e.nzSelected)),\n      takeUntil(this.destroy$)\n    ).subscribe((selected) => {\n      this.isChildMenuSelected = selected;\n      this.setClassMap();\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzOpen) {\n      this.nzSubmenuService.setOpenState(this.nzOpen);\n    }\n    if (changes.nzDisabled) {\n      this.nzSubmenuService.disabled = this.nzDisabled;\n      this.setClassMap();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}