UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

350 lines 32.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; /** * @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 */ import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay'; import { Platform } from '@angular/cdk/platform'; 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, getPlacementName, slideMotion, zoomBigMotion, DEFAULT_SUBMENU_POSITIONS, InputBoolean, NzMenuBaseService, NzNoAnimationDirective, NzUpdateHostClassService, POSITION_MAP } from 'ng-zorro-antd/core'; import { NzMenuItemDirective } from './nz-menu-item.directive'; import { NzSubmenuService } from './nz-submenu.service'; var NzSubMenuComponent = /** @class */ (function () { function NzSubMenuComponent(elementRef, nzMenuService, cdr, nzSubmenuService, nzUpdateHostClassService, platform, noAnimation) { this.elementRef = elementRef; this.nzMenuService = nzMenuService; this.cdr = cdr; this.nzSubmenuService = nzSubmenuService; this.nzUpdateHostClassService = nzUpdateHostClassService; this.platform = platform; this.noAnimation = noAnimation; this.nzOpen = false; this.nzDisabled = false; this.nzOpenChange = new EventEmitter(); this.placement = 'rightTop'; this.expandState = 'collapsed'; this.overlayPositions = tslib_1.__spread(DEFAULT_SUBMENU_POSITIONS); this.destroy$ = new Subject(); this.isChildMenuSelected = false; this.isMouseHover = false; } /** * @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.isMouseHover = value; this.setClassMap(); this.nzSubmenuService.setMouseEnterState(value); }; /** * @return {?} */ NzSubMenuComponent.prototype.setTriggerWidth = /** * @return {?} */ function () { if (this.nzSubmenuService.mode === 'horizontal' && this.platform.isBrowser) { this.triggerWidth = this.cdkOverlayOrigin.nativeElement.getBoundingClientRect().width; } }; /** * @param {?} position * @return {?} */ NzSubMenuComponent.prototype.onPositionChange = /** * @param {?} position * @return {?} */ function (position) { this.placement = (/** @type {?} */ (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[prefixName + "-active"] = this.isMouseHover && !this.nzDisabled, _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]', exportAs: 'nzSubmenu', 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'\"\n [@collapseMotion]=\"expandState\"\n [nzNoAnimation]=\"noAnimation?.nzNoAnimation\"\n [ngClass]=\"nzMenuClassName\"\n 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 [ngClass]=\"nzMenuClassName\">\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: NzMenuBaseService }, { type: ChangeDetectorRef }, { type: NzSubmenuService }, { type: NzUpdateHostClassService }, { type: Platform }, { type: NzNoAnimationDirective, decorators: [{ type: Host }, { type: Optional }] } ]; }; NzSubMenuComponent.propDecorators = { nzMenuClassName: [{ type: Input }], nzPaddingLeft: [{ type: Input }], nzOpen: [{ type: Input }], nzDisabled: [{ type: Input }], nzOpenChange: [{ type: Output }], cdkConnectedOverlay: [{ type: ViewChild, args: [CdkConnectedOverlay,] }], cdkOverlayOrigin: [{ type: ViewChild, args: [CdkOverlayOrigin, { read: ElementRef },] }], listOfNzSubMenuComponent: [{ type: ContentChildren, args: [NzSubMenuComponent, { descendants: true },] }], listOfNzMenuItemDirective: [{ type: ContentChildren, args: [NzMenuItemDirective, { descendants: true },] }] }; 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.nzMenuClassName; /** @type {?} */ NzSubMenuComponent.prototype.nzPaddingLeft; /** @type {?} */ NzSubMenuComponent.prototype.nzOpen; /** @type {?} */ NzSubMenuComponent.prototype.nzDisabled; /** @type {?} */ NzSubMenuComponent.prototype.nzOpenChange; /** @type {?} */ NzSubMenuComponent.prototype.cdkConnectedOverlay; /** @type {?} */ NzSubMenuComponent.prototype.cdkOverlayOrigin; /** @type {?} */ NzSubMenuComponent.prototype.listOfNzSubMenuComponent; /** @type {?} */ NzSubMenuComponent.prototype.listOfNzMenuItemDirective; /** @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 {?} * @private */ NzSubMenuComponent.prototype.isMouseHover; /** * @type {?} * @private */ NzSubMenuComponent.prototype.elementRef; /** @type {?} */ NzSubMenuComponent.prototype.nzMenuService; /** * @type {?} * @private */ NzSubMenuComponent.prototype.cdr; /** @type {?} */ NzSubMenuComponent.prototype.nzSubmenuService; /** * @type {?} * @private */ NzSubMenuComponent.prototype.nzUpdateHostClassService; /** * @type {?} * @private */ NzSubMenuComponent.prototype.platform; /** @type {?} */ NzSubMenuComponent.prototype.noAnimation; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-submenu.component.js","sourceRoot":"ng://ng-zorro-antd/menu/","sources":["nz-submenu.component.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\nimport { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport { Platform } from '@angular/cdk/platform';\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';\n\nimport {\n  collapseMotion,\n  getPlacementName,\n  slideMotion,\n  zoomBigMotion,\n  DEFAULT_SUBMENU_POSITIONS,\n  InputBoolean,\n  NzMenuBaseService,\n  NzNoAnimationDirective,\n  NzUpdateHostClassService,\n  POSITION_MAP\n} from 'ng-zorro-antd/core';\n\nimport { NzMenuItemDirective } from './nz-menu-item.directive';\nimport { NzSubmenuService } from './nz-submenu.service';\n\n@Component({\n  selector: '[nz-submenu]',\n  exportAs: 'nzSubmenu',\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})\nexport class NzSubMenuComponent implements OnInit, OnDestroy, AfterContentInit, OnChanges {\n  @Input() nzMenuClassName: string;\n  @Input() nzPaddingLeft: number;\n  @Input() @InputBoolean() nzOpen = false;\n  @Input() @InputBoolean() nzDisabled = false;\n  @Output() readonly nzOpenChange: EventEmitter<boolean> = new EventEmitter();\n\n  @ViewChild(CdkConnectedOverlay) cdkConnectedOverlay: CdkConnectedOverlay;\n  @ViewChild(CdkOverlayOrigin, { read: ElementRef }) cdkOverlayOrigin: ElementRef;\n  @ContentChildren(NzSubMenuComponent, { descendants: true })\n  listOfNzSubMenuComponent: QueryList<NzSubMenuComponent>;\n  @ContentChildren(NzMenuItemDirective, { descendants: true })\n  listOfNzMenuItemDirective: QueryList<NzMenuItemDirective>;\n\n  placement = 'rightTop';\n  triggerWidth: number;\n  expandState = 'collapsed';\n  overlayPositions = [...DEFAULT_SUBMENU_POSITIONS];\n\n  private destroy$ = new Subject<void>();\n  private isChildMenuSelected = false;\n  private isMouseHover = false;\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.isMouseHover = value;\n    this.setClassMap();\n    this.nzSubmenuService.setMouseEnterState(value);\n  }\n\n  setTriggerWidth(): void {\n    if (this.nzSubmenuService.mode === 'horizontal' && this.platform.isBrowser) {\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      [`${prefixName}-active`]: this.isMouseHover && !this.nzDisabled\n    });\n  }\n\n  constructor(\n    private elementRef: ElementRef,\n    public nzMenuService: NzMenuBaseService,\n    private cdr: ChangeDetectorRef,\n    public nzSubmenuService: NzSubmenuService,\n    private nzUpdateHostClassService: NzUpdateHostClassService,\n    private platform: Platform,\n    @Host() @Optional() public noAnimation?: NzNoAnimationDirective\n  ) {}\n\n  ngOnInit(): void {\n    combineLatest(this.nzSubmenuService.mode$, this.nzSubmenuService.open$)\n      .pipe(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 =\n          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(takeUntil(this.destroy$)).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$\n    )\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        this.cdr.markForCheck();\n      });\n  }\n\n  ngAfterContentInit(): void {\n    this.setTriggerWidth();\n    this.listOfNzMenuItemDirective.changes\n      .pipe(\n        startWith(true),\n        flatMap(() =>\n          merge(this.listOfNzMenuItemDirective.changes, ...this.listOfNzMenuItemDirective.map(menu => menu.selected$))\n        ),\n        map(() => this.listOfNzMenuItemDirective.some(e => e.nzSelected)),\n        takeUntil(this.destroy$)\n      )\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"]}