• Michael Intravartolo

Capturing Unhandled Errors In JavaScript Control Add-Ins

Not that I am saying it's a good thing, but trial and error is a fairly common approach to debuggin in the NAV world. We've all done it. Heck, even with the comprehensiv testability framework built in, we all still do it more often than we're happy to admit while sober.

But the overlord of trial and error in NAV is development of control add-ins in JavaScript. JavaScript itself is making it difficult in the first place, and then integration with NAV makes it even harder.

There is one situation in particular that's adding a cherry on top of all problems, and it's the creepy "A script error has occurred" error message. It's the equivalent of the BSoD.

This is what it looks like:

And if you've ever experienced it, you'll know how to appreciate the near-futility of anything that ensures.

First of all: refreshing the page or opening a new browser window - even though the error message suggests exactly that - often wont really help at all.

So, let me explain exactly why and this error happens. You will see this error message if an unhandled JavaScript error occurs in a function call invoked from C/AL. And with all the JavaScript frameworks out there, this can really be caused by absolutely anything and its sister. Even though, in theory, it's fairly easy to get to the heart (or, perhaps, some other organ) of the problem, it's amazing that when this error happens, you have clue as to why or where in JavaScript code it happened. A perfect example of an improperly handled unhandled error.

So, to help you avoid debugging through mountains of minified JavaScript gobbledygook that looks as Klingon to you as it does to me:

... through call stacks that, just like politicians in Croatia, say a lot, but nothing at all:

... here's a life saving hack for you.

Somewhere - the closer to the top, the better - in your JavaScript, add the following piece of code:

1 window.__controlAddInError__NAV = window.__controlAddInError;

2 window.__controlAddInError = function (e) {

3 console.log("Unhandled error has occurred: '" + e.message + "' - Stack: " + e.stack);

4 window.__controlAddInError__NAV(e);

5 };

You will still see the same "A script error...", but you keep all of its Freddy Kruger charm at bay, because this time, in the browser console window (hint: F12), it leaves a precious piece of information:

And now you know what, why, and where happened.

So, for all non-JavaScript folks, let me explain the mechanics of this. How exactly does this work?

First, the NAV JavaScript framework adds a lot of functionality to the runtime, one of those being the _controlAddInError function that's called every time an uncaught error happens inside of a C/AL method call the JavaScript control add-in

Now, in JavaScript, every function is also a variable, and I first obtain the reference to the function and store it in my _controlAddInError_NAV variable. I do this on the window object to help you avoid scoping issues in case you decide to paste this inside a function call in your code.

Then, I supplant my own function in place of the original _controlAddInError. The NAV extensibility framework has no way of knowing I did so, so it happily calls my function instead of its own.

My function logs the necessary information from the JavaScript Error object and then calls the original function to do whatever else (apart from showing the meaningless message) it needs to do.

And that's all.


Contact Us

Solution Systems, Inc.

3201 Tollview Dr. 

Rolling Meadows, IL 60008

Office: 847-590-3000

Email: info@solsyst.com

Support: 224-345-2020

Support Email: support@solsyst.com

  • Manufacturing Software | Illinois
  • Manufacturing Software | Illinois
  • Manufacturing Software | Illinois
  • Manufacturing Software | Illinois
  • Manufacturing Software | Chicago
  • Manufacturing Software | Illinois
  • Microsoft Business Podcast
  • Manufacturing Software | Chicago
  • Manufacturing Software | Chicago
  • Manufacturing Software | Chicago
Join our Mailing List