UNPKG

@uiowa/uiowa-mfk-material

Version:

mfk, uiowa-mfk

224 lines 18.1 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'; var MfkInputComponent = /** @class */ (function () { function MfkInputComponent(optionsService) { this.optionsService = optionsService; this._mfk = new Mfk(); this.options = []; this.mfkChange = new EventEmitter(); } Object.defineProperty(MfkInputComponent.prototype, "mfk", { get: /** * @return {?} */ function () { var _this = this; this.options .filter((/** * @param {?} o * @return {?} */ function (o) { return o.readonly; })) .forEach((/** * @param {?} o * @return {?} */ function (o) { _this._mfk[o.name] = o.defaultValue; })); return this._mfk; }, set: /** * @param {?} mfk * @return {?} */ function (mfk) { this.options .filter((/** * @param {?} o * @return {?} */ function (o) { return o.defaultValue; })) .forEach((/** * @param {?} o * @return {?} */ function (o) { if (!mfk[o.name]) { mfk[o.name] = o.defaultValue; } })); this._mfk = mfk; }, enumerable: true, configurable: true }); /** * @param {?} changes * @return {?} */ MfkInputComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (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 {?} */ MfkInputComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.options = this.optionsService.getAllOptions(); console.log(this.options); }; /** * @return {?} */ MfkInputComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { }; /** * @param {?} e * @return {?} */ MfkInputComponent.prototype.paste = /** * @param {?} e * @return {?} */ function (e) { /** @type {?} */ var 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 {?} */ MfkInputComponent.prototype.onKeyup = /** * @param {?} e * @return {?} */ function (e) { var _this = this; 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 {?} */ var currentInputFieldName = e.target['name']; if (this.mfk[currentInputFieldName].length === e.target['maxLength']) { // auto jump to next input field when current field is full /** @type {?} */ var currentInputFieldIndex = this.options.findIndex((/** * @param {?} o * @return {?} */ function (o) { return o.name === currentInputFieldName; })); var _loop_1 = function (i) { if (this_1.options[i].readonly) { return "continue"; } /** @type {?} */ var nextInputField = this_1.mfkInputFields.find((/** * @param {?} v * @return {?} */ function (v) { return v.el.nativeElement['name'] === _this.options[i].name; })); nextInputField.el.nativeElement.focus(); return "break"; }; var this_1 = this; for (var i = currentInputFieldIndex + 1; i < this.options.length; i++) { var state_1 = _loop_1(i); if (state_1 === "break") break; } } }; /** * @param {?} e * @return {?} */ MfkInputComponent.prototype.onKeydown = /** * @param {?} e * @return {?} */ function (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 {?} */ var 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 = function () { return [ { type: UiowaMfkOptionsService } ]; }; MfkInputComponent.propDecorators = { mfk: [{ type: Input }], options: [{ type: Input }], mfkChange: [{ type: Output }], mfkInputFields: [{ type: ViewChildren, args: [DigitOnlyDirective,] }] }; return MfkInputComponent; }()); export { MfkInputComponent }; 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"]}