UNPKG

@covalent/core

Version:

Core Teradata UI Platform for layouts, icons, custom components and themes. This should be added as a dependency for any project that wants to use layouts, icons and themes for Angular Material.

201 lines 24.1 kB
/* tslint:disable */ import { Directive, Input, Optional, ElementRef, HostBinding, HostListener, } from '@angular/core'; import { CovalentSideSheet } from './side-sheet'; import { _closeSideSheetVia, CovalentSideSheetRef } from './side-sheet-ref'; import * as i0 from "@angular/core"; import * as i1 from "./side-sheet-ref"; import * as i2 from "./side-sheet"; /** Counter used to generate unique IDs for dialog elements. */ let dialogElementUid = 0; /** * Button that will close the current dialog. */ export class CovalentSideSheetCloseDirective { constructor(dialogRef, _elementRef, _dialog) { this.dialogRef = dialogRef; this._elementRef = _elementRef; this._dialog = _dialog; /** Default to "button" to prevents accidental form submits. */ this.type = 'button'; } onClick($event) { this._onButtonClick($event); } 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.openSideSheets); } } ngOnChanges(changes) { const proxiedChange = changes['_CovalentSideSheetClose'] || changes['_CovalentSideSheetCloseResult']; 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`. _closeSideSheetVia(this.dialogRef, event.screenX === 0 && event.screenY === 0 ? 'keyboard' : 'mouse', this.dialogResult); } } CovalentSideSheetCloseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentSideSheetCloseDirective, deps: [{ token: i1.CovalentSideSheetRef, optional: true }, { token: i0.ElementRef }, { token: i2.CovalentSideSheet }], target: i0.ɵɵFactoryTarget.Directive }); CovalentSideSheetCloseDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.2", type: CovalentSideSheetCloseDirective, selector: "[td-side-sheet-close], [CovalentSideSheetClose]", inputs: { ariaLabel: ["aria-label", "ariaLabel"], type: "type", dialogResult: ["td-side-sheet-close", "dialogResult"], _CovalentSideSheetClose: ["CovalentSideSheetClose", "_CovalentSideSheetClose"] }, host: { listeners: { "click": "onClick($event)" }, properties: { "attr.arial-label": "this.ariaLabel", "attr.type": "this.type" } }, exportAs: ["CovalentSideSheetClose"], usesOnChanges: true, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentSideSheetCloseDirective, decorators: [{ type: Directive, args: [{ selector: '[td-side-sheet-close], [CovalentSideSheetClose]', exportAs: 'CovalentSideSheetClose', }] }], ctorParameters: function () { return [{ type: i1.CovalentSideSheetRef, decorators: [{ type: Optional }] }, { type: i0.ElementRef }, { type: i2.CovalentSideSheet }]; }, propDecorators: { ariaLabel: [{ type: HostBinding, args: ['attr.arial-label'] }, { type: Input, args: ['aria-label'] }], type: [{ type: HostBinding, args: ['attr.type'] }, { type: Input }], dialogResult: [{ type: Input, args: ['td-side-sheet-close'] }], _CovalentSideSheetClose: [{ type: Input, args: ['CovalentSideSheetClose'] }], onClick: [{ type: HostListener, args: ['click', ['$event']] }] } }); /** * Title of a side sheet element. Stays fixed to the top of the side sheet when scrolling. */ export class CovalentSideSheetTitleDirective { constructor( // The dialog title directive is always used in combination with a `CovalentSideSheetRef`. // 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 = `td-side-sheet-title-${dialogElementUid++}`; this.tdSideSheetTitle = true; this.idAttr = this.id; } ngOnInit() { if (this._dialogRef) { Promise.resolve().then(() => { const container = this._dialogRef._containerInstance; if (container && !container._ariaLabelledBy) { container._ariaLabelledBy = this.id; } }); } else { this._dialogRef = getClosestDialog(this._elementRef, this._dialog.openSideSheets); } } } CovalentSideSheetTitleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentSideSheetTitleDirective, deps: [{ token: i1.CovalentSideSheetRef, optional: true }, { token: i0.ElementRef }, { token: i2.CovalentSideSheet }], target: i0.ɵɵFactoryTarget.Directive }); CovalentSideSheetTitleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.2", type: CovalentSideSheetTitleDirective, selector: "[td-side-sheet-title], [CovalentSideSheetTitle]", inputs: { id: "id" }, host: { properties: { "class.td-side-sheet-title": "this.tdSideSheetTitle", "attr.id": "this.idAttr" } }, exportAs: ["CovalentSideSheetTitle"], ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentSideSheetTitleDirective, decorators: [{ type: Directive, args: [{ selector: '[td-side-sheet-title], [CovalentSideSheetTitle]', exportAs: 'CovalentSideSheetTitle', }] }], ctorParameters: function () { return [{ type: i1.CovalentSideSheetRef, decorators: [{ type: Optional }] }, { type: i0.ElementRef }, { type: i2.CovalentSideSheet }]; }, propDecorators: { id: [{ type: Input }], tdSideSheetTitle: [{ type: HostBinding, args: ['class.td-side-sheet-title'] }], idAttr: [{ type: HostBinding, args: ['attr.id'] }] } }); /** * Scrollable content container of a dialog. */ export class CovalentSideSheetContentDirective { constructor() { this.tdSideSheetContent = true; } } CovalentSideSheetContentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentSideSheetContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); CovalentSideSheetContentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.2", type: CovalentSideSheetContentDirective, selector: "[td-side-sheet-content], td-side-sheet-content, [CovalentSideSheetContent]", host: { properties: { "class.td-side-sheet-content": "this.tdSideSheetContent" } }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentSideSheetContentDirective, decorators: [{ type: Directive, args: [{ selector: `[td-side-sheet-content], td-side-sheet-content, [CovalentSideSheetContent]`, }] }], propDecorators: { tdSideSheetContent: [{ type: HostBinding, args: ['class.td-side-sheet-content'] }] } }); /** * Container for the bottom action buttons in a dialog. * Stays fixed to the bottom when scrolling. */ export class CovalentSideSheetActionsDirective { constructor() { this.tdSideSheetActions = true; } } CovalentSideSheetActionsDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentSideSheetActionsDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); CovalentSideSheetActionsDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.2", type: CovalentSideSheetActionsDirective, selector: "[td-side-sheet-actions], td-side-sheet-actions, [CovalentSideSheetActions]", host: { properties: { "class.td-side-sheet-actions": "this.tdSideSheetActions" } }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentSideSheetActionsDirective, decorators: [{ type: Directive, args: [{ selector: `[td-side-sheet-actions], td-side-sheet-actions, [CovalentSideSheetActions]`, }] }], propDecorators: { tdSideSheetActions: [{ type: HostBinding, args: ['class.td-side-sheet-actions'] }] } }); /** * Container for the wrapper part of the dialog */ export class CovalentSideSheetWrapperDirective { constructor() { this.tdSideSheetWrapper = true; } } CovalentSideSheetWrapperDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentSideSheetWrapperDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); CovalentSideSheetWrapperDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.2", type: CovalentSideSheetWrapperDirective, selector: "[td-side-sheet-wrapper], td-side-sheet-wrapper, [CovalentSideSheetWrapper]", host: { properties: { "class.td-side-sheet-wrapper": "this.tdSideSheetWrapper" } }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentSideSheetWrapperDirective, decorators: [{ type: Directive, args: [{ selector: `[td-side-sheet-wrapper], td-side-sheet-wrapper, [CovalentSideSheetWrapper]`, }] }], propDecorators: { tdSideSheetWrapper: [{ type: HostBinding, args: ['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. */ function getClosestDialog(element, openDialogs) { let parent = element.nativeElement.parentElement; while (parent && !parent.classList.contains('td-side-sheet-container')) { parent = parent.parentElement; } return parent ? openDialogs.find((dialog) => dialog.id === parent?.id) ?? openDialogs[0] : openDialogs[0]; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-sheet.content-directives.js","sourceRoot":"","sources":["../../../../../libs/angular/side-sheet/src/side-sheet.content-directives.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable */\nimport {\n  Directive,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  SimpleChanges,\n  ElementRef,\n  HostBinding,\n  HostListener,\n} 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})\nexport class CovalentSideSheetCloseDirective implements OnInit, OnChanges {\n  /** Screenreader label for the button. */\n  @HostBinding('attr.arial-label')\n  @Input('aria-label')\n  ariaLabel?: string;\n\n  /** Default to \"button\" to prevents accidental form submits. */\n  @HostBinding('attr.type')\n  @Input()\n  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  @HostListener('click', ['$event']) onClick($event: MouseEvent) {\n    this._onButtonClick($event);\n  }\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(\n        this._elementRef,\n        this._dialog.openSideSheets\n      );\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const proxiedChange =\n      changes['_CovalentSideSheetClose'] ||\n      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})\nexport class CovalentSideSheetTitleDirective implements OnInit {\n  /** Unique id for the dialog title. If none is supplied, it will be auto-generated. */\n  @Input() id = `td-side-sheet-title-${dialogElementUid++}`;\n\n  @HostBinding('class.td-side-sheet-title') tdSideSheetTitle = true;\n\n  @HostBinding('attr.id') idAttr = this.id;\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(\n        this._elementRef,\n        this._dialog.openSideSheets\n      );\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})\nexport class CovalentSideSheetContentDirective {\n  @HostBinding('class.td-side-sheet-content') tdSideSheetContent = true;\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: `[td-side-sheet-actions], td-side-sheet-actions, [CovalentSideSheetActions]`,\n})\nexport class CovalentSideSheetActionsDirective {\n  @HostBinding('class.td-side-sheet-actions') tdSideSheetActions = true;\n}\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})\nexport class CovalentSideSheetWrapperDirective {\n  @HostBinding('class.td-side-sheet-wrapper') tdSideSheetWrapper = true;\n}\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(\n  element: ElementRef<HTMLElement>,\n  openDialogs: CovalentSideSheetRef<any>[]\n): 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\n    ? openDialogs.find((dialog) => dialog.id === parent?.id) ?? openDialogs[0]\n    : openDialogs[0];\n}\n"]}