UNPKG

@uiowa/uiowa-mfk-material

Version:

mfk, uiowa-mfk

191 lines 16.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, Output, EventEmitter, ViewChildren, QueryList } from '@angular/core'; import { Mfk } from '../models/mfk'; import { UiowaMfkOptionsService } from '../services/uiowa-mfk-options.service'; import { DigitOnlyDirective } from '@uiowa/digit-only'; export class MfkInputComponent { /** * @param {?} optionsService */ constructor(optionsService) { this.optionsService = optionsService; this._mfk = new Mfk(); this.options = []; this.mfkChange = new EventEmitter(); } /** * @param {?} mfk * @return {?} */ set mfk(mfk) { this.options .filter((/** * @param {?} o * @return {?} */ o => o.defaultValue)) .forEach((/** * @param {?} o * @return {?} */ o => { if (!mfk[o.name]) { mfk[o.name] = o.defaultValue; } })); this._mfk = mfk; } /** * @return {?} */ get mfk() { this.options .filter((/** * @param {?} o * @return {?} */ o => o.readonly)) .forEach((/** * @param {?} o * @return {?} */ o => { this._mfk[o.name] = o.defaultValue; })); return this._mfk; } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { if (changes.mfk) { this.mfk = changes.mfk.currentValue; } if (changes.options) { this.options = changes.options.currentValue; this.options = this.optionsService.getOptions(this.options); } } /** * @return {?} */ ngOnInit() { this.options = this.optionsService.getAllOptions(); console.log(this.options); } /** * @return {?} */ ngAfterViewInit() { } /** * @param {?} e * @return {?} */ paste(e) { /** @type {?} */ const pastedInput = e.clipboardData.getData('text/plain').replace(/\D/g, ''); e.preventDefault(); if (!pastedInput) { return; } if (pastedInput.length < 40) { document.execCommand('insertText', false, pastedInput); } else { this.mfk.parseString(pastedInput); } this.mfkChange.emit(this.mfk); } /** * @param {?} e * @return {?} */ onKeyup(e) { this.mfkChange.emit(this.mfk); if ((e.keyCode < 48 || e.keyCode > 57) && (e.keyCode < 96 || e.keyCode > 105)) { return; // only numbers can trigger auto jump feature. } /** @type {?} */ const currentInputFieldName = e.target['name']; if (this.mfk[currentInputFieldName].length === e.target['maxLength']) { // auto jump to next input field when current field is full /** @type {?} */ const currentInputFieldIndex = this.options.findIndex((/** * @param {?} o * @return {?} */ o => o.name === currentInputFieldName)); for (let i = currentInputFieldIndex + 1; i < this.options.length; i++) { if (this.options[i].readonly) { continue; } /** @type {?} */ const nextInputField = this.mfkInputFields.find((/** * @param {?} v * @return {?} */ v => v.el.nativeElement['name'] === this.options[i].name)); nextInputField.el.nativeElement.focus(); break; } } } /** * @param {?} e * @return {?} */ onKeydown(e) { // handle "tab" key --> auto fill '0's if the input field has not completed if (e.keyCode !== 9) { return; } if (e.target['readOnly']) { return; } /** @type {?} */ const maxlength = e.target['maxLength']; while (this.mfk[e.target['name']].length < maxlength) { this.mfk[e.target['name']] = this.mfk[e.target['name']].concat('0'); } } } MfkInputComponent.decorators = [ { type: Component, args: [{ selector: 'uiowa-mfk-input', template: "<div id=\"mfk-container\">\r\n <div class=\"mfk-field\" fxLayout=\"row inline\" fxLayout.xs=\"column\" fxLayoutAlign=\"start center\"\r\n *ngFor=\"let option of options\" fxLayoutWrap fxLayoutGap=\"0.5%\">\r\n <mat-form-field class=\"form-control\" [ngStyle]=\"{'width.rem': option.width+0.5}\" appearance=\"outline\"\r\n floatLabel=\"always\" style=\" font-size: 14px;\">\r\n <mat-label>{{option.label}}</mat-label>\r\n <input matInput [attr.aria-label]=\"option.name\" [attr.name]=\"option.name\" [attr.maxlength]=\"option.length\"\r\n [readOnly]=\"option.readonly\" [(ngModel)]=\"mfk[option.name]\" (paste)=\"paste($event)\" (keyup)=\"onKeyup($event)\"\r\n (keydown)=\"onKeydown($event)\" inputmode=\"numeric\" pattern=\"[0-9]*\" digitOnly>\r\n </mat-form-field>\r\n\r\n\r\n </div>\r\n</div>\r\n", styles: [":host{display:inline-flex}.mfk-field{display:flex;flex-direction:row;flex-flow:row;vertical-align:bottom;margin-right:.25rem}.mat-form-field{padding:.375rem!important;font-size:1rem;font-weight:400;font-style:normal;font-variant:normal}.mat-label{font-size:.625rem;margin-bottom:0;white-space:nowrap}"] }] } ]; /** @nocollapse */ MfkInputComponent.ctorParameters = () => [ { type: UiowaMfkOptionsService } ]; MfkInputComponent.propDecorators = { mfk: [{ type: Input }], options: [{ type: Input }], mfkChange: [{ type: Output }], mfkInputFields: [{ type: ViewChildren, args: [DigitOnlyDirective,] }] }; if (false) { /** * @type {?} * @private */ MfkInputComponent.prototype._mfk; /** @type {?} */ MfkInputComponent.prototype.options; /** @type {?} */ MfkInputComponent.prototype.mfkChange; /** @type {?} */ MfkInputComponent.prototype.mfkInputFields; /** * @type {?} * @private */ MfkInputComponent.prototype.optionsService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mfk-input.component.js","sourceRoot":"ng://@uiowa/uiowa-mfk-material/","sources":["lib/mfk-input/mfk-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  Input,\r\n  Output,\r\n  OnChanges,\r\n  EventEmitter,\r\n  SimpleChanges,\r\n  ViewChildren,\r\n  QueryList,\r\n  AfterViewInit\r\n} from '@angular/core';\r\nimport { Mfk } from '../models/mfk';\r\nimport { MfkFieldOption } from '../models/mfk-field-option';\r\nimport { UiowaMfkOptionsService } from '../services/uiowa-mfk-options.service';\r\nimport { DigitOnlyDirective } from '@uiowa/digit-only';\r\n\r\n@Component({\r\n  selector: 'uiowa-mfk-input',\r\n  templateUrl: './mfk-input.component.html',\r\n  styleUrls: ['./mfk-input.component.css']\r\n})\r\nexport class MfkInputComponent implements OnInit, OnChanges, AfterViewInit {\r\n  private _mfk = new Mfk();\r\n  @Input()\r\n  set mfk(mfk: Mfk) {\r\n    this.options\r\n      .filter(o => o.defaultValue)\r\n      .forEach(o => {\r\n        if (!mfk[o.name]) {\r\n          mfk[o.name] = o.defaultValue;\r\n        }\r\n      });\r\n\r\n    this._mfk = mfk;\r\n  }\r\n  get mfk(): Mfk {\r\n    this.options\r\n      .filter(o => o.readonly)\r\n      .forEach(o => {\r\n        this._mfk[o.name] = o.defaultValue;\r\n      });\r\n    return this._mfk;\r\n  }\r\n  @Input() options?: MfkFieldOption[] = [];\r\n  @Output() mfkChange = new EventEmitter<Mfk>();\r\n\r\n  @ViewChildren(DigitOnlyDirective)\r\n  mfkInputFields: QueryList<DigitOnlyDirective>;\r\n\r\n  constructor(private readonly optionsService: UiowaMfkOptionsService) {}\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.mfk) {\r\n      this.mfk = changes.mfk.currentValue;\r\n    }\r\n    if (changes.options) {\r\n      this.options = changes.options.currentValue;\r\n      this.options = this.optionsService.getOptions(this.options);\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.options = this.optionsService.getAllOptions();\r\n    console.log(this.options);\r\n  }\r\n\r\n  ngAfterViewInit(): void {}\r\n\r\n  paste(e: ClipboardEvent) {\r\n    const pastedInput: string = e.clipboardData.getData('text/plain').replace(/\\D/g, ''); // get a digit-only string\r\n    e.preventDefault();\r\n    if (!pastedInput) {\r\n      return;\r\n    }\r\n    if (pastedInput.length < 40) {\r\n      document.execCommand('insertText', false, pastedInput);\r\n    } else {\r\n      this.mfk.parseString(pastedInput);\r\n    }\r\n    this.mfkChange.emit(this.mfk);\r\n  }\r\n\r\n  onKeyup(e: KeyboardEvent) {\r\n    this.mfkChange.emit(this.mfk);\r\n    if ((e.keyCode < 48 || e.keyCode > 57) && (e.keyCode < 96 || e.keyCode > 105)) {\r\n      return; // only numbers can trigger auto jump feature.\r\n    }\r\n    const currentInputFieldName = e.target['name'];\r\n    if (this.mfk[currentInputFieldName].length === e.target['maxLength']) {\r\n      // auto jump to next input field when current field is full\r\n      const currentInputFieldIndex = this.options.findIndex(o => o.name === currentInputFieldName);\r\n      for (let i = currentInputFieldIndex + 1; i < this.options.length; i++) {\r\n        if (this.options[i].readonly) {\r\n          continue;\r\n        }\r\n        const nextInputField = this.mfkInputFields.find(v => v.el.nativeElement['name'] === this.options[i].name);\r\n        nextInputField.el.nativeElement.focus();\r\n        break;\r\n      }\r\n    }\r\n  }\r\n\r\n  onKeydown(e: KeyboardEvent) {\r\n    // handle \"tab\" key --> auto fill '0's if the input field has not completed\r\n    if (e.keyCode !== 9) {\r\n      return;\r\n    }\r\n    if (e.target['readOnly']) {\r\n      return;\r\n    }\r\n    const maxlength = e.target['maxLength'];\r\n    while (this.mfk[e.target['name']].length < maxlength) {\r\n      this.mfk[e.target['name']] = this.mfk[e.target['name']].concat('0');\r\n    }\r\n  }\r\n}\r\n"]}