@uiowa/uiowa-mfk-material
Version:
mfk, uiowa-mfk
191 lines • 16.6 kB
JavaScript
/**
* @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"]}