KEMBAR78
JavaScript Guide | PDF | Java Script | Xml
0% found this document useful (0 votes)
828 views100 pages

JavaScript Guide

Javascript guide

Uploaded by

Mariecar Gecale
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
828 views100 pages

JavaScript Guide

Javascript guide

Uploaded by

Mariecar Gecale
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 100

MapperTM

JavaScript Guide
March 2011
Mapper JavaScript Guide
Document Release Date: 1 March 2011
Software Release: 3.12.0
Product Support: U.S.—+1 877.446.6847; EMEA—+44 (0)1483 569388
For International support outside EMEA, call +1 404.467.3806
© 2011 GXS, Inc. All rights reserved.

GXSTM, the GXS logo, BizManagerTM and InovisworksTM are all trademarks of GXS, Inc.

Unpublished rights reserved under the copyright laws of the United States.
Third-Party Acknowledgements include:
Copyright © 1999-2000 The Apache Software Foundation. All rights reserved.
Copyright © 2000-2002 Brett McLaughlin & Jason Hunter. All rights reserved.

All other trademarks and registered trademarks are the property of their respective owners.

The names of companies and individuals used in any sample database or as examples in the documentation are fictitious
and illustrate the use of the software, only. Any resemblance to actual companies or individuals, whether past or present,
is purely coincidental.

This document and the related software described in this manual are supplied under license or nondisclosure agreement
and may be used or copied only in accordance with the terms of the agreement. The information in this document is
subject to change without notice and does not represent a commitment on the part of GXS,

This document may contain examples of data screens or reports or other descriptions or examples which use the names
of individuals, companies, brands, categories, products and/or product codes. All of these names and codes are fictitious,
and any similarity to the names and codes used by an actual person or entity is entirely coincidental.

U.S. Government Users: This documentation and any software it describes are “commercial items” as that term is
defined in 48 C.F.R. 2.101 and successor regulations, consisting of “commercial computer software documentation”,
“documentation related to commercial computer software” or “commercial computer software” as such terms are used
in 48 C.F.R. 12.212 and 48 C.F.R. 252.227-7014(a)(1) and their successor regulations. Consistent with 48 C.F.R. 12.212
and 48 C.F.R. 252.227-7202-1 through 227.7202-4 and their successor regulations, all U.S. Government users, agencies
and contractors acquire this documentation and the software to which it relates with only those rights described in this
paragraph.

GXS
9711 Washingtonian Boulevard
Gaithersburg, MD 20878
Tel: +1 800.560.4347
Tel: +1 301.340.4000
www.gxs.com

2 Mapper JavaScript Guide


Contents
Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
About This Guide. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .9
Audience . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .9
Additional Documentation. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .9
Contacting Technical Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Professional Services and Training . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
General Inquiries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10

1 GXS Mapper JavaScript Overview


JavaScript Version Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
GXS Mapper JavaScript Features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
Using JavaScript in the GXS Mapper. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
JavaScript Editor Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
JavaScript Repository Overview. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
Translation States Overview. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16

2 Part 1—Document Nodes


JavaScript Document Object Overview. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
GXS Mapper JavaScript Document Objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
Document Envelopes. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
Source and Target Documents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
Document Level Access . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
Record Level Access. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
Field Level Access . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
Data Access . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
Navigating Document Structures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
Root Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
Child / Sibling Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
Instances . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
Occurrences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
Referencing Instances or Collection of Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
JavaScript Example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27

3 Part 2—Basic JavaScript Usage


Adding JavaScripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
Adding JavaScript to a Document Node. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
Adding JavaScripts to the Script Repository from the Document . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
Adding JavaScripts in the Repository . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
Locking Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
Loading Scripts from the Script Repository . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33

3
CONTENTS

4 Part 3 — Advanced JavaScript Usage


Instance Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
Instance Variable Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
Types of Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
Using Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
Loading Variable Sets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
Variable Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
Post-Enveloping Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
Envelope Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
Message Logging . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
Alert Messages. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
Audit Messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
Debug Messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
Reject Error Message . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
Data Tracking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
External Text Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
Opening and Closing External Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
Reading and Writing to Text Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
Writing to a file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
Reading From a File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
JavaScript Database Access . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
JavaScript Database Access Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
Opening a Database Connection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
Database Object. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
Pulling Data from a Database. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
RecordSets. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
Database JavaScript Example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
JavaScript To Create Document Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
New Records. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
New Sub Records . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
New Instance of a Field . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
New Fields . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59

5 Maintaining JavaScripts
Maintaing JavaScripts using the Repository . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
Accessing JavaScript Maintenance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
Viewing Repository Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
Removing Locks on Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
Editing Repository Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
Deleting Repository Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
Maintaining JavaScripts using the JavaScript Editor. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
Accessing the JavaScript Editor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
Navigating the JavaScript Editor Menu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
JavaScript Editor Syntax Checker . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
JavaScript Editor Display . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
Saving JavaScript Snipets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
Opening and Importing JavaScript Snipets. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
JavaScript Editor Keys . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68

4 Mapper JavaScript Guide


CONTENTS

A JavaScript Examples
Julian Date Conversion Example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
Convert Date to Julian Date . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
Convert Julian Date to Date . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
SDQ JavaScript Example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
Pull Value From Database JavaScript Example. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
Setting Counters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75

B Common JavaScript
Supported Objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
Array. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
Boolean. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
Date . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
Math . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
String . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
Supported Statements. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92
Reserved Words. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95

Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97

Mapper JavaScript Guide 5


CONTENTS

6 Mapper JavaScript Guide


List of Procedures
To load a JavaScript from the Script Repository . . . . . . . . . . . . . . . . . . . . . . . . . 31
To add a repository script . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
To lock scripts in the repository . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
To load a JavaScript from the Script Repository . . . . . . . . . . . . . . . . . . . . . . . . . 33
Working With Text Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
To access the JavaScript Maintenance Menu . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
To view scripts in the repository . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
To remove a lock on a script in the repository . . . . . . . . . . . . . . . . . . . . . . . . . . 63
To edits scripts in the repository . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
To delete a script in the repository. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
To access the JavaScript editor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
To save JavaScript snipets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
To open and import JavaScript snipets. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67

7
LIST OF PROCEDURES

8 Mapper JavaScript Guide


Introduction

avaScript is a scripting language that has been incorporated within the GXS Mapper to
J extend the functionality of the transformation engine.

About This Guide


This document introduces the JavaScript functionality within the GXS Mapper. It is not
intended as a JavaScript primer. The user should possess some basic knowledge of common
JavaScripting practices.
The following sections are included:
■ Chapter 1, “GXS Mapper JavaScript Overview”
■ Chapter 2, “Part 1—Document Nodes”
■ Chapter 3, “Part 2—Basic JavaScript Usage”
■ Chapter 4, “Part 3 — Advanced JavaScript Usage”
■ Chapter 5, “Maintaining JavaScripts”
■ Appendix A, “JavaScript Examples”
■ Appendix B, “Common JavaScript”

Audience
This guide addresses the needs of the those who build transformation maps for use with
BizManager, you must be able to do the following:
■ Have a basic working knowledge of common JavaScript.
■ Have a working knowledge of the document layouts used in communication with Trading
Partners.

Additional Documentation
Refer to these documents for additional information about GXS Mapper:
■ GXS Mapper User Guide
■ GXS Mapper Installation Guide
■ GXS Mapper System Messages Guide

Printing Documentation
You can print GXS Mapper documentation using the Adobe Acrobat Reader print functions.

9
Contacting Technical Support

Contacting Technical Support


If support for your product is provided by a GXS Business Partner, contact that Business
partner directly. If support is provided by GXS, go to
http://www.gxs.com/customers/global_service for your support needs.

Here you can select between our world class phone and portal support channels. Should you
select to use the portal support channel as your go forward method of accessing GXS support,
make sure you initiate a phone call and start the registration process so that you can have
access to a rich database of problem resolutions, release notes, known issues, and
announcements.
If the answer to your question is not in the database, you can log a problem ticket on the
Customer Support site.
Customer Support can be reached as follows:
■ With questions or problems related to software or documentation, log a ticket on the
customer support website: http://customer.gxs.com .
■ Contact GXS Customer Support-available 24 hours a day, seven days a week.
Geographic Location Type of Service Call
US Customer Support 1.877.446.6847 option 1
Implementation & Compliance 1.877.446.6847 option 2
Services
Educational Services 1.877.446.6847 option 3
Sales or Professional Services 1.877.446.6847 option 4
Billing Questions 1.877.446.6847 option 5
Payments 1.877.446.6847 option 6
UK Customer Support +44 (0)1483 569388
For out of hours support call
+1 404.467.3806
ASPAC Customer Support
Hong Kong +852-22332111
China (PRC):
■ "China Netcom users 10800 8521694
■ "China Telecom users 10800 1521694

Professional Services and Training


For assistance with product configuration and connectivity testing for BizManager, please
contact the GXS Professional Services team at http://www.gxs.com.
For information regarding BizManager training classes, contact the GXS Education Services
Team at http://www.gxs.com/customers/global_service/training/.

General Inquiries
For general inquiries, you can reach GXS corporate headquarters, as follows:
GXS
9711 Washingtonian Boulevard

10 Mapper JavaScript Guide


General Inquiries

Gaithersburg, MD 20878
Tel: +1 800.560.4347
Tel: +1 301.340.4000
www.gxs.com

Mapper JavaScript Guide 11


General Inquiries

12 Mapper JavaScript Guide


GXS Mapper JavaScript
Overview
1
J avaScript is a powerful scripting language. It is primarily used for internet web pages and
server side scripting. GXS Mapper contains a limited-use JavaScript interpreter to expand
the functionality of the Mapping engine by enabling it to take advantage of the features of
this popular scripting language.
JavaScript is used to manipulate data within a map when there is no formula available to
obtain the desired results.
This section incudes the following:
■ “JavaScript Version Support” on page 13
■ “GXS Mapper JavaScript Features” on page 14
■ “Using JavaScript in the GXS Mapper” on page 14

JavaScript Version Support


The GXS Mapper includes a limited-use JavaScript interpreter. It is based upon the ECMA-
262 Edition 1 standard. It is roughly equivalent to JavaScript version 1.1. For more
information on this standard, refer to the following URL:
http://www.ecma-international.org/
The JavaScript objects that are supported with the GXS Mapper include only those methods
that are defined in ECMA-262, included in JavaScript version 1.1, and relate to the raw data
contained in the source or target documents.
For example, HTML based objects such as Form and Style are not supported. String objects
such as <StringObject>.blink() are not supported.
JavaScript objects such as <StringObject>.subststring(start, stop) are supported.
Example: This script writes this audit message to the BizManager Operation Details page:
Message: AUDIT AEPEP0999 “BC”
JavaScript:
var x = “ABCDEFG”;
mekAudit(x.substring(1,3));
The GXS Mapper also includes object definitions that support the GXS Mapper data structure.
These objects typically start with the letters “mek” (Mapping Engine Kernel). For a list of the
GXS Mapper specific objects, refer “JavaScript Document Object Overview” on page 19.

13
GXS MAPPER JAVASCRIPT OVER VIEW
GXS Mapper JavaScript Features

GXS Mapper JavaScript Features


The GXS Mapper accomplishes transformation of a source document to a target document
primarily through the use of mapping links and formulas. The GXS Mapper includes a wide
variety of formulas to manipulate target data to meet the document requirements.
To augment the use of formulas for data manipulation and extend the features supported by
the GXS Mapper, a JavaScripting tool is available for your use. This tool contains objects
specifically defined for use with the GXS Mapper Source/Target document structure.
The GXS Mapper JavaScript enables the user to:
■ Access Source document nodes
■ Access and modify Target document nodes
■ Create new Target document nodes
■ Log custom audit and error messages
■ Create Session, Source, or Document variables
■ Access external files
■ Perform direct database read and write
■ Use scripting arrays for advanced JavaScript functionality
■ Maintain JavaScripts independently from maps.
■ Reuse JavaScripts in multiple maps.

Using JavaScript in the GXS Mapper


Typical HTML based JavaScript depends upon a trigger to begin the execution of the script.
These triggers may be, for example, the loading of a page or the click of a mouse. Triggers
are referred to as Event Handlers.
In the GXS Mapper, JavaScript Event Handlers are determined by the placement of the
JavaScript on specific nodes of the documents. For example, a JavaScript may be executed
when a source document record is read for the first time, or when the target document has
finished writing.

14 Mapper JavaScript Guide


G X S M A P P E R J AV A S C R I P T O VE R V I EW
Using JavaScript in the GXS Mapper 1

These Event Handlers are configured within the GXS Mapper GUI screens.

For more information regarding GXS Mapper’s JavaScript Event Handlers, see “Translation
States Overview” on page 16.
The following sections describe how JavaScripts can be created or maintained in the GXS
Mapper:
■ “JavaScript Editor Overview” on page 15
■ “JavaScript Repository Overview” on page 16
■ “Translation States Overview” on page 16

JavaScript Editor Overview


Adding JavaScript to a map is made easier by the GXS Mapper’s JavaScript editor. This editor
opens whenever an existing JavaScript in the map is opened or a new JavaScript is being
added.
The Editor includes the following features:
■ Syntax highlighter
■ Syntax checker
■ Search capability
■ Copy/Paste capability
■ Open/Save File

Mapper JavaScript Guide 15


GXS MAPPER JAVASCRIPT OVER VIEW
Using JavaScript in the GXS Mapper

This editor identifies common syntax errors, facilitating smoother development.

Important: JavaScript is case sensitive. This editor does not scan for proper use of case in
GXS Mapper MEK objects.
For more information on the GXS Mapper JavaScript editor, see
■ Chapter 3, “Part 2—Basic JavaScript Usage.”
■ Chapter 4, “Part 3 — Advanced JavaScript Usage.”

JavaScript Repository Overview


The JavaScript Repository feature allows you to create, manage, and reuse JavaScripts.
JavaScript maintenance is performed independently of a map this way the same script can be
used across multiple maps.
For more information regarding GXS Mapper’s JavaScript Repository functions, see
Chapter 3, “Part 2—Basic JavaScript Usage.”

Translation States Overview


When adding a JavaScript, you must choose a translation state that triggers the JavaScript to
run during transformation. Options vary based on the node selected.
Document Type JavaScript can be placed on these nodes:
EDI ■ Document Level
(includes X12, EDIFACT and ■ Segment level
TRADACOM)
JavaScript cannot be placed on individual EDI elements or sub-
elements
XML ■ Document Level
■ All XML Elements
(this includes Empty elements, group elements, and data
elements)
Flat Files ■ Document Level
(Fixed and Variable) ■ Record Level
JavaScript cannot be placed on individual Fields
Database ■ Document Level
■ Table Level
JavaScript cannot be placed on individual columns.
NACHA ■ Document Level
(Fixed and Variable) ■ Record Level
JavaScript cannot be placed on individual Fields

