@uiowa/uiowa-mfk-material
Version:
mfk, uiowa-mfk
224 lines • 18.1 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';
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"]}