blob: 31861a52d358f6d875ea794693d00e14b3901c90 [file] [log] [blame]
/**
* @fileoverview added by tsickle
* Generated from: side-sheet.content-directives.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/* tslint:disable */
import { Directive, Input, Optional, ElementRef } from '@angular/core';
import { CovalentSideSheet } from './side-sheet';
import { _closeSideSheetVia, CovalentSideSheetRef } from './side-sheet-ref';
/**
* Counter used to generate unique IDs for dialog elements.
* @type {?}
*/
let dialogElementUid = 0;
/**
* Button that will close the current dialog.
*/
export class CovalentSideSheetClose {
/**
* @param {?} dialogRef
* @param {?} _elementRef
* @param {?} _dialog
*/
constructor(dialogRef, _elementRef, _dialog) {
this.dialogRef = dialogRef;
this._elementRef = _elementRef;
this._dialog = _dialog;
/**
* Default to "button" to prevents accidental form submits.
*/
this.type = 'button';
}
/**
* @return {?}
*/
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 = (/** @type {?} */ (getClosestDialog(this._elementRef, this._dialog.openSideSheets)));
}
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
/** @type {?} */
const proxiedChange = changes['_CovalentSideSheetClose'] || changes['_CovalentSideSheetCloseResult'];
if (proxiedChange) {
this.dialogResult = proxiedChange.currentValue;
}
}
/**
* @param {?} event
* @return {?}
*/
_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`.
_closeSideSheetVia(this.dialogRef, event.screenX === 0 && event.screenY === 0 ? 'keyboard' : 'mouse', this.dialogResult);
}
}
CovalentSideSheetClose.decorators = [
{ type: Directive, args: [{
selector: '[td-side-sheet-close], [CovalentSideSheetClose]',
exportAs: 'CovalentSideSheetClose',
host: {
'(click)': '_onButtonClick($event)',
'[attr.aria-label]': 'ariaLabel || null',
'[attr.type]': 'type',
},
},] }
];
/** @nocollapse */
CovalentSideSheetClose.ctorParameters = () => [
{ type: CovalentSideSheetRef, decorators: [{ type: Optional }] },
{ type: ElementRef },
{ type: CovalentSideSheet }
];
CovalentSideSheetClose.propDecorators = {
ariaLabel: [{ type: Input, args: ['aria-label',] }],
type: [{ type: Input }],
dialogResult: [{ type: Input, args: ['td-side-sheet-close',] }],
_CovalentSideSheetClose: [{ type: Input, args: ['CovalentSideSheetClose',] }]
};
if (false) {
/**
* Screenreader label for the button.
* @type {?}
*/
CovalentSideSheetClose.prototype.ariaLabel;
/**
* Default to "button" to prevents accidental form submits.
* @type {?}
*/
CovalentSideSheetClose.prototype.type;
/**
* Dialog close input.
* @type {?}
*/
CovalentSideSheetClose.prototype.dialogResult;
/** @type {?} */
CovalentSideSheetClose.prototype._CovalentSideSheetClose;
/** @type {?} */
CovalentSideSheetClose.prototype.dialogRef;
/**
* @type {?}
* @private
*/
CovalentSideSheetClose.prototype._elementRef;
/**
* @type {?}
* @private
*/
CovalentSideSheetClose.prototype._dialog;
}
/**
* Title of a side sheet element. Stays fixed to the top of the side sheet when scrolling.
*/
export class CovalentSideSheetTitle {
/**
* @param {?} _dialogRef
* @param {?} _elementRef
* @param {?} _dialog
*/
constructor(_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 = `td-side-sheet-title-${dialogElementUid++}`;
}
/**
* @return {?}
*/
ngOnInit() {
if (this._dialogRef) {
Promise.resolve().then((/**
* @return {?}
*/
() => {
/** @type {?} */
const container = this._dialogRef._containerInstance;
if (container && !container._ariaLabelledBy) {
container._ariaLabelledBy = this.id;
}
}));
}
else {
this._dialogRef = (/** @type {?} */ (getClosestDialog(this._elementRef, this._dialog.openSideSheets)));
}
}
}
CovalentSideSheetTitle.decorators = [
{ type: Directive, args: [{
selector: '[td-side-sheet-title], [CovalentSideSheetTitle]',
exportAs: 'CovalentSideSheetTitle',
host: {
'class': 'td-side-sheet-title',
'[id]': 'id',
},
},] }
];
/** @nocollapse */
CovalentSideSheetTitle.ctorParameters = () => [
{ type: CovalentSideSheetRef, decorators: [{ type: Optional }] },
{ type: ElementRef },
{ type: CovalentSideSheet }
];
CovalentSideSheetTitle.propDecorators = {
id: [{ type: Input }]
};
if (false) {
/**
* Unique id for the dialog title. If none is supplied, it will be auto-generated.
* @type {?}
*/
CovalentSideSheetTitle.prototype.id;
/**
* @type {?}
* @private
*/
CovalentSideSheetTitle.prototype._dialogRef;
/**
* @type {?}
* @private
*/
CovalentSideSheetTitle.prototype._elementRef;
/**
* @type {?}
* @private
*/
CovalentSideSheetTitle.prototype._dialog;
}
/**
* Scrollable content container of a dialog.
*/
export class CovalentSideSheetContent {
}
CovalentSideSheetContent.decorators = [
{ type: Directive, args: [{
selector: `[td-side-sheet-content], td-side-sheet-content, [CovalentSideSheetContent]`,
host: { class: 'td-side-sheet-content' },
},] }
];
/**
* Container for the bottom action buttons in a dialog.
* Stays fixed to the bottom when scrolling.
*/
export class CovalentSideSheetActions {
}
CovalentSideSheetActions.decorators = [
{ type: Directive, args: [{
selector: `[td-side-sheet-actions], td-side-sheet-actions, [CovalentSideSheetActions]`,
host: { class: 'td-side-sheet-actions' },
},] }
];
/**
* Container for the wrapper part of the dialog
*/
export class CovalentSideSheetWrapper {
}
CovalentSideSheetWrapper.decorators = [
{ type: Directive, args: [{
selector: `[td-side-sheet-wrapper], td-side-sheet-wrapper, [CovalentSideSheetWrapper]`,
host: { class: 'td-side-sheet-wrapper' },
},] }
];
/**
* Finds the closest CovalentSideSheetRef 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.
* @return {?}
*/
function getClosestDialog(element, openDialogs) {
/** @type {?} */
let parent = element.nativeElement.parentElement;
while (parent && !parent.classList.contains('td-side-sheet-container')) {
parent = parent.parentElement;
}
return parent ? openDialogs.find((/**
* @param {?} dialog
* @return {?}
*/
(dialog) => dialog.id === (/** @type {?} */ (parent)).id)) : null;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-sheet.content-directives.js","sourceRoot":"../../../../../src/platform/core/side-sheet/","sources":["side-sheet.content-directives.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable */\nimport { Directive, Input, OnChanges, OnInit, Optional, SimpleChanges, ElementRef } from '@angular/core';\nimport { CovalentSideSheet } from './side-sheet';\nimport { _closeSideSheetVia, CovalentSideSheetRef } from './side-sheet-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: '[td-side-sheet-close], [CovalentSideSheetClose]',\n  exportAs: 'CovalentSideSheetClose',\n  host: {\n    '(click)': '_onButtonClick($event)',\n    '[attr.aria-label]': 'ariaLabel || null',\n    '[attr.type]': 'type',\n  },\n})\nexport class CovalentSideSheetClose 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('td-side-sheet-close') dialogResult: any;\n\n  @Input('CovalentSideSheetClose') _CovalentSideSheetClose: any;\n\n  constructor(\n    @Optional() public dialogRef: CovalentSideSheetRef<any>,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _dialog: CovalentSideSheet,\n  ) {}\n\n  ngOnInit(): void {\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.openSideSheets)!;\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const proxiedChange = changes['_CovalentSideSheetClose'] || changes['_CovalentSideSheetCloseResult'];\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    _closeSideSheetVia(\n      this.dialogRef,\n      event.screenX === 0 && event.screenY === 0 ? 'keyboard' : 'mouse',\n      this.dialogResult,\n    );\n  }\n}\n\n/**\n * Title of a side sheet element. Stays fixed to the top of the side sheet when scrolling.\n */\n@Directive({\n  selector: '[td-side-sheet-title], [CovalentSideSheetTitle]',\n  exportAs: 'CovalentSideSheetTitle',\n  host: {\n    'class': 'td-side-sheet-title',\n    '[id]': 'id',\n  },\n})\nexport class CovalentSideSheetTitle implements OnInit {\n  /** Unique id for the dialog title. If none is supplied, it will be auto-generated. */\n  @Input() id: string = `td-side-sheet-title-${dialogElementUid++}`;\n\n  constructor(\n    // The dialog title directive is always used in combination with a `CovalentSideSheetRef`.\n    // tslint:disable-next-line: lightweight-tokens\n    @Optional() private _dialogRef: CovalentSideSheetRef<any>,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _dialog: CovalentSideSheet,\n  ) {}\n\n  ngOnInit(): void {\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    } else {\n      this._dialogRef = getClosestDialog(this._elementRef, this._dialog.openSideSheets)!;\n    }\n  }\n}\n\n/**\n * Scrollable content container of a dialog.\n */\n@Directive({\n  selector: `[td-side-sheet-content], td-side-sheet-content, [CovalentSideSheetContent]`,\n  host: { class: 'td-side-sheet-content' },\n})\nexport class CovalentSideSheetContent {}\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: `[td-side-sheet-actions], td-side-sheet-actions, [CovalentSideSheetActions]`,\n  host: { class: 'td-side-sheet-actions' },\n})\nexport class CovalentSideSheetActions {}\n\n/**\n * Container for the wrapper part of the dialog\n */\n@Directive({\n  selector: `[td-side-sheet-wrapper], td-side-sheet-wrapper, [CovalentSideSheetWrapper]`,\n  host: { class: 'td-side-sheet-wrapper' },\n})\nexport class CovalentSideSheetWrapper {}\n\n/**\n * Finds the closest CovalentSideSheetRef 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: CovalentSideSheetRef<any>[]) {\n  let parent: HTMLElement | null = element.nativeElement.parentElement;\n\n  while (parent && !parent.classList.contains('td-side-sheet-container')) {\n    parent = parent.parentElement;\n  }\n\n  return parent ? openDialogs.find((dialog) => dialog.id === parent!.id) : null;\n}\n"]}