16 Mapper JavaScript Guide


G X S M A P P E R J AV A S C R I P T O VE R V I EW
Using JavaScript in the GXS Mapper 1

Translation states are events triggering a JavaScript during translation:


Where To Find This
Translation State State Description
StartDocumentRead Source Document The script is called when an entire document has
■ Document Level been read into the Source document object. The
translation engine does not pass any parameters
to the translation state.
No Target document exists at this point.
EndDocumentRead Source Document The script is called after all other Source
■ Document Level Document Definition events have been
processed and before any mapping takes place.
No Target document exists at this point.
ReadFirst Source Document The script is called on the first instance of the
■ Record, associated record (Segment, DB Table, or XML
EDI Segment, DB Element) within the Source Document.
Table, or XML
Element Level Subsequent instances of the record (Segment,
DB Table, or XML Element) do not trigger
another call of the script.
No Target document exists at this point.
Read Source Document The script is called on every instance of the
■ Record, associated record within the Source Document.
EDI Segment, DB No Target document exists at this point.
Table, or XML
Element Level
StartDocumentWrite Target Document The script is called as soon as a whole document
■ Document Level has been mapped to the Target document object.
The Target document nodes do NOT exist at
this point.
EndDocumentWrite Target Document The script is called after all other Target
■ Document Level Document Definition events have been
processed and before any formatting takes place.

Target document nodes have been created, but


Envelope processing has not taken place at this
point.
PostEnveloping Target Document The script is called after the enveloping process
■ Document Level has taken place.
■ If batching has been enabled on an EDI
target, this may affect several documents.
To change the outbound envelope setting fields,
use the setEnvelopeField object (see
“Document Envelopes” on page 20).

Mapper JavaScript Guide 17


GXS MAPPER JAVASCRIPT OVER VIEW
Using JavaScript in the GXS Mapper

Where To Find This


Translation State State Description
WriteFirst Target Document The script is called on the first instance of the
■ Record, associated record within the Target document.
EDI Segment, DB Subsequent instances of the record (Segment,
Table, or XML DB Table, or XML Element) do not trigger
Element Level another call of the script.
Write Target Document The script is called on every instance of the
■ Record, associated record within the document.
EDI Segment, DB
Table, or XML
Element Level

Important: JavaScript references depend upon the existence of a document node in order to
process correctly. Be sure to place the JavaScript on a node where the translation state can
trigger the call to the script at a time when all the nodes, referenced in the script, already
exist.
For example, the following script statement references a node on the target document.
var x = mek.targetDocument.getRootRecord(“HEADER”).getRecord(ADDRESSES);
If this JavaScript statement is placed on a source document node using StartDocumentRead,
EndDocumentRead, ReadFirst, or Read, the process would return null since the ‘Addresses’
record does not yet exist at this point. The variable x would not be created. This would force
the rest of the script to fail.

18 Mapper JavaScript Guide


Part 1—Document Nodes
2
his section describes the various document objects in the GXS Mapper and how they

T relate to Javascripts.
Topics include:
■ “JavaScript Document Object Overview” on page 19
■ “Navigating Document Structures” on page 22
■ “Referencing Instances or Collection of Nodes” on page 26
■ “JavaScript Example” on page 27

JavaScript Document Object Overview


JavaScript is a subset of the ECMA script standards by the ECMA International Organization.
The JavaScript incorporated with GXS Mapper is based upon the standard, ECMA-262 Edition
1. This is roughly equivalent to JavaScript version 1.1. (At the time of release of this
JavaScript Guide, the current JavaScript version is 1.5. Therefore, some newer JavaScripting
definitions may not be supported in GXS Mapper).
JavaScript is an Object Oriented programming language. The GXS Mapper’s JavaScript
supports common JavaScript v1.1 objects that apply to raw data manipulation such as String,
Date, and Array. It does not, of course, support HTML type objects such as Document, or
Button.
GXS Mapper’s JavaScript supports commonly used methods that apply to data manipulation.
Examples of these methods include String.charAt, String.indexOf, or Date.getDay. For a list of
common JavaScript terms that are supported by GXS Mapper, see “Common JavaScript” on
page 77.
If you are unsure about the JavaScript object or method you would like to use in a GXS
Mapper JavaScript, review the following steps:
1 Be sure the outcome of the script does not involve the display or formatting of the data
(example: <StringObject>.blink).
2 Check common JavaScript resources to validate that the Object and method is supported
in both ECMA-262 and JavaScript 1.1. (Refer to http://docs.sun.com/source/816-
6408-10/contents.htm for a list of objects, methods and properties.)
3 Add a simple one or two line JavaScript to a map in your GXS Mapper software. Test the
map in the GXS Mapper Test tab and review the results.

19
PAR T 1—DOCUMENT NODES
GXS Mapper JavaScript Document Objects

GXS Mapper JavaScript Document Objects


In order to access and act upon various components of the documents involved in a map,
GXS Mapper has defined a set of objects to use with GXS Mapper JavaScripting. These objects
contain the letters M E K (mapping engine kernel).
There are four basic document types supported in GXS Mapper:
■ XML
■ EDI
■ Flat (text) files
■ Direct Database Read
The object descriptions listed below are sorted by the type of document node it is designed
to reference.
These objects are designed to be combined to navigate to the desired node within a
document.
Groups or collections of nodes can also be referenced where looping is required.
Important: The JavaScript objects are case sensitive.

Object types include:


■ “Document Envelopes” on page 20
■ “Source and Target Documents” on page 21
■ “Document Level Access” on page 21
■ “Record Level Access” on page 21
■ “Field Level Access” on page 22
■ “Data Access” on page 22

Document Envelopes
All documents defined in GXS Mapper have envelope properties. These envelope values are
used to define the parts of the source document that are used to identify the source data and
match it to the appropriate Transformation Profile.
When source data is read and processed, the source envelope object is initialized with all the
data that was flagged as envelope fields. These fields can be accessed, changed, or created
using JavaScript.
Object Description
■ mek.inEnvelope corresponds to source documents
■ mek.outEnvelope corresponds to target documents
■ getEnvelopeField (“fieldname”) used to set a variable equal to the fieldname
■ setEnvelopeField(“fieldname”, “data”) used to place a value in the Envelope field

Example: This script changes the value of the ISA15 element in a target EDI X12 document
after BizManager has finished the enveloping process.
Note: This script is placed on the target document node under Post Processing.

mek.outEnvelope.setEnvelopeField(“ISA15”,”X”);

20 Mapper JavaScript Guide


PA R T 1 —DO CU ME NT NO DE S
GXS Mapper JavaScript Document Objects 2

Source and Target Documents


To manipulate data that is contained in the source or target document you first must be able
to navigate to the exact node within the document. This is accomplished using the following
mek document objects.
Object Description
■ mek.sourceDocument points to the source document
■ mek.targetDocument points to the target document

To navigate further into the document, additional objects are provided. These objects are
linked together with a period (.). The following sections list objects in the following format:
<mek-object>.getRootRecord(“recordname”)

where <mek-object> is equal to a previously defined object.


Example: mek.sourceDocument.getRootRecord(“HEADER”);

Document Level Access


Navigate to objects within the Document:
Example: mek.sourceDocument.getRootRecord(“HEADER”);
Object Description
■ <mek-object>.getRootRecord(“recordname”) Flat File & Database table version
■ <mek-object>.getRootElement(“element-tag”) XML version
■ <mek-object>.getRootSegment(“segment-tag”) EDI version

Record Level Access


Navigate to Record objects.
Example: mek.sourceDocument.getRootRecord(“HEADER”).getRecord(“Address”);
Object Description
■ <mek-object>.getRecord(“recordname”) Flat File & Database table version
■ <mek-object>.getXMLElement(“element-tag”) XML version
■ <mek-object>.getSegment(“segment-tag”) EDI version
■ mekRec ■ Can be used by any document
type
var x = mekRec.getField(1); ■ The script must be placed on the
record, segment, table, or XML
group element being referenced.

mekRec
Typically, to access a specific node within a defined document, GXS Mapper’s JavaScript
would specify the path to the node starting at the document level. This can be simplified by
using mekRec on a Record, Segment, XML Element, or Table node. When used, mekRec
references the first instance of the node on which it is placed and removes the need to specify
the Source/Target Document, Root Record, or parent records. The following example
accesses the same N4 segment in an EDI X12 850 document. The first example may be placed
on any node. The second example needs to be placed on the N4 segment.

Mapper JavaScript Guide 21


PAR T 1—DOCUMENT NODES
Navigating Document Structures

Example 1:
mek.sourceDocument.getRootRecord(“ST”).getRecord(“N1”).getRecord(“N4”);
Example 2:
mekRec(“N4”);
Use of mekRec has the following advantages:
■ Less chance of error in the path defined
■ Placing the JavaScript on the Record node results in the script not being executed if the
Record does not exist within the actual data. There is, therefore, less chance of
NullPointerException error if the record does not exist.
Important: mekRec references the first instance of the record. If multiple instances of the
record need to be referenced, getRecords must be used (see “Referencing Instances or
Collection of Nodes” on page 26).

Field Level Access


Navigate to fields, EDI elements, XML elements, or XML attributes.
Example:
mek.sourceDocument.getRootRecord(“HEADER”).getRecord(“Address”).getField(“Street”);
Object Description
■ <mek-object>.getField(“fieldname”) Flat File & Database column version
■ <mek-object>.getXMLElement(“element-tag”) XML version
■ <mek-object>.getXMLAttribute(“attributename”) XML version
■ <mek-object>.getEDIElement(“element-tag”) EDI version

Data Access
To access the data within a Field, element, attribute, or database table column, use one of the
following:
Example:
mek.sourceDocument.getRootRecord(“HEADER”).getRecord(“Address”).getField(“Street”).
setData(“Maple Ave”);
Object Description
■ <mek-object>.getData() sets a variable equal to the value of a
document node.
■ <mek-object>.setData(“value”) places the new value in the object
Note: you cannot change the value of a
source document node.

Navigating Document Structures


As seen in the examples used in the previous section, mek objects can be linked together to
access specific nodes within a document. Linked objects must follow the document’s
hierarchal path specifications.
The structure of the JavaScript must follow the hierarchy structure of the document layout.
The document structure includes the following components:

22 Mapper JavaScript Guide


PA R T 1 —DO CU ME NT NO DE S
Navigating Document Structures 2

■ “Root Nodes” on page 23


■ “Child / Sibling Nodes” on page 23
■ “Instances” on page 24
■ “Occurrences” on page 25

Root Nodes
The Root node is the highest level of a document hierarchy group. XML documents have only
one root element. EDI X12 documents use the ST segment as the root segment. EDI EDIFACT
use UNH segments as the root segment. Flat Files may have several root records. The Invoice
Flat File example has three root records.

Root
Records

Example:
var x = mek.sourceDocument.getRootRecord(“OrderDetail-Rec”);

Child / Sibling Nodes


Other nodes that exist with a document are children of the Root nodes. Nodes that exist on
the same hierarchal level are called sibling nodes. To reference the child nodes of a
document, start with the root node and follow the hierarchal path.
Sibling nodes do not have to be named.
Root > Child > Child
Header-Rec > Company Address-Rec
OrderDetail-Rec > Item-Rec > Location-Rec

Mapper JavaScript Guide 23


PAR T 1—DOCUMENT NODES
Navigating Document Structures

In the example, Item-Rec is a child of OrderDetail-Rec and a sibling of BillingTerms-Rec.

Parent

Sibling

Child

Example: All these script statements reference the first Item-Rec record. All counts within
JavaScript start with 0.
var x=mek.sourceDocument.getRootRecord(“OrderDetail-Rec”).getRecord(“Item-Rec”);
var x=mek.sourceDocument.getRootRecord(“OrderDetail-Rec”).getRecord(2);
var x=mek.sourceDocument.getRootRecord(“OrderDetail-Rec.Item-Rec”);

Instances
Many documents have repeating nodes. These nodes may have child nodes that repeat as
groups. In the example, the Location-Rec record repeats. The Item-Rec record also repeats.
Repeating document nodes are called Instances.
You can reference a document instance by using the instance number with getRecords(n) or
getInstance(n).

Two instances of
Item-Rec

24 Mapper JavaScript Guide


PA R T 1 —DO CU ME NT NO DE S
Navigating Document Structures 2

Example: Both these scripts reference the first instance of the Item-Rec record. All counts
within JavaScript start with 0.
var x = mek.sourceDocument.getRootRecord(“OrderDetail-Rec”).getRecords(“Item-
Rec”).getInstance(0);
var x = mek.sourceDocument.getRootRecord(“OrderDetail-Rec”).getRecords(“Item-
Rec”,0);

Occurrences
When a document contains two un-related nodes that have the same name or tag and are on
the same hierarchy level, the nodes are referred to as occurrences.
In the Contact XML example, there is a Type element that is the first child of the Contact
element. There is also a Type element that is the last child of the Contact element. The
second Type element is not a repeat of the first. It is a second occurrence. Since the two nodes
share the same tag name, they are separate occurrences of the Type element
The second occurrence is repeated three times. This second occurrence, therefore, has three
instances.
When referencing a collection of nodes, the plural version of the “get” method is used (see
“Referencing Instances or Collection of Nodes” on page 26):
■ getRecords
■ getXMLElements
■ getSegments
You can reference a document occurrence by using the occurrence number with getRecord.

Two occurrences of Type


The second occurrence
has three instances

Example: This JavaScript statement references the first occurrence of the Type element.
(<Type>Primary</Type>)
var x =
mek.sourceDocument.getRootElement(“ContactList”).getXMLElement(“Contact”).getX
MLElements(“Type”,0)

Mapper JavaScript Guide 25


PAR T 1—DOCUMENT NODES
Referencing Instances or Collection of Nodes

Example: This JavaScript statement references the second occurrence of the Type element.
(<Type>International</Type>)
var x =
mek.sourceDocument.getRootElement(“ContactList”).getXMLElement(“Contact”).getX
MLElements(“Type”,1)

