UNPKG

@grapecity/inputman.angular

Version:

このパッケージには、Angular用の[InputManJS](https://developer.mescius.jp/inputmanjs)コンポーネントが含まれます。

112 lines 15.4 kB
import { ElementRef, Input, Output, forwardRef, EventEmitter, Component } from '@angular/core'; import { MethodType, getMethodPrefix, IMCtrl, isEmpty } from '../common'; import * as i0 from "@angular/core"; export function provideParent(component) { return { provide: GcComponents, useExisting: forwardRef(() => component) }; } export class GcComponents { constructor(ref) { this.onInitialized = new EventEmitter(); this._container = ref.nativeElement; } ngOnChanges(changes) { if (!this._imCtrl) { return; } Object.keys(changes).forEach((key) => { var currentValue = changes[key].currentValue; this.setValueToIMControl(key, currentValue); }); } setValueToIMControl(key, value) { if (value === undefined) { return; } if (this.isSetAccessor(key)) { this._imCtrl[key] = value; return; } var setter = this.tryGetPropertyOperator(key, MethodType.setter); if (this.hasRealMethod(setter)) { if (this.propDic && this.propDic[key] && this.propDic[key].isPramArr === true) { this._imCtrl[setter].apply(this._imCtrl, value); } else { this._imCtrl[setter](value); } } } isSetAccessor(key, prototype = Object.getPrototypeOf(this._imCtrl)) { let descriptor = Object.getOwnPropertyDescriptor(prototype, key); if (descriptor && descriptor.set) { return true; } else { prototype = Object.getPrototypeOf(prototype); if (prototype) { return this.isSetAccessor(key, prototype); } } return false; } ngOnDestroy() { if (this._container != null) { if ((this._imCtrl).destroy) { (this._imCtrl).destroy(); } this._container.remove(); } } ngAfterContentInit() { this.initGcComponent(); if (typeof this._imCtrl === 'object') { this.onInitialized.emit(this._imCtrl); } this.bindEvent(); if (this.propDic) { var unSupportWithinConfigProps = Object.keys(this.propDic).filter(p => this.propDic[p] && this.propDic[p].supportWithinConfig === false); unSupportWithinConfigProps.sort((p1, p2) => { return this.propDic[p1].order - this.propDic[p2].order; }); unSupportWithinConfigProps.forEach(p => { this.setValueToIMControl(p, this[p]); }); } this._container[IMCtrl] = this._imCtrl; } tryGetPropertyOperator(propertyName, methodType) { var method = ""; if (this.propDic && this.propDic[propertyName]) { method = methodType === MethodType.getter ? this.propDic[propertyName].getter : this.propDic[propertyName].setter; if (!isEmpty(method)) { return method; } } return getMethodPrefix(methodType) + propertyName[0].toUpperCase() + propertyName.slice(1); } hasRealMethod(methodName) { return this._imCtrl && typeof this._imCtrl[methodName] === "function"; } getNestedIMControl() { return this._imCtrl; } createTemplate(element) { this._container.appendChild(element); if (element && this.name) { element.setAttribute('name', this.name); } } } GcComponents.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GcComponents, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); GcComponents.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GcComponents, selector: "ng-component", inputs: { name: "name" }, outputs: { onInitialized: "onInitialized" }, usesOnChanges: true, ngImport: i0, template: '', isInline: true }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GcComponents, decorators: [{ type: Component, args: [{ template: '' }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { name: [{ type: Input }], onInitialized: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GcComponents.js","sourceRoot":"","sources":["../../../components/GcComponents.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnChanges, OnDestroy, AfterContentInit, ElementRef, SimpleChanges, Input, Output, forwardRef, EventEmitter, Component, Injectable } from '@angular/core';\nimport { PropertyDictionary, MethodType, getMethodPrefix, IMCtrl, isEmpty } from '../common';\n\nexport function provideParent(component: any) {\n    return { provide: GcComponents, useExisting: forwardRef(() => component) };\n}\n\n@Component({\n    template: ''\n})\nexport abstract class GcComponents<T extends object> implements OnChanges, AfterContentInit, OnDestroy {\n    protected _container: Element;\n    protected _imCtrl: T;\n    protected propDic: PropertyDictionary;\n\n    constructor(ref: ElementRef) {\n        this._container = ref.nativeElement;\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (!this._imCtrl) {\n            return;\n        }\n\n        Object.keys(changes).forEach((key: string) => {\n            var currentValue = changes[key].currentValue;\n            this.setValueToIMControl(key, currentValue);\n        });\n    }\n\n    protected setValueToIMControl(key: string, value: any): void {\n        if (value === undefined) {\n            return;\n        }\n\n        if (this.isSetAccessor(key)) {\n            this._imCtrl[key] = value;\n            return;\n        }\n\n        var setter = this.tryGetPropertyOperator(key, MethodType.setter);\n        if (this.hasRealMethod(setter)) {\n            if (this.propDic && this.propDic[key] && this.propDic[key].isPramArr === true) {\n                this._imCtrl[setter].apply(this._imCtrl, value);\n            } else {\n                this._imCtrl[setter](value);\n            }\n        }\n    }\n\n    private isSetAccessor(key: string, prototype: Object = Object.getPrototypeOf(this._imCtrl)) {\n\n        let descriptor = Object.getOwnPropertyDescriptor(prototype, key);\n        if (descriptor && descriptor.set) {\n            return true;\n        } else {\n            prototype = Object.getPrototypeOf(prototype);\n            if (prototype) {\n                return this.isSetAccessor(key, prototype);\n            }\n        }\n        return false;\n    }\n\n    public ngOnDestroy(): void {\n        if(this._container != null) {\n            if(((this._imCtrl) as any).destroy){\n                ((this._imCtrl) as any).destroy();\n            }\n            this._container.remove();\n        }\n    }\n\n    public ngAfterContentInit(): void {\n        this.initGcComponent();\n        if (typeof this._imCtrl === 'object') {\n            this.onInitialized.emit(this._imCtrl);\n        }\n        this.bindEvent();\n        if (this.propDic) {\n            var unSupportWithinConfigProps = Object.keys(this.propDic).filter(p => this.propDic[p] && this.propDic[p].supportWithinConfig === false);\n            unSupportWithinConfigProps.sort((p1, p2) => {\n                return this.propDic[p1].order - this.propDic[p2].order;\n            });\n\n            unSupportWithinConfigProps.forEach(p => {\n                this.setValueToIMControl(p, this[p]);\n            });\n        }\n        this._container[IMCtrl] = this._imCtrl;\n    }\n\n    protected abstract initGcComponent(): void;\n\n    protected abstract bindEvent(): void;\n\n    private tryGetPropertyOperator(propertyName: string, methodType: MethodType): string {\n        var method: string = \"\";\n        if (this.propDic && this.propDic[propertyName]) {\n            method = methodType === MethodType.getter ? this.propDic[propertyName].getter : this.propDic[propertyName].setter;\n            if (!isEmpty(method)) {\n                return method;\n            }\n        }\n        return getMethodPrefix(methodType) + propertyName[0].toUpperCase() + propertyName.slice(1);\n    }\n\n    private hasRealMethod(methodName: string): boolean {\n        return this._imCtrl && typeof this._imCtrl[methodName] === \"function\";\n    }\n\n    public getNestedIMControl(): T {\n        return this._imCtrl;\n    }\n\n    protected createTemplate(element: HTMLElement) {\n        this._container.appendChild(element);\n        if (element && this.name) {\n            element.setAttribute('name', this.name);\n        }\n    }\n\n    @Input()\n    public name: string;\n\n    @Output()\n    public onInitialized: EventEmitter<T> = new EventEmitter();\n}"]}