You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
107 lines
14 KiB
107 lines
14 KiB
/**
|
|
* @license
|
|
* Copyright Google LLC 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://angular.io/license
|
|
*/
|
|
import { DomPortalOutlet, TemplatePortal } from '@angular/cdk/portal';
|
|
import { DOCUMENT } from '@angular/common';
|
|
import { ApplicationRef, ChangeDetectorRef, ComponentFactoryResolver, Directive, Inject, InjectionToken, Injector, TemplateRef, ViewContainerRef, } from '@angular/core';
|
|
import { Subject } from 'rxjs';
|
|
/**
|
|
* Injection token that can be used to reference instances of `MatMenuContent`. It serves
|
|
* as alternative token to the actual `MatMenuContent` class which could cause unnecessary
|
|
* retention of the class and its directive metadata.
|
|
*/
|
|
import * as ɵngcc0 from '@angular/core';
|
|
export const MAT_MENU_CONTENT = new InjectionToken('MatMenuContent');
|
|
export class _MatMenuContentBase {
|
|
constructor(_template, _componentFactoryResolver, _appRef, _injector, _viewContainerRef, _document, _changeDetectorRef) {
|
|
this._template = _template;
|
|
this._componentFactoryResolver = _componentFactoryResolver;
|
|
this._appRef = _appRef;
|
|
this._injector = _injector;
|
|
this._viewContainerRef = _viewContainerRef;
|
|
this._document = _document;
|
|
this._changeDetectorRef = _changeDetectorRef;
|
|
/** Emits when the menu content has been attached. */
|
|
this._attached = new Subject();
|
|
}
|
|
/**
|
|
* Attaches the content with a particular context.
|
|
* @docs-private
|
|
*/
|
|
attach(context = {}) {
|
|
if (!this._portal) {
|
|
this._portal = new TemplatePortal(this._template, this._viewContainerRef);
|
|
}
|
|
this.detach();
|
|
if (!this._outlet) {
|
|
this._outlet = new DomPortalOutlet(this._document.createElement('div'), this._componentFactoryResolver, this._appRef, this._injector);
|
|
}
|
|
const element = this._template.elementRef.nativeElement;
|
|
// Because we support opening the same menu from different triggers (which in turn have their
|
|
// own `OverlayRef` panel), we have to re-insert the host element every time, otherwise we
|
|
// risk it staying attached to a pane that's no longer in the DOM.
|
|
element.parentNode.insertBefore(this._outlet.outletElement, element);
|
|
// When `MatMenuContent` is used in an `OnPush` component, the insertion of the menu
|
|
// content via `createEmbeddedView` does not cause the content to be seen as "dirty"
|
|
// by Angular. This causes the `@ContentChildren` for menu items within the menu to
|
|
// not be updated by Angular. By explicitly marking for check here, we tell Angular that
|
|
// it needs to check for new menu items and update the `@ContentChild` in `MatMenu`.
|
|
// @breaking-change 9.0.0 Make change detector ref required
|
|
if (this._changeDetectorRef) {
|
|
this._changeDetectorRef.markForCheck();
|
|
}
|
|
this._portal.attach(this._outlet, context);
|
|
this._attached.next();
|
|
}
|
|
/**
|
|
* Detaches the content.
|
|
* @docs-private
|
|
*/
|
|
detach() {
|
|
if (this._portal.isAttached) {
|
|
this._portal.detach();
|
|
}
|
|
}
|
|
ngOnDestroy() {
|
|
if (this._outlet) {
|
|
this._outlet.dispose();
|
|
}
|
|
}
|
|
}
|
|
_MatMenuContentBase.ɵfac = function _MatMenuContentBase_Factory(t) { return new (t || _MatMenuContentBase)(ɵngcc0.ɵɵdirectiveInject(ɵngcc0.TemplateRef), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ComponentFactoryResolver), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ApplicationRef), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.Injector), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ViewContainerRef), ɵngcc0.ɵɵdirectiveInject(DOCUMENT), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ChangeDetectorRef)); };
|
|
_MatMenuContentBase.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: _MatMenuContentBase });
|
|
_MatMenuContentBase.ctorParameters = () => [
|
|
{ type: TemplateRef },
|
|
{ type: ComponentFactoryResolver },
|
|
{ type: ApplicationRef },
|
|
{ type: Injector },
|
|
{ type: ViewContainerRef },
|
|
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
|
|
{ type: ChangeDetectorRef }
|
|
];
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(_MatMenuContentBase, [{
|
|
type: Directive
|
|
}], function () { return [{ type: ɵngcc0.TemplateRef }, { type: ɵngcc0.ComponentFactoryResolver }, { type: ɵngcc0.ApplicationRef }, { type: ɵngcc0.Injector }, { type: ɵngcc0.ViewContainerRef }, { type: undefined, decorators: [{
|
|
type: Inject,
|
|
args: [DOCUMENT]
|
|
}] }, { type: ɵngcc0.ChangeDetectorRef }]; }, null); })();
|
|
/**
|
|
* Menu content that will be rendered lazily once the menu is opened.
|
|
*/
|
|
export class MatMenuContent extends _MatMenuContentBase {
|
|
}
|
|
MatMenuContent.ɵfac = /*@__PURE__*/ function () { let ɵMatMenuContent_BaseFactory; return function MatMenuContent_Factory(t) { return (ɵMatMenuContent_BaseFactory || (ɵMatMenuContent_BaseFactory = ɵngcc0.ɵɵgetInheritedFactory(MatMenuContent)))(t || MatMenuContent); }; }();
|
|
MatMenuContent.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: MatMenuContent, selectors: [["ng-template", "matMenuContent", ""]], features: [ɵngcc0.ɵɵProvidersFeature([{ provide: MAT_MENU_CONTENT, useExisting: MatMenuContent }]), ɵngcc0.ɵɵInheritDefinitionFeature] });
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatMenuContent, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: 'ng-template[matMenuContent]',
|
|
providers: [{ provide: MAT_MENU_CONTENT, useExisting: MatMenuContent }]
|
|
}]
|
|
}], null, null); })();
|
|
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"menu-content.js","sources":["../../../../../../src/material/menu/menu-content.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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://angular.io/license\n */\n\nimport {DomPortalOutlet, TemplatePortal} from '@angular/cdk/portal';\nimport {DOCUMENT} from '@angular/common';\nimport {\n  ApplicationRef,\n  ChangeDetectorRef,\n  ComponentFactoryResolver,\n  Directive,\n  Inject,\n  InjectionToken,\n  Injector,\n  OnDestroy,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport {Subject} from 'rxjs';\n\n/**\n * Injection token that can be used to reference instances of `MatMenuContent`. It serves\n * as alternative token to the actual `MatMenuContent` class which could cause unnecessary\n * retention of the class and its directive metadata.\n */\nexport const MAT_MENU_CONTENT = new InjectionToken<MatMenuContent>('MatMenuContent');\n\n@Directive()\nexport abstract class _MatMenuContentBase implements OnDestroy {\n  private _portal: TemplatePortal<any>;\n  private _outlet: DomPortalOutlet;\n\n  /** Emits when the menu content has been attached. */\n  readonly _attached = new Subject<void>();\n\n  constructor(\n    private _template: TemplateRef<any>,\n    private _componentFactoryResolver: ComponentFactoryResolver,\n    private _appRef: ApplicationRef,\n    private _injector: Injector,\n    private _viewContainerRef: ViewContainerRef,\n    @Inject(DOCUMENT) private _document: any,\n    private _changeDetectorRef?: ChangeDetectorRef) {}\n\n  /**\n   * Attaches the content with a particular context.\n   * @docs-private\n   */\n  attach(context: any = {}) {\n    if (!this._portal) {\n      this._portal = new TemplatePortal(this._template, this._viewContainerRef);\n    }\n\n    this.detach();\n\n    if (!this._outlet) {\n      this._outlet = new DomPortalOutlet(this._document.createElement('div'),\n          this._componentFactoryResolver, this._appRef, this._injector);\n    }\n\n    const element: HTMLElement = this._template.elementRef.nativeElement;\n\n    // Because we support opening the same menu from different triggers (which in turn have their\n    // own `OverlayRef` panel), we have to re-insert the host element every time, otherwise we\n    // risk it staying attached to a pane that's no longer in the DOM.\n    element.parentNode!.insertBefore(this._outlet.outletElement, element);\n\n    // When `MatMenuContent` is used in an `OnPush` component, the insertion of the menu\n    // content via `createEmbeddedView` does not cause the content to be seen as \"dirty\"\n    // by Angular. This causes the `@ContentChildren` for menu items within the menu to\n    // not be updated by Angular. By explicitly marking for check here, we tell Angular that\n    // it needs to check for new menu items and update the `@ContentChild` in `MatMenu`.\n    // @breaking-change 9.0.0 Make change detector ref required\n    if (this._changeDetectorRef) {\n      this._changeDetectorRef.markForCheck();\n    }\n\n    this._portal.attach(this._outlet, context);\n    this._attached.next();\n  }\n\n  /**\n   * Detaches the content.\n   * @docs-private\n   */\n  detach() {\n    if (this._portal.isAttached) {\n      this._portal.detach();\n    }\n  }\n\n  ngOnDestroy() {\n    if (this._outlet) {\n      this._outlet.dispose();\n    }\n  }\n}\n\n/**\n * Menu content that will be rendered lazily once the menu is opened.\n */\n@Directive({\n  selector: 'ng-template[matMenuContent]',\n  providers: [{provide: MAT_MENU_CONTENT, useExisting: MatMenuContent}],\n})\nexport class MatMenuContent extends _MatMenuContentBase {}\n"]}
|