UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

243 lines (242 loc) 17.1 kB
/** * @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"]}