Skip to content

A simple javascript wrapper library for use with MeadCo's ScriptX Add-on and/or ScriptX.Services

License

Notifications You must be signed in to change notification settings

MeadCo/MeadCoScriptXJS

Repository files navigation

MeadCoScriptXJS

GitHub release (latest SemVer) npm Nuget
MIT License

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:

  1. MeadCo.ScriptX - Wraps the core printing functionality
  2. 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 IE
  • SERVICE: 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 promises
  • MeadCo.ScriptX.StartAsync() - Complete initialization including services connection and print settings
Printing Functions

The library includes wrappers for common printing tasks:

  • PrintPage() - Print the current document
  • PrintFrame() - Print a specific frame
  • BackgroundPrintURL() - Download and print HTML from a URL
  • BackgroundPrintHTML() - Print provided HTML content
  • DirectPrintString() - Send raw data directly to a printer
  • PreviewPage() - Preview the document before printing
Dialog Functions

Functions to launch printing-related dialogs:

  • PageSetup() - Configure page settings
  • PrintSetup() - Configure printer settings
Utility Functions
  • GetAvailablePrinters() - List available printers
  • GetComponentVersion() - Get component version information
  • WaitForSpoolingComplete() - Wait for print jobs to complete
  • CloseWindow() - 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:

  1. Traditional callback-based methods (e.g., PrintPage())
  2. 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

MeadCo ScriptX JS Library

NPM Use

npm install meadco-scriptxjs --save

CDN Use


jsDelivr hits (npm)

<script src="https://cdn.jsdelivr.net/npm/meadco-scriptxjs@1/dist/meadco-scriptx.min.js"></script>

Quick start - ScriptX.Services for any browser

  1. Link to the required libraries with service connection details
  2. Initialise the library
  3. 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>

Quick start for working with ScriptX Add-on only

  1. Link to meadco-scriptx.js <script src="https://cdn.jsdelivr.net/npm/meadco-scriptxjs@1/dist/meadco-scriptx.min.js"></script>
  2. 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

Copyright

Copyright © 2013-2025 Mead & Co Ltd.

License

MeadCoScriptXJS is under MIT license - http://www.opensource.org/licenses/mit-license.php