com.phloxui
Version:
PhloxUI Ng2+ Framework
243 lines (242 loc) • 17.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, Input, Output, EventEmitter, ElementRef } from '@angular/core';
import { AbstractHasFormatterDataView } from './AbstractHasFormatterDataView';
import { DATA_CHANGE_EVENT } from '../../share/CustomEventType';
import { FormatterFactory } from '../../service/FormatterFactory.service';
import { Option } from '../../decorator/Option.decorator';
import { EventUtils } from '../../share/utils/EventUtils';
var /** @type {?} */ TYPE_NAME = "phx-string-editor-data-view";
var /** @type {?} */ DEFAULT_FIELD = "label";
var StringEditorDataView = /** @class */ (function (_super) {
tslib_1.__extends(StringEditorDataView, _super);
function StringEditorDataView(elementRef, formatterFactory) {
var _this = _super.call(this, elementRef, formatterFactory) || this;
_this.DEFAULT_FIELD_NAME = "label";
_this.handler = new EventEmitter();
_this.changeEvent = new EventEmitter();
return _this;
}
/**
* @return {?}
*/
StringEditorDataView.prototype.ngOnInit = /**
* @return {?}
*/
function () {
_super.prototype.ngOnInit.call(this);
// Auto set default field if not specified
if (this.field === null || typeof this.field !== 'string') {
this.field = DEFAULT_FIELD;
}
if (this.data !== null && typeof this.data !== 'undefined') {
this.setData(this.data);
}
};
/**
* @param {?} changes
* @return {?}
*/
StringEditorDataView.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes['data'] !== null && typeof changes['data'] !== 'undefined') {
var /** @type {?} */ oldData = changes['data'].previousValue;
var /** @type {?} */ newData = changes['data'].currentValue;
if (oldData !== newData) {
this.setData(newData);
}
}
};
/**
* @param {?} $event
* @return {?}
*/
StringEditorDataView.prototype.onValueChanged = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ data = {
data: this.value,
source: ($event === null || typeof $event === 'undefined') ? undefined : $event.target
};
var /** @type {?} */ ev = EventUtils.newCustomEvent(DATA_CHANGE_EVENT, this, data, $event);
this.changeEvent.emit(ev);
this.handler.emit(ev);
this.handler.emit($event);
};
/**
* @param {?} data
* @return {?}
*/
StringEditorDataView.prototype.setData = /**
* @param {?} data
* @return {?}
*/
function (data) {
_super.prototype.setData.call(this, data);
this.value = this.getFormattedData();
};
/**
* @return {?}
*/
StringEditorDataView.prototype.getEventHandler = /**
* @return {?}
*/
function () {
return this.handler;
};
/**
* @param {?} event
* @return {?}
*/
StringEditorDataView.prototype.setEventHandler = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.handler = event;
};
/**
* @return {?}
*/
StringEditorDataView.prototype.getChangeEvent = /**
* @return {?}
*/
function () {
return this.changeEvent;
};
/**
* @param {?} event
* @return {?}
*/
StringEditorDataView.prototype.setChangeEvent = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.changeEvent = event;
};
/**
* @return {?}
*/
StringEditorDataView.prototype.isSelfDataDirty = /**
* @return {?}
*/
function () {
return false;
};
/**
* @return {?}
*/
StringEditorDataView.prototype.selfSaveData = /**
* @return {?}
*/
function () {
};
/**
* @return {?}
*/
StringEditorDataView.prototype.selfResetData = /**
* @return {?}
*/
function () {
};
StringEditorDataView.TYPE_NAME = TYPE_NAME;
StringEditorDataView.DEFAULT_FIELD = DEFAULT_FIELD;
StringEditorDataView.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"phx-string-editor-data-view\"><input type=\"text\" class=\"form-control\" [(ngModel)]=\"value\" (input)=\"onValueChanged($event)\"></div>\n"
},] },
];
/** @nocollapse */
StringEditorDataView.ctorParameters = function () { return [
{ type: ElementRef, },
{ type: FormatterFactory, },
]; };
StringEditorDataView.propDecorators = {
"data": [{ type: Input },],
"field": [{ type: Input },],
"dataParent": [{ type: Input },],
"ignoreParentData": [{ 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 },],
"handler": [{ type: Output, args: ['phxHandler',] },],
"changeEvent": [{ type: Output, args: ['phxChange',] },],
};
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", EventEmitter)
], StringEditorDataView.prototype, "handler", void 0);
tslib_1.__decorate([
Option('change'),
tslib_1.__metadata("design:type", EventEmitter)
], StringEditorDataView.prototype, "changeEvent", void 0);
return StringEditorDataView;
}(AbstractHasFormatterDataView));
export { StringEditorDataView };
function StringEditorDataView_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
StringEditorDataView.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
StringEditorDataView.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
StringEditorDataView.propDecorators;
/** @type {?} */
StringEditorDataView.TYPE_NAME;
/** @type {?} */
StringEditorDataView.DEFAULT_FIELD;
/** @type {?} */
StringEditorDataView.prototype.value;
/** @type {?} */
StringEditorDataView.prototype.DEFAULT_FIELD_NAME;
/** @type {?} */
StringEditorDataView.prototype.data;
/** @type {?} */
StringEditorDataView.prototype.field;
/** @type {?} */
StringEditorDataView.prototype.dataParent;
/** @type {?} */
StringEditorDataView.prototype.ignoreParentData;
/** @type {?} */
StringEditorDataView.prototype.ignoreParentDisabled;
/** @type {?} */
StringEditorDataView.prototype.delegateHistory;
/** @type {?} */
StringEditorDataView.prototype.onDisabled;
/** @type {?} */
StringEditorDataView.prototype.onEnabled;
/** @type {?} */
StringEditorDataView.prototype.loadingEnabled;
/** @type {?} */
StringEditorDataView.prototype.i18nKey;
/** @type {?} */
StringEditorDataView.prototype.bypass;
/** @type {?} */
StringEditorDataView.prototype.options;
/** @type {?} */
StringEditorDataView.prototype.disabled;
/** @type {?} */
StringEditorDataView.prototype.handler;
/** @type {?} */
StringEditorDataView.prototype.changeEvent;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"StringEditorDataView.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/dataview/StringEditorDataView.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, ElementRef } from '@angular/core';\nimport { IDataView } from './IDataView';\nimport { AbstractHasFormatterDataView } from './AbstractHasFormatterDataView';\nimport { DataUtils } from '../../share/utils/DataUtils';\nimport { DATA_CHANGE_EVENT } from '../../share/CustomEventType';\nimport { FormatterFactory } from '../../service/FormatterFactory.service';\nimport { Option } from '../../decorator/Option.decorator';\nimport { EventUtils } from '../../share/utils/EventUtils';\nimport { IHasData } from '../IHasData';\n\nconst TYPE_NAME: string = \"phx-string-editor-data-view\";\n\nconst DEFAULT_FIELD: string = \"label\";\n\n// Waiting for remove. Use TextBox instade this component\n@Component({\n    moduleId: module.id,\n    selector: TYPE_NAME,\n    template: `<div class=\"phx-string-editor-data-view\"><input type=\"text\" class=\"form-control\" [(ngModel)]=\"value\" (input)=\"onValueChanged($event)\"></div>\n`\n})\nexport class StringEditorDataView extends AbstractHasFormatterDataView implements OnInit {\n\n    public static readonly TYPE_NAME: string = TYPE_NAME;\n\n    public static readonly DEFAULT_FIELD: string = DEFAULT_FIELD;\n\n    public value: string;\n\n    private DEFAULT_FIELD_NAME: string = \"label\";\n\n    @Input()\n    protected data: any;\n    @Input()\n    protected field: string;\n    @Input()\n    protected dataParent: IHasData;\n    @Input()\n    protected ignoreParentData: boolean;\n    @Input()\n    protected ignoreParentDisabled: boolean;\n    @Input()\n    protected delegateHistory: boolean;\n    @Input()\n    protected onDisabled: Function;\n    @Input()\n    protected onEnabled: Function;\n    @Input()\n    protected loadingEnabled: boolean;\n    @Input()\n    protected i18nKey: string;\n    @Input('i18nBypass')\n    protected bypass: boolean;\n    @Input()\n    protected options: any;\n    @Input()\n    protected disabled: boolean;\n    @Option()\n    @Output('phxHandler')\n    protected handler: EventEmitter<any>;\n    @Option('change')\n    @Output('phxChange')\n    protected changeEvent: EventEmitter<any>;\n\n    constructor(elementRef: ElementRef, formatterFactory: FormatterFactory) {\n        super(elementRef, formatterFactory);\n\n        this.handler = new EventEmitter();\n        this.changeEvent = new EventEmitter();\n    }\n\n    // Override\n    public ngOnInit(): void {\n      super.ngOnInit();\n\n      // Auto set default field if not specified\n      if (this.field === null || typeof this.field !== 'string') {\n        this.field = DEFAULT_FIELD;\n      }\n\n      if(this.data !== null && typeof this.data !== 'undefined'){\n        this.setData(this.data);\n      }\n    }\n\n    public ngOnChanges(changes: any) {\n      if (changes['data'] !== null && typeof changes['data'] !== 'undefined') {\n        let oldData = changes['data'].previousValue;\n        let newData: any = changes['data'].currentValue;\n\n        if (oldData !== newData) {\n          this.setData(newData);\n        }\n      }\n    }\n\n    public onValueChanged($event: Event) {\n        let data: any = {\n          data: this.value,\n          source: ($event === null || typeof $event === 'undefined') ? undefined : $event.target\n        };\n        let ev = EventUtils.newCustomEvent(DATA_CHANGE_EVENT, this, data, $event);\n\n        this.changeEvent.emit(ev);\n        this.handler.emit(ev);\n        this.handler.emit($event);\n    }\n\n    public setData(data: any): void {\n      super.setData(data);\n\n      this.value = this.getFormattedData();\n    }\n\n    public getEventHandler(): EventEmitter<any> {\n        return this.handler;\n    }\n\n    public setEventHandler(event: EventEmitter<any>): void {\n        this.handler = event;\n    }\n\n    public getChangeEvent(): EventEmitter<any> {\n        return this.changeEvent;\n    }\n\n    public setChangeEvent(event: EventEmitter<any>): void {\n        this.changeEvent = event;\n    }\n\n    public isSelfDataDirty(): boolean {\n        return false;\n    }\n\n    public selfSaveData(): void {\n\n    }\n\n    public selfResetData(): void {\n\n    }\n}\n"]}