MeadCo ScriptX.Services Client Library
Current version 1.16.2
The MeadCo ScriptX.Services Client Library serves a dual function:
- It acts as a structured framework for interacting with the ScriptX.Services API and
- Provides an emulated version of the MeadCo ScriptX.Add-on for Internet Explorer on Windows platforms.
In a binary-free environment, the javascript ScriptX.Services Client Library bridges the gap between client devices and the server system providing printing services, regardless of the server's location:
- in the cloud at scriptxservices.meadroid.com
- an on premise Microsoft Windows (x64) Server
- a Microsoft Windows x64 PC
When the MeadCoScriptXJS library is integrated, it ensures a high degree of compatibility with in-browser scripts originally designed for the Add-on. This compatibility allows the same code to be executed with either the Add-on for Internet Explorer or with ScriptX Services in any evergreen/modern browser. This integration eliminates the need for significant code rewrites.
For those who have developed a significant amount of client JavaScript code for the ScriptX Add-On for Internet Explorer the libraries enable a smooth transition to ScriptX.Services allowing for the retention of a substantial portion of the original code. While much of the existing code will continue to operate unmodified, some code may require updates. A comprehensive discussion outlines the potential challenges.
Moreover, the MeadCoScriptXJS library is optimised for contemporary applications, offering support "async" operations as many APIs return a Promise object over the callback model of this library.
A Note on Browsers and Devices
The MeadCo ScriptX.Add-on continues to be available and supports Internet Explorer. JavaScript code in this scenario will be utilizing the "window.factory" object.
The MeadCo ScriptX.Services Client Library is developed for "evergreen" browsers. As of v1.15, Internet Explorer is no longer actively tested or supported.
By using this compatibility layer written in JavaScript, the same browser client code can be brought to more modern browsers. This is, of course, provided that the HTML that renders successfully in the older browser also renders correctly in modern browsers.
The ScriptX.Services Client libraries are self-sufficient and do not depend on anything other than themselves. We understand that our clients are diverse and may have dependencies on many libraries. We aim not to work against those choices but to work in harmony with them.
Architectural Overview
Background
ScriptX.Addon (a COM/ActiveX object) appears to script code in the browser (Internet Explorer) as the object "window.factory" (assuming that the de-facto standard id of "factory" has been used on the ScriptX <object /> element). From this object, the object "printing" is available, leading to code such as this:
factory.printing.header = "";
factory.printing.footer = "";
factory.printing.Print(false);
The extensive API of properties and methods is documented here.
MeadCoScriptXJS Library
In addition to the ScriptX.Addon API a javascript library was developed to extend the API with convenience functions. Started in 2013, this library took the approach of "namespaces" / static classes, which were popular(-ish) then as a means of ensuring no clashes of names etc. A significant amount of code has been written that relies upon this library. By definition there is only ever one instance of ScriptX.Addon on a page and therefore a static singleton javascript 'class' instance is perfectly adequate.
It is also known and acknowleged that much code utilising ScriptX.Addon predates React, Angular, Vue etc. etc. and exists in a world of relatively un-complex page operations; a "print button" and some code to set print parameters and then print (though the back-end code generating HTML to be printed was likely complex and comprehensive).
This library implemented the following static objects/classes:
- MeadCo
- MeadCo.ScriptX
- MeadCo.ScriptX.Utils
- MeadCo.ScriptX.Printing
- MeadCo.Licensing
- MeadCo.Licensing.LicMgr
The "trick" here was that MeadCo.ScriptX.Utils was pointed to "factory", MeadCo.ScriptX.Printing was pointed to "factory.printing" and MeadCo.Licensing.LicMgr pointed to "secmgr".
MeadCo.ScriptX.Printing therefore exposed the entire printing API.
MeadCo.ScriptX is an object providing for verified initialisation and a number of functions that wrapped common operations into a simpler API. So, for example (using jQuery):
<script type="text/javascript">
   $(window).on('load', function () {
     if ( MeadCo.ScriptX.Init() (
     {
        $("#info").text("ScriptX version: " + MeadCo.ScriptX.GetComponentVersion("scriptx.factory"));
        MeadCo.ScriptX.Printing.header = 
          "MeadCo's ScriptX&b:&p of &P:&bBasic Printing Sample";
        MeadCo.ScriptX.Printing.footer = 
          "The de facto standard for advanced web-based printing";
        MeadCo.ScriptX.Printing.orientation = "landscape";
        $("#btnprint").click(function() { 
            MeadCo.ScriptX.PrintPage(false);
     }      
   });
</script>
The final "trick" is that if MeadCo.ScriptX.Printing is pointed to an implementation of the .Addon API in javascript and that implementation uses the ScriptX.Services API to perform printing then code using the MeadCoScriptXJS library will work with .Addon and .Services with no changes in simple cases and few changes in more complex cases.
Support for .Addon Emulation in ScriptX.Services
The MeadCo ScriptX.Service Client Library implements a heirarchy of static 'classes' (or singleton object instances!) at the bottom of which is an implementation of the .Addon API (factory, factory.printing et al) in javascript. The implementation is necessarily imperfect. In particular the support for synchronous coding with the ubiquitous WaitFortSpoolingComplete() API is impossible to emulate fully in javascript thaty workls in all browsers (the only possible way to attempt an eumulation causes blocking in the browser via synchronous AJAX which is deeply unsatisfactory and so is not implemented).
Such imperfections are smoothed by use of the MeadCoScriptXJS library which provides a layer to hide the differences betweeen .Addon and .Services and so enable a single code base. For example there is an implementation of the WaitFortSpoolingComplete() API which returns a Promise. This in turn enables the use of
await MeadCo.ScriptX.WaitForSpoolingComplete();- obviously this must be within an async block so some re-coding is required.
Note that the MeadCoScriptXJS library does not have to be used. In its absense, meadco-scriptxfactory.js and its dependencies on the hierarchy implement a reasonable and usable emulation of "factory.printing" though functionality such as WaitForSpoolingComplete is not a compatible emulation.
User Interface
The library does not implement any UI - Printer or Print Settings dialogs. This enables decoupling from any UI dependencies that may be problematic - for example, to Bootstrap, or to not Bootstrap?
However, a few APIs do 'require' a UI, for example, prompted printing.
A simple extension mechanism is implemented into which implementation of UI may be patched.
All that is required is to implement the named functions.
| function | Purpose | 
|---|---|
| MeadCo.ScriptX.Print.UI.PageSetup(function (bAccepted) {} ) | A page setup dialog, headers and footers etc. | 
| MeadCo.ScriptX.Print.UI.PrinterSettings(function (bAccepted) {} ) | A printer set up dialog - list of available printers, use of collated printing | 
This is discussed in more detail in the Dialogs with ScriptX.Services article. Exemplar implemenations of UI are provided: Bootstrap3/4 with jQuery (implemented assuming Bootstrap and jQuery) and Bootstrap 5 no jQuery
See also:
- MeadCoScriptXJS project for a higher level abstraction which provides a number of convenient functions for the use of ScriptX in any of its forms, Add-on or Services.
- ScriptX Add-on for Internet Explorer API reference.
- ScriptX.Services on Cloud
- ScriptX Services Samples - Cloud, On Premise, for Windows PC the samples make use of MeadCoScriptXJS and ScriptX.Services.Client to deliver samples that work in any scenario with the same code.
- start - a quick start guide to using the library.