com.phloxui
Version:
PhloxUI Ng2+ Framework
619 lines (618 loc) • 46.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, Input, Output, ElementRef, EventEmitter } from '@angular/core';
import { TextArea } from '../../../../../component/dataview/input/TextArea.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';
const /** @type {?} */ TYPE_NAME = "material-text-area";
const /** @type {?} */ NORMAL = 'normal';
const /** @type {?} */ SUCCESS = 'success';
const /** @type {?} */ WARNING = 'warning';
const /** @type {?} */ ERROR = 'error';
export class MaterialTextArea extends TextArea {
/**
* @param {?} elementRef
* @param {?} formatterFactory
* @param {?} needFocusService
*/
constructor(elementRef, formatterFactory, needFocusService) {
super(elementRef, formatterFactory, needFocusService);
this.active = false;
}
/**
* @return {?}
*/
ngOnInit() {
super.ngOnInit();
this.refreshActiveTextArea();
}
/**
* @return {?}
*/
refreshActiveTextArea() {
let /** @type {?} */ val = this.formattedData;
if (val !== null && typeof val !== 'undefined') {
if (typeof val === 'string' && val === '') {
this.active = false;
return;
}
if (!this.active) {
this.active = true;
}
}
else {
this.active = false;
}
}
/**
* @return {?}
*/
doExpand() {
if (this.elementRef && typeof $(this.elementRef.nativeElement).find('.material-text-area') !== 'undefined') {
let /** @type {?} */ ele = $(this.elementRef.nativeElement).find('.material-text-area');
if (typeof $(ele).find('textarea') !== 'undefined') {
let /** @type {?} */ textarea = $(ele).find('textarea');
if (textarea[0].clientHeight < textarea[0].scrollHeight) {
textarea.height((textarea[0].scrollHeight));
}
}
}
}
/**
* @return {?}
*/
getClassMatFocused() {
return this.isReadOnly() ? { 'mat-focused': this._isClassFocused() } : {};
}
/**
* @return {?}
*/
_hasLabel() {
if (this.label !== null && typeof this.label === 'string') {
return true;
}
return false;
}
/**
* @return {?}
*/
_hasDescription() {
if (this.description !== null && typeof this.description === 'string' && this.description !== '') {
return true;
}
return false;
}
/**
* @return {?}
*/
_displayHelp() {
let /** @type {?} */ hasHelp = this.hasHelp();
return hasHelp;
}
/**
* @return {?}
*/
_isActive() {
return this.active;
}
/**
* @return {?}
*/
_isClassFocused() {
return this.classFocused;
}
/**
* @param {?} $event
* @return {?}
*/
onKeyUp($event) {
// emit event
super.onKeyUp($event);
}
/**
* @param {?} inputValue
* @param {?} results
* @return {?}
*/
onValidationEnd(inputValue, results) {
}
/**
* @param {?} data
* @param {?} inputVal
* @return {?}
*/
onDataChange(data, inputVal) {
super.onDataChange(data, inputVal);
this.refreshActiveTextArea();
}
/**
* @param {?} $event
* @return {?}
*/
doFocus($event) {
super.doFocus($event);
this.active = true;
this.classFocused = true;
}
/**
* @param {?} $event
* @return {?}
*/
doLostFocus($event) {
super.doLostFocus($event);
this.refreshActiveTextArea();
this.classFocused = false;
}
/**
* @param {?} event
* @return {?}
*/
onFocus(event) {
super.onFocus(event);
this.active = true;
this.classFocused = true;
}
/**
* @param {?} $event
* @return {?}
*/
onFocusing($event) {
this.needFocusService.setFocusingComponent(this, $event);
}
/**
* @param {?} $event
* @return {?}
*/
onLostFocusing($event) {
this.needFocusService.resetFocusingComponent($event);
}
/**
* @param {?} $event
* @return {?}
*/
onValueChanged($event) {
super.onValueChanged($event);
this.refreshActiveTextArea();
}
/**
* @return {?}
*/
getDescription() {
return this.description;
}
/**
* @param {?} description
* @return {?}
*/
setDescription(description) {
this.description = description;
}
/**
* @return {?}
*/
getLabel() {
return this.label;
}
/**
* @param {?} label
* @return {?}
*/
setLabel(label) {
this.label = label;
}
/**
* @return {?}
*/
isAutosize() {
return this.autosize;
}
/**
* @param {?} autosize
* @return {?}
*/
setAutosize(autosize) {
this.autosize = autosize;
}
/**
* @return {?}
*/
getMatAutosizeMinRows() {
return this.matAutosizeMinRows;
}
/**
* @param {?} matAutosizeMinRows
* @return {?}
*/
setMatAutosizeMinRows(matAutosizeMinRows) {
this.matAutosizeMinRows = matAutosizeMinRows;
}
/**
* @return {?}
*/
getMatAutosizeMaxRows() {
return this.matAutosizeMaxRows;
}
/**
* @param {?} matAutosizeMaxRows
* @return {?}
*/
setMatAutosizeMaxRows(matAutosizeMaxRows) {
this.matAutosizeMaxRows = matAutosizeMaxRows;
}
}
MaterialTextArea.TYPE_NAME = TYPE_NAME;
MaterialTextArea.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: `<div class="material-input material-text-area" [style.width]="getWidth()">
<div class="textarea-wrapper" [class.active]="_isActive()">
<mat-form-field [ngClass]="getClassMatFocused()">
<textarea *ngIf="isAutosize() !== null && isAutosize() !== undefined && isAutosize()" matInput placeholder="{{getLabel() | phx_text}}" [disabled]="isDisabled()" [readonly]="isReadOnly()" [class.dirty]="isDataDirty()" (change)="onValueChanged($event)"
(focusin)="onFocusing($event)" (blur)="onLostFocusing($event)" (keyup)="onKeyUp($event)" (keydown)="onKeyDown($event)" [value]="formattedData | phx_text" [class.normal]="isNormal() && !isDisabled()" [class.success]="isSuccess() && !isDisabled()"
[class.warning]="isWarning() && !isDisabled()" [class.error]="isError() && !isDisabled()" [mat-autosize]="isAutosize()" [matAutosizeMinRows]="getMatAutosizeMinRows()" [matAutosizeMaxRows]="getMatAutosizeMaxRows()"></textarea>
<textarea *ngIf="isAutosize() === null || isAutosize() === undefined || !isAutosize()" matInput placeholder="{{getLabel() | phx_text}}" [disabled]="isDisabled()" [readonly]="isReadOnly()" [class.dirty]="isDataDirty()"
(change)="onValueChanged($event)" (focusin)="onFocusing($event)" (blur)="onLostFocusing($event)" (keyup)="onKeyUp($event)" (keydown)="onKeyDown($event)" [value]="formattedData | phx_text" [class.normal]="isNormal() && !isDisabled()"
[class.success]="isSuccess() && !isDisabled()" [class.warning]="isWarning() && !isDisabled()" [class.error]="isError() && !isDisabled()"></textarea>
</mat-form-field>
</div>
<div class="validation" [style.display]="getValidationResultMessage() ? undefined : 'none'" [class.normal]="isNormal() && !isDisabled()" [class.success]="isSuccess() && !isDisabled()" [class.warning]="isWarning() && !isDisabled()" [class.error]="isError() && !isDisabled()">
<ng-template [ngIf]="getValidationResultMessage()" [ngIfElse]="validation_else">
{{getValidationResultMessage() | phx_text}}
</ng-template>
<ng-template #validation_else>
<!-- We've to put whitespace if there is no validation msg to prevent empty dom -->
<!-- since if validate msg's <div> dom is empty, the component positioning -->
<!-- will be misplaced. -->
{{ ' ' }}
</ng-template>
</div>
<div class="description" [style.display]="getValidationResultMessage() ? 'none' : undefined" [class.normal]="isNormal() && !isDisabled()" [class.success]="isSuccess() && !isDisabled()" [class.warning]="isWarning() && !isDisabled()" [class.error]="isError() && !isDisabled()">
<ng-template [ngIf]="getDescription()" [ngIfElse]="description_else">
{{ getDescription() | phx_text }}
</ng-template>
<ng-template #description_else>
<!-- We've to put whitespace if there is no description to prevent empty dom -->
<!-- since if description's <div> dom is empty, the component positioning -->
<!-- will be misplaced. -->
{{ ' ' }}
</ng-template>
</div>
<div class="help">
{{getHelp() | phx_text}}
</div>
</div>
`
},] },
];
/** @nocollapse */
MaterialTextArea.ctorParameters = () => [
{ type: ElementRef, },
{ type: FormatterFactory, },
{ type: NeedFocusService, },
];
MaterialTextArea.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 },],
"cols": [{ type: Input },],
"rows": [{ type: Input },],
"label": [{ type: Input },],
"description": [{ type: Input },],
"autosize": [{ type: Input },],
"matAutosizeMinRows": [{ type: Input },],
"matAutosizeMaxRows": [{ 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)
], MaterialTextArea.prototype, "dataParent", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextArea.prototype, "ignoreParentData", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], MaterialTextArea.prototype, "data", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextArea.prototype, "ignoreParentDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextArea.prototype, "delegateHistory", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], MaterialTextArea.prototype, "onDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], MaterialTextArea.prototype, "onEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextArea.prototype, "loadingEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextArea.prototype, "i18nKey", void 0);
tslib_1.__decorate([
Option('i18nBypass'),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextArea.prototype, "bypass", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextArea.prototype, "disabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextArea.prototype, "field", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextArea.prototype, "name", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextArea.prototype, "typeOfData", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextArea.prototype, "readOnly", void 0);
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", Object)
], MaterialTextArea.prototype, "help", void 0);
tslib_1.__decorate([
Option('formatter.instance'),
tslib_1.__metadata("design:type", Object)
], MaterialTextArea.prototype, "formatter", void 0);
tslib_1.__decorate([
Option('formatter.name'),
tslib_1.__metadata("design:type", String)
], MaterialTextArea.prototype, "formatterName", void 0);
tslib_1.__decorate([
Option('formatter.options'),
tslib_1.__metadata("design:type", Object)
], MaterialTextArea.prototype, "formatterOptions", void 0);
tslib_1.__decorate([
Option('formatter.usePropertyValue'),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextArea.prototype, "formatterUsePropertyValue", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextArea.prototype, "type", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextArea.prototype, "width", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Number)
], MaterialTextArea.prototype, "cols", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Number)
], MaterialTextArea.prototype, "rows", void 0);
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextArea.prototype, "label", void 0);
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", String)
], MaterialTextArea.prototype, "description", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialTextArea.prototype, "autosize", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Number)
], MaterialTextArea.prototype, "matAutosizeMinRows", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Number)
], MaterialTextArea.prototype, "matAutosizeMaxRows", void 0);
tslib_1.__decorate([
Option('load'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "loadEvent", void 0);
tslib_1.__decorate([
Option('startValidate'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "startValidateEvent", void 0);
tslib_1.__decorate([
Option('endValidate'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "endValidateEvent", void 0);
tslib_1.__decorate([
Option('beforeFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "beforeFocusEvent", void 0);
tslib_1.__decorate([
Option('focus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "focusEvent", void 0);
tslib_1.__decorate([
Option('beforeLostFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "beforeLostFocusEvent", void 0);
tslib_1.__decorate([
Option('lostFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "lostFocusEvent", void 0);
tslib_1.__decorate([
Option('beforeChange'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "beforeChangeEvent", void 0);
tslib_1.__decorate([
Option('change'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "changeEvent", void 0);
tslib_1.__decorate([
Option('beforeKeyUp'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "beforeKeyUpEvent", void 0);
tslib_1.__decorate([
Option('keyUp'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "keyUpEvent", void 0);
tslib_1.__decorate([
Option('beforeKeyDown'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "beforeKeyDownEvent", void 0);
tslib_1.__decorate([
Option('keyDown'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialTextArea.prototype, "keyDownEvent", void 0);
function MaterialTextArea_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
MaterialTextArea.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
MaterialTextArea.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
MaterialTextArea.propDecorators;
/** @type {?} */
MaterialTextArea.TYPE_NAME;
/** @type {?} */
MaterialTextArea.prototype.dataParent;
/** @type {?} */
MaterialTextArea.prototype.ignoreParentData;
/** @type {?} */
MaterialTextArea.prototype.data;
/** @type {?} */
MaterialTextArea.prototype.ignoreParentDisabled;
/** @type {?} */
MaterialTextArea.prototype.delegateHistory;
/** @type {?} */
MaterialTextArea.prototype.onDisabled;
/** @type {?} */
MaterialTextArea.prototype.onEnabled;
/** @type {?} */
MaterialTextArea.prototype.loadingEnabled;
/** @type {?} */
MaterialTextArea.prototype.i18nKey;
/** @type {?} */
MaterialTextArea.prototype.bypass;
/** @type {?} */
MaterialTextArea.prototype.options;
/** @type {?} */
MaterialTextArea.prototype.disabled;
/** @type {?} */
MaterialTextArea.prototype.field;
/** @type {?} */
MaterialTextArea.prototype.name;
/** @type {?} */
MaterialTextArea.prototype.typeOfData;
/** @type {?} */
MaterialTextArea.prototype.readOnly;
/** @type {?} */
MaterialTextArea.prototype.help;
/** @type {?} */
MaterialTextArea.prototype.formatter;
/** @type {?} */
MaterialTextArea.prototype.formatterName;
/** @type {?} */
MaterialTextArea.prototype.formatterOptions;
/** @type {?} */
MaterialTextArea.prototype.formatterUsePropertyValue;
/** @type {?} */
MaterialTextArea.prototype.type;
/** @type {?} */
MaterialTextArea.prototype.width;
/** @type {?} */
MaterialTextArea.prototype.cols;
/** @type {?} */
MaterialTextArea.prototype.rows;
/** @type {?} */
MaterialTextArea.prototype.label;
/** @type {?} */
MaterialTextArea.prototype.description;
/** @type {?} */
MaterialTextArea.prototype.autosize;
/** @type {?} */
MaterialTextArea.prototype.matAutosizeMinRows;
/** @type {?} */
MaterialTextArea.prototype.matAutosizeMaxRows;
/** @type {?} */
MaterialTextArea.prototype.loadEvent;
/** @type {?} */
MaterialTextArea.prototype.startValidateEvent;
/** @type {?} */
MaterialTextArea.prototype.endValidateEvent;
/** @type {?} */
MaterialTextArea.prototype.beforeFocusEvent;
/** @type {?} */
MaterialTextArea.prototype.focusEvent;
/** @type {?} */
MaterialTextArea.prototype.beforeLostFocusEvent;
/** @type {?} */
MaterialTextArea.prototype.lostFocusEvent;
/** @type {?} */
MaterialTextArea.prototype.beforeChangeEvent;
/** @type {?} */
MaterialTextArea.prototype.changeEvent;
/** @type {?} */
MaterialTextArea.prototype.beforeKeyUpEvent;
/** @type {?} */
MaterialTextArea.prototype.keyUpEvent;
/** @type {?} */
MaterialTextArea.prototype.beforeKeyDownEvent;
/** @type {?} */
MaterialTextArea.prototype.keyDownEvent;
/** @type {?} */
MaterialTextArea.prototype.active;
/** @type {?} */
MaterialTextArea.prototype.classFocused;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MaterialTextArea.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/theme/material/component/dataview/input/MaterialTextArea.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, ElementRef, EventEmitter } from '@angular/core';\r\nimport { TextArea } from '../../../../../component/dataview/input/TextArea.component';\r\nimport { IHasData } from '../../../../../component/IHasData';\r\nimport { ValidationResult } from '../../../../../component/model/ValidationResult';\r\nimport { IHasHelp } from '../../../../../component/IHasHelp';\r\nimport { I18N } from '../../../../../decorator/I18N.decorator';\r\nimport { Option } from '../../../../../decorator/Option.decorator';\r\nimport { NeedFocusService } from '../../../../../service/NeedFocusService.service';\r\nimport { FormatterFactory } from '../../../../../service/FormatterFactory.service';\r\nimport { IFormatter } from '../../../../../share/formatter/IFormatter';\r\n\r\ndeclare var $: any;\r\n\r\nconst TYPE_NAME: string = \"material-text-area\";\r\n\r\nconst NORMAL: string = 'normal';\r\nconst SUCCESS: string = 'success';\r\nconst WARNING: string = 'warning';\r\nconst ERROR: string = 'error';\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"material-input material-text-area\" [style.width]=\"getWidth()\">\r\n\t<div class=\"textarea-wrapper\" [class.active]=\"_isActive()\">\r\n\t\t<mat-form-field [ngClass]=\"getClassMatFocused()\">\r\n\t\t\t<textarea *ngIf=\"isAutosize() !== null && isAutosize() !== undefined && isAutosize()\" matInput placeholder=\"{{getLabel() | phx_text}}\" [disabled]=\"isDisabled()\" [readonly]=\"isReadOnly()\" [class.dirty]=\"isDataDirty()\" (change)=\"onValueChanged($event)\"\r\n\t\t\t  (focusin)=\"onFocusing($event)\" (blur)=\"onLostFocusing($event)\" (keyup)=\"onKeyUp($event)\" (keydown)=\"onKeyDown($event)\" [value]=\"formattedData | phx_text\" [class.normal]=\"isNormal() && !isDisabled()\" [class.success]=\"isSuccess() && !isDisabled()\"\r\n\t\t\t  [class.warning]=\"isWarning() && !isDisabled()\" [class.error]=\"isError() && !isDisabled()\" [mat-autosize]=\"isAutosize()\" [matAutosizeMinRows]=\"getMatAutosizeMinRows()\" [matAutosizeMaxRows]=\"getMatAutosizeMaxRows()\"></textarea>\r\n\t\t\t<textarea *ngIf=\"isAutosize() === null || isAutosize() === undefined || !isAutosize()\" matInput placeholder=\"{{getLabel() | phx_text}}\" [disabled]=\"isDisabled()\" [readonly]=\"isReadOnly()\" [class.dirty]=\"isDataDirty()\"\r\n\t\t\t  (change)=\"onValueChanged($event)\" (focusin)=\"onFocusing($event)\" (blur)=\"onLostFocusing($event)\" (keyup)=\"onKeyUp($event)\" (keydown)=\"onKeyDown($event)\" [value]=\"formattedData | phx_text\" [class.normal]=\"isNormal() && !isDisabled()\"\r\n\t\t\t  [class.success]=\"isSuccess() && !isDisabled()\" [class.warning]=\"isWarning() && !isDisabled()\" [class.error]=\"isError() && !isDisabled()\"></textarea>\r\n\t\t</mat-form-field>\r\n\t</div>\r\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()\">\r\n\t\t<ng-template [ngIf]=\"getValidationResultMessage()\" [ngIfElse]=\"validation_else\">\r\n\t\t\t{{getValidationResultMessage() | phx_text}}\r\n\t\t</ng-template>\r\n\t\t<ng-template #validation_else>\r\n\t\t\t<!-- We've to put whitespace if there is no validation msg to prevent empty dom -->\r\n\t\t\t<!-- since if validate msg's <div> dom is empty, the component positioning -->\r\n\t\t\t<!-- will be misplaced. -->\r\n\t\t\t{{ '&nbsp;' }}\r\n\t\t</ng-template>\r\n\t</div>\r\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()\">\r\n\t\t<ng-template [ngIf]=\"getDescription()\" [ngIfElse]=\"description_else\">\r\n\t\t\t{{ getDescription() | phx_text }}\r\n\t\t</ng-template>\r\n\t\t<ng-template #description_else>\r\n\t\t\t<!-- We've to put whitespace if there is no description to prevent empty dom -->\r\n\t\t\t<!-- since if description's <div> dom is empty, the component positioning -->\r\n\t\t\t<!-- will be misplaced. -->\r\n\t\t\t{{ '&nbsp;' }}\r\n\t\t</ng-template>\r\n\t</div>\r\n\t<div class=\"help\">\r\n\t\t{{getHelp() | phx_text}}\r\n\t</div>\r\n</div>\r\n`\r\n})\r\nexport class MaterialTextArea extends TextArea implements OnInit, IHasHelp {\r\n\r\n  public static readonly TYPE_NAME: string = TYPE_NAME;\r\n\r\n  // Re-declare field to declare ng @Input.\r\n  // --- from AbstractHasData\r\n  @Input()\r\n  @Option()\r\n  protected dataParent: IHasData;\r\n  @Input()\r\n  @Option()\r\n  protected ignoreParentData: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected data: any;\r\n  @Input()\r\n  @Option()\r\n  protected ignoreParentDisabled: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected delegateHistory: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected onDisabled: Function;\r\n  @Input()\r\n  @Option()\r\n  protected onEnabled: Function;\r\n  @Input()\r\n  @Option()\r\n  protected loadingEnabled: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected i18nKey: string;\r\n  @Input('i18nBypass')\r\n  @Option('i18nBypass')\r\n  protected bypass: boolean;\r\n  @Input()\r\n  protected options: any;\r\n  @Input()\r\n  @Option()\r\n  protected disabled: boolean;\r\n  // --- from AbstractDataView\r\n  @Input()\r\n  @Option()\r\n  protected field: string;\r\n  // --- from AbstractInputDataView\r\n  @Input()\r\n  @Option()\r\n  protected name: string;\r\n  @Input()\r\n  @Option()\r\n  protected typeOfData: string;\r\n  @Input()\r\n  @Option()\r\n  protected readOnly: boolean;\r\n  @Input()\r\n  @I18N()\r\n  @Option()\r\n  protected help: any;\r\n  // --- from AbstractHasFormatterInputDataView\r\n  @Input('formatter')\r\n  @Option('formatter.instance')\r\n  protected formatter: IFormatter;\r\n  @Input('formatterName')\r\n  @Option('formatter.name')\r\n  protected formatterName: string;\r\n  @Input('formatterOptions')\r\n  @Option('formatter.options')\r\n  protected formatterOptions: any;\r\n  @Input('formatterUsePropertyValue')\r\n  @Option('formatter.usePropertyValue')\r\n  protected formatterUsePropertyValue: boolean;\r\n  // --- from TextBox\r\n  @Input()\r\n  @Option()\r\n  protected type: string;\r\n  @Input()\r\n  @Option()\r\n  protected width: string;\r\n  // --- from TextArea\r\n  @Input()\r\n  @Option()\r\n  protected cols: number;\r\n  @Input()\r\n  @Option()\r\n  protected rows: number;\r\n  // --- self\r\n  @Input()\r\n  @I18N()\r\n  @Option()\r\n  protected label: string;\r\n  @Input()\r\n  @I18N()\r\n  @Option()\r\n  protected description: string;\r\n  @Input()\r\n  @Option()\r\n  protected autosize: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected matAutosizeMinRows: number;\r\n  @Input()\r\n  @Option()\r\n  protected matAutosizeMaxRows: number;\r\n\r\n  // Re-declare field to declare ng @Output.\r\n  // --- from AbstractHasData\r\n  @Output('phxLoad')\r\n  @Option('load')\r\n  protected loadEvent: EventEmitter<any>;\r\n  // --- from AbstractDataView\r\n  // --- from AbstractInputDataView\r\n  @Output('phxStartValidate')\r\n  @Option('startValidate')\r\n  protected startValidateEvent: EventEmitter<any>;\r\n  @Output('phxEndValidate')\r\n  @Option('endValidate')\r\n  protected endValidateEvent: EventEmitter<any>;\r\n  @Output('phxBeforeFocus')\r\n  @Option('beforeFocus')\r\n  protected beforeFocusEvent: EventEmitter<any>;\r\n  @Output('phxFocus')\r\n  @Option('focus')\r\n  protected focusEvent: EventEmitter<any>;\r\n  @Output('phxBeforeLostFocus')\r\n  @Option('beforeLostFocus')\r\n  protected beforeLostFocusEvent: EventEmitter<any>;\r\n  @Output('phxLostFocus')\r\n  @Option('lostFocus')\r\n  protected lostFocusEvent: EventEmitter<any>;\r\n  @Output('phxBeforeChange')\r\n  @Option('beforeChange')\r\n  protected beforeChangeEvent: EventEmitter<any>;\r\n  @Output('phxChange') \r\n  @Option('change')\r\n  protected changeEvent: EventEmitter<any>;\r\n  // --- from AbstractHasFormatterInputDataView\r\n  // --- from TextBox\r\n  @Option('beforeKeyUp')\r\n  @Output('phxBeforeKeyUp')\r\n  protected beforeKeyUpEvent: EventEmitter<any>;\r\n  @Option('keyUp')\r\n  @Output('phxKeyUp')\r\n  protected keyUpEvent: EventEmitter<any>;\r\n  @Option('beforeKeyDown')\r\n  @Output('phxBeforeKeyDown')\r\n  protected beforeKeyDownEvent: EventEmitter<any>;\r\n  @Option('keyDown')\r\n  @Output('phxKeyDown')\r\n  protected keyDownEvent: EventEmitter<any>;\r\n\r\n  // --- from Self\r\n  private active: boolean;\r\n  private classFocused: boolean;\r\n  // private _autoExpand: boolean;\r\n\r\n  constructor(elementRef: ElementRef, formatterFactory: FormatterFactory, needFocusService: NeedFocusService) {\r\n    super(elementRef, formatterFactory, needFocusService);\r\n\r\n    this.active = false;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    this.refreshActiveTextArea();\r\n  } \r\n\r\n  private refreshActiveTextArea(): void {\r\n    let val = this.formattedData;\r\n\r\n    if (val !== null && typeof val !== 'undefined') {\r\n      if (typeof val === 'string' && val === '') {\r\n        this.active = false;\r\n        return;\r\n      }\r\n      if (!this.active) {\r\n        this.active = true;\r\n      }\r\n    } else {\r\n      this.active = false;\r\n    }\r\n  }\r\n\r\n  private doExpand(): void {\r\n    if (this.elementRef && typeof $(this.elementRef.nativeElement).find('.material-text-area') !== 'undefined') {\r\n      let ele = $(this.elementRef.nativeElement).find('.material-text-area');\r\n\r\n      if (typeof $(ele).find('textarea') !== 'undefined') {\r\n        let textarea = $(ele).find('textarea');\r\n\r\n        if (textarea[0].clientHeight < textarea[0].scrollHeight) {\r\n          textarea.height((textarea[0].scrollHeight));\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  public getClassMatFocused(): any{\r\n    return this.isReadOnly() ? {'mat-focused': this._isClassFocused()} : {};\r\n  }\r\n\r\n  public _hasLabel(): boolean {\r\n    if (this.label !== null && typeof this.label === 'string') {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public _hasDescription(): boolean {\r\n    if (this.description !== null && typeof this.description === 'string' && this.description !== '') {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public _displayHelp(): boolean {\r\n    let hasHelp = this.hasHelp();\r\n\r\n    return hasHelp;\r\n  }\r\n\r\n  public _isActive(): boolean {\r\n    return this.active;\r\n  }\r\n\r\n  public _isClassFocused(): boolean {\r\n    return this.classFocused;\r\n  }\r\n\r\n  // To auto expand textarea\r\n  public onKeyUp($event: Event): void {\r\n    // emit event\r\n    super.onKeyUp($event);\r\n  }\r\n\r\n  protected onValidationEnd(inputValue: any, results: ValidationResult[]): void {\r\n  }\r\n\r\n  protected onDataChange(data: any, inputVal: any): void {\r\n    super.onDataChange(data, inputVal);\r\n\r\n    this.refreshActiveTextArea();\r\n  }\r\n\r\n  protected doFocus($event: Event): void {\r\n    super.doFocus($event);\r\n\r\n    this.active = true;\r\n    this.classFocused = true;\r\n  }\r\n\r\n  protected doLostFocus($event: Event): void {\r\n    super.doLostFocus($event);\r\n\r\n    this.refreshActiveTextArea();\r\n    this.classFocused = false;\r\n  }\r\n  public onFocus(event: any): void {\r\n    super.onFocus(event);\r\n\r\n    this.active = true;\r\n    this.classFocused = true;\r\n  }\r\n\r\n  public onFocusing($event: Event): void {\r\n    this.needFocusService.setFocusingComponent(this, $event);\r\n  }\r\n\r\n  public onLostFocusing($event: Event): void {\r\n    this.needFocusService.resetFocusingComponent($event);\r\n  }\r\n\r\n  public onValueChanged($event: Event) {\r\n    super.onValueChanged($event);\r\n\r\n    this.refreshActiveTextArea();\r\n  }\r\n\r\n  public getDescription(): string {\r\n    return this.description;\r\n  }\r\n\r\n  public setDescription(description: string): void {\r\n    this.description = description;\r\n  }\r\n\r\n  public getLabel(): string {\r\n    return this.label;\r\n  }\r\n\r\n  public setLabel(label: string): void {\r\n    this.label = label;\r\n  }\r\n\r\n  public isAutosize(): boolean {\r\n    return this.autosize;\r\n  }\r\n\r\n  public setAutosize(autosize: boolean): void {\r\n    this.autosize = autosize;\r\n  }\r\n\r\n  public getMatAutosizeMinRows(): number {\r\n    return this.matAutosizeMinRows;\r\n  }\r\n\r\n  public setMatAutosizeMinRows(matAutosizeMinRows: number): void {\r\n    this.matAutosizeMinRows = matAutosizeMinRows;\r\n  }\r\n\r\n  public getMatAutosizeMaxRows(): number {\r\n    return this.matAutosizeMaxRows;\r\n  }\r\n\r\n  public setMatAutosizeMaxRows(matAutosizeMaxRows: number): void {\r\n    this.matAutosizeMaxRows = matAutosizeMaxRows;\r\n  }\r\n}\r\n"]}