ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
312 lines • 28.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: menu.directive.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __decorate, __metadata, __read } 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 { ChangeDetectorRef, ContentChildren, Directive, EventEmitter, Inject, Input, Optional, Output, QueryList, SkipSelf } from '@angular/core';
import { InputBoolean } from 'ng-zorro-antd/core/util';
import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { NzMenuItemDirective } from './menu-item.directive';
import { MenuService } from './menu.service';
import { NzIsMenuInsideDropDownToken, NzMenuServiceLocalToken } from './menu.token';
import { NzSubMenuComponent } from './submenu.component';
/**
* @param {?} serviceInsideDropDown
* @param {?} serviceOutsideDropDown
* @return {?}
*/
export function MenuServiceFactory(serviceInsideDropDown, serviceOutsideDropDown) {
return serviceInsideDropDown ? serviceInsideDropDown : serviceOutsideDropDown;
}
/**
* @param {?} isMenuInsideDropDownToken
* @return {?}
*/
export function MenuDropDownTokenFactory(isMenuInsideDropDownToken) {
return isMenuInsideDropDownToken ? isMenuInsideDropDownToken : false;
}
var NzMenuDirective = /** @class */ (function () {
function NzMenuDirective(nzMenuService, isMenuInsideDropDown, cdr) {
this.nzMenuService = nzMenuService;
this.isMenuInsideDropDown = isMenuInsideDropDown;
this.cdr = cdr;
this.nzInlineIndent = 24;
this.nzTheme = 'light';
this.nzMode = 'vertical';
this.nzInlineCollapsed = false;
this.nzSelectable = !this.isMenuInsideDropDown;
this.nzClick = new EventEmitter();
this.actualMode = 'vertical';
this.inlineCollapsed$ = new BehaviorSubject(this.nzInlineCollapsed);
this.mode$ = new BehaviorSubject(this.nzMode);
this.destroy$ = new Subject();
this.listOfOpenedNzSubMenuComponent = [];
}
/**
* @param {?} inlineCollapsed
* @return {?}
*/
NzMenuDirective.prototype.setInlineCollapsed = /**
* @param {?} inlineCollapsed
* @return {?}
*/
function (inlineCollapsed) {
this.nzInlineCollapsed = inlineCollapsed;
this.inlineCollapsed$.next(inlineCollapsed);
};
/**
* @return {?}
*/
NzMenuDirective.prototype.updateInlineCollapse = /**
* @return {?}
*/
function () {
if (this.listOfNzMenuItemDirective) {
if (this.nzInlineCollapsed) {
this.listOfOpenedNzSubMenuComponent = this.listOfNzSubMenuComponent.filter((/**
* @param {?} submenu
* @return {?}
*/
function (submenu) { return submenu.nzOpen; }));
this.listOfNzSubMenuComponent.forEach((/**
* @param {?} submenu
* @return {?}
*/
function (submenu) { return submenu.setOpenStateWithoutDebounce(false); }));
}
else {
this.listOfOpenedNzSubMenuComponent.forEach((/**
* @param {?} submenu
* @return {?}
*/
function (submenu) { return submenu.setOpenStateWithoutDebounce(true); }));
this.listOfOpenedNzSubMenuComponent = [];
}
}
};
/**
* @return {?}
*/
NzMenuDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
combineLatest([this.inlineCollapsed$, this.mode$])
.pipe(takeUntil(this.destroy$))
.subscribe((/**
* @param {?} __0
* @return {?}
*/
function (_a) {
var _b = __read(_a, 2), inlineCollapsed = _b[0], mode = _b[1];
_this.actualMode = inlineCollapsed ? 'vertical' : mode;
_this.nzMenuService.setMode(_this.actualMode);
_this.cdr.markForCheck();
}));
this.nzMenuService.descendantMenuItemClick$.pipe(takeUntil(this.destroy$)).subscribe((/**
* @param {?} menu
* @return {?}
*/
function (menu) {
_this.nzClick.emit(menu);
if (_this.nzSelectable && !menu.nzMatchRouter) {
_this.listOfNzMenuItemDirective.forEach((/**
* @param {?} item
* @return {?}
*/
function (item) { return item.setSelectedState(item === menu); }));
}
}));
};
/**
* @return {?}
*/
NzMenuDirective.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
var _this = this;
this.inlineCollapsed$.pipe(takeUntil(this.destroy$)).subscribe((/**
* @return {?}
*/
function () {
_this.updateInlineCollapse();
_this.cdr.markForCheck();
}));
};
/**
* @param {?} changes
* @return {?}
*/
NzMenuDirective.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
var nzInlineCollapsed = changes.nzInlineCollapsed, nzInlineIndent = changes.nzInlineIndent, nzTheme = changes.nzTheme, nzMode = changes.nzMode;
if (nzInlineCollapsed) {
this.inlineCollapsed$.next(this.nzInlineCollapsed);
}
if (nzInlineIndent) {
this.nzMenuService.setInlineIndent(this.nzInlineIndent);
}
if (nzTheme) {
this.nzMenuService.setTheme(this.nzTheme);
}
if (nzMode) {
this.mode$.next(this.nzMode);
if (!changes.nzMode.isFirstChange() && this.listOfNzSubMenuComponent) {
this.listOfNzSubMenuComponent.forEach((/**
* @param {?} submenu
* @return {?}
*/
function (submenu) { return submenu.setOpenStateWithoutDebounce(false); }));
}
}
};
/**
* @return {?}
*/
NzMenuDirective.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.destroy$.next();
this.destroy$.complete();
};
NzMenuDirective.decorators = [
{ type: Directive, args: [{
selector: '[nz-menu]',
exportAs: 'nzMenu',
providers: [
{
provide: NzMenuServiceLocalToken,
useClass: MenuService
},
/** use the top level service **/
{
provide: MenuService,
useFactory: MenuServiceFactory,
deps: [[new SkipSelf(), new Optional(), MenuService], NzMenuServiceLocalToken]
},
/** check if menu inside dropdown-menu component **/
{
provide: NzIsMenuInsideDropDownToken,
useFactory: MenuDropDownTokenFactory,
deps: [[new SkipSelf(), new Optional(), NzIsMenuInsideDropDownToken]]
}
],
host: {
'[class.ant-dropdown-menu]': "isMenuInsideDropDown",
'[class.ant-dropdown-menu-root]': "isMenuInsideDropDown",
'[class.ant-dropdown-menu-light]': "isMenuInsideDropDown && nzTheme === 'light'",
'[class.ant-dropdown-menu-dark]': "isMenuInsideDropDown && nzTheme === 'dark'",
'[class.ant-dropdown-menu-vertical]': "isMenuInsideDropDown && actualMode === 'vertical'",
'[class.ant-dropdown-menu-horizontal]': "isMenuInsideDropDown && actualMode === 'horizontal'",
'[class.ant-dropdown-menu-inline]': "isMenuInsideDropDown && actualMode === 'inline'",
'[class.ant-dropdown-menu-inline-collapsed]': "isMenuInsideDropDown && nzInlineCollapsed",
'[class.ant-menu]': "!isMenuInsideDropDown",
'[class.ant-menu-root]': "!isMenuInsideDropDown",
'[class.ant-menu-light]': "!isMenuInsideDropDown && nzTheme === 'light'",
'[class.ant-menu-dark]': "!isMenuInsideDropDown && nzTheme === 'dark'",
'[class.ant-menu-vertical]': "!isMenuInsideDropDown && actualMode === 'vertical'",
'[class.ant-menu-horizontal]': "!isMenuInsideDropDown && actualMode === 'horizontal'",
'[class.ant-menu-inline]': "!isMenuInsideDropDown && actualMode === 'inline'",
'[class.ant-menu-inline-collapsed]': "!isMenuInsideDropDown && nzInlineCollapsed"
}
},] }
];
/** @nocollapse */
NzMenuDirective.ctorParameters = function () { return [
{ type: MenuService },
{ type: Boolean, decorators: [{ type: Inject, args: [NzIsMenuInsideDropDownToken,] }] },
{ type: ChangeDetectorRef }
]; };
NzMenuDirective.propDecorators = {
listOfNzMenuItemDirective: [{ type: ContentChildren, args: [NzMenuItemDirective, { descendants: true },] }],
listOfNzSubMenuComponent: [{ type: ContentChildren, args: [NzSubMenuComponent, { descendants: true },] }],
nzInlineIndent: [{ type: Input }],
nzTheme: [{ type: Input }],
nzMode: [{ type: Input }],
nzInlineCollapsed: [{ type: Input }],
nzSelectable: [{ type: Input }],
nzClick: [{ type: Output }]
};
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzMenuDirective.prototype, "nzInlineCollapsed", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzMenuDirective.prototype, "nzSelectable", void 0);
return NzMenuDirective;
}());
export { NzMenuDirective };
if (false) {
/** @type {?} */
NzMenuDirective.ngAcceptInputType_nzInlineCollapsed;
/** @type {?} */
NzMenuDirective.ngAcceptInputType_nzSelectable;
/** @type {?} */
NzMenuDirective.prototype.listOfNzMenuItemDirective;
/** @type {?} */
NzMenuDirective.prototype.listOfNzSubMenuComponent;
/** @type {?} */
NzMenuDirective.prototype.nzInlineIndent;
/** @type {?} */
NzMenuDirective.prototype.nzTheme;
/** @type {?} */
NzMenuDirective.prototype.nzMode;
/** @type {?} */
NzMenuDirective.prototype.nzInlineCollapsed;
/** @type {?} */
NzMenuDirective.prototype.nzSelectable;
/** @type {?} */
NzMenuDirective.prototype.nzClick;
/** @type {?} */
NzMenuDirective.prototype.actualMode;
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.inlineCollapsed$;
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.mode$;
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.destroy$;
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.listOfOpenedNzSubMenuComponent;
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.nzMenuService;
/** @type {?} */
NzMenuDirective.prototype.isMenuInsideDropDown;
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.directive.js","sourceRoot":"ng://ng-zorro-antd/menu/","sources":["menu.directive.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 {\n  AfterContentInit,\n  ChangeDetectorRef,\n  ContentChildren,\n  Directive,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges,\n  SkipSelf\n} from '@angular/core';\nimport { BooleanInput } from 'ng-zorro-antd/core/types';\nimport { InputBoolean } from 'ng-zorro-antd/core/util';\nimport { BehaviorSubject, combineLatest, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { NzMenuItemDirective } from './menu-item.directive';\nimport { MenuService } from './menu.service';\nimport { NzIsMenuInsideDropDownToken, NzMenuServiceLocalToken } from './menu.token';\nimport { NzMenuModeType, NzMenuThemeType } from './menu.types';\nimport { NzSubMenuComponent } from './submenu.component';\n\nexport function MenuServiceFactory(serviceInsideDropDown: MenuService, serviceOutsideDropDown: MenuService): MenuService {\n  return serviceInsideDropDown ? serviceInsideDropDown : serviceOutsideDropDown;\n}\nexport function MenuDropDownTokenFactory(isMenuInsideDropDownToken: boolean): boolean {\n  return isMenuInsideDropDownToken ? isMenuInsideDropDownToken : false;\n}\n\n@Directive({\n  selector: '[nz-menu]',\n  exportAs: 'nzMenu',\n  providers: [\n    {\n      provide: NzMenuServiceLocalToken,\n      useClass: MenuService\n    },\n    /** use the top level service **/\n    {\n      provide: MenuService,\n      useFactory: MenuServiceFactory,\n      deps: [[new SkipSelf(), new Optional(), MenuService], NzMenuServiceLocalToken]\n    },\n    /** check if menu inside dropdown-menu component **/\n    {\n      provide: NzIsMenuInsideDropDownToken,\n      useFactory: MenuDropDownTokenFactory,\n      deps: [[new SkipSelf(), new Optional(), NzIsMenuInsideDropDownToken]]\n    }\n  ],\n  host: {\n    '[class.ant-dropdown-menu]': `isMenuInsideDropDown`,\n    '[class.ant-dropdown-menu-root]': `isMenuInsideDropDown`,\n    '[class.ant-dropdown-menu-light]': `isMenuInsideDropDown && nzTheme === 'light'`,\n    '[class.ant-dropdown-menu-dark]': `isMenuInsideDropDown && nzTheme === 'dark'`,\n    '[class.ant-dropdown-menu-vertical]': `isMenuInsideDropDown && actualMode === 'vertical'`,\n    '[class.ant-dropdown-menu-horizontal]': `isMenuInsideDropDown && actualMode === 'horizontal'`,\n    '[class.ant-dropdown-menu-inline]': `isMenuInsideDropDown && actualMode === 'inline'`,\n    '[class.ant-dropdown-menu-inline-collapsed]': `isMenuInsideDropDown && nzInlineCollapsed`,\n    '[class.ant-menu]': `!isMenuInsideDropDown`,\n    '[class.ant-menu-root]': `!isMenuInsideDropDown`,\n    '[class.ant-menu-light]': `!isMenuInsideDropDown && nzTheme === 'light'`,\n    '[class.ant-menu-dark]': `!isMenuInsideDropDown && nzTheme === 'dark'`,\n    '[class.ant-menu-vertical]': `!isMenuInsideDropDown && actualMode === 'vertical'`,\n    '[class.ant-menu-horizontal]': `!isMenuInsideDropDown && actualMode === 'horizontal'`,\n    '[class.ant-menu-inline]': `!isMenuInsideDropDown && actualMode === 'inline'`,\n    '[class.ant-menu-inline-collapsed]': `!isMenuInsideDropDown && nzInlineCollapsed`\n  }\n})\nexport class NzMenuDirective implements AfterContentInit, OnInit, OnChanges, OnDestroy {\n  static ngAcceptInputType_nzInlineCollapsed: BooleanInput;\n  static ngAcceptInputType_nzSelectable: BooleanInput;\n\n  @ContentChildren(NzMenuItemDirective, { descendants: true }) listOfNzMenuItemDirective: QueryList<NzMenuItemDirective>;\n  @ContentChildren(NzSubMenuComponent, { descendants: true }) listOfNzSubMenuComponent: QueryList<NzSubMenuComponent>;\n  @Input() nzInlineIndent = 24;\n  @Input() nzTheme: NzMenuThemeType = 'light';\n  @Input() nzMode: NzMenuModeType = 'vertical';\n  @Input() @InputBoolean() nzInlineCollapsed = false;\n  @Input() @InputBoolean() nzSelectable = !this.isMenuInsideDropDown;\n  @Output() readonly nzClick = new EventEmitter<NzMenuItemDirective>();\n  actualMode: NzMenuModeType = 'vertical';\n  private inlineCollapsed$ = new BehaviorSubject<boolean>(this.nzInlineCollapsed);\n  private mode$ = new BehaviorSubject<NzMenuModeType>(this.nzMode);\n  private destroy$ = new Subject();\n  private listOfOpenedNzSubMenuComponent: NzSubMenuComponent[] = [];\n\n  setInlineCollapsed(inlineCollapsed: boolean): void {\n    this.nzInlineCollapsed = inlineCollapsed;\n    this.inlineCollapsed$.next(inlineCollapsed);\n  }\n\n  updateInlineCollapse(): void {\n    if (this.listOfNzMenuItemDirective) {\n      if (this.nzInlineCollapsed) {\n        this.listOfOpenedNzSubMenuComponent = this.listOfNzSubMenuComponent.filter(submenu => submenu.nzOpen);\n        this.listOfNzSubMenuComponent.forEach(submenu => submenu.setOpenStateWithoutDebounce(false));\n      } else {\n        this.listOfOpenedNzSubMenuComponent.forEach(submenu => submenu.setOpenStateWithoutDebounce(true));\n        this.listOfOpenedNzSubMenuComponent = [];\n      }\n    }\n  }\n\n  constructor(\n    private nzMenuService: MenuService,\n    @Inject(NzIsMenuInsideDropDownToken) public isMenuInsideDropDown: boolean,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    combineLatest([this.inlineCollapsed$, this.mode$])\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(([inlineCollapsed, mode]) => {\n        this.actualMode = inlineCollapsed ? 'vertical' : mode;\n        this.nzMenuService.setMode(this.actualMode);\n        this.cdr.markForCheck();\n      });\n    this.nzMenuService.descendantMenuItemClick$.pipe(takeUntil(this.destroy$)).subscribe(menu => {\n      this.nzClick.emit(menu);\n      if (this.nzSelectable && !menu.nzMatchRouter) {\n        this.listOfNzMenuItemDirective.forEach(item => item.setSelectedState(item === menu));\n      }\n    });\n  }\n\n  ngAfterContentInit(): void {\n    this.inlineCollapsed$.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.updateInlineCollapse();\n      this.cdr.markForCheck();\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { nzInlineCollapsed, nzInlineIndent, nzTheme, nzMode } = changes;\n    if (nzInlineCollapsed) {\n      this.inlineCollapsed$.next(this.nzInlineCollapsed);\n    }\n    if (nzInlineIndent) {\n      this.nzMenuService.setInlineIndent(this.nzInlineIndent);\n    }\n    if (nzTheme) {\n      this.nzMenuService.setTheme(this.nzTheme);\n    }\n    if (nzMode) {\n      this.mode$.next(this.nzMode);\n      if (!changes.nzMode.isFirstChange() && this.listOfNzSubMenuComponent) {\n        this.listOfNzSubMenuComponent.forEach(submenu => submenu.setOpenStateWithoutDebounce(false));\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}