UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

206 lines (205 loc) 15.7 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'; const /** @type {?} */ TYPE_NAME = "phx-string-editor-data-view"; const /** @type {?} */ DEFAULT_FIELD = "label"; export class StringEditorDataView extends AbstractHasFormatterDataView { /** * @param {?} elementRef * @param {?} formatterFactory */ constructor(elementRef, formatterFactory) { super(elementRef, formatterFactory); this.DEFAULT_FIELD_NAME = "label"; this.handler = new EventEmitter(); this.changeEvent = new EventEmitter(); } /** * @return {?} */ ngOnInit() { super.ngOnInit(); // 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 {?} */ ngOnChanges(changes) { if (changes['data'] !== null && typeof changes['data'] !== 'undefined') { let /** @type {?} */ oldData = changes['data'].previousValue; let /** @type {?} */ newData = changes['data'].currentValue; if (oldData !== newData) { this.setData(newData); } } } /** * @param {?} $event * @return {?} */ onValueChanged($event) { let /** @type {?} */ data = { data: this.value, source: ($event === null || typeof $event === 'undefined') ? undefined : $event.target }; let /** @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 {?} */ setData(data) { super.setData(data); this.value = this.getFormattedData(); } /** * @return {?} */ getEventHandler() { return this.handler; } /** * @param {?} event * @return {?} */ setEventHandler(event) { this.handler = event; } /** * @return {?} */ getChangeEvent() { return this.changeEvent; } /** * @param {?} event * @return {?} */ setChangeEvent(event) { this.changeEvent = event; } /** * @return {?} */ isSelfDataDirty() { return false; } /** * @return {?} */ selfSaveData() { } /** * @return {?} */ selfResetData() { } } 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> ` },] }, ]; /** @nocollapse */ StringEditorDataView.ctorParameters = () => [ { 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); 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"]}