@ng-zi/extensions-ag-grid
Version:
AgGrid Extension for Ag-grid
74 lines • 12.2 kB
JavaScript
import { Injectable } from "@angular/core";
import { BaseComponentWrapper } from 'ag-grid-community';
import * as i0 from "@angular/core";
export class AngularFrameworkComponentWrapper extends BaseComponentWrapper {
setViewContainerRef(viewContainerRef, angularFrameworkOverrides) {
this.viewContainerRef = viewContainerRef;
this.angularFrameworkOverrides = angularFrameworkOverrides;
}
createWrapper(OriginalConstructor, compType) {
let angularFrameworkOverrides = this.angularFrameworkOverrides;
let that = this;
class DynamicAgNg2Component extends BaseGuiComponent {
init(params) {
angularFrameworkOverrides.runInsideAngular(() => {
super.init(params);
this._componentRef.changeDetectorRef.detectChanges();
});
}
createComponent() {
return angularFrameworkOverrides.runInsideAngular(() => that.createComponent(OriginalConstructor));
}
hasMethod(name) {
return wrapper.getFrameworkComponentInstance()[name] != null;
}
callMethod(name, args) {
const componentRef = this.getFrameworkComponentInstance();
return angularFrameworkOverrides.runInsideAngular(() => wrapper.getFrameworkComponentInstance()[name].apply(componentRef, args));
}
addMethod(name, callback) {
wrapper[name] = callback;
}
}
let wrapper = new DynamicAgNg2Component();
return wrapper;
}
createComponent(componentType) {
return this.viewContainerRef.createComponent(componentType);
}
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AngularFrameworkComponentWrapper, deps: null, target: i0.ɵɵFactoryTarget.Injectable }); }
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AngularFrameworkComponentWrapper }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AngularFrameworkComponentWrapper, decorators: [{
type: Injectable
}] });
class BaseGuiComponent {
init(params) {
this._params = params;
this._componentRef = this.createComponent();
this._agAwareComponent = this._componentRef.instance;
this._frameworkComponentInstance = this._componentRef.instance;
this._eGui = this._componentRef.location.nativeElement;
this._agAwareComponent.agInit(this._params);
}
getGui() {
return this._eGui;
}
/** `getGui()` returns the `ng-component` element. This returns the actual root element. */
getRootElement() {
const firstChild = this._eGui.firstChild;
return firstChild;
}
destroy() {
if (this._frameworkComponentInstance && typeof this._frameworkComponentInstance.destroy === 'function') {
this._frameworkComponentInstance.destroy();
}
if (this._componentRef) {
this._componentRef.destroy();
}
}
getFrameworkComponentInstance() {
return this._frameworkComponentInstance;
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angularFrameworkComponentWrapper.js","sourceRoot":"","sources":["../../../reference/angularFrameworkComponentWrapper.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentRef, Injectable, NgZone, ViewContainerRef} from \"@angular/core\";\r\nimport {BaseComponentWrapper, FrameworkComponentWrapper, GridApi, WrappableInterface} from 'ag-grid-community';\r\nimport { AngularFrameworkOverrides } from \"./angularFrameworkOverrides\";\r\nimport { AgFrameworkComponent } from \"./ag-grid.interfaces\";\r\n\r\n@Injectable()\r\nexport class AngularFrameworkComponentWrapper extends BaseComponentWrapper<WrappableInterface> implements FrameworkComponentWrapper {\r\n    private viewContainerRef!: ViewContainerRef;\r\n    private angularFrameworkOverrides!: AngularFrameworkOverrides;\r\n\r\n    public setViewContainerRef(viewContainerRef: ViewContainerRef, angularFrameworkOverrides: AngularFrameworkOverrides) {\r\n        this.viewContainerRef = viewContainerRef;\r\n        this.angularFrameworkOverrides = angularFrameworkOverrides;\r\n    }\r\n\r\n    createWrapper(OriginalConstructor: { new(): any }, compType: any): WrappableInterface {\r\n        let angularFrameworkOverrides = this.angularFrameworkOverrides;\r\n        let that = this;\r\n        class DynamicAgNg2Component extends BaseGuiComponent<any, AgFrameworkComponent<any>> implements WrappableInterface {\r\n            init(params: any): void {\r\n                angularFrameworkOverrides.runInsideAngular(() => {\r\n                    super.init(params);\r\n                    this._componentRef.changeDetectorRef.detectChanges();\r\n                });\r\n            }\r\n\r\n            protected createComponent(): ComponentRef<AgFrameworkComponent<any>> {\r\n                return angularFrameworkOverrides.runInsideAngular(() => that.createComponent(OriginalConstructor));\r\n            }\r\n\r\n            hasMethod(name: string): boolean {\r\n                return wrapper.getFrameworkComponentInstance()[name] != null;\r\n            }\r\n\r\n            callMethod(name: string, args: IArguments): void {\r\n                const componentRef = this.getFrameworkComponentInstance();\r\n                return angularFrameworkOverrides.runInsideAngular(() => wrapper.getFrameworkComponentInstance()[name].apply(componentRef, args));\r\n            }\r\n\r\n            addMethod(name: string, callback: Function): void {\r\n                (wrapper as any)[name] = callback\r\n            }\r\n        }\r\n        let wrapper = new DynamicAgNg2Component();\r\n        return wrapper;\r\n    }\r\n\r\n    public createComponent<T>(componentType: { new(...args: any[]): T; }): ComponentRef<T> {\r\n        return this.viewContainerRef.createComponent(componentType);\r\n    }\r\n}\r\n\r\nabstract class BaseGuiComponent<P, T extends AgFrameworkComponent<P>> {\r\n    protected _params!: P;\r\n    protected _eGui!: HTMLElement;\r\n    protected _componentRef!: ComponentRef<T>;\r\n    protected _agAwareComponent!: T;\r\n    protected _frameworkComponentInstance: any;  // the users component - for accessing methods they create\r\n\r\n    protected init(params: P): void {\r\n        this._params = params;\r\n\r\n        this._componentRef = this.createComponent();\r\n        this._agAwareComponent = this._componentRef.instance;\r\n        this._frameworkComponentInstance = this._componentRef.instance;\r\n        this._eGui = this._componentRef.location.nativeElement;\r\n\r\n        this._agAwareComponent.agInit(this._params);\r\n    }\r\n\r\n    public getGui(): HTMLElement {\r\n        return this._eGui;\r\n    }\r\n\r\n    /** `getGui()` returns the `ng-component` element. This returns the actual root element. */\r\n    public getRootElement(): HTMLElement {\r\n        const firstChild = this._eGui.firstChild;\r\n        return firstChild as HTMLElement;\r\n    }\r\n\r\n    public destroy(): void {\r\n        if (this._frameworkComponentInstance && typeof this._frameworkComponentInstance.destroy === 'function') {\r\n            this._frameworkComponentInstance.destroy();\r\n        }\r\n        if (this._componentRef) {\r\n            this._componentRef.destroy();\r\n        }\r\n    }\r\n\r\n    public getFrameworkComponentInstance(): any {\r\n        return this._frameworkComponentInstance;\r\n    }\r\n\r\n    protected abstract createComponent(): ComponentRef<T>;\r\n}\r\n"]}