meadco-scriptxjs
v1.10.8
Published
Wrapper library for working with MeadCo ScriptX add-on for Internet Explorer and ScriptX.Print Services
Downloads
51
Maintainers
Readme
MeadCoScriptXJS
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.
Key Components
The library is organized into two main namespaces:
- MeadCo.ScriptX - Wraps the core printing functionality
- MeadCo.Licensing - Handles license management
Core Functionality
The MeadCo.ScriptX namespace provides core functionality:
Connection Types
The library supports two connection modes:
ADDON: Direct connection to ScriptX Add-on in IESERVICE: Connection to ScriptX.Services for cross-browser compatibility
Initialization
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
Printing Functions
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
Dialog Functions
Functions to launch printing-related dialogs:
PageSetup()- Configure page settingsPrintSetup()- Configure printer settings
Utility Functions
GetAvailablePrinters()- List available printersGetComponentVersion()- Get component version informationWaitForSpoolingComplete()- Wait for print jobs to completeCloseWindow()- Close window after ensuring print jobs complete
Browser Compatibility
The library handles differences between:
- Synchronous operations in ScriptX Add-on
- Asynchronous operations in ScriptX.Services
- Provides promise-based wrappers to unify APIs
Licensing Module
The MeadCo.Licensing namespace provides functionality to:
- Initialize the licensing system
- Check if the current document is properly licensed
- Report licensing errors
Modern vs Legacy Support
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.
Packages
NuGet Gallery
NPM Use
npm install meadco-scriptxjs --saveCDN Use
<script src="https://cdn.jsdelivr.net/npm/meadco-scriptxjs@1/dist/meadco-scriptx.min.js"></script>Quick start - ScriptX.Services for any browser
- 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/[email protected]/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>Quick start for working with ScriptX Add-on only
- 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.
Resources
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
Copyright © 2013-2025 Mead & Co Ltd.
License
MeadCoScriptXJS is under MIT license - http://www.opensource.org/licenses/mit-license.php
