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.
198 lines
21 KiB
198 lines
21 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 { Directive, Input, Optional, ElementRef, } from '@angular/core';
|
|
import { MatDialog } from './dialog';
|
|
import { _closeDialogVia, MatDialogRef } from './dialog-ref';
|
|
/** Counter used to generate unique IDs for dialog elements. */
|
|
import * as ɵngcc0 from '@angular/core';
|
|
import * as ɵngcc1 from './dialog-ref';
|
|
import * as ɵngcc2 from './dialog';
|
|
let dialogElementUid = 0;
|
|
/**
|
|
* Button that will close the current dialog.
|
|
*/
|
|
export class MatDialogClose {
|
|
constructor(
|
|
/**
|
|
* Reference to the containing dialog.
|
|
* @deprecated `dialogRef` property to become private.
|
|
* @breaking-change 13.0.0
|
|
*/
|
|
// The dialog title directive is always used in combination with a `MatDialogRef`.
|
|
// tslint:disable-next-line: lightweight-tokens
|
|
dialogRef, _elementRef, _dialog) {
|
|
this.dialogRef = dialogRef;
|
|
this._elementRef = _elementRef;
|
|
this._dialog = _dialog;
|
|
/** Default to "button" to prevents accidental form submits. */
|
|
this.type = 'button';
|
|
}
|
|
ngOnInit() {
|
|
if (!this.dialogRef) {
|
|
// When this directive is included in a dialog via TemplateRef (rather than being
|
|
// in a Component), the DialogRef isn't available via injection because embedded
|
|
// views cannot be given a custom injector. Instead, we look up the DialogRef by
|
|
// ID. This must occur in `onInit`, as the ID binding for the dialog container won't
|
|
// be resolved at constructor time.
|
|
this.dialogRef = getClosestDialog(this._elementRef, this._dialog.openDialogs);
|
|
}
|
|
}
|
|
ngOnChanges(changes) {
|
|
const proxiedChange = changes['_matDialogClose'] || changes['_matDialogCloseResult'];
|
|
if (proxiedChange) {
|
|
this.dialogResult = proxiedChange.currentValue;
|
|
}
|
|
}
|
|
_onButtonClick(event) {
|
|
// Determinate the focus origin using the click event, because using the FocusMonitor will
|
|
// result in incorrect origins. Most of the time, close buttons will be auto focused in the
|
|
// dialog, and therefore clicking the button won't result in a focus change. This means that
|
|
// the FocusMonitor won't detect any origin change, and will always output `program`.
|
|
_closeDialogVia(this.dialogRef, event.screenX === 0 && event.screenY === 0 ? 'keyboard' : 'mouse', this.dialogResult);
|
|
}
|
|
}
|
|
MatDialogClose.ɵfac = function MatDialogClose_Factory(t) { return new (t || MatDialogClose)(ɵngcc0.ɵɵdirectiveInject(ɵngcc1.MatDialogRef, 8), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ElementRef), ɵngcc0.ɵɵdirectiveInject(ɵngcc2.MatDialog)); };
|
|
MatDialogClose.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: MatDialogClose, selectors: [["", "mat-dialog-close", ""], ["", "matDialogClose", ""]], hostVars: 2, hostBindings: function MatDialogClose_HostBindings(rf, ctx) { if (rf & 1) {
|
|
ɵngcc0.ɵɵlistener("click", function MatDialogClose_click_HostBindingHandler($event) { return ctx._onButtonClick($event); });
|
|
} if (rf & 2) {
|
|
ɵngcc0.ɵɵattribute("aria-label", ctx.ariaLabel || null)("type", ctx.type);
|
|
} }, inputs: { type: "type", dialogResult: ["mat-dialog-close", "dialogResult"], ariaLabel: ["aria-label", "ariaLabel"], _matDialogClose: ["matDialogClose", "_matDialogClose"] }, exportAs: ["matDialogClose"], features: [ɵngcc0.ɵɵNgOnChangesFeature] });
|
|
MatDialogClose.ctorParameters = () => [
|
|
{ type: MatDialogRef, decorators: [{ type: Optional }] },
|
|
{ type: ElementRef },
|
|
{ type: MatDialog }
|
|
];
|
|
MatDialogClose.propDecorators = {
|
|
ariaLabel: [{ type: Input, args: ['aria-label',] }],
|
|
type: [{ type: Input }],
|
|
dialogResult: [{ type: Input, args: ['mat-dialog-close',] }],
|
|
_matDialogClose: [{ type: Input, args: ['matDialogClose',] }]
|
|
};
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatDialogClose, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: '[mat-dialog-close], [matDialogClose]',
|
|
exportAs: 'matDialogClose',
|
|
host: {
|
|
'(click)': '_onButtonClick($event)',
|
|
'[attr.aria-label]': 'ariaLabel || null',
|
|
'[attr.type]': 'type'
|
|
}
|
|
}]
|
|
}], function () { return [{ type: ɵngcc1.MatDialogRef, decorators: [{
|
|
type: Optional
|
|
}] }, { type: ɵngcc0.ElementRef }, { type: ɵngcc2.MatDialog }]; }, { type: [{
|
|
type: Input
|
|
}], dialogResult: [{
|
|
type: Input,
|
|
args: ['mat-dialog-close']
|
|
}], ariaLabel: [{
|
|
type: Input,
|
|
args: ['aria-label']
|
|
}], _matDialogClose: [{
|
|
type: Input,
|
|
args: ['matDialogClose']
|
|
}] }); })();
|
|
/**
|
|
* Title of a dialog element. Stays fixed to the top of the dialog when scrolling.
|
|
*/
|
|
export class MatDialogTitle {
|
|
constructor(
|
|
// The dialog title directive is always used in combination with a `MatDialogRef`.
|
|
// tslint:disable-next-line: lightweight-tokens
|
|
_dialogRef, _elementRef, _dialog) {
|
|
this._dialogRef = _dialogRef;
|
|
this._elementRef = _elementRef;
|
|
this._dialog = _dialog;
|
|
/** Unique id for the dialog title. If none is supplied, it will be auto-generated. */
|
|
this.id = `mat-dialog-title-${dialogElementUid++}`;
|
|
}
|
|
ngOnInit() {
|
|
if (!this._dialogRef) {
|
|
this._dialogRef = getClosestDialog(this._elementRef, this._dialog.openDialogs);
|
|
}
|
|
if (this._dialogRef) {
|
|
Promise.resolve().then(() => {
|
|
const container = this._dialogRef._containerInstance;
|
|
if (container && !container._ariaLabelledBy) {
|
|
container._ariaLabelledBy = this.id;
|
|
}
|
|
});
|
|
}
|
|
}
|
|
}
|
|
MatDialogTitle.ɵfac = function MatDialogTitle_Factory(t) { return new (t || MatDialogTitle)(ɵngcc0.ɵɵdirectiveInject(ɵngcc1.MatDialogRef, 8), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ElementRef), ɵngcc0.ɵɵdirectiveInject(ɵngcc2.MatDialog)); };
|
|
MatDialogTitle.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: MatDialogTitle, selectors: [["", "mat-dialog-title", ""], ["", "matDialogTitle", ""]], hostAttrs: [1, "mat-dialog-title"], hostVars: 1, hostBindings: function MatDialogTitle_HostBindings(rf, ctx) { if (rf & 2) {
|
|
ɵngcc0.ɵɵhostProperty("id", ctx.id);
|
|
} }, inputs: { id: "id" }, exportAs: ["matDialogTitle"] });
|
|
MatDialogTitle.ctorParameters = () => [
|
|
{ type: MatDialogRef, decorators: [{ type: Optional }] },
|
|
{ type: ElementRef },
|
|
{ type: MatDialog }
|
|
];
|
|
MatDialogTitle.propDecorators = {
|
|
id: [{ type: Input }]
|
|
};
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatDialogTitle, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: '[mat-dialog-title], [matDialogTitle]',
|
|
exportAs: 'matDialogTitle',
|
|
host: {
|
|
'class': 'mat-dialog-title',
|
|
'[id]': 'id'
|
|
}
|
|
}]
|
|
}], function () { return [{ type: ɵngcc1.MatDialogRef, decorators: [{
|
|
type: Optional
|
|
}] }, { type: ɵngcc0.ElementRef }, { type: ɵngcc2.MatDialog }]; }, { id: [{
|
|
type: Input
|
|
}] }); })();
|
|
/**
|
|
* Scrollable content container of a dialog.
|
|
*/
|
|
export class MatDialogContent {
|
|
}
|
|
MatDialogContent.ɵfac = function MatDialogContent_Factory(t) { return new (t || MatDialogContent)(); };
|
|
MatDialogContent.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: MatDialogContent, selectors: [["", "mat-dialog-content", ""], ["mat-dialog-content"], ["", "matDialogContent", ""]], hostAttrs: [1, "mat-dialog-content"] });
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatDialogContent, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: `[mat-dialog-content], mat-dialog-content, [matDialogContent]`,
|
|
host: { 'class': 'mat-dialog-content' }
|
|
}]
|
|
}], null, null); })();
|
|
/**
|
|
* Container for the bottom action buttons in a dialog.
|
|
* Stays fixed to the bottom when scrolling.
|
|
*/
|
|
export class MatDialogActions {
|
|
}
|
|
MatDialogActions.ɵfac = function MatDialogActions_Factory(t) { return new (t || MatDialogActions)(); };
|
|
MatDialogActions.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: MatDialogActions, selectors: [["", "mat-dialog-actions", ""], ["mat-dialog-actions"], ["", "matDialogActions", ""]], hostAttrs: [1, "mat-dialog-actions"] });
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatDialogActions, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: `[mat-dialog-actions], mat-dialog-actions, [matDialogActions]`,
|
|
host: { 'class': 'mat-dialog-actions' }
|
|
}]
|
|
}], null, null); })();
|
|
/**
|
|
* Finds the closest MatDialogRef to an element by looking at the DOM.
|
|
* @param element Element relative to which to look for a dialog.
|
|
* @param openDialogs References to the currently-open dialogs.
|
|
*/
|
|
function getClosestDialog(element, openDialogs) {
|
|
let parent = element.nativeElement.parentElement;
|
|
while (parent && !parent.classList.contains('mat-dialog-container')) {
|
|
parent = parent.parentElement;
|
|
}
|
|
return parent ? openDialogs.find(dialog => dialog.id === parent.id) : null;
|
|
}
|
|
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dialog-content-directives.js","sources":["../../../../../../src/material/dialog/dialog-content-directives.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 {\n  Directive,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  SimpleChanges,\n  ElementRef,\n} from '@angular/core';\nimport {MatDialog} from './dialog';\nimport {_closeDialogVia, MatDialogRef} from './dialog-ref';\n\n/** Counter used to generate unique IDs for dialog elements. */\nlet dialogElementUid = 0;\n\n/**\n * Button that will close the current dialog.\n */\n@Directive({\n  selector: '[mat-dialog-close], [matDialogClose]',\n  exportAs: 'matDialogClose',\n  host: {\n    '(click)': '_onButtonClick($event)',\n    '[attr.aria-label]': 'ariaLabel || null',\n    '[attr.type]': 'type',\n  }\n})\nexport class MatDialogClose implements OnInit, OnChanges {\n  /** Screenreader label for the button. */\n  @Input('aria-label') ariaLabel: string;\n\n  /** Default to \"button\" to prevents accidental form submits. */\n  @Input() type: 'submit' | 'button' | 'reset' = 'button';\n\n  /** Dialog close input. */\n  @Input('mat-dialog-close') dialogResult: any;\n\n  @Input('matDialogClose') _matDialogClose: any;\n\n  constructor(\n\n    /**\n     * Reference to the containing dialog.\n     * @deprecated `dialogRef` property to become private.\n     * @breaking-change 13.0.0\n     */\n    // The dialog title directive is always used in combination with a `MatDialogRef`.\n    // tslint:disable-next-line: lightweight-tokens\n    @Optional() public dialogRef: MatDialogRef<any>,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _dialog: MatDialog) {}\n\n  ngOnInit() {\n    if (!this.dialogRef) {\n      // When this directive is included in a dialog via TemplateRef (rather than being\n      // in a Component), the DialogRef isn't available via injection because embedded\n      // views cannot be given a custom injector. Instead, we look up the DialogRef by\n      // ID. This must occur in `onInit`, as the ID binding for the dialog container won't\n      // be resolved at constructor time.\n      this.dialogRef = getClosestDialog(this._elementRef, this._dialog.openDialogs)!;\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const proxiedChange = changes['_matDialogClose'] || changes['_matDialogCloseResult'];\n\n    if (proxiedChange) {\n      this.dialogResult = proxiedChange.currentValue;\n    }\n  }\n\n  _onButtonClick(event: MouseEvent) {\n    // Determinate the focus origin using the click event, because using the FocusMonitor will\n    // result in incorrect origins. Most of the time, close buttons will be auto focused in the\n    // dialog, and therefore clicking the button won't result in a focus change. This means that\n    // the FocusMonitor won't detect any origin change, and will always output `program`.\n    _closeDialogVia(this.dialogRef,\n        event.screenX === 0 && event.screenY === 0 ? 'keyboard' : 'mouse', this.dialogResult);\n  }\n}\n\n/**\n * Title of a dialog element. Stays fixed to the top of the dialog when scrolling.\n */\n@Directive({\n  selector: '[mat-dialog-title], [matDialogTitle]',\n  exportAs: 'matDialogTitle',\n  host: {\n    'class': 'mat-dialog-title',\n    '[id]': 'id',\n  },\n})\nexport class MatDialogTitle implements OnInit {\n  /** Unique id for the dialog title. If none is supplied, it will be auto-generated. */\n  @Input() id: string = `mat-dialog-title-${dialogElementUid++}`;\n\n  constructor(\n      // The dialog title directive is always used in combination with a `MatDialogRef`.\n      // tslint:disable-next-line: lightweight-tokens\n      @Optional() private _dialogRef: MatDialogRef<any>,\n      private _elementRef: ElementRef<HTMLElement>,\n      private _dialog: MatDialog) {}\n\n  ngOnInit() {\n    if (!this._dialogRef) {\n      this._dialogRef = getClosestDialog(this._elementRef, this._dialog.openDialogs)!;\n    }\n\n    if (this._dialogRef) {\n      Promise.resolve().then(() => {\n        const container = this._dialogRef._containerInstance;\n\n        if (container && !container._ariaLabelledBy) {\n          container._ariaLabelledBy = this.id;\n        }\n      });\n    }\n  }\n}\n\n\n/**\n * Scrollable content container of a dialog.\n */\n@Directive({\n  selector: `[mat-dialog-content], mat-dialog-content, [matDialogContent]`,\n  host: {'class': 'mat-dialog-content'}\n})\nexport class MatDialogContent {}\n\n\n/**\n * Container for the bottom action buttons in a dialog.\n * Stays fixed to the bottom when scrolling.\n */\n@Directive({\n  selector: `[mat-dialog-actions], mat-dialog-actions, [matDialogActions]`,\n  host: {'class': 'mat-dialog-actions'}\n})\nexport class MatDialogActions {}\n\n\n/**\n * Finds the closest MatDialogRef to an element by looking at the DOM.\n * @param element Element relative to which to look for a dialog.\n * @param openDialogs References to the currently-open dialogs.\n */\nfunction getClosestDialog(element: ElementRef<HTMLElement>, openDialogs: MatDialogRef<any>[]) {\n  let parent: HTMLElement | null = element.nativeElement.parentElement;\n\n  while (parent && !parent.classList.contains('mat-dialog-container')) {\n    parent = parent.parentElement;\n  }\n\n  return parent ? openDialogs.find(dialog => dialog.id === parent!.id) : null;\n}\n"]}
|