makeImage issue

It seems nothing is happening when using the makeImage.

Here is an example:

function makeImage(data){
myDiagram.model = go.Model.fromJson(data);
$(’#loadModal .modal-body .image’).html(myDiagram.makeImage());
}

The model is succesfully changed but the makeImage is simply ignored.
Any ideas?

Diagram.makeImage returns an HTML element object, not a string in HTML format. So it would seem plausible that jQuery’s html method is ignoring the argument that you are giving it. Maybe you should call replaceWith instead? It depends on what your HTML is.

There seems to be an issue with the makeImage function:

myDiagram.model = go.Model.fromJson(data);
var img = myDiagram.makeImage(“image/png”);
$(’#loadModal .modal-body .image’).replaceWith(“test”);

When the myDiagram.makeImage(“image/png”); is used everything afterwards is ignored. When i remove it the test is successfully shown. Just to be sure I have GoJS v1.0.5… Not sure if that is an issue.

EDIT: same with 1.0.8

Diagram.makeImage takes a single optional argument that must be a JavaScript object holding properties that the method will look at. Basically all of those object properties are arguments to makeImage that are being passed by name instead of the usual function arguments being passed by position in the argument list.

Anyway, passing a string as the argument to makeImage should be throwing an error. Are you not seeing that behavior in the console or debugger? Whenever a lot of stuff does not execute in HTML JavaScript, you should check whether there was an exception that was ignored.

k so I finally figured how the console worked for debugging javascript (never done it before) and never really had an issue either :)

So I did indeed receive an error saying an object had to be used as an argument. As image/png is set to default I removed the argument. But when I do the following:

myDiagram.model = go.Model.fromJson(data);
img = myDiagram.makeImage;
$(’#loadModal .modal-body .image’).replaceWith(img);

I still get that error. But when I use a string in replaceWith no error is given.

Found it!

But I thought if you don’t use arguments it would take the default values.
When I do add the type of teh image: myDiagram.makeImage({type:“image/png”});

it works.

EDIT:
It works kind of… I get a blank image.

Here is an example:



Any idea why this might be possible?

Thanks

Sorry, I didn’t realize you had modified your post to say that there was a problem after all.

If you execute your code after the diagram is visible on the page, does it produce a non-blank image? In other words, does the problem only happen when the diagram or the page is initializing or not yet loaded?

that was the issue… Apparently it wasn’t loaded yet while trying to create an image.
Is there a way to check whether or not the diagram has finished loading?

Typically JavaScript initialization of page elements happens in a body.onload event handler (as shown by the samples), or in a jQuery.ready (or similar) function.

Diagram.makeImage makes sure all of the internal diagram initialization and update is done. You just need to make sure the properties of the Diagram, and in particular the Diagram.model, have been set.