Call component method from custom Viewer button (Angular)

Stimulsoft Reports.JS discussion
Post Reply
mrapi
Posts: 282
Joined: Sat Dec 20, 2008 1:08 am

Call component method from custom Viewer button (Angular)

Post by mrapi »

Hi
Using Angular 6,I've added a custom button to viewer but I'm not able to call component method from it,I got
core.js:1598 ERROR TypeError: this.myMethod is not a function
the code used :

Code: Select all

  ngOnInit() {

    var report = new Stimulsoft.Report.StiReport();
    report.loadFile("reports/Report.mdc");
    this.viewer.report = report;
    this.viewer.renderHtml("viewer");


 const userButton = this.viewer.jsObject.SmallButton('userButton', 'MyButton', 'emptyImage');
        userButton.action = function () {
          alert('ok');
		  this.myMethod();
        };
        const toolbarTable = this.viewer.jsObject.controls.toolbar.firstChild.firstChild;
        const buttonsTable = toolbarTable.rows[0].lastChild.lastChild;
        const userButtonCell = buttonsTable.rows[0].insertCell(0);
        userButtonCell.className = 'stiJsViewerClearAllStyles';
        userButtonCell.appendChild(userButton);


     }

myMethod(){
	
	alert('call myMethod') ;
}
sample project is attached
thanks
Attachments
my-new-app.zip
(1.67 MiB) Downloaded 387 times
Barnaby
Posts: 27
Joined: Tue Dec 20, 2016 1:57 am

Re: Call component method from custom Viewer button (Angular)

Post by Barnaby »

this is a keyword in javascript, and it changes depending on where its being called from.

In your case, this is being called inside userButton.action, so this would probably be the object userButton.

If your function is global, you don't need to use this, otherwise you could do something like userButton.myMethod = myMethod; then using this would work.
mrapi
Posts: 282
Joined: Sat Dec 20, 2008 1:08 am

Re: Call component method from custom Viewer button (Angular)

Post by mrapi »

Hi.
without 'this' got this error:
Cannot find name 'myMethod'
angular 2+ uses typescript and it is very strict about calling global functions/variable

thanks
HighAley
Posts: 8430
Joined: Wed Jun 08, 2011 7:40 am
Location: Stimulsoft Office

Re: Call component method from custom Viewer button (Angular)

Post by HighAley »

Hello, Barnaby.

Did you solve your issue?
Let us know if you still need our help.

Thank you.
mrapi
Posts: 282
Joined: Sat Dec 20, 2008 1:08 am

Re: Call component method from custom Viewer button (Angular)

Post by mrapi »

Hi.it is not not solved
HighAley
Posts: 8430
Joined: Wed Jun 08, 2011 7:40 am
Location: Stimulsoft Office

Re: Call component method from custom Viewer button (Angular)

Post by HighAley »

Hello.

Did you try this solution:
this is a keyword in javascript, and it changes depending on where its being called from.

In your case, this is being called inside userButton.action, so this would probably be the object userButton.

If your function is global, you don't need to use this, otherwise you could do something like userButton.myMethod = myMethod; then using this would work.
Thank you.
mrapi
Posts: 282
Joined: Sat Dec 20, 2008 1:08 am

Re: Call component method from custom Viewer button (Angular)

Post by mrapi »

Hi
yes,but got this error: Cannot find name 'myMethod'
Barnaby
Posts: 27
Joined: Tue Dec 20, 2016 1:57 am

Re: Call component method from custom Viewer button (Angular)

Post by Barnaby »

I've not really used typescript before. Is this.myMethod available in ngOnInit?
If so you should be able to do this

Code: Select all

userButton.myMethod = this.myMethod;
userButton.action = function () {
   alert('ok');
   this.myMethod();
};
mrapi
Posts: 282
Joined: Sat Dec 20, 2008 1:08 am

Re: Call component method from custom Viewer button (Angular)

Post by mrapi »

Hi,now I've seen your complete code,it works,one mention: if inside component method there are used other members,all must be assigned to button:

Code: Select all

 userButton.myMethod = this.myMethod;
 userButton.bsModalRef = this.bsModalRef;
 userButton.outResult = this.outResult;
..
myMethod(){
this.bsModalRef.hide();
    this.outResult.next(true);
}
Thanks
Last edited by mrapi on Thu Feb 14, 2019 6:14 am, edited 1 time in total.
Lech Kulikowski
Posts: 7452
Joined: Tue Mar 20, 2018 5:34 am

Re: Call component method from custom Viewer button (Angular)

Post by Lech Kulikowski »

Hello,

Thank you for the provided solution.
Post Reply