MeadCoScriptXJS is a JavaScript library that provides a wrapper around MeadCo's ScriptX functionality. ScriptX is a solution for consistent printing from web browsers, available in two forms: ScriptX Add-on (for Internet Explorer) and ScriptX Services (for any browser).
This library has been used with our samples system for some time.
The aim of the library is to hide differences between versions of ScriptX and provide easy access to some common functionality. The library works with both free and licensed ScriptX. Some convenience wrappers require licensed ScriptX functionality.
The library is organized into two main namespaces:
- MeadCo.ScriptX - Wraps the core printing functionality
- MeadCo.Licensing - Handles license management
The MeadCo.ScriptX
namespace provides core functionality:
The library supports two connection modes:
ADDON
: Direct connection to ScriptX Add-on in IESERVICE
: Connection to ScriptX.Services for cross-browser compatibility
The library provides multiple initialization methods:
MeadCo.ScriptX.Init()
- Synchronous initialization (deprecated)MeadCo.ScriptX.InitAsync()
- Asynchronous initialization using promisesMeadCo.ScriptX.StartAsync()
- Complete initialization including services connection and print settings
The library includes wrappers for common printing tasks:
PrintPage()
- Print the current documentPrintFrame()
- Print a specific frameBackgroundPrintURL()
- Download and print HTML from a URLBackgroundPrintHTML()
- Print provided HTML contentDirectPrintString()
- Send raw data directly to a printerPreviewPage()
- Preview the document before printing
Functions to launch printing-related dialogs:
PageSetup()
- Configure page settingsPrintSetup()
- Configure printer settings
GetAvailablePrinters()
- List available printersGetComponentVersion()
- Get component version informationWaitForSpoolingComplete()
- Wait for print jobs to completeCloseWindow()
- Close window after ensuring print jobs complete
The library handles differences between:
- Synchronous operations in ScriptX Add-on
- Asynchronous operations in ScriptX.Services
- Provides promise-based wrappers to unify APIs
The MeadCo.Licensing
namespace provides functionality to:
- Initialize the licensing system
- Check if the current document is properly licensed
- Report licensing errors
The library provides two API patterns:
- Traditional callback-based methods (e.g.,
PrintPage()
) - Promise-based methods (e.g.,
PrintPage2()
) for modern asynchronous code
The code is designed to be backward compatible with older browsers while also supporting modern JavaScript practices when available.
npm install meadco-scriptxjs --save
<script src="https://cdn.jsdelivr.net/npm/meadco-scriptxjs@1/dist/meadco-scriptx.min.js"></script>
- Link to the required libraries with service connection details
- Initialise the library
- Initilise print parameters
The same code will work when the add-on is present and the add-on will be used in preference (applies to IE 11 only)
<script src="https://cdn.jsdelivr.net/npm/meadco-scriptxjs@1/dist/meadco-scriptx.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/scriptxprint-html@1.7/dist/meadco-scriptxservices.min.js"
data-meadco-server="https://scriptxservices.meadroid.com"
data-meadco-license="xxx-xxx-xxxxxxx-xxx"></script>
<script>
window.addEventListener('load', async function() {
try {
await MeadCo.ScriptX.InitAsync();
// Configure printing parameters
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";
document.querySelector("#btnprint").addEventListener('click', function() {
// print page without showing the print dialog
MeadCo.ScriptX.PrintPage(false);
});
} catch(error) {
console.error("Failed to initialize ScriptX:", error);
}
});
</script>
- Link to meadco-scriptx.js
<script src="https://cdn.jsdelivr.net/npm/meadco-scriptxjs@1/dist/meadco-scriptx.min.js"></script>
- Initialise the library in the document ready/window loaded event handler, and initialise printing parameters. For example, when using jQuery:
For those functions that return a Promise a promise polyfill is required if the browser does not support promises (for example Internet Explorer). We recommend (and test with) Promise Polyfill
<script src="https://cdn.jsdelivr.net/npm/meadco-scriptxjs@1/dist/meadco-scriptx.min.js"></script>
<script>
$(window).on('load', function () {
if (MeadCo.ScriptX.Init()) {
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";
// link the ui ...
$("#print_link").click(function (e) {
e.preventDefault(); MeadCo.ScriptX.PrintPage(false);
});
}
});
</script>
Please note that the library is not dependent upon jQuery or any other libraries.
-
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.
Copyright © 2013-2025 Mead & Co Ltd.
MeadCoScriptXJS is under MIT license - http://www.opensource.org/licenses/mit-license.php