Example: This JavaScript statement references the third instance of the second occurrence of
the Type element. (<Type>Limited Hours</Type>. Notice that the syntax of the path
specification is: [Occurrence Number]NodeName[Instance Number].
var x =
mek.sourceDocument.getRootElement(“ContactList”).getXMLElement(“Contact”).getX
MLElements(“[1]Type[2]”)

Referencing Instances or Collection of Nodes


A collection of records is a series of all instances of a particular record (even if only one
instance exists). This is the only way in which instances can be accessed. When referencing a
collection of nodes, the plural version of the “get” method is used. Various syntax types exist
for the different data types.

Object Description
■ <mek-object>.getRecords(“recordname”) Flat File & Database table version
■ <mek-object>.getXMLElements(“element-tag”) XML version
■ <mek-object>.getSegments(“segment-tag”) EDI version

These functions obtain a named record collection from within the document records’
hierarchy.
Example:
var x = mek.sourceDocument.getRootSegment(“ST”).getRecords(“DTM”);

Accessing Records Within an Instance


Once an Instance collection has been identified, records may be accessed individually or as
part of a loop process.

26 Mapper JavaScript Guide


PA R T 1 —DO CU ME NT NO DE S
JavaScript Example 2

INDIVIDUAL
You can reference a document instance by using the instance number with getInstance(n) or
getRecords(n).
var x =
mek.sourceDocument.getRootSegment(“ST”).getRecords(“DTM”).getInstance(1);

var x = mek.sourceDocument.getRootSegment(“ST”).getRecords(“DTM”,1);

LOOP PROCESS
You can reference an entire collection of records by using instanceCount within a JavaScript
for statement.
var x = mek.sourceDocument.getRootSegment(“ST”).getRecords(“DTM”);
for ( var n = 0; n <x.instanceCount(); ++n)
{ //Commands are placed in this section }

JavaScript Example
This is a JavaScript that can be placed on the document End Document Write level of the
target document. This script navigates to the IT1 instances. It finds each IT1 09 element and
remove the first three characters from the value of this element.

//JavaScript example that removes the first three characters of the IT109
elements
//First reference the IT1 instance group
var x = mek.targetDocument.getRootSegment("ST").getSegments("IT1");
for (var n = 0; n < x.instanceCount(); ++n)

// This section will loop through each IT1 instance,


//find the IT109 element
//perform a substring command to remove the first three characters
//and set the modified value back into the IT109
{
var x_instance = x.getInstance(n);
var x_value = x_instance.getEDIElement("IT109").getData();
var x_mod = x_value.substring(3,9);
x_instance.getEDIElement("IT109").setData(x_mod);
}

Mapper JavaScript Guide 27


PAR T 1—DOCUMENT NODES
JavaScript Example

28 Mapper JavaScript Guide


Part 2—Basic JavaScript
Usage
3
efining JavaScripts in the GXS Mapper is made easier by the JavaScript editor. This

D editor opens whenever an existing JavaScript in the map is opened or a new


JavaScript is being added. Additionally, the JavaScript Repository feature allows you
to create, manage, and reuse JavaScripts. JavaScript maintenance is performed independently
of a map this way the same script can be used across multiple maps.
This section describes how to create basic JavaScript mapping and defining JavaScripts in the
Repository. Topics include:
■ “Adding JavaScript to a Document Node” on page 30
■ “Adding JavaScripts to the Script Repository from the Document” on page 31

Adding JavaScripts
JavaScripts can be added to a document node by using either of the following methods:
■ Add JavaScripts directly to a document node. See “Adding JavaScript to a Document Node” on
page 30.
Note: Scripts added using this method are
only available in the map where the JavaScript
was created.
■ Add JavaScripts into the document and Script See “Adding JavaScripts to the Script Repository
Repository from within a document. from the Document” on page 31

Note: Scripts added using this method are


available to any map by loading the script
from the repository.

29
PA R T 2 — B A S I C J AV A S C R I P T U S AGE
Adding JavaScripts

Adding JavaScript to a Document Node


To add a JavaScript

1 From the Map tab, right-click on the node where the JavaScript is to be triggered and
select Add/Edit Script.
2 Select a Translation State where you want the JavaScript to be triggered from the list.

■ StartDocumentRead ■ EndDocumentWrite
■ EndDocumentRead ■ PostEnveloping
■ ReadFirst ■ WriteFirst
■ Read ■ Write
■ StartDocumentWrite

Note: Trigger options vary based on the node selected.


For more information about these translation stages, see “Translation States Overview” on
page 16.
The Script Editor dialog opens.

3 Type the JavaScript code and click OK.


The JavaScript editor checks your script for common syntax errors. If there are no errors,
the JavaScript screen closes and you are returned to the Map screen.
Important: When you Validate your map, the Validation does not check the included
JavaScript. Test your map to ensure that JavaScript is working properly.

30 Mapper JavaScript Guide


PAR T 2—BASIC JAVASCRIPT USAGE
Adding JavaScripts in the Repository 3

Adding JavaScripts to the Script Repository from the Document


Use the Add to Repository tool add JavaScripts displayed in the Script Editor to the Script
Repository.

To load a JavaScript from the Script Repository


1 Open a map from the GXS Mapper Main window and click the Map tab.
2 Right-click the document node where the JavaScript is to be added and select Add/Edit
Script.
The Script Editor dialog opens.
3 Type the JavaScript in the text box and click OK.
The Add Script Properties dialog opens.

4 Type the following:


■ Name (no spaces).
■ Description.
5 Click OK.
The script is added to the repository.
Note: If the name entered already exists, you are prompted to overwrite the existing
repository script if the script is not locked by another user.

Adding JavaScripts in the Repository


JavaScripts can be added to the Script Repository. After the scripts are added, they must be
locked, before the script can be loaded into a map.

To add a repository script


1 From the Script Maintenance, click Add.

Mapper JavaScript Guide 31


PA R T 2 — B A S I C J AV A S C R I P T U S AGE
Adding JavaScripts in the Repository

The Add Repository Script dialog opens.

2 Do one of the following:


■ Type the JavaScript text and click OK.
■ Click File > Open and select an existing file and click OK.
The Add Script Properties dialog opens.

3 Type the following:


■ Name (no spaces).
■ Description.
4 Click OK.
The script is added to the repository.
Note: If the name entered already exists, you are prompted to overwrite the existing
repository script if the script is not locked by another user.

Locking Scripts
Locking scripts prevents other users from making changes to the script. Only the user who
locked a script can unlock it or modify it when it is locked.

To lock scripts in the repository


1 From the Mapper main menu, select Repository > Script Maintenance.
The Script Maintenance dialog opens.
2 Select a script and click Lock.

32 Mapper JavaScript Guide


PAR T 2—BASIC JAVASCRIPT USAGE
Adding JavaScripts in the Repository 3

The script is now locked and cannot be changed by other users. The user name of the
user who locked the script displays in the Locked By column.

Loading Scripts from the Script Repository


Use the Load from Repository tool to populate the script text by loading individual script(s)
from the Script Repository.

To load a JavaScript from the Script Repository


1 Open a map from the GXS Mapper Main window and click the Map tab.
2 Right-click the document node where the JavaScript is to be added and select Add/Edit
Script.
The Script Editor dialog opens.
3 Click Tools > Load from Repository.
The Select Script to Load dialog opens.

4 Highlight a script and click Select.


The contents of the selected script populates the script editor.
5 Do any of the following:
■ Select another script to append to the existing text. Repeat steps 3 and 4.
■ Make edits as needed to the script.
■ Click OK to save changes and exit the Script Editor.

Mapper JavaScript Guide 33


PA R T 2 — B A S I C J AV A S C R I P T U S AGE
Adding JavaScripts in the Repository

34 Mapper JavaScript Guide


Part 3 — Advanced JavaScript
Usage
4
dvanced JavaScripting includes the use of additional features, such as variables,

A references to text files and message logging, in your JavaScript.


Topics include:
■ “Instance Variables” on page 35
■ “Message Logging” on page 43
■ “External Text Files” on page 48
■ “JavaScript Database Access” on page 53
■ “JavaScript To Create Document Nodes” on page 58

Instance Variables
GXS Mapper relies on JavaScript to provide the ability to use variables in a map. This is
accomplished through the use of Instance Variables. An Instance variable is a defined object.
This section includes:
■ “Instance Variable Overview” on page 35
■ “Types of Variables” on page 36
■ “Using Variables” on page 36
■ “Loading Variable Sets” on page 37
■ “Variable Examples” on page 37
■ “Post-Enveloping Variables” on page 38

Instance Variable Overview


Usually, data that is created or read in one script only persists as long as the execution of that
script. Through the use of Instance Variables, data created in one script can be saved for use
in another, unconnected script.
If, for example, your map requires a counter variable, a JavaScript can be placed on the
Target Document node (StartDocumentWrite) that opens a database to retrieve a starting
counter value. That counter can then be assigned to an Instance variable which would then

35
PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
Instance Variables

be available to a script on a target detail record to increment and place counter values in a
target field.
Important: If variables are not initialized properly, accessing these variables causes a Java
NullPointerException error to occur. This causes the script, and possible the map, to fail. It is
advisable to programmatically check for “null” within the JavaScripts prior to issuing a
command accessing specific variables.

Types of Variables
The amount of processing time that the variable is available depends on the type of Instance
variable that is defined. Variables available include:
Variable Types Persistence
Document Level - documentVars The variable exists only through the processing of a
single document.
If a file consisting of several documents is being
processed, the variable is deleted at the end of each
document and is recreated with a new value at the
start of each document.
Data Source Level - dataSourceVars The variable exist as long as a single input file. A single
file may contain many documents.
If a file consisting of several documents is being
processed, the variable value at the end of the
processing of each document is carried over to the
next document.
Session Level - sessionVars The variable exists as long as the MEK process. Each
session may contain several files. Each file may contain
several documents.
The variable value at the end of the processing of each
document is carried over to the next document.
Post-Enveloping - getEnvelopeField The variable is used to get EDI enveloping information
during the “Post Enveloping” script event. The
envelope information available contains “outEnvelope”
and “inEnvelope” structures.

Using Variables
Variables, typically set in JavaScripts, are placed on the source document or near the
beginning of the target document.
■ Set Variable
To use the Instance Variable feature, you must set the variables. This creates the variable
and load a defined value.
Syntax: mek.sessionVars.set(“variableName”,”variableValue”)
Examples:
mek.sessionVars.set(“myvar”, “Hello”);
mek.documentVars.set(“countervar”, “0”);
■ Get Variable
To retrieve Instance Variables for use later in the map, use get as shown below. This pulls
the value of the Instance Variable for use in further processing.

36 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
Instance Variables 4

Syntax: mek.sessionVars.get(“variableName”);
Example:
var x = mek.sessionVars.get(“myvar”);
var y = mek.documentVars.get(“countervar”);

Loading Variable Sets


Instance Variables can be set up at the start of a Session, File, or Document by importing a set
of variables from an external properties file. This file may reside on any network directory
that is accessible to the GXS Mapper processor during the map execution. This can be useful
for setting variables based upon certain criteria in the source or target document.
This feature is accomplished through the use of a load method.
Load Examples:
■ mek.sessionVars.load(“http://10.55.555.12:8080/default/POvars.txt”);
■ mek.sessionVars.load(“file:C:/default/POvars.txt”);
■ mek.sessionVars.load(“ftp://10.55.555.12:1022/default/POvars.txt”);
The properties file must be a text-format file with the following layout:

Script Example:
■ #1 script on the Source document level (StartDocumentRead)
mek.documentVars.load(“file:C:/test/POvars.txt”);
■ #2 script on the target detail record(Write)
var x = mek.documentVars.get(“variableName1”);
mekAudit(x);
■ Result is an audit entry on the map results = Audit AEPEP0999 value1

Variable Examples
Example 1
■ #1 script on the Source document level (StartDocumentRead)
mek.documentVars.set(“CompanyName”, “Best Co.”);
■ #2 script on the target REF segment(Write). This script replaces the mapped value of the
target element, REF03, with the value of the variable, CompanyName. The resulting
REF03 element contains Best Co.
var x = mek.documentVars.get(“CompanyName”);
var y = mek.Rec.getEDIElement(“REF03”).setData(x);

Mapper JavaScript Guide 37


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
Instance Variables

Important: The REF03 element must have a mapped value. This can be accomplished by
defining a default value in the BDD, using a formula to assign a default value, or by creating
the document node.

In this example, it is required that the node exists before the JavaScript is executed. If REF03
does not exist, vary will be null and the script fails.
Example 2
■ #1 script on the Source document level (StartDocumentRead). This script opens a database
to retrieve a value that is used in the target document.
//Create connection to database
var myDB =
openDB("sqlserver","DBSERVER;database=MAP_TEST","user1","pass");
myDB.open(true);
// Create a data set from a DB query
var x = myDB.createRecordSet().query("SELECT CO_ID FROM
user1.IDENTIFIER WHERE PARTY_NAME ='Acme'");
while (x.next()) {
//retrieve the value and set as an Instance Variable
var y = x.getString("PARTY_ID");
mek.documentVars.set(“MyValue”,y); }
x.close();
myDB.close();

■ #2 script on the Target PO1 segment(Write). This script modifies the mapped value of the
target element, PO1 09, by prepending the value from the variable, MyValue.
//Get value from Instance variable
var A = mek.documentVars.get(“MyValue”);
//Set a reference B to the PO1 09 element
var B=
mek.targetDocument.getRootSegment(“ST”).getSegment(PO1).getEDIElemen
t(“PO109”);
// Get the value of PO1 09
var C = B.getData();
//C = mapped data for PO1 09, A= value pulled from the database. A+C
prepends the value from the database to the mapped value of PO1 09.
B.setData(A+C);

Post-Enveloping Variables
JavaScript can be used to get EDI enveloping information during the “Post Enveloping” script
event. The envelope information available contains “outEnvelope” and “inEnvelope”
structures.
This section provides the following examples to obtain envelope information along with the
variable names you can use to get envelope information.
■ “Example to Get Interchange Control Number Information” on page 38
■ “Envelope Variables” on page 39

Example to Get Interchange Control Number Information


The following script is an example of how to get the Interchange Control number in the Post
Enveloping Java script event:
var icr_number=mek.outEnvelope.getEnvelopeField("UNB0020");

38 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
Instance Variables 4

Where the var “icr_number” contains the Interchange Control number.


Note: The literal for EDIFACT is UNB0020 and the literal for X12 is ISA13.

Important: When “Minimize Groups and Interchanges” is in effect the Interchange Control
number is not assigned during the execution of individual transformations. It is assigned
during in a final session commit. A test for this condition can be done by testing the
Interchange Control number for 0.
Example:
var icr_number=mek.outEnvelope.getEnvelopeField("UNB0020");
if(icr_number = "0")
{
mekError("The Interchange control number is invalid: " + icr_number);
}
Execute this code in the “Post Enveloping” script event and it produces the following result
during transformation:
ECTMCT0034 Document rejected. Unable to output current document. Unable to
write document. Error occurred whilst running JavaScript event. The
Interchange control number is invalid: 0 Sep 29, 2008 2:26 PM Reject
Document rejected. An error occurred when attempting to output the current
document. Unable to write document. Error occurred whilst running
JavaScript event during post enveloping. The Interchange control number is
invalid: 0

ECTFT0008 Unable to output current document.


An error occurred when attempting to output the current document.

EFTFT0008 Unable to write document.

ECTJS0003 Error occurred whilst running JavaScript event.


Error occurred whilst running JavaScript event during post enveloping.

EEPEP0997 The Interchange control number is invalid: 0


The Interchange control number is invalid: 0

Envelope Variables
The section lists all the envelope variables which can be used when retrieving information
using the getEnvelopeField command.
The variables are listed by the supported envelope type:
■ “X12 Interchange Envelope” on page 40
■ “X12 Group Envelope” on page 40
■ “X12 Transaction Set Envelope” on page 40
■ “X12 Interchange Control Trailer” on page 40
■ “X12 Functional Group Trailer” on page 41
■ “X12 Transaction Set Trailer” on page 41
■ “EDIFACT UNA Envelope” on page 41
■ “EDIFACT UNB Envelope” on page 41
■ “EDIFACT UNH Envelope” on page 42

Mapper JavaScript Guide 39


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
Instance Variables

■ “EDIFACT UNZ Envelope” on page 43


■ “EDIFACT UNG Envelope” on page 42
■ “EDIFACT UNE Envelope” on page 41
■ “EDIFACT UNH Envelope” on page 42

X12 Interchange Envelope


Variable Name Description
ISA01 Authorization Information Qualifier
ISA02 Authorization Information
ISA03 Security Information Qualifier
ISA04 Security Information
ISA05 Interchange ID Qualifier (Sender)
ISA06 Interchange Sender ID
ISA07 Interchange ID Qualifier (Receiver)
ISA08 Interchange Receiver ID
ISA11 Interchange Control Standards identifier
ISA12 Interchange Control Version Number
ISA13 Interchange Control Number
ISA14 Acknowledgement Requested
ISA15 Test Indicator

X12 Group Envelope


Variable Name Description
GS01 Functional Identifier Code
GS02 Application Sender’s Code
GS03 Application Receiver’s Code
GS06 Group Control Number
GS07 Responsible Agency Code
GS08 Version / Release / Industry / Identifier Code

X12 Transaction Set Envelope


Variable Name Description
ST01 Transaction Set Identifier Code
ST02 Transaction Set Control Number

X12 Interchange Control Trailer


Variable Name Description
IEA02 Interchange Control Number

40 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
Instance Variables 4

X12 Functional Group Trailer


Variable Name Description
GE02 Group Control Number

X12 Transaction Set Trailer


Variable Name Description
SE02 Transaction Set Control Number

EDIFACT UNA Envelope


Variable Name Description UNA
FieldSeparator Envelope Field Separator UNA2 - Data element separator
SubfieldSeparator Envelope Subfield Separator UNA1 - Component data element
separator
ReleaseCharacter Envelope Release Character UNA4 - Release character
RepetitionSeparator Envelope Repetition Separator UNA5
RecordTerminator Envelope Record Terminator UNA6 - Segment terminator

EDIFACT UNE Envelope


Variable Name Description UNE
UNE0048 Group_reference UNE02

EDIFACT UNB Envelope


Variable Name Description UNB
UNBS0010001 Syntax Identification UNB0101
UNBS0010002 Version Number UNB0102
UNBS0010080 Service Code List Directory UNB0103
Version Number
UNBS0010133 Character Encoding UNB0104
UNBS0020004 Sender Identifier UNB0201
UNBS0020007 Sender Identifier Code Qualifier UNB0202
UNBS0020008 Sender Reverse Routing UNB0203
UNBS0020042 Sender Interrnal Subid UNB0204
UNBS0030010 Receiver ID UNB0301
UNBS0030007 Receiver ID Code Qualifier UNB0302
UNBS0030014 Receiver Routing UNB0303
UNBS0030046 Receiver Internal Subid UNB0304
UNB0020 Interchange Reference UNB0501
UNBS0050022 Recipients Password UNB0601
UNBS0050025 Recipients Password Qualifier UNB0602
UNB0026 Application Reference UNB0701
UNB0029 Processing Priority Code UNB0801
UNB0031 Acknowledgement Request UNB0901

Mapper JavaScript Guide 41


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
Instance Variables

Variable Name Description UNB


UNB0032 Communications Agreement ID UNB1001
UNB0035 Test Indicator UNB1101

EDIFACT UNG Envelope


variable name string UNG
UNG0038 Group Identification UNG01
UNGS0060040 Sender ID UNG0201
UNGS0060007 Sender ID Code Qualifier UNG0202
UNGS0070044 Receiver ID UNG0301
UNGS0070007 Receiver ID Code Qualifier UNG0302
UNG0048 Group Reference UNG05
UNG0051 Control Agency UNG06
UNGS0080052 Message Version UNG0701
UNGS0080054 Message Release UNG0702
UNGS0080057 Message Association Code UNG0703
UNG0058 Application Password UNG08

EDIFACT UNH Envelope


Variable Description UNH
UNH0062 Message Reference Number UNH01
UNHS0090065 Message Type UNH0201
UNHS0090052 Message Version Number UNH0202
UNHS0090054 Message Release Number UNH0203
UNHS0090051 Controlling Agency UNH0204
UNHS0090057 Association Assigned Code UNH0205
UNHS0090110 Code List Dir Version Number UNH0206
UNHS0090113 Message Type Subfunc ID UNH0207
UNH0068 Common Access Reference UNH03
UNHS0100070 Sequence of Transfers UNH0401
UNHS0100073 First and Last Transfer UNH0402
UNHS0160115 Message Subset ID UNH0501
UNHS0160116 Message Subset Version Number UNH0502
UNHS0160118 Message Subset Release Number UNH0503
UNHS0160051 Controlling Agency Coded UNH0504
UNHS0170121 Message Implementation Guideline UNH0601
ID
UNHS0170122 Message Implementation Guideline UNH0602
Version Number
UNHS0170124 Message Implementation Guideline UNH0603
Release Number
UNHS0170051 Controlling Agency Coded UNH0604
UNHS0180127 Scenario ID UNH0701

42 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
Message Logging 4

Variable Description UNH


UNHS0180128 Scenario Version Number UNH0702
UNHS0180130 Scenario Release Number UNH0703
UNHS0180051 Controlling Agency Coded UNH0704

EDIFACT UNZ Envelope


Variable Name Description UNZ
UNZ0020 Interchange Reference UNZ02

Message Logging
GXS Mapper’s JavaScripting offers additional tools for logging custom messages and data.
These messages can be written to BizManager’s Transformation audit messages or to log files.
This section includes:
■ “Alert Messages” on page 43
■ “Audit Messages” on page 44
■ “Debug Messages” on page 45
■ “Reject Error Message” on page 45
■ “Data Tracking” on page 46

Alert Messages
The Alert function is a messaging tool for use within the GXS Mapper. When testing a map in
the GXS Mapper Test tab, Alert sends a custom message to the screen, stopping the
transformation process until the user responds by clicking OK.
Within the BizManager Transformation process, Alert does not send the message to the
screen. Rather, it is send to the Operations Detail screen and BizManager Transformation log.

Example:
var x = mekRec(“FOB”).getEDIElement(“FOB01).getData();
if (x != “BP”)
{ alert(“Incorrect Code”);
}

Mapper JavaScript Guide 43


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
Message Logging

Audit Messages
The Audit function is an easy way to send custom messages to the list of Audit messages that
is displayed for every Mapping/Transformation process. These Audit messages can be seen in
the test message log on the GXS Mapper or on the Operation Details screen of BizManager.

Audit messages can be strings defined to alert or inform the user of the Mapping process.
This is useful in testing new maps.
Example1:
var x =
mek.sourceDocument.getRootSegment(“ST”).getSegment(“FOB”).getEDIElement(“FOB
01).getData();
if (x == “BP”)
{ mekAudit(“Paid by Buyer”);
}
Example2 (must be placed on FOB segment):
var x = mekRec(“FOB”).getEDIElement(“FOB01).getData();
if (x == “BP”)
{ mekAudit(“Paid by Buyer”);
}
Audit messages can also include variables created from values pulled from the source or
target documents, or from values set in JavaScript variables.
Example1:
var x =
mek.sourceDocument.getRootSegment(“ST”).getSegment(“BEG”).getEDIElement(“BEG
05”).getData();
mekAudit(“The Purchase Order date is “+x);
Example2 (must be placed on the BEG segment):
var x = mekRec.getEDIElement(“BEG05”).getData();
mekAudit(“The Purchase Order date is “+x);

44 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
Message Logging 4

Debug Messages
The Debug function is also an easy way to log custom messages. Unlike the Audit function
that displays messages, the Debug function simply writes its data to the log files.
In the GXS Mapper, maps that are tested write debug messages to the map.log file. This log
file can be located in the <MapperInstallDir>\app3.x.x\logs folder.
In BizManager, during the transformation process, the Debug message is written to the
transformationservice.log file. This is located in the <BizManagerInstallDir>\app3.x.x\logs
folder. Like the Audit messages, this feature can also include variables created from values
pulled from the source or target documents, or from values set in JavaScript variables.
Example:
debug (“Program got this far!”);

Reject Error Message


The error message function, mekError, extends the power of logging custom messages.
When this JavaScript is executed, the mapping controller is informed that a fatal error has
taken place and reject the Transformation process.
The message defined with mekError is logged to the Audit log; similar to the Audit message
mekAudit.
In the GXS Mapper test screen, the MEK engine aborts the map process. Depending upon the
settings in your BizManager Transformation profile, the BizManager transformation process
aborts all or part of your source file.
Like the Audit messages, this feature can also include variables created from values pulled
from the source or target documents, or from values set in JavaScript variables. This can be
used to check either the source or target for expected values and if not found, reject the
transformation process.
Example:

Mapper JavaScript Guide 45


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
Message Logging

mekError(“Error Testing”);

In a transformation where the source document is an EDI type, when a JavaScript contains
mekError, a negative acknowledgement document (997/CONTRL) is generated by default.
To modify this output, add a value of “999” as a second parameter to the mekError
statement.
Examples:
mekError(“Error Testing”); <=======Negative FA is generated.
mekError(“Error Testing”, “997”); <==Negative FA is generated.
mekError(“Error Testing”, “999”); <==Positive FA is generated.

Data Tracking
The Data tracking facility allows users to log the values of various data objects. BizManager
allows tracking up to four values in a single map. Data that appears in the Source or Target
documents can be tracked by setting the tracking property in the GXS Mapper Document
definition properties, (See the GXS Mapper User Guide for more information regarding Tracking
Properties). These values can be accessed and modified using JavaScript.
Data objects that do not appear in the source or target documents can also be tracked using
JavaScript.
Refer to the following data tracking sections:
■ “Access Defined Tracking Values” on page 46
■ “Setting Tracking Values” on page 47

Access Defined Tracking Values


To access a value that is being tracked from the source or target document, you must first
define the tracking in the document definition properties.
1 Locate node of the value to be tracked
2 Enter a tracking name in the properties panel

46 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
Message Logging 4

3 Set the priority

Once the tracking is defined, the Tracking name can be referenced in a JavaScript.
The following JavaScript pulls the value of the tracked Invoice number, srcINV. It then
displays this number in the Audit log
Syntax: mek.tracking.getTrackingField(trackingName);
Example:
var x = mek.tracking.getTrackingField(“srcINV”);
mekAudit(x);
Audit Log displays : Audit AEPEP0999 62568

Setting Tracking Values


Tracking values that are set in the document definition tracking properties exist in either the
source or the target document. Other data objects can also be tracked using this JavaScript
facility. Other data objects can include, for example, values that have been returned from a
database query during the processing of a transformation.
Setting tracking values can also be used to modify defined tracked values from the document
definition properties, without modifying the actual values in the source or target documents.
Syntax: mek.tracking.setTrackingField(trackingName, Value, Priority)
Note: The Priority parameter is an integer between one (1) and three (3), where one (1) is
the highest priority.
Example:
//Get the value of the defined tracked value srcINV
var x = mek.tracking.getTrackingField("srcINV");
//prepend “INV” to the beginning of each value for recording in BizManager.

Mapper JavaScript Guide 47


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
External Text Files

//This does not change the value in the target document


mek.tracking.setTrackingField("srcINV", "INV"+x,1);
//Add a new tracked value called “newINV”
mek.tracking.setTrackingField("newINV","custom",3);

External Text Files


This feature allows the GXS Mapper to create, open, write to, and read external text files that
are located on a local or mapped drive of the GXS Mapper or BizManager Transformation
server.
Writing to an external file is useful, for example, if a user needs to keep a separate list of all
the Purchase Order numbers received from a Trading partner.
Reading from an external file can be used, for example, to read in a list of part numbers or
other values that can be assigned to an Instance Variable or an array for later use in data
processing.
This section includes:
■ “Opening and Closing External Files” on page 48
■ “Reading and Writing to Text Files” on page 49

Opening and Closing External Files

Working With Text Files


Text files may be created, opened, or closed using the following:
■ openFile(“Full file path and name”)
This opens a file for modification. The process returns null if the file cannot be opened. If
the specified file does not exist, an attempt is made to create it. The defined path must
exist for the file to be created.
■ <FileObject>.close()
This closes the file and returns a value of “0” if the file closed successfully. Otherwise it
returns a value of “-1”.
Example:

48 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
External Text Files 4

var x= openFile("C:\\Lists\\Parts.txt");
var y = readLn(x);
x.close();

Reading and Writing to Text Files


Once a text file is open you can read from it or write to it. Access to the file can be performed
in different modes depending on the layout of the text file:
■ Line Based Access - Each string of data is written on its own line. Lines are separated by a
<CR>character.
■ Delimiter Based Access - All data is written on one line and is separated by the delimiter
characters <<<stringdata>>>.
Refer to the following sections:
■ “Writing to a file” on page 49
■ “Reading From a File” on page 51

Writing to a file
When you write to a text file, you have the option to overwrite the text file each time the
JavaScript is called or to append data at every write.
See...
■ “Line Based Access - Overwrite Existing Data” on page 49
■ “Line Based Access - Append To Existing File” on page 50
■ “Delimiter Based Access - Overwrite Existing Data” on page 50
■ “Delimiter Based Access - Append To Existing File” on page 51
■ “Line Based Access - Read as one string” on page 51
■ “Delimiter Based Access - Append To Existing File” on page 52

Line Based Access - Overwrite Existing Data


When GXS Mapper’s JavaScript executes a writeLn command, it identifies the data that needs
to be written and appends a <CR> character. It then writes the data to the file, overwriting
any existing data one character at a time.
writeLn(String data or variable);
Example:

Existing data

var x = mek.sourceDocument.getRootRecord(“HEADER”).getField(“PONUM”).getData();
var y = openFile("C:\\InboundList\\PONumbers.txt");
y.writeLn(x);

Mapper JavaScript Guide 49


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
External Text Files

y.close();
Data overwritten

Line Based Access - Append To Existing File


When GXS Mapper’s JavaScript executes a appendLn command, it identifies the data that
needs to be written and appends a <CR> character. It then writes the data at the end of the
existing data in the file.
appendLn(String data or variable);
Example:
var x = mek.sourceDocument.getRootRecord(“HEADER”).getField(“PONUM”).getData();
var y = openFile("C:\\InboundList\\PONumbers.txt");
y.appendLn(x);
y.close()

Delimiter Based Access - Overwrite Existing Data


When GXS Mapper’s JavaScript executes an output command, it identifies the data that needs
to be written, prepends “<<<“, and appends “>>>”. It then writes the data to the file,
overwriting any existing data one character at a time.
output(String data or variable);
Example:

Existing data

var x = mek.sourceDocument.getRootRecord(“HEADER”).getField(“PONUM”).getData();
var y = openFile("C:\\InboundList\\PONumbers.txt");
y.output(x);

50 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
External Text Files 4

y.close();
Data overwritten

Delimiter Based Access - Append To Existing File


When GXS Mapper’s JavaScript executes a appput command, it identifies the data that needs
to be written, prepends “<<<“, and appends “>>>”. It then writes the data at the end of
the existing data in the file.
appput(String data or variable);
Example:
var x = mek.sourceDocument.getRootRecord(“HEADER”).getField(“PONUM”).getData();
var y = openFile("C:\\InboundList\\PONumbers.txt");
y.appput(x);
y.close();

Reading From a File


If you have a text file containing information required for the mapping process, you can
open and read one line at a time by issuing either the readLn (Line Based) or input
(Delimiter Based) commands.

Line Based Access - Read as one string


readLn();
Example:
var x = openFile("C:\\PONumbers.txt");
//read the first delimited value
var y1 = x.readLn();
//read the second delimited value
var y2 = x.readLn();
//place the values in an Array
var z = new Array(y1,y2);

Mapper JavaScript Guide 51


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
External Text Files

//display the values in the Audit log


mekAudit(z[0]);
mekAudit(z[1]);
x.close();

Delimiter Based Access - Append To Existing File


writeLn(String data or variable);
Example:
var x = openFile("C:\\PONumbers.txt");
//read the first delimited value
var y1 = x.input();
//read the second delimited value
var y2 = x.input();
//place the values in an Array
var z = new Array(y1,y2);
//display the values in the Audit log
mekAudit(z[0]);
mekAudit(z[1]);

52 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
JavaScript Database Access 4

x.close();

JavaScript Database Access


of the document types that is supported by GXS Mapper and Transformation is direct
database connections. Data can be read from a database or written to a database just as easily
as it can from a text file. The communication to the database is done using JDBC.
This section includes:
■ “JavaScript Database Access Overview” on page 53
■ “Opening a Database Connection” on page 53
■ “Database Object” on page 54
■ “Database JavaScript Example” on page 57

JavaScript Database Access Overview


The JavaScript included with the GXS Mapper also supports direct database connections. The
same JDBC drivers that are supplied to define a database BDD can also be used by JavaScript.
If you have other database connections defined in a Windows OS system’s ODBC Data Source
Administrator, these connections can also be referenced in JavaScript.
For a complete list of supported databases, refer to Technical Requirements in the GXS Mapper
Installation Guide.
JavaScript in GXS Mapper can be used to:
■ Open an existing database.
■ Query a database table.
■ Issue standard SQL commands such as Insert and Update.
■ Commit Changes
■ Rollback changes if errors occur.

Opening a Database Connection


A database connection is initiated with a call to openDB. This does not actually open the
database; the open function performs that task. This sets the parameters and initiates the
connection to the Database.

Mapper JavaScript Guide 53


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
JavaScript Database Access

Syntax: openDB(<DBType>,<DB URL or Connection>,<login>,<password>);


■ DBType - enter the database type from the table above.
■ DB URL or Connection - The initialization and configuration needed for the database
connection. This may be a DSN name for ODBC.
■ login - This is the database login. This may be left blank if not needed for the database
connection.
■ password - This is the database password. This may be left blank if not needed for the
database connection.
For additional information by database types, see:
■ “Oracle” on page 54
■ “MS SQL Server” on page 54
■ “DB2” on page 54
■ “ODBC” on page 54

Oracle
Oracle uses a thin client connection string that includes the server host URL, the database
port, and the database name.
var myDB = openDB("oracle", "thin:@mymachine.logon.com:1521:dbtest1",
"mylogin", "mypswd");

MS SQL Server
MySQL includes server host name, port number, and database name separated by one
forward slash
var MySQL_DB =
openDB("MySQL","hostname.itlogon.com:3306/dbname","userid","password");

DB2
DB2/400 includes server host name and the database name separated by one forward slash,
var myDB2400_DB =
openDB("DB2/400","hostname.itlogon.com/dbname","userid","password");

ODBC
ODBC uses the Data Source Name. This name must be configured in your Windows Data
Source Administrator.
var myDB = openDB("odbc", "MyDSN", "mylogin", "mypswd");

Database Object
The database objects hold the connection to the database open until a close() method is
called. For efficient running of the database during the Transformation process, it is
imperative to always close the database connection at the end of the JavaScript. See...
■ “Pulling Data from a Database” on page 55
■ “RecordSets” on page 56

54 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
JavaScript Database Access 4

Pulling Data from a Database


The following methods can be used to pull data from a database, write data to a database, or
issue data control commands.

■ Method open(true/false)
■ Description This method actually opens the database connection previously
created in the openDB statement.
■ If open is set to true, and the database supports transaction
processing, then nothing is committed until the commit()
method is called.
■ If open is set to false, then all database operations are
committed as they are invoked.
var X = openDB("sqlserver", "MyDBServer/database=Northwind", "sa", "sa");
X.open(true);

■ Method createRecordSet()
■ Description Creates a new Record Set Object This is used in querying
database tables.
The query returns a set of data which is referenced by the
RecordSet.
var RS = NWtestdb.createRecordSet().query("select * from Region");

■ Method close()
■ Description Close the current database connection.
Close all open Recordsets.
var X = openDB("sqlserver", "MyDBServer/database=Northwind", "sa", "sa");
X.open(true);
X.close();

■ Method getConnection()
■ Description This allows the user to directly access the JDBC connection
object itself for more advanced tasks like querying the database
capabilities.
■ All queries must be JDBC compliant.

var X = openDB("sqlserver", "MyDBServer/database=Northwind", "sa", "sa");


X.getConnection();

Mapper JavaScript Guide 55


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
JavaScript Database Access

■ Method command()
■ Description Execute a command on the database. Commands are standard sql
statements such as insert, update, or create table.
■ All sql commands must be JDBC compliant.
var X = openDB("sqlserver", "MyDBServer/database=Northwind", "sa", "sa");
X.open(false);
X.command(“insert into Region(RegionID, RegionDescription) Values (5,’International’)”);

■ Method commit()
■ Description This commits a transaction in the database. It is only used if
transactional operations are supported in the database.
var X = openDB("sqlserver", "MyDBServer/database=Northwind", "sa", "sa");
X.open(false);
X.command(“insert into Region(RegionID, RegionDescription) Values (5,’International’)”);
X.commit();

■ Method rollback()
■ Description This rolls back a transaction in a database. It is only be used if
transactional operations are supported in the database.
var X = openDB("sqlserver", "MyDBServer/database=Northwind", "sa", "sa");
X.open(false);
X.command(“insert into Region(RegionID, RegionDescription) Values (5,’International’)”);
X.rollback();

■ Method query(SQL select statement)


■ Description Executes an SQL query to obtain a recordset of data. The
Recordset object returned is a JDBC object. All JDBC
commands matching the version of JDBC used, are available.
If no data is returned, the Recordset object is set to null.

var RS = NWtestdb.createRecordSet().query("select * from Region");

RecordSets
Recordsets are returned from a query command as a JDBC object. Additional commands
must be used to pull specific data from the object.
Important: Recordsets must be closed along with the database connection at the end of the
script.
while - Creates a loop that evaluates if the Recordset has more rows to read. If true, it
executes a block of statements. The loop then repeats, as long as the Recordset has not

56 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
JavaScript Database Access 4

reached the end of the data returned from the query. The commands in the loop typically
have brackets at the beginning and the end of the loop.
next() - advances to the next row of data returned from the query
getString - gets the value of a database column whose data type is string or character.
getInt - gets the value of a database column whose data type is numeric or integer.
Example:
while (X.next()) {
//retrieve the value of the PartyCounter and PartyID columns to display with the audit messages
var y = X.getInt("PARTY_COUNTER");
var z = X.getString("PARTY_ID");
mekAudit(“Counter is “+y+”, ID is “+z);
}

Database JavaScript Example


This example connects to an MS SQL Server. It then opens the demo database, Northwind.
This database has a table, Region. Region has two columns with four rows. The JavaScript
reads the table rows, pulling the value of the last RegionID. It increments the value of the ID
by 1 and write a new row to the table with the new RegionID value.
Region Table Before JavaScript execution

//create a connection to the Northwind database


var NW = openDB("sqlserver","MySQLServer;database=Northwind",
"sa","sa");
//Open the database object - do not require commit
NW.open(false);
//Create a recordSet of all the rows in the Region table
var x = NW.createRecordSet().query("select * from Region");
//Use ‘while’ to read through the rows, setting the variable ‘A’
//equal to the value of the RegionID. When all the rows have
//been read, ‘A’ will equal the value of the last RegionID
while (x.next())
{
var A = x.getInt("RegionID");
}
//Increment the last RegionID by 1
var B = (A+1);
//Insert a new row into the Region table using the new value ‘B’
//for the RegionID and a new string ‘International” for the
RegionDescription
NW.command("insert into Region (RegionID, RegionDescription) Values
("+B+",'International')");

Mapper JavaScript Guide 57


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
JavaScript To Create Document Nodes

//Close the database and the recordset


x.close();
NW.close();

Region Table After JavaScript execution

JavaScript To Create Document Nodes


The Transformation process involves reading the source document nodes and creating nodes
for the target document. This process depends on the ability to use cardinality links to
‘trigger’ the creation of specific nodes.
When this linking process does not fulfill all the requirements for creation of the target
nodes, GXS Mapper’s JavaScript can be used to generate new instances of nodes that have
been defined as part of the Document definition.
The syntax used is similar to the Document Objects listed in “JavaScript Document Object
Overview” on page 19.
The object descriptions listed below are sorted by the type of document node it is designed
to reference.
These objects are designed to be combined with other Document objects to create the
desired node within a document. The JavaScript typically sets an object (var x) to the location
in the target document where the new node is created.
Example:
var x = mek.targetDocument.getRootRecord(“HEADER”).getRecord(“DETAIL”);
The object “x” can then be substituted for the <mek-object> listed in the tables below.
Note: For a full example of creating a new segment in a target EDI document, see “SDQ
JavaScript Example” on page 72.
This section includes:
■ “New Records” on page 59
■ “New Sub Records” on page 59
■ “New Instance of a Field” on page 59
■ “New Fields” on page 59

58 Mapper JavaScript Guide


PAR T 3 — ADVANCED JAVASCRIPT USAGE
JavaScript To Create Document Nodes 4

New Records
This set of functions attempts to create a new instance of a record off the record from which
the function is called. The index is the instance number of the record being created. The
number of the instance being created must be allowed in the document definition.
Example:x.newSubRecordInstance(n); - where n is the instance number
Object Description
■ <mek-object>.newRecordInstance(index) generic version
■ <mek-object>.newXMLElementInstance(index) XML version
■ <mek-object>.newSegmentInstance(index) EDI version

New Sub Records


This set of functions attempts to create a new instance of a record off the record from which
the function is called. The recordName is the Record Reference name, Segment Tag Name,
or XML Element Tag Name of the node being created. The name of the instance being
created must match the layout described in the document definition.
Example:x.newSubSegmentInstance("SDQ");
Object Description
■ <mek-object>.newSubRecordInstance(recordName) generic version
■ <mek- XML version
object>.newSubXMLElementInstance(recordName)
■ <mek-object>.newSubSegmentInstance(recordName) EDI version

New Instance of a Field


This set of functions attempts to create a new instance of a field within the record from
which the function is called. The index is the instance number of the field being created. The
number of the field being created must be allowed in the document definition.
Example:x.newEDIElementInstance(n); - where n is the instance number
Object Description
■ <mek-object>.newFieldInstance(index) generic version
■ <mek-object>.newAttributeInstance(index) XML version
■ <mek-object>.newEDIElementInstance(index) EDI version

New Fields
This set of functions attempts to create a new field within the record from which the
function is called. The Name is the Field Reference name, EDI Element Tag Name, or XML
Attribute Name of the node being created. The name of the instance being created must
match the layout described in the document definition.

Mapper JavaScript Guide 59


PA R T 3 — A D V A N C E D J AV A S C R I P T U S AGE
JavaScript To Create Document Nodes

Example:x.newEDIElementInstance("SDQ01");
Object Description
■ <mek-object>.newFieldInstance(fieldName) generic version
■ <mek-object>.newAttributeInstance(attributeName) XML version
■ <mek-object>.newEDIElementInstance(elementName) EDI version

Important: For this method of creating a new node to work, the Reference name property
and the Declaration (or Element) name property must be the same in the GXS Mapper
document definition.

60 Mapper JavaScript Guide


Maintaining JavaScripts
5
he GXS Mapper allows you to create, manage, and reuse JavaScripts from within the

T Mapper Script Repository or JavaScript Editor.


Topics include:
■ “Maintaing JavaScripts using the Repository” on page 61
■ “Maintaining JavaScripts using the JavaScript Editor” on page 64

Maintaing JavaScripts using the Repository


JavaScript maintenance is performed independently of a map this way the same script can be
used across multiple maps.
Topics include:
■ “Accessing JavaScript Maintenance” on page 62
■ “Viewing Repository Scripts” on page 62
■ “Removing Locks on Scripts” on page 63
■ “Editing Repository Scripts” on page 63
■ “Deleting Repository Scripts” on page 64

61
M A I N T A I N I N G J AV A S C R I P T S
Maintaing JavaScripts using the Repository

Accessing JavaScript Maintenance

To access the JavaScript Maintenance Menu


1 From the Mapper main menu, select Repository > Script Maintenance.

The Script Maintenance dialog opens.

2 Continue with any of the following:

To Refer to this section in the JavaScript Guide


Add a script “Viewing Repository Scripts” on page 62
View a script “Viewing Repository Scripts” on page 62
Edit a script “Editing Repository Scripts” on page 63
Lock or remove a lock “Locking Scripts” on page 32
for a script
Delete a script “Deleting Repository Scripts” on page 64

Viewing Repository Scripts

To view scripts in the repository


1 From the Mapper main menu, select Repository > Script Maintenance.
The Script Maintenance dialog opens.
2 Select a script and click View.

62 Mapper JavaScript Guide


MAINTAINING JAVASCRIPTS
Maintaing JavaScripts using the Repository 5

The View Repository Script dialog opens displaying the script contents.

Removing Locks on Scripts


Note: Only the user who locked a script can remove the lock.

To remove a lock on a script in the repository


1 From the Mapper main menu, select Repository > Script Maintenance.
The Script Maintenance dialog opens.
2 Select a script and click Remove Lock.
The lock is removed from the script.

Editing Repository Scripts


The content of a JavaScript or the description can be edited only when the selected script in
the repository is not locked or locked by the current user.

To edits scripts in the repository


1 From the Mapper main menu, select Repository > Script Maintenance.
The Script Maintenance dialog opens.
2 Select a script and click Edit.
The Edit Repository Script dialog opens.

Mapper JavaScript Guide 63


M A I N T A I N I N G J AV A S C R I P T S
Maintaining JavaScripts using the JavaScript Editor

3 Modify the script text and click OK.


The Edit Script Properties dialog opens.

4 Modify the Description (as needed) and click OK.


The Script Maintenance dialog opens.

Deleting Repository Scripts

To delete a script in the repository


1 From the Mapper main menu, select Repository > Script Maintenance.
The Script Maintenance dialog opens.
2 Select a script and click Delete.
The Delete Scripts confirmation dialog opens.
Click Yes to delete the script.

Maintaining JavaScripts using the JavaScript Editor


The following sections describe how to maintain JavaScripts using the JavaScript Editor:
■ “Accessing the JavaScript Editor” on page 64
■ “Navigating the JavaScript Editor Menu” on page 65
■ “JavaScript Editor Syntax Checker” on page 66
■ “JavaScript Editor Display” on page 66
■ “Saving JavaScript Snipets” on page 67
■ “Opening and Importing JavaScript Snipets” on page 67
■ “JavaScript Editor Keys” on page 68

Accessing the JavaScript Editor

To access the JavaScript editor


1 Open a map from the GXS Mapper Main window and click the Map tab.
2 Locate the document node where the JavaScript is to be added. Right-click on this node
and select Add/Edit Script.
3 Select the appropriate Translation State. See “Translation States Overview” on page 16.

64 Mapper JavaScript Guide


MAINTAINING JAVASCRIPTS
Maintaining JavaScripts using the JavaScript Editor 5

The JavaScript editor screen opens.

Bold red indicates


missing quotation mark

Navigating the JavaScript Editor Menu

Menu Item Description


File Provides the ability to save JavaScript snipets as individual files and
■ Open to later open these files to import JavaScript in other maps or in
other nodes within the same map.
■ Save As
Edit Provides basic clipboard functionality
■ Cut
■ Copy
■ Paste
Search Provides basic string search functionality
■ Find
■ Find Next
Search Provides the ability to jump to a specific line in the script.
■ Go To Line
Tools Provides the ability to check the basic syntax of the script. See
■ Check Syntax example that follows.
■ Load from Repository Provides the ability to load a script from the Script repository or
add the current map's script to the Script Repository.
■ Add to Repository

Mapper JavaScript Guide 65


M A I N T A I N I N G J AV A S C R I P T S
Maintaining JavaScripts using the JavaScript Editor

JavaScript Editor Syntax Checker

Cursor positioned on
line with errors

Error message

■ The checker identifies the first error in the script, position the cursor on this line and
display an error message.
■ The JavaScript editor does not check for valid use of the GXS Mapper objects, mek

JavaScript Editor Display


The JavaScript Editor uses the following display properties:
■ Text displayed in green ■ Keywords:
■ function
■ var
■ Text displayed in bold ■ Keywords:
black ■ else
■ for
■ if
■ in
■ new
■ return
■ while
■ with
■ break
■ case
■ continue
■ default
■ Text displayed in bold dark ■ Keywords:
red ■ true
■ false
■ this
■ Strings in bold red ■ If the ending quote is missing, the string displays
in bold red. If the beginning quote is missing, the
ending quote displays bold red.
■ Rectangles around ■ Marks pair matching. If the caret is placed after a
parenthesis or braces. parenthesis or brace, its partner displays with a
rectangle around it

66 Mapper JavaScript Guide


MAINTAINING JAVASCRIPTS
Maintaining JavaScripts using the JavaScript Editor 5

Saving JavaScript Snipets


If you find yourself using the same JavaScript in multiple maps, or if you want to keep a
library of JavaScript Snipets, use the File option on the Javascript editor taskbar to save script
in individual files.

To save JavaScript snipets


1 Open a map from the GXS Mapper Main window and click the Map tab.
2 Right-click the document node where the JavaScript is to be added and select Add/Edit
Script.
3 Select the appropriate Translation State. See “Translation States Overview” on page 16.
The JavaScript editor screen opens.
4 Type the JavaScript required for your map.
5 After checking the JavaScript syntax, do one of the following:
■ To save the entire contents of the JavaScript Editor, Click File > Save As.
■ To save a portion of the JavaScript, highlight the part of the JavaScript text that you
would like to save.
Click File > Save As. A Save As pop up window opens giving you the option to save
the selected text or the entire contents of the JavaScript editor window.
■ Click Selected to save the highlighted text.
■ Click All to save the entire JavaScript.

6 Navigate to the directory where the file is to be saved.


7 Enter a name for the file and click Open.
The file is created and a Success message is displayed.

Opening and Importing JavaScript Snipets

To open and import JavaScript snipets


1 Open a map from the GXS Mapper Main window and click the Map tab.
2 Right-click the document node where the JavaScript is to be added and select Add/Edit
Script.
3 Select the appropriate Translation State. See “Translation States Overview” on page 16.
The JavaScript Editor screen opens.
4 Type any JavaScript required. Select an insertion point for the JavaScript to be imported
and click File > Open.

Mapper JavaScript Guide 67


M A I N T A I N I N G J AV A S C R I P T S
Maintaining JavaScripts using the JavaScript Editor

5 Navigate to the directory on a local drive where the file has been saved, select the name of
the file and click Open.
The entire contents of the file is placed in the JavaScript Editor window.
6 Click OK to check the syntax and save the JavaScript in your map.

JavaScript Editor Keys


The editor supports the use of shortcut keys to navigate the JavaScript window.
Keys Result
<Backspace> Backspace cursor deleting previous character.
<Ctrl>+<Backspace> Deletes previous word.
<Delete> Deletes character at current cursor position.
<Ctrl>+<Delete> Deletes word at current cursor position.
<Enter> Inserts a new line at current cursor position.
<Tab> Inserts <Tab> at current cursor position.
<Insert> Toggles overwrite/insert mode.
<Home> Moves the cursor to the beginning of the
current line.
<Shift>+<Home> Selects all from the beginning of the current
line to the current cursor position.
<Ctrl>+<Home> Moves the cursor to the beginning of the script.
<Ctrl>+<Shift>+<Home> Selects all from the beginning of the script to
the current cursor position.
<End> Moves the cursor to the end of the current
line.
<Shift>+<End> Selects all from the current cursor position to
the end of the current line.
<Ctrl>+<End> Moves the cursor to the end of the script.
<Ctrl>+<Shift>+<End> Selects all from the current cursor position to
the end of the script.
<Ctrl>+a Selects all.
<PageUp> Moves the cursor up one page.
The number of lines in one page depends upon
the size of the editor window open.
<Shift>+<PageUp> Selects all from the current cursor position to
all lines included one page up.
The number of lines in one page depends upon
the size of the editor window open.
<PageDown> Moves the cursor down one page.
The number of lines in one page depends upon
the size of the editor window open.
<Shift>+<PageDown> Selects all from the current cursor position to
all lines included one page down.
The number of lines in one page depends upon
the size of the editor window open.
<Left Arrow> Moves the cursor left one character.
<Ctrl>+<LeftArrow> Moves the cursor left one word.

68 Mapper JavaScript Guide


MAINTAINING JAVASCRIPTS
Maintaining JavaScripts using the JavaScript Editor 5

Keys Result
<Shift>+<LeftArrow> Selects the previous character.
<Ctrl>+<Shift>+<LeftArrow> Selects the previous word.
<RightArrow> Moves the cursor right one character.
<Ctrl>+<RightArrow> Moves the cursor right one word.
<Shift>+<RightArrow> Selects the next character.
<Ctrl>+<Shift>+<RightArrow> Selects the next word.
<UpArrow> Moves the cursor one line up.
<Shift>+<UpArrow> Selects all from the current cursor position to
the same cursor position one line up.
<DownArrow> Moves the cursor one line down.
<Shift>+<DownArrow> Selects all from the current cursor position to
the same cursor position one line down.
<Ctrl>+c Copies selected text.
<Ctrl>+x Cuts selected text.
<Ctrl>+v Pastes selected text.
<Ctrl>+S Save JavaScript as a text file
<Ctrl>+O Open a text file and place the contents in the
JavaScript Editor window at the insertion point
as new JavaScript code.

Mapper JavaScript Guide 69


M A I N T A I N I N G J AV A S C R I P T S
Maintaining JavaScripts using the JavaScript Editor

70 Mapper JavaScript Guide


JavaScript Examples
A
his section contains JavaScript examples that incorporate many of the individual

T features discussed in other parts of this book. It is meant to demonstrate how the
various concepts can be combined to offer solutions for custom data management
requirements.
Examples included in this section:
■ “Julian Date Conversion Example” on page 71
■ “SDQ JavaScript Example” on page 72
■ “Pull Value From Database JavaScript Example” on page 75
■ “Setting Counters” on page 75

Julian Date Conversion Example


There are many definitions of the Julian Date format. These two scripts define a julian date as
having the format YYYYDDD, where YYYY is the full year and DDD is the number of days
that have passed in that year. The values for DDD are 1 - 365, or 1-366 in a leap year.
There are two JavaScripts displayed here. The first converts a date with the format of
YYYYMMDD to a Julian date format of YYYYDDD. The second script converts a Julian
formatted date, YYYYDDD, to a standard date with the format of YYYYMMDD.
See:
■ “Convert Date to Julian Date” on page 71
■ “Convert Julian Date to Date” on page 72

Convert Date to Julian Date


// Convert YYYYMMDD to YYYYDDD
var YYYY=2005; var MM=3; var DD=22;
var regularYearMonths = new Array(0, 31, 59,
90,120,151,181,212,243,273,304,334);
var leapYearMonths = new Array(0, 31, 60,
91,121,152,182,213,244,274,305,335);
var monthArray=regularYearMonths;

// determine if its a leap year -----


if ((YYYY/4) != Math.floor(YYYY/4))
monthArray=regularYearMonths;
else if ((YYYY/100) != Math.floor(YYYY/100))

71
J AV A S CR I P T E X A M P L ES
SDQ JavaScript Example

monthArray=leapYearMonths;
else if ((YYYY/400) != Math.floor(YYYY/400))
monthArray=regularYearMonths;
else
monthArray=leapYearMonths;

// determine number of days into the year (DDD)


DDD = monthArray [MM-1] + DD;
if(DDD < 10) = "00" + DD;
else
if(DDD < 100) = "0" + DD;
var julianDate = '' + YYYY + DDD;
mekAudit("===>Regular Date "+YYYY+"/"+MM+"/"+DD+" is Julian
Date="+julianDate);

Convert Julian Date to Date


// Convert YYYYDDD to a YYYYMMDD
var julianDate="200581";
var regularYearMonths = new Array(0, 31, 59,
90,120,151,181,212,243,273,304,334);
var leapYearMonths = new Array(0, 31, 60,
91,121,152,182,213,244,274,305,335);
var YYYY = julianDate.substring(0,4)
var DDD = Number(julianDate.substring(4,6));

// determine if its a leap year ----------------


var monthArray=regularYearMonths
if ((YYYY/4) != Math.floor(YYYY/4))
monthArray=regularYearMonths;
else if ((YYYY/100) != Math.floor(YYYY/100))
monthArray=leapYearMonths;
else if ((YYYY/400) != Math.floor(YYYY/400))
monthArray=regularYearMonths;
else
monthArray=leapYearMonths;

// how many months into the year?


for (MM=0; MM<12;MM++)
if( monthArray[MM] >= DDD) break;
if(MM==1)
DD = DDD;
else
DD = DDD - monthArray[MM-1];
if(MM<10) MM="0"+MM;
var regularDate = YYYY+"/"+MM+"/"+DD;
mekAudit("===>Julian Date "+ julianDate+" is Regular Date
="+regularDate);

SDQ JavaScript Example


Some EDI documents that use the SDQ segments can easily be mapped using appropriate
formulas in the GXS Mapper (see the GXS Mapper User Guide). These documents typically have
only one SDQ segment per parent detail segment (such as a PO1). However, if a target EDI
document requires more than one SDQ segment per parent detail segment, you need to
create all the SDQ segments with JavaScript similar to the one listed here.
//Set variable IT1Recs to the target IT1 Segment instances
var IT1Recs =
mek.targetDocument.getRootRecord("ST").getRecords("IT1");

//Set detailrecs to the source detail records.


//The number of detail records should be equal to the
//number of IT1 segments. This was already created by the map

72 Mapper JavaScript Guide


JAVASCRIPT EXAMPLES
SDQ JavaScript Example

var detailRecs =
mek.sourceDocument.getRootRecord("HEADER").getRecords("Detail_Record
");

//Set the first loop. This will be performed for each instance of
//the target IT1 segment
for (var x=0; x < IT1Recs.instanceCount(); ++x)
{
location_count = 0
//Get the instance of IT1 and then get the same instance
//of the source detail record
var IT1Instance = IT1Recs.getInstance(x);
var detailInstance = detailRecs.getInstance(x);
//Get all the instances of the Items_Per_Location records
//for the corresponding detail record
var locationRecs = detailInstance.getRecords("Items_Per_Location");
for (var n=0; n < locationRecs.instanceCount(); ++n)
{
var Locationinstance = locationRecs.getInstance(n);
//This loop will first create a new SDQ segment and then
//fill the SDQ segment with the information from the first nine
// Items_Per_Location records associated with
//this instance of the detail record.
//When the SDQ is full - after nine locations have been read -
//a new SDQ is created. SDQ 23 is left blank
if (location_count == 0)
{
newSDQ = IT1Instance.newSubSegmentInstance("SDQ");
newSDQ.newEDIElementInstance(0);
newSDQ.newEDIElementInstance(1);
newSDQ.newEDIElementInstance(2);
newSDQ.newEDIElementInstance(3);
newSDQ.newEDIElementInstance(4);
newSDQ.newEDIElementInstance(5);
newSDQ.newEDIElementInstance(6);
newSDQ.newEDIElementInstance(7);
newSDQ.newEDIElementInstance(8);
newSDQ.newEDIElementInstance(9);
newSDQ.newEDIElementInstance(10);
newSDQ.newEDIElementInstance(11);
newSDQ.newEDIElementInstance(12);
newSDQ.newEDIElementInstance(13);
newSDQ.newEDIElementInstance(14);
newSDQ.newEDIElementInstance(15);
newSDQ.newEDIElementInstance(16);
newSDQ.newEDIElementInstance(17);
newSDQ.newEDIElementInstance(18);
newSDQ.newEDIElementInstance(19);
newSDQ.newEDIElementInstance(20);
newSDQ.newEDIElementInstance(21);
newSDQ.newEDIElementInstance(22);
newSDQ.getEDIElement("SDQ01").setData("EA");
newSDQ.getEDIElement("SDQ03").setData(Locationinstance.getField("Loc
ation_Code").getData());
newSDQ.getEDIElement("SDQ04").setData(Locationinstance.getField("Qua
ntity").getData());
}
else if (location_count == 1)
{
newSDQ.getEDIElement("SDQ05").setData(Locationinstance.getField("Loc
ation_Code").getData());
newSDQ.getEDIElement("SDQ06").setData(Locationinstance.getField("Qua
ntity").getData());
}
else if (location_count == 2)
{
newSDQ.getEDIElement("SDQ07").setData(Locationinstance.getField("Loc
ation_Code").getData());

Mapper JavaScript Guide 73


J AV A S CR I P T E X A M P L ES
SDQ JavaScript Example

newSDQ.getEDIElement("SDQ08").setData(Locationinstance.getField("Qua
ntity").getData());
}
else if (location_count == 3)
{
newSDQ.getEDIElement("SDQ09").setData(Locationinstance.getField("Loc
ation_Code").getData());
newSDQ.getEDIElement("SDQ10").setData(Locationinstance.getField("Qua
ntity").getData());
}
else if (location_count == 4)
{
newSDQ.getEDIElement("SDQ11").setData(Locationinstance.getField("Loc
ation_Code").getData());

newSDQ.getEDIElement("SDQ12").setData(Locationinstance.getField("Qua
ntity").getData());
}
else if (location_count == 5)
{
newSDQ.getEDIElement("SDQ13").setData(Locationinstance.getField("Loc
ation_Code").getData());
newSDQ.getEDIElement("SDQ14").setData(Locationinstance.getField("Qua
ntity").getData());
}
else if (location_count == 6)
{

newSDQ.getEDIElement("SDQ15").setData(Locationinstance.getField("Loc
ation_Code").getData());
newSDQ.getEDIElement("SDQ16").setData(Locationinstance.getField("Qua
ntity").getData());
}
else if (location_count == 7)
{
newSDQ.getEDIElement("SDQ17").setData(Locationinstance.getField("Loc
ation_Code").getData());
newSDQ.getEDIElement("SDQ18").setData(Locationinstance.getField("Qua
ntity").getData());
}
else if (location_count == 8)
{
newSDQ.getEDIElement("SDQ19").setData(Locationinstance.getField("Loc
ation_Code").getData());
newSDQ.getEDIElement("SDQ20").setData(Locationinstance.getField("Qua
ntity").getData());
}
else if (location_count == 9)
{
newSDQ.getEDIElement("SDQ21").setData(Locationinstance.getField("Loc
ation_Code").getata());
newSDQ.getEDIElement("SDQ22").setData(Locationinstance.getField("Qua
ntity").getData());
}
location_count = location_count + 1;
if (location_count == 10) location_count = 0;
}
}

74 Mapper JavaScript Guide


JAVASCRIPT EXAMPLES
Pull Value From Database JavaScript Example

Pull Value From Database JavaScript Example


This JavaScript connects to a typical MS SQL database, opens the demo Northwind database,
and pulls a value from the Region table.
//Open the Microsoft demo Northwind database

var NWtestdb = openDB("sqlserver",


"MyDBServer001:1433/database=Northwind", "sa", "sa")
NWtestdb.open(true);

//Issue a select query to obtain the contents of the Region table.


//This information is put into a Record set which can be read
//one by one

var RecSet2 = NWtestdb.createRecordSet().query("select * from


Region");
while (RecSet2.next())
{
var A = RecSet2.getString("RegionID");
if (A == "1")
var B = RecSet2.getString("RegionDescription");
}
//When the data is obtained, further processing can be defined.
//This script simply displays the value with the audit messages.

mekAudit(B);
RecSet2.close();
NWtestdb.close();

Setting Counters
Use this javaScript if your map requires a count of the instances of a specific node. This is a
two part JavaScript. The first part is placed on the document level to reset the counter at the
beginning of each new document. The second part is placed on the node being counted.
//Place on the document level to initialize or reset the counter for each
new document.
mek.documentVars.set(“elementCnt”, 1);
----------------------------------------
//If the document is an XML type, place this JavaScript on the XML element
that needs to be counted.
var cnt = mek.documentVars.get(“elementCnt”);
mekRec.setData(cnt++);
mek.documentVars.set(“elementCnt”, cnt);
----------------------------------------
//If the document is not an XML type, place this JavaScript on a record,
segment, or table. This JavaScript will count the number of occurrences of
Field4. Replace Field4 with the name of your Field, EDI element, or column
that needs to be counted.
var cnt = mek.documentVars.get(“elementCnt”);
mekRec.getField(“Field4”)setData(cnt++);
mek.documentVars.set(“elementCnt”, cnt);

Mapper JavaScript Guide 75


J AV A S CR I P T E X A M P L ES
Setting Counters

76 Mapper JavaScript Guide


Common JavaScript
B
Bot all JavaScript objects or methods are supported for use in GXS Mapper. GXS

N Mapper contains a limited-use JavaScript interpreter which is used to expand the


functionality of the Mapping engine by enabling extended data manipulation
capabilities through the use of the features in this popular scripting language. The JavaScript
incorporated with GXS Mapper is based upon the standard, ECMA-262 Edition 1. This is
roughly equivalent to JavaScript version 1.1. This section contains information related to
common JavaScript objects, methods and statements that are supported by GXS Mapper.
This section includes:
■ “Supported Objects” on page 77
■ “Supported Statements” on page 92
■ “Reserved Words” on page 95

Supported Objects
Only the JavaScript objects and methods that are supported in GXS Mapper 3.12.0 are listed
in the following tables.
The examples shown here have used the BizManager JavaScript function, mekAudit, to display
the results of the JavaScript as Audit messages. These Audit messages can be seen in the test
message log on the GXS Mapper or on the Operation Details page of BizManager. Numeric
results were changed to String-format to accommodate the messaging display requirements.

See:
■ “Array” on page 78

77
COMMON JAVASCRIPT
Supported Objects

■ “Boolean” on page 80
■ “Date” on page 80
■ “Math” on page 84
■ “String” on page 88

Array
■ Object Array
■ Method new
■ Description An array is an ordered set of values associated with a single
variable name.
■ Example var x = new Array("part1", "part2", "part3");
mekAudit(x[2]);
Audit log: “part3”

■ Object Array
■ Method join
■ Description Joins all elements of an array into a string.
■ Example var x = new Array("a","b","c");
var y =x.join("+ ");
mekAudit(y);
Audit log: “a+b+c”

■ Object Array
■ Method reverse
■ Description Transposes the elements of an array: the first array element
becomes the last and the last becomes the first.
■ Example var x = new Array("a","b","c");
var y =x.reverse();
mekAudit(x[0]);
Audit log: “c”

■ Object Array
■ Method sort
■ Description Sorts the elements of an array. (follows JavaScript 1.1 behavior).
■ Example var x = new Array("x","b","c","e","f");
var y =x.sort();
mekAudit(y[0]);
Audit log: “b”

78 Mapper JavaScript Guide


C OM M O N J AV A S C R I P T
Supported Objects B

■ Object Array
■ Method toString
■ Description Returns a string representing the array and its elements.
■ Example var x = new Array("a","b","c","d");
var y =x.toString();
mekAudit(y);
Audit log: “a,b,c,d”

Mapper JavaScript Guide 79


COMMON JAVASCRIPT
Supported Objects

Boolean
■ Object Boolean
■ Method new
■ Description A Boolean object can be set to evaluate conditions within a
JavaScript. Do not confuse Boolean values of true and false with
the use of a Boolean object.
Any object whose value is not undefined or null, including a
Boolean object whose value is false, evaluates to true when
passed to a conditional statement.
■ Example var x = new Boolean("true");
if (x)
{
mekAudit("It is true");
}
Audit log: “It is true”
------------------------------
var x = new Boolean(0);
if (x)
{
mekAudit("It is true");
}
This evaluates to false - no audit message.

Date
■ Object Date
■ Method new
■ Description
Lets you work with dates and times. The supported Date
methods follow the JavaScript 1.1 behavior.
If you supply no arguments, new creates a Date object for today's
date and time.
■ Example var x = new Date();
var z = x.toString();
mekAudit(z);
Audit log: “Wed Aug 30 11:50:31 PDT 2006”

■ Object Date
■ Method getDate / getUTCDate
■ Description
Returns the day of the month for the specified date.
■ Example var x = new Date();
var y = x.getDate();
var z = y.toString();
mekAudit(z);
Audit log: “30”

80 Mapper JavaScript Guide


C OM M O N J AV A S C R I P T
Supported Objects B

■ Object Date
■ Method getDay / getUTCDay
■ Description
Returns the day of the week for the specified date. The Day is
display as a numeric value (Sunday = 0, Monday = 1, etc.).
(UTC returns Universal Time)
■ Example var x = new Date();
var y = x.getDay();
var z = y.toString();
mekAudit(z);
Audit log: “3”

■ Object Date
■ Method getMonth / getUTCMonth
■ Description
Returns the month in the specified date The Month is display as a
numeric value (January = 0, February = 1, etc.).
(UTC returns Universal Time)
■ Example var x = new Date();
var y = x.getMonth();
var z = y.toString();
mekAudit(z);
Audit log: “7”

■ Object Date
■ Method getYear
■ Description
Returns the year in the specified date. The Year is display as a
numeric value minus 1900.
■ Example var x = new Date();
var y = x.getYear();
var z = y.toString();
mekAudit(z);
Audit log: “106”

■ Object Date
■ Method getTime

Mapper JavaScript Guide 81


COMMON JAVASCRIPT
Supported Objects

■ Description
Returns a numeric value of the number of milliseconds since
January 1, 1970 00:00:00.
■ Example var x = new Date();
var y = x.getTime();
var z = y.toString();
mekAudit(z);
Audit log: “1156989699397”

■ Object Date
■ Method getHours / getUTCHours
getMinutes / getUTCMinutes
getSeconds / getUTCSeconds
getMilliseconds / getUTCMilliseconds
■ Description
Returns the hour, minutes, seconds, and milliseconds in the
specified date.
(UTC returns Universal Time)
■ Example var x = new Date();
var y1 = x.getHours();
var y2 = x.getMinutes();
var y3 = x.getSeconds();
var y4 = x.getMilliseconds();

var z1 = y1.toString();
var z2 = y2.toString();
var z3 = y3.toString();
var z4 = y4.toString();

mekAudit(z1 + “ “ +z2+ “ “ +z3+ “ “ +z4);

Audit log: “19 10 16 182”

■ Object Date
■ Method setDate / setUTCDate
■ Description
Sets the day of the month for a specified date The Day value is set
as a numeric value.
(UTC sets Universal Time)
■ Example var x = new Date();
var y = x.setDate(30);
var z = x.toString();
mekAudit(z);
Audit log: “Wed Aug 30 11:50:31 PDT 2006”

82 Mapper JavaScript Guide


C OM M O N J AV A S C R I P T
Supported Objects B

■ Object Date
■ Method setMonth / setUTCMonth
■ Description
Sets the month for a specified date The Month is set as a numeric
value (January = 0, February = 1, etc.).
(UTC returns Universal Time)
■ Example var x = new Date();
var y = x.setMonth(7);
var z = x.toString();
mekAudit(z);
Audit log: “Wed Aug 30 11:50:31 PDT 2006”

■ Object Date
■ Method setHours / setUTCHours
setMinutes / setUTCMinutes
setSeconds / setUTCSeconds
setMilliseconds / setUTCMilliseconds
■ Description
Sets the hour, minutes, seconds, and milliseconds for a specified
date.
(UTC returns Universal Time)
■ Example var x = new Date();
var y1 = x.setHours(19);
var y2 = x.setMinutes(35);
var y3 = x.setSeconds(47);
var y4 = x.setMilliseconds(43);

var z = x.toString();
mekAudit(z);

Audit log: “Wed Aug 30 19:35:47 PDT 2006”

■ Object Date
■ Method setYear
■ Description
Sets the year for a specified date. The Year is set as a numeric
four digit value.
■ Example var x = new Date();
var y = x.getYear(2006);
var z = x.toString();
mekAudit(z);
Audit log: “Wed Aug 30 11:50:31 PDT 2006”

Mapper JavaScript Guide 83


COMMON JAVASCRIPT
Supported Objects

■ Object Date
■ Method setTime
■ Description
Set a specific time by specifying a numeric value of the number of
milliseconds since January 1, 1970 00:00:00.
■ Example var x = new Date();
var y = x.getTime(1156989699397);
var z = x.toString();
mekAudit(z);

Audit log: “Wed Aug 30 19:01:39 PDT 2006”

Math
■ Object Math
■ Method abs
■ Description
Returns the absolute value of a number.
■ Example var x = -11
var y = Math.abs(x);
var z = y.toString();
mekAudit(z);

Audit log: “11”

■ Object Math
■ Method acos
asin
atan
cos
sin
tan

84 Mapper JavaScript Guide


C OM M O N J AV A S C R I P T
Supported Objects B

■ Description
acos - Returns the arccosine of a number.
asin - Returns the arcsine of a number.
atan - Returns the arctangent of a number.
cos - Returns the cosine of a number.
sin - Returns the sine of a number.
tan - Returns the tangent of a number.
■ Example var x = -1
var y1 = Math.acos(x);
var y2 = Math.asin(x);
var y3 = Math.atan(x);
var y4 = Math.cos(x);
var y5 = Math.sin(x);
var y6 = Math.tan(x);

var z1 = y1.toString();
var z2 = y2.toString();
var z3 = y3.toString();
var z4 = y4.toString();
var z5 = y5.toString();
var z6 = y6.toString();

mekAudit(z1);
mekAudit(z2);
mekAudit(z3);
mekAudit(z4);
mekAudit(z5);
mekAudit(z6);

Audit log:
+3.141592653589793
+1.5707963267948966
-0.7853981633974483
+0.5403023058681398
-0.8414709848078965
-1.5574077246549023

■ Object Math
■ Method ceil

Mapper JavaScript Guide 85


COMMON JAVASCRIPT
Supported Objects

■ Description
Returns the smallest integer greater than or equal to a number.
■ Example var x = 23.444
var y = Math.ceil(x);
var z = y.toString();
mekAudit(z);
Audit log: “24”

■ Object Math
■ Method floor
■ Description
Returns the largest integer less than or equal to a number.
■ Example var x = 23.444
var y = Math.floor(x);
var z = y.toString();
mekAudit(z);
Audit log: “23”

■ Object Math
■ Method log
■ Description
Returns the natural logarithm (base E) of a number.
■ Example var x= 99
var y = Math.log(x);
var z = y.toString();
mekAudit(z);
Audit log: “4.59511985013459”

■ Object Math
■ Method max
min

86 Mapper JavaScript Guide


C OM M O N J AV A S C R I P T
Supported Objects B

■ Description
max - Returns the greater of two numbers.
min - Returns the lesser of two numbers.
■ Example var x1= 99
var x2 = 50
var y1 = Math.max(x1,x2);
var y2 = Math.min(x1,x2);

var z1 = y1.toString();
var z2 = y2.toString();

mekAudit("The maximum number is " + z1);


mekAudit("The minimum number is " + z2);

Audit log: “The maximum number is 99”


“The minimum number is 50”

■ Object Math
■ Method pow
■ Description
Returns the value of x to the power of y.
■ Example var x= 9
var y = 2
var z = Math.pow(x,y);

var z1 = z.toString();
mekAudit(z1);

Audit log: “81”

■ Object Math
■ Method random
■ Description
Returns a pseudo-random number between 0 and 1.
■ Example var y = Math.random();
var z = y.toString();
mekAudit(z);
Audit log: “0.6955030824421441”

■ Object Math
■ Method round

Mapper JavaScript Guide 87


COMMON JAVASCRIPT
Supported Objects

■ Description
Returns the value of a number rounded to the nearest integer.
■ Example var x1= 5.4
var x2 = 5.5
var y1 = Math.round(x1);
var y2 = Math.round(x2);

var z1 = y1.toString();
var z2 = y2.toString();
mekAudit(z1 + ", " + z2);

Audit log: “5, 6”

■ Object Math
■ Method sqrt
■ Description
Returns the square root of a number.
■ Example var x= 99
var y = Math.sqrt(x);
var z = y.toString();
mekAudit(z);
Audit log: “9.9498743710662”

String
■ Object String
■ Method charAt
■ Description
Returns the character at the specified index.
■ Example var x= "Acme Services Company";
var y = x.charAt(5);

mekAudit(y);
Audit log: “S”

■ Object String
■ Method charCodeAt
■ Description
Returns a number indicating the Unicode value of the character
at the given index.
■ Example var x= "Acme Services Company";
var y = x.charCodeAt(5);
var z = y.toString();
mekAudit(z);
Audit log: “83”

88 Mapper JavaScript Guide


C OM M O N J AV A S C R I P T
Supported Objects B

■ Object String
■ Method concat
■ Description
Combines the text of two strings and returns a new string.
■ Example Audit log: “83”

■ Object String
■ Method indexOf
■ Description
Returns the index within the calling String object of the first
occurrence of the specified value, or -1 if not found.
■ Example var x= "Acme Services Company";
var y = x.indexOf("Services");
var z = y.toString();
mekAudit(z);

Audit log: 5
-----------------------------
var x= "Acme Services Company";
var y = x.indexOf("Services", 6);
var z = y.toString();
mekAudit(z);

Audit log: “-1”

■ Object String
■ Method lastIndexOf
■ Description
Returns the index within the calling String object of the last
occurrence of the specified value, or -1 if not found.
■ Example var x= "Acme Services Company";
var y = x.indexOf("e");
var z = y.toString();
mekAudit(z);

Audit log: 3

var x= "Acme Services Company";


var y = x.lastIndexOf("e");
var z = y.toString();
mekAudit(z);

Audit log: “11”

Mapper JavaScript Guide 89


COMMON JAVASCRIPT
Supported Objects

■ Object String
■ Method length
■ Description
Returns the number of characters in a string.
■ Example var x= "Acme Services Company";
var y = x.length;
var z = y.toString();
mekAudit(z);

Audit log: “21”

■ Object String
■ Method split
■ Description
Splits a String object into an array of strings by separating the
string into substrings.
■ Example var x= "Acme Services Company";
var y = x.split(" ");

mekAudit(y[0]);

Audit log: “Acme”

■ Object String
■ Method substring
■ Description
Returns the characters in a string between two indexes into the
string.
■ Example var x= "Acme Services Company";
var y = x.substring(5,13);

mekAudit(y);

Audit log: “Services”

■ Object String
■ Method toUpperCase
toLowerCase

90 Mapper JavaScript Guide


C OM M O N J AV A S C R I P T
Supported Objects B

■ Description
toUpperCase - Returns the calling string value converted to
lowercase.
toLowerCase - Returns the calling string value converted to
uppercase.
■ Example var x= "Acme Services Company";
var y = x.toUpperCase();

mekAudit(y);

Audit log: “ACME SERVICES COMPANY”

Mapper JavaScript Guide 91


COMMON JAVASCRIPT
Supported Statements

Supported Statements
JavaScript statements consist of keywords used with the appropriate syntax. Statements can be
used to set conditions or modify the behavior of an object. The following statements are
supported with GXS Mapper.

■ Statement Break
■ Description
Use to terminate a loop,
■ Example var A =
mek.targetDocument.getRootSegment("ST").getSegments("IT1
");
for (var x=0; x< A.instanceCount(); ++x)
{
if (x == 3) {break}
mekAudit("Instance Count = " + x);
}
var y = 1;

Audit log:
“Instance Count = 0
Instance Count = 1 ”

■ Statement Continue
■ Description
Use to break the current loop and continue with the next value.
■ Example var A =
mek.targetDocument.getRootSegment("ST").getSegments("IT1
");
for (var x=0; x< A.instanceCount(); ++x)
{
if (x == 3) {continue}
mekAudit("Instance Count = " + x);
}

Audit log: “Instance Count = 0


Instance Count = 1
Instance Count = 3”

■ Statement while

92 Mapper JavaScript Guide


C OM M O N J AV A S C R I P T
Supported Statements B

■ Description
Creates a loop that evaluates an expression, and if it is true, executes a block of
statements. The loop then repeats, as long as the specified condition is true.
■ Example var x = 0;
while (x < 2)
{
mekAudit("My Counter = " +x);
x = x+1;
}

Audit log: “My Counter = 0


My Counter = 1

■ Statement for
■ Description
Creates a loop that consists of three optional expressions, enclosed in
parentheses and separated by semicolons, followed by a block of statements
executed in the loop.
■ Example var A =
mek.targetDocument.getRootSegment("ST").getSegments("IT1
");
for (var x=0; x< A.instanceCount(); ++x)
{
if (x == 3) {continue}
mekAudit("Instance Count = " + x);
}
var y = 1;

■ Statement if ... else


■ Description
Executes a set of statements if a specified condition is true. If the condition is
false, another set of statements can be executed. The statements to be
executed are enclosed with brackets { }.
■ Example var A =
mek.targetDocument.getRootSegment("ST").getSegments("IT1
");
for (var x=0; x< A.instanceCount(); ++x)
{
if (x == 3)
mekAudit("Instance Count = " + x);
}
else
{
mekAudit("...Not three");
}

Mapper JavaScript Guide 93


COMMON JAVASCRIPT
Supported Statements

■ Statement with
■ Description
Establishes the default object for a set of statements.
■ Example var x = -1
with (Math)
{
var y1 = acos(x);
var y2 = asin(x);
var y3 = atan(x);
var y4 = cos(x);
var y5 = sin(x);
var y6 = tan(x);
}
var z1 = y1.toString();
var z2 = y2.toString();
var z3 = y3.toString();
var z4 = y4.toString();
var z5 = y5.toString();
var z6 = y6.toString();

mekAudit(z1);
mekAudit(z2);
mekAudit(z3);
mekAudit(z4);
mekAudit(z5);
mekAudit(z6);

Audit log:
+3.141592653589793
+1.5707963267948966
-0.7853981633974483
+0.5403023058681398
-0.8414709848078965
-1.5574077246549023

94 Mapper JavaScript Guide


C OM M O N J AV A S C R I P T
Reserved Words B

Reserved Words
The following words are considered reserved words and should not be used within a
JavaScript as a variable name or value.
abstract boolean break
byte case catch
char class const
continue debugger default
delete do double
else enum export
extends FALSE final
finally float for
function goto if
implements import in
instanceof int interface
long native new
null package private
protected public return
short static super
switch synchronized this
throw throws transient
TRUE try typeof
var void volatile
while with

Mapper JavaScript Guide 95


COMMON JAVASCRIPT
Reserved Words

96 Mapper JavaScript Guide


INDEX

Index
A JavaScript, 62
abs, 84 Delimiter Based Access, 51
Access Source, 14 direct database, 14, 53
Access Target, 14 document definition, 46
acos, 84 Document Envelopes, 20
add Document Level, 16, 36
JavaScript, 62 document type
Add JavaScript, 16 database, 16
Add/Edit Script, 30 EDI, 16
adding javascripts, 31 flat files, 16
Alert Messages, 43 NACHA, 16
appendLn, 50 XML, 16
appput, 51 documentVars, 36
Array, 78
arrays, 14 E
asin, 84 ECMA, 19
atan, 84 ECMA-262, 13, 19
Audit Messages, 43 Edit
JavaScript, 62
B Editor, 15
Boolean, 80 editor, 15, 29
Break, 92 Editor Display, 66
Editor Keys, 68
C Editor Menu, 65
ceil, 85 EndDocumentRead, 17, 30
charAt, 88 EndDocumentWrite, 17, 30
charCodeAt, 88 EnvelopeField, 20
Child Nodes, 23 Event Handlers, 14
close(), 48 External Files, 48
Collection of Nodes, 26 external files, 14
command(), 56
commit(), 56 F
concat, 89 Features, 14
contacting Technical Support, 10 floor, 86
Continue, 92 for, 93
Copy/Paste, 15
cos, 84 G
Create Nodes, 58 getConnection, 55
Create Target, 14 getData, 22
createRecordSet, 55 getDate, 80
getDay, 81
D getEDIElement, 22
Data Source Level, 36 getEnvelopeField, 36
Data Tracking, 43, 46 getField, 22
Database Object, 54 getHours, 82
dataSourceVars, 36 getInstance, 27
Date, 80 getInt, 57
new, 80 getMilliseconds, 82
Debug, 45 getMinutes, 82
Debug Messages, 43 getMonth, 81
delete getRecord(, 21

Mapper JavaScript Guide 97


INDEX

getRootElement, 21 M
getRootRecord, 21 M E K (mapping engine kernel), 20
getRootSegment, 21 Mapping Engine Kernel, 13
getSeconds, 82 maps
getSegment, 21 adding JavaScript to, 30
getString, 57 Math, 84
getTime, 81 max, 86
getUTCDate, 80 mek, 13
getUTCDay, 81 mekAudit, 44
getUTCMonth, 81 mekError, 45
getXMLAttribute, 22 min, 86
getXMLElement, 21–22
getYear, 81 N
GXS New Records, 59
corporate information, 10 New Sub Records, 59
newAttributeInstance, 59–60
I newEDIElementInstance, 60
if/else, 93 newEDIElementInstance(, 59
import JavaScript, 67 newFieldInstance, 59–60
indexOf, 89 newRecordInstance, 59
inEnvelope, 20 newSegmentInstance, 59
Initialize variables, 36 newSubRecordInstance, 59
Instance Variable, 35 newSubSegmentInstance, 59
newSubXMLElementInstance, 59
J newXMLElementInstance, 59
JavaScript, 30 null, 18
maintenance menu, 62 NullPointerException, 22
repository, 61
add, 31, 62 O
delete, 62, 64 Objects, 20
edit, 62–63 Open File, 15
lock, 62 openFile, 49
remove lock, 62 opneDB, 54
view, 62 outEnvelope, 20
JavaScript editor, 15, 29, 64
JavaScript Snipets, 67 P
JavaScript version, 13, 19 Post-Enveloping, 36
javascripts PostEnveloping, 17, 30
in multiple maps, 14 pow, 87
maintain independently, 14 printing documentation, 9
join, 78 Professional Services, 10

L Q
lastIndexOf, 89 query, 56
length, 90
Load from Repository, 33 R
Load JavaScript random, 87
from repository, 31, 33 Read, 17, 30
Loading Variables, 37 ReadFirst, 17, 30
lock readLn, 49
JavaScript, 62 Record Level, 16
remove, 62 RecordSets, 56
Log, 14 Reject, 45
log, 86 Reject Error Messages, 43
Loop Process, 27 repository

98 Mapper JavaScript Guide


INDEX

adding scripts, 31 sourceDocument, 21


JavaScript, 61 split, 90
reserved words, 95 sqrt, 88
reuse javascripts, 14 StartDocumentRead, 17, 30
reverse, 78 StartDocumentWrite, 17, 30
rollback(), 56 String, 88
Root Nodes, 23 substring, 90
round, 87 Syntax Checker, 66
Syntax checker, 15
S Syntax highlighter, 15
Save File, 15
Save JavaScript, 67 T
script Table Level, 16
repository, 61 tan, 84
script repository targetDocument, 21
adding, 31 Technical Support, contacting, 10
scripts Text Files, 48
load from repository, 33 toLowerCase, 90
Search, 15 toString, 79
Segment level, 16 toUpperCase, 90
Session Level, 36 Tracking Values, 46
sessionVars, 36 translation states, 16
setData, 22 Triggers, 14
setDate, 82
setHours, 83 V
setMilliseconds, 83 variables, 14
setMinutes, 83 Version, 13
setMonth, 83 view
setSeconds, 83 JavaScript, 62
setTime, 84
setUTCDate, 82 W
setUTCMonth, 83 while, 92
setYear, 83 Write, 18, 30
Sibling Nodes, 23 WriteFirst, 18, 30
sin, 84 writeLn, 49
Snipets, 67
sort, 78

Mapper JavaScript Guide 99


INDEX

100 Mapper JavaScript Guide

You might also like