I'm following the docs here to add a context menu item to my grid. The issue is that from the scope of getContextMenuItems (in the example), I'm unable to access any other methods or variables in my component. Is this possible? Example below:
private varIWantToAccess: boolean = false;
function getContextMenuItems(params) {
var result = [
{ // custom item
name: 'Alert ' + params.value,
action: function ()
{
window.alert('Alerting about ' + params.value);
this.varIWantToAccess = true; // Builds fine, but throws a run time exception, since this "this" context is different than the one that has "varIWantToAccess"
}
},
....
return result;
}
Thanks!
I assume that you are speaking of an Angular 2 or 4 component using TypeScript. If so then use fat arrow to connect to your function.
Example:
This should provide you the scope you need.
You need to provide parent context property to the item. Sample context menu item:
{ name: 'BreakoutReport', action: function () { this.context.isDrillDownData = false; this.context.isBreakOutReport = true; this.context.populateBreakOutGrid(); }, cssClasses: ['redFont', 'bold'], disabled: !params.value.drillDownReport, context: params.context }
Here, this.context has access to all the parent functions. Remeber, this context needs to be set in grid options first and then can be transferred to context menu items.
1st step: set context in gridOptions
2nd step: pass context to context menu subitems
You can add the reference to
this
in grid's context -And then,
thisComponent
can be access as below -Same can be done for any other call backs like
cellRenderer
.