Dependency management
The Uno Bootstrapper uses RequireJS for dependency management, allowing for dependencies to be resolved in a stable manner.
For instance, a script defined this way, placed in the WasmScripts
folder:
define(() => {
var txt = document.createTextNode("Loaded !");
var parent = document.getElementById('uno-body');
parent.insertBefore(txt, parent.lastChild);
});
will be executed appropriately.
Dependencies can also be declared this way:
define([], function() { return MyModule; });
If you're taking a dependency on an AMD enabled library, you'll need to publish the library as it would outside of the normal require flow.
As an example, to be able to use html2canvas:
Add the
html2canvas.js
file as anEmbeddedResource
in theWasmScripts
folderThen create an additional file called
myapp.js
, also as anEmbeddedResource
require([`${config.uno_app_base}/html2canvas`], c => window.html2canvas = c);
You'll then be able to access
window.html2canvas
from C# usingeval()
.
Using multiple dependencies
In some cases, the simple inclusion of dependencies may allow for defining a dependency graph.
To do so, here's an example of dependency graph:
Add a
MyLib.js
file in theWasmScripts
folder:require( [`${config.uno_app_base}/Assets/js/test1`, `${config.uno_app_base}/Assets/js/test2`], (r1, r2) => { debugger; } );
Make sure to set the
Build action
of the file toEmbeddedResource
.Then create an
Assets/js
folder in your application, then add a file namedtest1.js
:console.log('test1.js loaded'); define({name: "test1"});
Finally, in an
Assets/js
, add a file namedtest2.js
:console.log('test2.js loaded'); define({ name: "test2" });
When running the application, the MyLib.js
file will be loaded first, then will automatically register the test1.js
and test2.js
file to be recursively loaded, where r1
and r2
have the defined values in the dependencies.
Dependency management for Emscripten
Emscripten modules initialization is performed in an asynchronous way and the Bootstrapper will ensure that a dependency that exposes a module will have finished its initialization for starting the Main
method of the C# code.