com.phloxui
Version:
PhloxUI Ng2+ Framework
683 lines (682 loc) • 51.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ElementRef, Input, Output, EventEmitter } from '@angular/core';
import { TextBox } from '../../../../../component/dataview/input/TextBox.component';
import { I18N } from '../../../../../decorator/I18N.decorator';
import { Option } from '../../../../../decorator/Option.decorator';
import { NeedFocusService } from '../../../../../service/NeedFocusService.service';
import { FormatterFactory } from '../../../../../service/FormatterFactory.service';
var /** @type {?} */ TYPE_NAME = "material-text-box";
var /** @type {?} */ NORMAL = 'normal';
var /** @type {?} */ SUCCESS = 'success';
var /** @type {?} */ WARNING = 'warning';
var /** @type {?} */ ERROR = 'error';
var /** @type {?} */ DEFAULT_BUTTON_ICON = 'close';
var /** @type {?} */ DEFAULT_BUTTON_POSITION = 'suffix';
var MaterialTextBox = /** @class */ (function (_super) {
tslib_1.__extends(MaterialTextBox, _super);
function MaterialTextBox(elementRef, formatterFactory, needFocusService) {
var _this = _super.call(this, elementRef, formatterFactory, needFocusService) || this;
_this.active = false;
_this.clearFunc = function () { _this.formattedData = ''; };
return _this;
}
/**
* @return {?}
*/
MaterialTextBox.prototype.ngOnInit = /**
* @return {?}
*/
function () {
_super.prototype.ngOnInit.call(this);
this.refreshActiveTextBox();
};
/**
* @return {?}
*/
MaterialTextBox.prototype._displayHelp = /**
* @return {?}
*/
function () {
var /** @type {?} */ hasHelp = this.hasHelp();
return hasHelp && this.isShowHelp();
};
/**
* @return {?}
*/
MaterialTextBox.prototype.refreshActiveTextBox = /**
* @return {?}
*/
function () {
var /** @type {?} */ val = this.getFormattedData();
if (val !== null && typeof val !== 'undefined') {
if (typeof val === 'string' && val === '') {
this.active = false;
}
else {
this.active = true;
}
}
else {
this.active = false;
}
};
/**
* @param {?} inputValue
* @param {?} results
* @return {?}
*/
MaterialTextBox.prototype.onValidationEnd = /**
* @param {?} inputValue
* @param {?} results
* @return {?}
*/
function (inputValue, results) {
};
/**
* @param {?} data
* @param {?} inputVal
* @return {?}
*/
MaterialTextBox.prototype.onDataChange = /**
* @param {?} data
* @param {?} inputVal
* @return {?}
*/
function (data, inputVal) {
_super.prototype.onDataChange.call(this, data, inputVal);
this.refreshActiveTextBox();
};
/**
* @param {?} $event
* @return {?}
*/
MaterialTextBox.prototype.doFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
_super.prototype.doFocus.call(this, $event);
this.active = true;
this.classFocused = true;
};
/**
* @param {?} $event
* @return {?}
*/
MaterialTextBox.prototype.doLostFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
_super.prototype.doLostFocus.call(this, $event);
this.refreshActiveTextBox();
this.classFocused = false;
};
/**
* @return {?}
*/
MaterialTextBox.prototype.getClassMatFocused = /**
* @return {?}
*/
function () {
return this.isReadOnly() ? { 'mat-focused': this._isClassFocused() } : {};
};
/**
* @return {?}
*/
MaterialTextBox.prototype._isActive = /**
* @return {?}
*/
function () {
return this.active;
};
/**
* @return {?}
*/
MaterialTextBox.prototype._isClassFocused = /**
* @return {?}
*/
function () {
return this.classFocused;
};
/**
* @param {?} $event
* @return {?}
*/
MaterialTextBox.prototype.onValueChanged = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
_super.prototype.onValueChanged.call(this, $event);
this.refreshActiveTextBox();
};
/**
* @param {?} data
* @return {?}
*/
MaterialTextBox.prototype.selfSaveData = /**
* @param {?} data
* @return {?}
*/
function (data) {
_super.prototype.selfSaveData.call(this, data);
this.refreshActiveTextBox();
};
/**
* @return {?}
*/
MaterialTextBox.prototype.getDescription = /**
* @return {?}
*/
function () {
return this.description;
};
/**
* @param {?} description
* @return {?}
*/
MaterialTextBox.prototype.setDescription = /**
* @param {?} description
* @return {?}
*/
function (description) {
this.description = description;
};
/**
* @return {?}
*/
MaterialTextBox.prototype.getLabel = /**
* @return {?}
*/
function () {
return this.label;
};
/**
* @param {?} label
* @return {?}
*/
MaterialTextBox.prototype.setLabel = /**
* @param {?} label
* @return {?}
*/
function (label) {
this.label = label;
};
/**
* @return {?}
*/
MaterialTextBox.prototype.resetValidationResult = /**
* @return {?}
*/
function () {
_super.prototype.resetValidationResult.call(this);
this.active = false;
};
/**
* @param {?} $event
* @return {?}
*/
MaterialTextBox.prototype.onBtnClick = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (!this.isReadOnly() && !this.isDisabled()) {
this.setButtonHandler(this.showClearButton ? this.clearFunc : this.buttonHandler);
if (this.buttonHandler !== null && this.buttonHandler !== undefined) {
this.buttonHandler(this, $event);
}
}
};
/**
* @return {?}
*/
MaterialTextBox.prototype.isShowClearButton = /**
* @return {?}
*/
function () {
return this.showClearButton;
};
/**
* @param {?} showClearButton
* @return {?}
*/
MaterialTextBox.prototype.setShowClearButton = /**
* @param {?} showClearButton
* @return {?}
*/
function (showClearButton) {
this.showClearButton = showClearButton;
};
/**
* @return {?}
*/
MaterialTextBox.prototype.getButtonIcon = /**
* @return {?}
*/
function () {
return this.showClearButton ? DEFAULT_BUTTON_ICON : this.buttonIcon;
};
/**
* @param {?} buttonIcon
* @return {?}
*/
MaterialTextBox.prototype.setButtonIcon = /**
* @param {?} buttonIcon
* @return {?}
*/
function (buttonIcon) {
this.buttonIcon = buttonIcon;
};
/**
* @return {?}
*/
MaterialTextBox.prototype.getButtonPosition = /**
* @return {?}
*/
function () {
return this.showClearButton ? DEFAULT_BUTTON_POSITION : (!this.buttonPosition ? DEFAULT_BUTTON_POSITION : this.buttonPosition);
};
/**
* @param {?} buttonPosition
* @return {?}
*/
MaterialTextBox.prototype.setButtonPosition = /**
* @param {?} buttonPosition
* @return {?}
*/
function (buttonPosition) {
this.buttonPosition = buttonPosition;
};
/**
* @return {?}
*/
MaterialTextBox.prototype.getButtonHandler = /**
* @return {?}
*/
function () {
return this.showClearButton ? this.clearFunc : (!this.buttonHandler ? this.clearFunc : this.buttonHandler);
};
/**
* @param {?} buttonHandler
* @return {?}
*/
MaterialTextBox.prototype.setButtonHandler = /**
* @param {?} buttonHandler
* @return {?}
*/
function (buttonHandler) {
this.buttonHandler = buttonHandler;
};
/**
* @param {?} $event
* @return {?}
*/
MaterialTextBox.prototype.onKeyUp = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.isReadOnly() || this.isDisabled()) {
return;
}
_super.prototype.onKeyUp.call(this, $event);
};
/**
* @param {?} $event
* @return {?}
*/
MaterialTextBox.prototype.onKeyDown = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.isReadOnly() || this.isDisabled()) {
return;
}
_super.prototype.onKeyDown.call(this, $event);
};
MaterialTextBox.TYPE_NAME = TYPE_NAME;
MaterialTextBox.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"material-input material-text-box\" [style.width]=\"getWidth()\">\n\t<div class=\"textbox-wrapper\" [class.active]=\"_isActive()\">\n\t\t<mat-form-field [ngClass]=\"getClassMatFocused()\">\n\t\t\t<input matInput placeholder=\"{{getLabel() | phx_text}}\" [attr.maxlength]=\"getMaxLength()\" type=\"{{getType()}}\" class=\"form-control\" [disabled]=\"isDisabled()\" [readonly]=\"isReadOnly()\" [class.dirty]=\"isDataDirty()\" (change)=\"onValueChanged($event)\" (focusin)=\"onFocusing($event)\" (blur)=\"onLostFocusing($event)\" (keyup)=\"onKeyUp($event)\"\n\t\t\t (keydown)=\"onKeyDown($event)\" [value]=\"formattedData | phx_text\" [class.normal]=\"isNormal() && !isDisabled()\" [class.success]=\"isSuccess() && !isDisabled()\" [class.warning]=\"isWarning() && !isDisabled()\" [class.error]=\"isError() && !isDisabled()\">\n\t\t\t\t<button mat-button *ngIf=\"(getButtonIcon() || isShowClearButton()) && (formattedData && getButtonPosition() === 'suffix' && !(isDisabled() || isReadOnly()))\" matSuffix mat-icon-button (click)=\"onBtnClick($event)\">\n \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n\t\t\t\t</button>\n\t\t\t\t<button mat-button *ngIf=\"(getButtonIcon() || isShowClearButton()) && (formattedData && getButtonPosition() === 'prefix' && !(isDisabled() || isReadOnly()))\" matPrefix mat-icon-button (click)=\"onBtnClick($event)\">\n \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n\t\t\t\t</button>\n\t\t\t\t<button mat-button *ngIf=\"(getButtonIcon() || isShowClearButton()) && (formattedData && getButtonPosition() === 'suffix' && (isDisabled() || isReadOnly()))\" disabled matSuffix mat-icon-button (click)=\"onBtnClick($event)\">\n \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n\t\t\t\t</button>\n\t\t\t\t<button mat-button *ngIf=\"(getButtonIcon() || isShowClearButton()) && (formattedData && getButtonPosition() === 'prefix' && (isDisabled() || isReadOnly()))\" disabled matPrefix mat-icon-button (click)=\"onBtnClick($event)\">\n \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n\t\t\t\t</button>\n\t\t</mat-form-field>\n\t</div>\n\t<div class=\"validation\" [style.display]=\"getValidationResultMessage() ? undefined : 'none'\" [class.normal]=\"isNormal() && !isDisabled()\" [class.success]=\"isSuccess() && !isDisabled()\" [class.warning]=\"isWarning() && !isDisabled()\" [class.error]=\"isError() && !isDisabled()\">\n\t\t<ng-template [ngIf]=\"getValidationResultMessage()\" [ngIfElse]=\"validation_else\">\n\t\t\t{{getValidationResultMessage() | phx_text}}\n\t\t</ng-template>\n\t\t<ng-template #validation_else>\n\t\t\t<!-- We've to put whitespace if there is no validation msg to prevent empty dom -->\n\t\t\t<!-- since if validate msg's <div> dom is empty, the component positioning -->\n\t\t\t<!-- will be misplaced. -->\n\t\t\t{{ ' ' }}\n\t\t</ng-template>\n\t</div>\n\t<div class=\"description\" [style.display]=\"getValidationResultMessage() ? 'none' : undefined\" [class.normal]=\"isNormal() && !isDisabled()\" [class.success]=\"isSuccess() && !isDisabled()\" [class.warning]=\"isWarning() && !isDisabled()\" [class.error]=\"isError() && !isDisabled()\">\n\t\t<ng-template [ngIf]=\"getDescription()\" [ngIfElse]=\"description_else\">\n\t\t\t{{ getDescription() | phx_text }}\n\t\t</ng-template>\n\t\t<ng-template #description_else>\n\t\t\t<!-- We've to put whitespace if there is no description to prevent empty dom -->\n\t\t\t<!-- since if description's <div> dom is empty, the component positioning -->\n\t\t\t<!-- will be misplaced. -->\n\t\t\t{{ ' ' }}\n\t\t</ng-template>\n\t</div>\n\t<div class=\"help\">\n\t\t{{getHelp() | phx_text}}\n\t</div>\n</div>\n"
},] },
];
/** @nocollapse */
MaterialTextBox.ctorParameters = function () { return [
{ type: ElementRef, },
{ type: FormatterFactory, },
{ type: NeedFocusService, },
]; };
MaterialTextBox.propDecorators = {
"dataParent": [{ type: Input },],
"ignoreParentData": [{ type: Input },],
"data": [{ type: Input },],
"ignoreParentDisabled": [{ type: Input },],
"delegateHistory": [{ type: Input },],
"onDisabled": [{ type: Input },],
"onEnabled": [{ type: Input },],
"loadingEnabled": [{ type: Input },],
"i18nKey": [{ type: Input },],
"bypass": [{ type: Input, args: ['i18nBypass',] },],
"options": [{ type: Input },],
"disabled": [{ type: Input },],
"field": [{ type: Input },],
"name": [{ type: Input },],
"typeOfData": [{ type: Input },],
"readOnly": [{ type: Input },],
"help": [{ type: Input },],
"formatter": [{ type: Input, args: ['formatter',] },],
"formatterName": [{ type: Input, args: ['formatterName',] },],
"formatterOptions": [{ type: Input, args: ['formatterOptions',] },],
"formatterUsePropertyValue": [{ type: Input, args: ['formatterUsePropertyValue',] },],
"type": [{ type: Input },],
"width": [{ type: Input },],
"label": [{ type: Input },],
"description": [{ type: Input },],
"maxLength": [{ type: Input, args: ['phxMaxLength',] },],
"buttonIcon": [{ type: Input },],
"buttonPosition": [{ type: Input },],
"buttonHandler": [{ type: Input },],
"showClearButton": [{ type: Input },],
"loadEvent": [{ type: Output, args: ['phxLoad',] },],
"startValidateEvent": [{ type: Output, args: ['phxStartValidate',] },],
"endValidateEvent": [{ type: Output, args: ['phxEndValidate',] },],
"beforeFocusEvent": [{ type: Output, args: ['phxBeforeFocus',] },],
"focusEvent": [{ type: Output, args: ['phxFocus',] },],
"beforeLostFocusEvent": [{ type: Output, args: ['phxBeforeLostFocus',] },],
"lostFocusEvent": [{ type: Output, args: ['phxLostFocus',] },],
"beforeChangeEvent": [{ type: Output, args: ['phxBeforeChange',] },],
"changeEvent": [{ type: Output, args: ['phxChange',] },],
"beforeKeyUpEvent": [{ type: Output, args: ['phxBeforeKeyUp',] },],
"keyUpEvent": [{ type: Output, args: ['phxKeyUp',] },],
"beforeKeyDownEvent": [{ type: Output, args: ['phxBeforeKeyDown',] },],
"keyDownEvent": [{ type: Output, args: ['phxKeyDown',] },],
};
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], MaterialTextBox.prototype, "dataParent", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextBox.prototype, "ignoreParentData", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], MaterialTextBox.prototype, "data", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextBox.prototype, "ignoreParentDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextBox.prototype, "delegateHistory", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], MaterialTextBox.prototype, "onDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], MaterialTextBox.prototype, "onEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextBox.prototype, "loadingEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "i18nKey", void 0);
tslib_1.__decorate([
Option('i18nBypass'),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextBox.prototype, "bypass", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextBox.prototype, "disabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "field", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "name", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "typeOfData", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextBox.prototype, "readOnly", void 0);
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", Object)
], MaterialTextBox.prototype, "help", void 0);
tslib_1.__decorate([
Option('formatter.instance'),
tslib_1.__metadata("design:type", Object)
], MaterialTextBox.prototype, "formatter", void 0);
tslib_1.__decorate([
Option('formatter.name'),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "formatterName", void 0);
tslib_1.__decorate([
Option('formatter.options'),
tslib_1.__metadata("design:type", Object)
], MaterialTextBox.prototype, "formatterOptions", void 0);
tslib_1.__decorate([
Option('formatter.usePropertyValue'),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextBox.prototype, "formatterUsePropertyValue", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "type", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "width", void 0);
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "label", void 0);
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "description", void 0);
tslib_1.__decorate([
Option('maxLength'),
tslib_1.__metadata("design:type", Number)
], MaterialTextBox.prototype, "maxLength", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "buttonIcon", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextBox.prototype, "buttonPosition", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], MaterialTextBox.prototype, "buttonHandler", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextBox.prototype, "showClearButton", void 0);
tslib_1.__decorate([
Option('load'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "loadEvent", void 0);
tslib_1.__decorate([
Option('startValidate'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "startValidateEvent", void 0);
tslib_1.__decorate([
Option('endValidate'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "endValidateEvent", void 0);
tslib_1.__decorate([
Option('beforeFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "beforeFocusEvent", void 0);
tslib_1.__decorate([
Option('focus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "focusEvent", void 0);
tslib_1.__decorate([
Option('beforeLostFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "beforeLostFocusEvent", void 0);
tslib_1.__decorate([
Option('lostFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "lostFocusEvent", void 0);
tslib_1.__decorate([
Option('beforeChange'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "beforeChangeEvent", void 0);
tslib_1.__decorate([
Option('change'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "changeEvent", void 0);
tslib_1.__decorate([
Option('beforeKeyUp'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "beforeKeyUpEvent", void 0);
tslib_1.__decorate([
Option('keyUp'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "keyUpEvent", void 0);
tslib_1.__decorate([
Option('beforeKeyDown'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "beforeKeyDownEvent", void 0);
tslib_1.__decorate([
Option('keyDown'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextBox.prototype, "keyDownEvent", void 0);
return MaterialTextBox;
}(TextBox));
export { MaterialTextBox };
function MaterialTextBox_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
MaterialTextBox.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
MaterialTextBox.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
MaterialTextBox.propDecorators;
/** @type {?} */
MaterialTextBox.TYPE_NAME;
/** @type {?} */
MaterialTextBox.prototype.dataParent;
/** @type {?} */
MaterialTextBox.prototype.ignoreParentData;
/** @type {?} */
MaterialTextBox.prototype.data;
/** @type {?} */
MaterialTextBox.prototype.ignoreParentDisabled;
/** @type {?} */
MaterialTextBox.prototype.delegateHistory;
/** @type {?} */
MaterialTextBox.prototype.onDisabled;
/** @type {?} */
MaterialTextBox.prototype.onEnabled;
/** @type {?} */
MaterialTextBox.prototype.loadingEnabled;
/** @type {?} */
MaterialTextBox.prototype.i18nKey;
/** @type {?} */
MaterialTextBox.prototype.bypass;
/** @type {?} */
MaterialTextBox.prototype.options;
/** @type {?} */
MaterialTextBox.prototype.disabled;
/** @type {?} */
MaterialTextBox.prototype.field;
/** @type {?} */
MaterialTextBox.prototype.name;
/** @type {?} */
MaterialTextBox.prototype.typeOfData;
/** @type {?} */
MaterialTextBox.prototype.readOnly;
/** @type {?} */
MaterialTextBox.prototype.help;
/** @type {?} */
MaterialTextBox.prototype.formatter;
/** @type {?} */
MaterialTextBox.prototype.formatterName;
/** @type {?} */
MaterialTextBox.prototype.formatterOptions;
/** @type {?} */
MaterialTextBox.prototype.formatterUsePropertyValue;
/** @type {?} */
MaterialTextBox.prototype.type;
/** @type {?} */
MaterialTextBox.prototype.width;
/** @type {?} */
MaterialTextBox.prototype.label;
/** @type {?} */
MaterialTextBox.prototype.description;
/** @type {?} */
MaterialTextBox.prototype.maxLength;
/** @type {?} */
MaterialTextBox.prototype.buttonIcon;
/** @type {?} */
MaterialTextBox.prototype.buttonPosition;
/** @type {?} */
MaterialTextBox.prototype.buttonHandler;
/** @type {?} */
MaterialTextBox.prototype.showClearButton;
/** @type {?} */
MaterialTextBox.prototype.loadEvent;
/** @type {?} */
MaterialTextBox.prototype.startValidateEvent;
/** @type {?} */
MaterialTextBox.prototype.endValidateEvent;
/** @type {?} */
MaterialTextBox.prototype.beforeFocusEvent;
/** @type {?} */
MaterialTextBox.prototype.focusEvent;
/** @type {?} */
MaterialTextBox.prototype.beforeLostFocusEvent;
/** @type {?} */
MaterialTextBox.prototype.lostFocusEvent;
/** @type {?} */
MaterialTextBox.prototype.beforeChangeEvent;
/** @type {?} */
MaterialTextBox.prototype.changeEvent;
/** @type {?} */
MaterialTextBox.prototype.beforeKeyUpEvent;
/** @type {?} */
MaterialTextBox.prototype.keyUpEvent;
/** @type {?} */
MaterialTextBox.prototype.beforeKeyDownEvent;
/** @type {?} */
MaterialTextBox.prototype.keyDownEvent;
/** @type {?} */
MaterialTextBox.prototype.active;
/** @type {?} */
MaterialTextBox.prototype.classFocused;
/** @type {?} */
MaterialTextBox.prototype.clearFunc;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MaterialTextBox.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/theme/material/component/dataview/input/MaterialTextBox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, Output, EventEmitter } from '@angular/core';\nimport { IHasData } from '../../../../../component/IHasData';\nimport { TextBox } from '../../../../../component/dataview/input/TextBox.component';\nimport { ValidationResult } from '../../../../../component/model/ValidationResult';\nimport { IHasHelp } from '../../../../../component/IHasHelp';\nimport { I18N } from '../../../../../decorator/I18N.decorator';\nimport { Option } from '../../../../../decorator/Option.decorator';\nimport { NeedFocusService } from '../../../../../service/NeedFocusService.service';\nimport { IFormatter } from '../../../../../share/formatter/IFormatter';\nimport { FormatterFactory } from '../../../../../service/FormatterFactory.service';\n\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"material-text-box\";\n\nconst NORMAL: string = 'normal';\nconst SUCCESS: string = 'success';\nconst WARNING: string = 'warning';\nconst ERROR: string = 'error';\n\nconst DEFAULT_BUTTON_ICON = 'close';\nconst DEFAULT_BUTTON_POSITION = 'suffix';\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"material-input material-text-box\" [style.width]=\"getWidth()\">\n\t<div class=\"textbox-wrapper\" [class.active]=\"_isActive()\">\n\t\t<mat-form-field [ngClass]=\"getClassMatFocused()\">\n\t\t\t<input matInput placeholder=\"{{getLabel() | phx_text}}\" [attr.maxlength]=\"getMaxLength()\" type=\"{{getType()}}\" class=\"form-control\" [disabled]=\"isDisabled()\" [readonly]=\"isReadOnly()\" [class.dirty]=\"isDataDirty()\" (change)=\"onValueChanged($event)\" (focusin)=\"onFocusing($event)\" (blur)=\"onLostFocusing($event)\" (keyup)=\"onKeyUp($event)\"\n\t\t\t  (keydown)=\"onKeyDown($event)\" [value]=\"formattedData | phx_text\" [class.normal]=\"isNormal() && !isDisabled()\" [class.success]=\"isSuccess() && !isDisabled()\" [class.warning]=\"isWarning() && !isDisabled()\" [class.error]=\"isError() && !isDisabled()\">\n\t\t\t\t<button mat-button *ngIf=\"(getButtonIcon() || isShowClearButton()) && (formattedData && getButtonPosition() === 'suffix' && !(isDisabled() || isReadOnly()))\" matSuffix mat-icon-button (click)=\"onBtnClick($event)\">\n    \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n\t\t\t\t</button>\n\t\t\t\t<button mat-button *ngIf=\"(getButtonIcon() || isShowClearButton()) && (formattedData && getButtonPosition() === 'prefix' && !(isDisabled() || isReadOnly()))\" matPrefix mat-icon-button (click)=\"onBtnClick($event)\">\n    \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n\t\t\t\t</button>\n\t\t\t\t<button mat-button *ngIf=\"(getButtonIcon() || isShowClearButton()) && (formattedData && getButtonPosition() === 'suffix' && (isDisabled() || isReadOnly()))\" disabled matSuffix mat-icon-button (click)=\"onBtnClick($event)\">\n    \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n\t\t\t\t</button>\n\t\t\t\t<button mat-button *ngIf=\"(getButtonIcon() || isShowClearButton()) && (formattedData && getButtonPosition() === 'prefix' && (isDisabled() || isReadOnly()))\" disabled matPrefix mat-icon-button (click)=\"onBtnClick($event)\">\n    \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n\t\t\t\t</button>\n\t\t</mat-form-field>\n\t</div>\n\t<div class=\"validation\" [style.display]=\"getValidationResultMessage() ? undefined : 'none'\" [class.normal]=\"isNormal() && !isDisabled()\" [class.success]=\"isSuccess() && !isDisabled()\" [class.warning]=\"isWarning() && !isDisabled()\" [class.error]=\"isError() && !isDisabled()\">\n\t\t<ng-template [ngIf]=\"getValidationResultMessage()\" [ngIfElse]=\"validation_else\">\n\t\t\t{{getValidationResultMessage() | phx_text}}\n\t\t</ng-template>\n\t\t<ng-template #validation_else>\n\t\t\t<!-- We've to put whitespace if there is no validation msg to prevent empty dom -->\n\t\t\t<!-- since if validate msg's <div> dom is empty, the component positioning -->\n\t\t\t<!-- will be misplaced. -->\n\t\t\t{{ '&nbsp;' }}\n\t\t</ng-template>\n\t</div>\n\t<div class=\"description\" [style.display]=\"getValidationResultMessage() ? 'none' : undefined\" [class.normal]=\"isNormal() && !isDisabled()\" [class.success]=\"isSuccess() && !isDisabled()\" [class.warning]=\"isWarning() && !isDisabled()\" [class.error]=\"isError() && !isDisabled()\">\n\t\t<ng-template [ngIf]=\"getDescription()\" [ngIfElse]=\"description_else\">\n\t\t\t{{ getDescription() | phx_text }}\n\t\t</ng-template>\n\t\t<ng-template #description_else>\n\t\t\t<!-- We've to put whitespace if there is no description to prevent empty dom -->\n\t\t\t<!-- since if description's <div> dom is empty, the component positioning -->\n\t\t\t<!-- will be misplaced. -->\n\t\t\t{{ '&nbsp;' }}\n\t\t</ng-template>\n\t</div>\n\t<div class=\"help\">\n\t\t{{getHelp() | phx_text}}\n\t</div>\n</div>\n`\n})\nexport class MaterialTextBox extends TextBox implements OnInit, IHasHelp {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  // Re-declare field to declare ng @Input.\n  // --- from AbstractHasData\n  @Input()\n  @Option()\n  protected dataParent: IHasData;\n  @Input()\n  @Option()\n  protected ignoreParentData: boolean;\n  @Input()\n  @Option()\n  protected data: any;\n  @Input()\n  @Option()\n  protected ignoreParentDisabled: boolean;\n  @Input()\n  @Option()\n  protected delegateHistory: boolean;\n  @Input()\n  @Option()\n  protected onDisabled: Function;\n  @Input()\n  @Option()\n  protected onEnabled: Function;\n  @Input()\n  @Option()\n  protected loadingEnabled: boolean;\n  @Input()\n  @Option()\n  protected i18nKey: string;\n  @Input('i18nBypass')\n  @Option('i18nBypass')\n  protected bypass: boolean;\n  @Input()\n  protected options: any;\n  @Input()\n  @Option()\n  protected disabled: boolean;\n  // --- from AbstractDataView\n  @Input()\n  @Option()\n  protected field: string;\n  // --- from AbstractInputDataView\n  @Input()\n  @Option()\n  protected name: string;\n  @Input()\n  @Option()\n  protected typeOfData: string;\n  @Input()\n  @Option()\n  protected readOnly: boolean;\n  @Input()\n  @I18N()\n  @Option()\n  protected help: any;\n  // --- from AbstractHasFormatterInputDataView\n  @Input('formatter')\n  @Option('formatter.instance')\n  protected formatter: IFormatter;\n  @Input('formatterName')\n  @Option('formatter.name')\n  protected formatterName: string;\n  @Input('formatterOptions')\n  @Option('formatter.options')\n  protected formatterOptions: any;\n  @Input('formatterUsePropertyValue')\n  @Option('formatter.usePropertyValue')\n  protected formatterUsePropertyValue: boolean;\n  // --- from TextBox\n  @Input()\n  @Option()\n  protected type: string;\n  @Input()\n  @Option()\n  protected width: string;\n  // --- self\n  @I18N()\n  @Option()\n  @Input()\n  protected label: string;\n  @I18N()\n  @Option()\n  @Input()\n  protected description: string;\n  @Option('maxLength')\n  @Input('phxMaxLength')\n  protected maxLength: number;\n  @Input()\n  @Option()\n  protected buttonIcon: string;\n  @Input()\n  @Option()\n  protected buttonPosition: string;\n  @Input()\n  @Option()\n  protected buttonHandler: Function;\n  @Input()\n  @Option()\n  protected showClearButton: boolean;\n\n  // Re-declare field to declare ng @Output.\n  // --- from AbstractHasData\n  @Output('phxLoad')\n  @Option('load')\n  protected loadEvent: EventEmitter<any>;\n  // --- from AbstractDataView\n  // --- from AbstractInputDataView\n  @Output('phxStartValidate')\n  @Option('startValidate')\n  protected startValidateEvent: EventEmitter<any>;\n  @Output('phxEndValidate')\n  @Option('endValidate')\n  protected endValidateEvent: EventEmitter<any>;\n  @Output('phxBeforeFocus')\n  @Option('beforeFocus')\n  protected beforeFocusEvent: EventEmitter<any>;\n  @Output('phxFocus')\n  @Option('focus')\n  protected focusEvent: EventEmitter<any>;\n  @Output('phxBeforeLostFocus')\n  @Option('beforeLostFocus')\n  protected beforeLostFocusEvent: EventEmitter<any>;\n  @Output('phxLostFocus')\n  @Option('lostFocus')\n  protected lostFocusEvent: EventEmitter<any>;\n  @Output('phxBeforeChange')\n  @Option('beforeChange')\n  protected beforeChangeEvent: EventEmitter<any>;\n  @Output('phxChange')\n  @Option('change')\n  protected changeEvent: EventEmitter<any>;\n  // --- from AbstractHasFormatterInputDataView\n  // --- from TextBox\n  @Option('beforeKeyUp')\n  @Output('phxBeforeKeyUp')\n  protected beforeKeyUpEvent: EventEmitter<any>;\n  @Option('keyUp')\n  @Output('phxKeyUp')\n  protected keyUpEvent: EventEmitter<any>;\n  @Option('beforeKeyDown')\n  @Output('phxBeforeKeyDown')\n  protected beforeKeyDownEvent: EventEmitter<any>;\n  @Option('keyDown')\n  @Output('phxKeyDown')\n  protected keyDownEvent: EventEmitter<any>;\n\n  private active: boolean;\n  private classFocused: boolean;\n  private clearFunc: Function;\n\n  constructor(elementRef: ElementRef, formatterFactory: FormatterFactory, needFocusService: NeedFocusService) {\n    super(elementRef, formatterFactory, needFocusService);\n\n    this.active = false;\n    this.clearFunc = () => { this.formattedData = ''; };\n\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n    this.refreshActiveTextBox();\n  }\n\n  public _displayHelp(): boolean {\n    let hasHelp = this.hasHelp();\n\n    return hasHelp && this.isShowHelp();\n  }\n\n  private refreshActiveTextBox(): void {\n    let val = this.getFormattedData();\n\n    if (val !== null && typeof val !== 'undefined') {\n      if (typeof val === 'string' && val === '') {\n        this.active = false;\n      } else {\n        this.active = true;\n      }\n    } else {\n      this.active = false;\n    }\n  } \n\n  protected onValidationEnd(inputValue: any, results: ValidationResult[]): void {\n  }\n\n  protected onDataChange(data: any, inputVal: any): void {\n    super.onDataChange(data, inputVal);\n\n    this.refreshActiveTextBox();\n  }\n\n  protected doFocus($event: Event): void {\n    super.doFocus($event);\n\n    this.active = true;\n    this.classFocused = true;\n  }\n\n  protected doLostFocus($event: Event): void {\n    super.doLostFocus($event);\n\n    this.refreshActiveTextBox();\n    this.classFocused = false;\n  }\n\n  public getClassMatFocused(): any {\n    return this.isReadOnly() ? { 'mat-focused': this._isClassFocused() } : {};\n  }\n\n  public _isActive(): boolean {\n    return this.active;\n  }\n\n  public _isClassFocused(): boolean {\n    return this.classFocused;\n  }\n\n  public onValueChanged($event: Event) {\n    super.onValueChanged($event);\n\n    this.refreshActiveTextBox();\n  }\n\n  public selfSaveData(data: any): void {\n    super.selfSaveData(data);\n\n    this.refreshActiveTextBox();\n  }\n\n  public getDescription(): string {\n    return this.description;\n  }\n\n  public setDescription(description: string): void {\n    this.description = description;\n  }\n\n  public getLabel(): string {\n    return this.label;\n  }\n\n  public setLabel(label: string): void {\n    this.label = label;\n  }\n\n  public resetValidationResult(): void {\n    super.resetValidationResult();\n\n    this.active = false;\n  }\n\n  public onBtnClick($event: Event) {\n    if (!this.isReadOnly() && !this.isDisabled()) {\n\n      this.setButtonHandler(this.showClearButton ? this.clearFunc : this.buttonHandler);\n\n      if (this.buttonHandler !== null && this.buttonHandler !== undefined) {\n        this.buttonHandler(this, $event);\n      }\n    }\n  }\n\n  public isShowClearButton(): boolean {\n    return this.showClearButton;\n  }\n\n  public setShowClearButton(showClearButton: boolean): void {\n    this.showClearButton = showClearButton;\n  }\n\n  public getButtonIcon(): string {\n    return this.showClearButton ? DEFAULT_BUTTON_ICON : this.buttonIcon;\n  }\n\n  public setButtonIcon(buttonIcon: string): void {\n    this.buttonIcon = buttonIcon;\n  }\n\n  public getButtonPosition(): string {\n    return this.showClearButton ? 