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.

84 lines 16.9 kB
import { Component, ViewChild, ElementRef, NgZone, } from '@angular/core'; import { MatDialogRef } from '@angular/material/dialog'; import { LEFT_ARROW, RIGHT_ARROW } from '@angular/cdk/keycodes'; import { fromEvent, Subject, takeUntil } from 'rxjs'; import * as i0 from "@angular/core"; import * as i1 from "@angular/material/dialog"; import * as i2 from "@angular/forms"; import * as i3 from "@angular/common"; import * as i4 from "@angular/material/input"; import * as i5 from "@angular/material/form-field"; import * as i6 from "@angular/material/button"; import * as i7 from "../dialog.component"; export class TdPromptDialogComponent { _ngZone; _dialogRef; title; message; value; cancelButton = 'CANCEL'; acceptButton = 'ACCEPT'; /** The native `<input matInput />` element. */ _input; _closeBtn; _acceptBtn; _destroy$ = new Subject(); constructor(_ngZone, _dialogRef) { this._ngZone = _ngZone; this._dialogRef = _dialogRef; } ngAfterViewInit() { this._ngZone.runOutsideAngular(() => { // Note: `element.focus()` causes re-layout and this may lead to frame drop on slower devices. // `Promise` is a microtask and microtask are executed within the current rendering frame. // Animation tasks are executed within the next rendering frame. // We focus input once everything is rendered and good to go. requestAnimationFrame(() => this._input.nativeElement.focus()); fromEvent(this._input.nativeElement, 'focus') .pipe(takeUntil(this._destroy$)) .subscribe(() => { // This is executed when the input is focused, selects all text. this._input.nativeElement.select(); }); fromEvent(this._closeBtn.nativeElement, 'keydown') .pipe(takeUntil(this._destroy$)) .subscribe((event) => { if (event.keyCode === RIGHT_ARROW) { this._acceptBtn.nativeElement.focus(); } }); fromEvent(this._acceptBtn.nativeElement, 'keydown') .pipe(takeUntil(this._destroy$)) .subscribe((event) => { if (event.keyCode === LEFT_ARROW) { this._closeBtn.nativeElement.focus(); } }); }); } ngOnDestroy() { this._destroy$.next(); } cancel() { this._dialogRef.close(); } accept() { this._dialogRef.close(this.value); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TdPromptDialogComponent, deps: [{ token: i0.NgZone }, { token: i1.MatDialogRef }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: TdPromptDialogComponent, selector: "td-prompt-dialog", viewQueries: [{ propertyName: "_input", first: true, predicate: ["input"], descendants: true, static: true }, { propertyName: "_closeBtn", first: true, predicate: ["closeBtn"], descendants: true, read: ElementRef, static: true }, { propertyName: "_acceptBtn", first: true, predicate: ["acceptBtn"], descendants: true, read: ElementRef, static: true }], ngImport: i0, template: "<td-dialog>\n <ng-container tdDialogTitle *ngIf=\"title\">{{ title }}</ng-container>\n <ng-container tdDialogContent>\n <span class=\"td-dialog-message\">{{ message }}</span>\n <form #form=\"ngForm\" novalidate>\n <div class=\"td-dialog-input-wrapper\">\n <mat-form-field class=\"td-dialog-input\">\n <input\n matInput\n #input\n (keydown.enter)=\"$event.preventDefault(); form.valid && accept()\"\n [(ngModel)]=\"value\"\n name=\"value\"\n required\n />\n </mat-form-field>\n </div>\n </form>\n </ng-container>\n <ng-container tdDialogActions>\n <button mat-button #closeBtn (click)=\"cancel()\">{{ cancelButton }}</button>\n <button\n mat-button\n color=\"accent\"\n #acceptBtn\n [disabled]=\"!form.valid\"\n (click)=\"accept()\"\n >\n {{ acceptButton }}\n </button>\n </ng-container>\n</td-dialog>\n", styles: [".td-dialog-input-wrapper{flex-direction:row;box-sizing:border-box;display:flex}.td-dialog-input-wrapper .td-dialog-input{flex:1;box-sizing:border-box}.td-dialog-message{word-break:break-word}\n"], dependencies: [{ kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i7.TdDialogComponent, selector: "td-dialog" }, { kind: "directive", type: i7.TdDialogTitleDirective, selector: "[tdDialogTitle]" }, { kind: "directive", type: i7.TdDialogActionsDirective, selector: "[tdDialogActions]" }, { kind: "directive", type: i7.TdDialogContentDirective, selector: "[tdDialogContent]" }] }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TdPromptDialogComponent, decorators: [{ type: Component, args: [{ selector: 'td-prompt-dialog', template: "<td-dialog>\n <ng-container tdDialogTitle *ngIf=\"title\">{{ title }}</ng-container>\n <ng-container tdDialogContent>\n <span class=\"td-dialog-message\">{{ message }}</span>\n <form #form=\"ngForm\" novalidate>\n <div class=\"td-dialog-input-wrapper\">\n <mat-form-field class=\"td-dialog-input\">\n <input\n matInput\n #input\n (keydown.enter)=\"$event.preventDefault(); form.valid && accept()\"\n [(ngModel)]=\"value\"\n name=\"value\"\n required\n />\n </mat-form-field>\n </div>\n </form>\n </ng-container>\n <ng-container tdDialogActions>\n <button mat-button #closeBtn (click)=\"cancel()\">{{ cancelButton }}</button>\n <button\n mat-button\n color=\"accent\"\n #acceptBtn\n [disabled]=\"!form.valid\"\n (click)=\"accept()\"\n >\n {{ acceptButton }}\n </button>\n </ng-container>\n</td-dialog>\n", styles: [".td-dialog-input-wrapper{flex-direction:row;box-sizing:border-box;display:flex}.td-dialog-input-wrapper .td-dialog-input{flex:1;box-sizing:border-box}.td-dialog-message{word-break:break-word}\n"] }] }], ctorParameters: () => [{ type: i0.NgZone }, { type: i1.MatDialogRef }], propDecorators: { _input: [{ type: ViewChild, args: ['input', { static: true }] }], _closeBtn: [{ type: ViewChild, args: ['closeBtn', { static: true, read: ElementRef }] }], _acceptBtn: [{ type: ViewChild, args: ['acceptBtn', { static: true, read: ElementRef }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prompt-dialog.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/dialogs/src/prompt-dialog/prompt-dialog.component.ts","../../../../../../libs/angular/dialogs/src/prompt-dialog/prompt-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  NgZone,\n  OnDestroy,\n} from '@angular/core';\nimport { MatDialogRef } from '@angular/material/dialog';\nimport { LEFT_ARROW, RIGHT_ARROW } from '@angular/cdk/keycodes';\nimport { fromEvent, Subject, takeUntil } from 'rxjs';\n\n@Component({\n  selector: 'td-prompt-dialog',\n  templateUrl: './prompt-dialog.component.html',\n  styleUrls: ['./prompt-dialog.component.scss'],\n})\nexport class TdPromptDialogComponent implements AfterViewInit, OnDestroy {\n  title?: string;\n  message?: string;\n  value?: string;\n  cancelButton = 'CANCEL';\n  acceptButton = 'ACCEPT';\n\n  /** The native `<input matInput />` element. */\n  @ViewChild('input', { static: true }) _input!: ElementRef<HTMLInputElement>;\n\n  @ViewChild('closeBtn', { static: true, read: ElementRef })\n  _closeBtn!: ElementRef<HTMLButtonElement>;\n\n  @ViewChild('acceptBtn', { static: true, read: ElementRef })\n  _acceptBtn!: ElementRef<HTMLButtonElement>;\n\n  private _destroy$ = new Subject<void>();\n\n  constructor(\n    private _ngZone: NgZone,\n    private _dialogRef: MatDialogRef<TdPromptDialogComponent>\n  ) {}\n\n  ngAfterViewInit(): void {\n    this._ngZone.runOutsideAngular(() => {\n      // Note: `element.focus()` causes re-layout and this may lead to frame drop on slower devices.\n      // `Promise` is a microtask and microtask are executed within the current rendering frame.\n      // Animation tasks are executed within the next rendering frame.\n      // We focus input once everything is rendered and good to go.\n      requestAnimationFrame(() => this._input.nativeElement.focus());\n\n      fromEvent(this._input.nativeElement, 'focus')\n        .pipe(takeUntil(this._destroy$))\n        .subscribe(() => {\n          // This is executed when the input is focused, selects all text.\n          this._input.nativeElement.select();\n        });\n\n      fromEvent<KeyboardEvent>(this._closeBtn.nativeElement, 'keydown')\n        .pipe(takeUntil(this._destroy$))\n        .subscribe((event) => {\n          if (event.keyCode === RIGHT_ARROW) {\n            this._acceptBtn.nativeElement.focus();\n          }\n        });\n\n      fromEvent<KeyboardEvent>(this._acceptBtn.nativeElement, 'keydown')\n        .pipe(takeUntil(this._destroy$))\n        .subscribe((event) => {\n          if (event.keyCode === LEFT_ARROW) {\n            this._closeBtn.nativeElement.focus();\n          }\n        });\n    });\n  }\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n  }\n\n  cancel(): void {\n    this._dialogRef.close();\n  }\n\n  accept(): void {\n    this._dialogRef.close(this.value);\n  }\n}\n","<td-dialog>\n  <ng-container tdDialogTitle *ngIf=\"title\">{{ title }}</ng-container>\n  <ng-container tdDialogContent>\n    <span class=\"td-dialog-message\">{{ message }}</span>\n    <form #form=\"ngForm\" novalidate>\n      <div class=\"td-dialog-input-wrapper\">\n        <mat-form-field class=\"td-dialog-input\">\n          <input\n            matInput\n            #input\n            (keydown.enter)=\"$event.preventDefault(); form.valid && accept()\"\n            [(ngModel)]=\"value\"\n            name=\"value\"\n            required\n          />\n        </mat-form-field>\n      </div>\n    </form>\n  </ng-container>\n  <ng-container tdDialogActions>\n    <button mat-button #closeBtn (click)=\"cancel()\">{{ cancelButton }}</button>\n    <button\n      mat-button\n      color=\"accent\"\n      #acceptBtn\n      [disabled]=\"!form.valid\"\n      (click)=\"accept()\"\n    >\n      {{ acceptButton }}\n    </button>\n  </ng-container>\n</td-dialog>\n"]}