Property 'getFrameworkComponentInstance' does not exist on type 'ICellRendererComp'
Asked Answered
B

3

8

I'm trying to get the instance of cell renderer (Angular component) on rowSelected event handler:

onRowSelected($event) {
    var selectedRow = this.gridApi.getDisplayedRowAtIndex($event.rowIndex);
    var params = { columns: ['added'], rowNodes: [selectedRow]};
    var instances = this.gridApi.getCellRendererInstances(params);
    if (instances.length > 0) {
        var wrapperInstance = instances[0].getFrameworkComponentInstance();
    }
}

Unfortunately I get the error during the compilation of angular application (ts):

Property 'getFrameworkComponentInstance' does not exist on type 'ICellRendererComp'

The implementation comes from official documentation at https://www.ag-grid.com/javascript-grid-cell-rendering-components/ (find Accessing Cell Renderer Instances).

Here is possible factory method which define public getFrameworkComponentInstance.

It's unexpected situation because when I debug this method I can get the renderer with method getFrameworkComponentInstance on instances[0].

Boffin answered 13/1, 2020 at 17:53 Comment(0)
G
6

From what I saw in the interfaces of the ICellRenderer, the interface ICellRendererComp doesn't have the function getFrameworkComponentInstance.

Interfaces of ICellRendererComp

I've worked a lot with ag-grid-angular and I found out that sometimes, the interfaces are not relevant to what's really in the object (Missing functions/variables).

The problem is mainly because of tslint that doesn't trust the method since it isn't in the interface. To fix that, I created my own custom interface that extends the ICellRendererComp but with the function.

enter image description here

That way when you try to call your instance you can cast it to your interface. I tried a lot of things and only this worked for me.

enter image description here

Githens answered 15/1, 2020 at 19:49 Comment(1)
This workaround works. The problem is not related to tslint but to tsc. Still searching for another solution or waiting for the other answer. Thanks!Boffin
L
3

I agree with the reasons in the above answer, however a shorter approach has saved me time.
Instead of creating a custom interface, the following has worked for me -

if (instances.length > 0) {
        var cellRenderer: any = instances[0];
        var wrapperInstance = cellRenderer.getFrameworkComponentInstance();
    }
Lard answered 18/1, 2020 at 21:5 Comment(0)
P
2

From v27 of AG Grid

You no longer need to use the method getFrameworkComponentInstance(), as your Angular component will be returned directly from getCellRendererInstances(). So you can loop through the components and call their methods directly.

const instances = this.gridApi.getCellRendererInstances(params) as MyComponent[];

instances.forEach((instance) => {
  instance.myComponentFunction();
});

See updated documentation here: Component Cell Renderer

Paradrop answered 9/2, 2022 at 9:41 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.