Report Writer Tutorial
Report Writer Tutorial
Copyright
Limitation of liability
This document is provided as-is. Information and views expressed in this document, including
URL and other Internet Web site references, may change without notice. You bear the risk of using
it.
Some examples depicted herein are provided for illustration only and are fictitious. No real
association or connection is intended or should be inferred.
Intellectual property
This document does not provide you with any legal rights to any intellectual property in any
Microsoft product.
You may copy and use this document for your internal, reference purposes.
Trademarks
Microsoft, Dexterity, Excel, Microsoft Dynamics, Visual Basic, Windows, and Windows Vista are
trademarks of the Microsoft group of companies. FairCom and c-tree Plus are trademarks of
FairCom Corporation and are registered in the United States and other countries.
All other trademarks are property of their respective owners.
Warranty disclaimer
Microsoft Corporation disclaims any warranty regarding the sample code contained in this
documentation, including the warranties of merchantability and fitness for a particular purpose.
License agreement
Use of this product is covered by a license agreement provided with the software product. If you
have any questions, please call the Microsoft Dynamics GPCustomer Assistance Department at
800-456-0025 (in the U.S. or Canada) or +1-701-281-6500.
Publication date
January 2011
Contents
Introduction ................................................................................................................................. 2
Whats in this manual .................................................................................................................. 2
Symbols and conventions............................................................................................................ 3
Product support ............................................................................................................................ 3
USERS
GUIDE
C O N T E N T S
Chapter 5: Sorting............................................................................................................. 43
Using a main table key .............................................................................................................. 43
Creating a sorting definition .................................................................................................... 43
Chapter 6: Restrictions................................................................................................. 47
Defining report restrictions ...................................................................................................... 47
Restriction functions .................................................................................................................. 49
ii
U S E R S
G U I D E
C O N T E N T S
USERS
GUIDE
iii
C O N T E N T S
iv
U S E R S
G U I D E
C O N T E N T S
USERS
GUIDE
C O N T E N T S
vi
U S E R S
G U I D E
C O N T E N T S
USERS
GUIDE
vii
viii
U S E R S
G U I D E
INTRODUCTION
Introduction
Welcome to the Report Writer, the tool you can use to create and customize
reports. With the Report Writer, you can change the appearance of existing
reports, make global changes that affect all reports, or create your own new
reports. If you have the Modifier with Visual Basic for Applications (VBA),
you can use scripting to further customize your reports.
Part 1, Basics, describes how to get started with the Report Writer, and
describes the Report Writer interface.
Part 8, Storing and Accessing Reports, describes the Reports dictionary. It also explains how to control access to reports you have modified with the Report Writer. Packaging reports is also described.
You can also refer to the Report Writer online help for more information
about using the Report Writer. The sample reports available for Microsoft
Dynamics GP are another good source of information.
U S E R S
G U I D E
IN TRO DUCT IO N
Description
Convention
Description
Part 1, Basics
Chapter 5, Sorting
or ALT+M
Product support
Technical support for the Report Writer can be accessed using the following
methods.
USERS
GUIDE
U S E R S
G U I D E
PART 1: BASICS
Part 1: Basics
This portion of the documentation contains basic information you should
know before you begin using the Report Writer. The following information
is discussed:
U S E R S
G U I D E
Chapter 1, Getting Started with the Report Writer, describes the basic
tasks you can perform with the Report Writer, the terminology used to
describe reports, and how reports are stored. It also describes how to
start the Report Writer.
Chapter 2, The Report Writer Interface, describes the interface for the
Report Writer.
Chapter 1:
USERS
GUIDE
PA RT
B A S I C S
Terminology
To get the most benefit from the Report Writer, you need to understand
some basic terminology used to describe reports.
Original reports
An original report is one that was provided with the accounting system.
Original reports are stored in the main application dictionary.
Modified reports
A modified report is a copy of an original report that you have made changes
to. Modified reports are stored in the Reports dictionary. A modified report
can be substituted for an original report in the accounting system. When a
user prints the report, theyre actually using the modified report, rather
than the original.
Custom reports
A custom report is one that was created using the Report Writer. You can
start with a blank report, or you can start by making a copy of a report that
already exists in the accounting system. Custom reports are stored in the
Reports dictionary. You must use a special procedure to print custom
reports in the accounting system.
Storing reports
All changes and additions you make using the Report Writer are stored in
the reports dictionary for the application. By storing the new and modified
resources in a separate dictionary, the integrity of the system can be
maintained. For example, the following illustration shows the dictionary
for Microsoft Dynamics GP and its associated reports dictionary.
New and modified
resources are stored in
the reports dictionary.
Dynamics
Reports.dic
You will learn more about the reports dictionary in Chapter 30, Storing
Reports.
U S E R S
G U I D E
C H A P T E R
G ET T IN G
S T AR T E D
W IT H
TH E
R E P O R T
W R IT E R
Select the product whose reports you want to access, then click OK. If
Microsoft Dynamics GP is the only product available, this window
wont appear.
USERS
GUIDE
10
U S E R S
G U I D E
Chapter 2:
Description
Opens the Data Types window, where you can view or edit
existing data types.
Opens the Fields window, where you can view a list of fields in
the application.
Opens the Tables or Virtual Tables window, where you can view
information about tables or virtual tables in the application.
Opens the Report Writer window, which allows you to create new
or modified reports.
Menus
The following items are available in the Report Writer menu bar.
File: Print Setup
This menu item opens the printer setup dialog box. This dialog box allows
you to configure the currently selected printer.
File: Generate Resource Reports
This menu item prints a resource report for the application. The resource
report is a text file that lists all resources in the current dictionary, their
internal resource IDs and any resources associated with the listed resource.
When you choose Generate Resource Reports, a dialog box will appear and
allow you to name the report and select its location.
USERS
GUIDE
11
PA RT
B A S I C S
12
U S E R S
G U I D E
C H A P T E R
T HE
R E PO R T
WR I T ER
IN T E R F AC E
Windows:
This menu displays a list of the windows currently open. Selecting a
window from this menu makes the window active.
Help: Lookup
This menu item opens any lookup window for the current field.
Help: Contents
This menu item displays the contents topic for the Report Writer online
help.
Help: Search for Help On
This menu item displays the search window for the help system, allowing
you to search the Report Writer online help.
Help: Window Help
This menu item displays help for the current window in the Report Writer.
Help: About
This menu item displays the About window for the main application.
Windows
The Report Writer uses several types of windows. Review the following
descriptions to learn how each is used.
USERS
GUIDE
13
PA RT
B A S I C S
Definition windows
Definition windows allow you to customize individual resources. For
example, you will use the Format Definition window to customize how
data is displayed on reports.
14
U S E R S
G U I D E
C H A P T E R
T HE
R E PO R T
WR I T ER
IN T E R F AC E
Layout window
You will use the Layout window to specify the layout of reports in the
application. The Layout window uses a graphics metaphor you may
already be familiar with: an assortment of tools you can use for drawing
and creating objects; a built-in grid that allows easy alignment of objects;
moveable objects in a layout like an object-oriented drawing program; and
standard cut-copy-and-paste techniques so you can import graphics you
create in other applications.
Standard buttons
The following buttons are used throughout the Report Writer:
Button
Description
Saves changes and closes the current window.
USERS
GUIDE
15
PA RT
B A S I C S
Button
Description
Deletes the selected resource.
16
U S E R S
G U I D E
18
U S E R S
G U I D E
Chapter 3:
Report Definition
Before you can work with the layout of a report, you must open an existing
report definition or create a new one. The report definition specifies
important characteristics of the report, such as its name. Many of these
characteristics can be adjusted after you begin designing the report layout.
Information about the report definition is divided into the following
sections:
USERS
GUIDE
19
PA RT
C R E A TI N G
R E P O R T S
Click New to add another table to the report. The Related Tables
window will open. This window contains a list of all tables that have a
relationship with the main table already defined using the Table
Relationship Definition window. An asterisk appearing next to the
table name denotes a one-to-many relationship. Select the desired table
and click OK. Each table that is added to the report and is directly
linked to the main table will be listed below the main table in the
Report Table Relationships window, with a single dash to the left of the
table name.
To add a table that is linked to a table other than the main table, select
the secondary tables name in the Report Table Relationships window
and click New. Select the name of the table to be added and click OK.
This table will appear in the Report Table Relationships window below
the table that it is linked to, and will have two dashes to the left of its
name.
20
U S E R S
G U I D E
C H A P T E R
R EP O R T
D E FI N IT IO N
Main table
The dashes indicate the level of
linking between the current table
and the main table. Two dashes
indicate that this table has a
relationship with the Customer
Master Summary table, which in
turn is related to the main table.
You can have only one one-to-many relationship among the tables used
for the report. For example, if the Customer Master Address File table
has a one-to-many relationship with another table used in the report, all
of the other relationships must be one-to-one.
Once you have added all the necessary additional tables, click Close to
close the Report Table Relationships window.
5. Set the maximum number of records for the report.
Use the Max Records field to restrict the number of records that will be
printed on the report. The default value for this field is 0, which
indicates that all records will be printed.
If you enter the number 10 in the Max Records field, for example, only
the first 10 records in the report will be printed, unless a restriction has
been created to specify another number. Any limit set using a
restriction overrides the limit set using the Max Records field.
You may want to enter a relatively small number while youre creating the
report, so that test reports will be generated more quickly. Be sure to change the
number to 0 or another appropriate number when you are finished testing.
What is an appropriate number depends upon the type of report and
how it will be used. For example, you could generate a report that lists
all sales statistics by salesperson. If the user will only want to view the
top ten salespersons, you could set the Max Records field to 10.
USERS
GUIDE
21
PA RT
C R E A TI N G
R E P O R T S
Report options
Several options are available to control characteristics of a report. Use the
following procedure to set options for the report.
1. Set the report format options.
These settings specify various characteristics of the report. The Format
Options are described in detail below.
Text Report Mark this option if you want to create a text report. Text
reports do not allow you to specify fonts or use graphical items in your
report, such as lines and pictures. However, text reports are less likely
to be adversely affected by different printer configurations.
We suggest you create graphics reports only when creating custom reports for
specific clients, where you can be sure of the type of printer the report will be
printed to. If you create graphics reports for general distribution, be sure to test
the reports with a wide variety of printers.
Skip Blank Records Mark this option to include only records for
which there is corresponding data in the main and related tables. If
there isnt a corresponding record in each of the related tables, the
entire record wont be included in the report.
Suppress Decimals Mark this option to round currency values to
the nearest whole currency unit. This option is primarily used for
international versions of applications where inflation makes the
fractional portions of currency amounts insignificant.
2. Set page orientation options.
You can specify the page orientation that will be used for the report.
Printer Setting Choose this option to use the page orientation as
specified for the printer currently selected.
Portrait Choose this option to have the report printed in portrait
mode, regardless of the current printer setting.
Landscape Choose this option to have the report printed in
landscape mode, regardless of the current printer setting.
22
U S E R S
G U I D E
C H A P T E R
Refer to Chapter 4,
Report Layout, for
more information
about the Report
Layout window.
R EP O R T
D E FI N IT IO N
USERS
GUIDE
23
PA RT
C R E A TI N G
R E P O R T S
First Page Header Choose this option if you want the page header
to be printed on the first page of the report. If you dont want to print
page headers on any page of the report, use the Report Section Options
window to inactivate page headers. If page headers have been
inactivated, the Page Header check box will appear dimmed.
Last Page Footer Choose this option if you want the page footer to
print on the last page of the report. If you dont want to print page
footers on any page of the report, use the Report Section Options
window to inactivate page footers. If page footers have been
inactivated, the Page Footer check box will appear dimmed.
Preprinted Form Select this option to remove the built-in margin
from the layout area when designing a text report. With this option
selected, you can place fields anywhere in the layout area. However, if
you place fields outside of the printers predefined margins, data
outside of the margin will not print.
If Preprinted Form is not selected, a margin will appear in the report
layout area; the margin is drawn to show the default printer margins of
the currently-selected printer. The Report Writer will not allow you to
place fields outside of this margin.
If Preprinted Form is not selected and you lay out a report while you
have one printer selected, then save the report layout, select a different
printer and reopen the report layout, the margins may shift, depending
on the default margins of the new printer. If the margins shift, fields in
the layout area will shift with the left and top margins. This shift may
force fields outside of the area bounded by the right margin.
The Preprinted Form selection isnt available if the Best Text Fit option
is selected. The use of preprinted forms isnt an option when Best Text
Fit is selected because the size and spacing of the font used for Best Text
Fit reports varies based on the data in the report. Therefore, you can
never be certain that text will appear in the appropriate position on a
preprinted form.
24
U S E R S
G U I D E
C H A P T E R
R EP O R T
D E FI N IT IO N
Use RF for Last PF Mark this option to replace the last page footer
on the report with the report footer. The report footer will be printed in
the area designated for the page footer. If you mark this option, the
page footer and report footer must be the same size, and both sections
must be active.
To access the Footer
Options window, open
the Report Layout
window, select Report
Options from the Tools
menu, and click Add or
Open in the Additional
Footers section.
Mark this option if the report will contain totals in the report footer. For
instance, an invoice report containing invoice numbers, invoice items
and an additional footer could have a Sum type field in the additional
footer (which breaks on the invoice number field) to display the sum of
the invoice items. If you wish to display an overall sum at the bottom of
the report as well, you must place it in the report footer, then mark Use
RF For Last PF, as well as Suppress Last Records Footer in the Footer
Options window for the additional footer.
Mark the options indicating what type of information you want included
on the report, and then click OK. The report will be generated.
Printing report definitions for existing reports is a good way to learn about the
report.
USERS
GUIDE
25
26
U S E R S
G U I D E
Chapter 4:
Report Layout
Once youve planned and defined your report, youre ready to design the
report layout. Use the information provided here to create a report layout
using the Report Layout window. Information about the report layout is
divided into the following sections:
USERS
GUIDE
27
PA RT
C R E A TI N G
R E P O R T S
Toolbox
The type of report being created is displayed in the Toolbox, next to the
arrow tool. Also, several tools are available only when creating graphics
reports, such as the line and picture tools.
Layout area
For a text report, the layout area includes a left border, a right border, and
two intermediate vertical guides. These guides mark the positions 80
characters and 132 characters from the left margin. They can help you more
precisely place fields in the layout area and are especially useful if youre
using a preprinted form and have specified a fixed-pitch text option. Then,
regardless of the printer printed to, you are assured of proper placement of
fields.
For graphics reports, the layout area simply includes the left and right
borders.
To make the various sections of the layout area easier to distinguish, you
can mark the Colorize Report Sections item in the Layout menu. This makes
the various sections of the report appear lightly shaded.
Layout sections
Before you can add fields and data to the report layout, you must decide
where to place that information in the layout area. The Report Layout
window for a new report contains four evenly-spaced blank sections,
separated by border lines. Each border has a handle in the left margin that
is labeled using a one- or two-letter abbreviation. Each section can be
resized by dragging the handle up or down. Once fields have been placed
in a section, you cant drag the lower border of a section above the lowest
field in the section.
Additional headers and
additional footers are
described in Chapter 8,
Additional Headers
and Footers.
28
U S E R S
G U I D E
C H A P T E R
R E P O R T
L AY O U T
Use
Page Header
(PH)
Items in this section are placed at the top of every report page. Page number, date, and
time fields are commonly placed in this section of a report. You can prevent the Page
Header from being included on the first page of a report by unmarking the First Page
Header option in the Report Definition window.
To exclude page headers from a report, unmark the Page Header option in the Report
Section Options window.
Report Header
(RH)
Items in this section appear only on the first page of a report. The title of the report and
introductory information are often included in this section. If a page header is also
included on the first page, the report header will appear after the page header.
To exclude a report header from a report, unmark the Report Header option in the
Report Section Options window.
Additional Headers
(H1, H2, H3...)
Additional headers and footers allow you to create groupings in your report. Each
header will print when the data in the field it is based on changes. Therefore, the
sorting order used will affect the order in which the headers appear on the report. For
example, if the field related to header 2 is sorted before the field for header 1, header 2
will print before header 1.
Use the Report Section Options window to add additional headers. You can have up to
15 additional headers in a report.
Body (B)
The report body normally contains the bulk of the report. Depending on the number of
additional headers and the sorting order used, there could be a body section for each
additional header section.
Additional Footers
(F1, F2, F3...)
Additional headers and footers allow you to create groupings in your report. Footers
should correspond to headers and break on the same fields. They are often used to
display summary data, such as a total of all records in the reports body under the
footers related header.
Use the Report Section Options window to add additional footers. You can have up to
15 additional footers in a report.
Report Footer
(RF)
Items in this section appear only on the last page of a report. Summary information is
often included in this section. If a page footer is also included on the last page, the
report footer will appear before the page footer.
To exclude a report footer from a report, unmark the Report Footer option in the Report
Section Options window.
Page Footer
(PF)
Items in this section are placed at the bottom of every report page. This section often
includes administrative information, such as the name of the person running the
report. You can prevent this section from being included on the last page of a report by
unmarking the Last Page Footer option in the Report Definition window.
To exclude page footers from a report, unmark the Page Footer option in the Report
Section Options window.
USERS
GUIDE
29
PA RT
C R E A TI N G
R E P O R T S
The Toolbox
Use the Toolbox to place the fields and other items in the report layout area.
The Toolbox windows Layout and Arrange tabs let you toggle between
two different sets of tools. Tools in the Layout tab help you place
information in the layout area, while tools in the Arrange tab are used to
arrange selected items in the layout area.
To activate the Toolbox window, simply move the pointer from the Layout
window to the Toolbox window. The following illustration shows the
Toolbox for a graphical report when the Layout tab is displayed and a field
in the Layout area is selected. Each of the Layout and Arrange tools, as well
as the Pos and Size fields, are described in the following sections.
30
U S E R S
G U I D E
Name
Description
Arrow tool
Use the arrow tool to select objects in the layout area. When
you select an object, handles will appear; dragging a handle
allows you to resize the object. To select more than one
object at once, hold down the SHIFT key as you select the
object, or drag the arrow tool to draw a rectangle around the
set of objects you want to select. You can also use the arrow
tool to drag objects to a new position in the layout area.
C H A P T E R
Tool
R E P O R T
L AY O U T
Name
Description
Divider tool
Use the divider tool to divide the report into columns, such
as for printing labels. To mark a division on the report, click
the divider tool, then click in the body of the report where
you want to place the division. You must add the division to
the right of any existing fields; the division wont appear if
there are fields or other objects to the right of where youve
clicked. Once youve placed a division on the report, you
cant add any objects to the right of the division. You can
reposition a division by dragging it with the arrow tool.
Text tool
Use the text tool to place text in the layout area, such as a
report title or column headings. You can enter up to 79
characters in a text field. You cant use the ENTER key to make
the text wrap; this can only be accomplished by resizing the
text field.
Date tool
Use the date tool to add fields that display the current date.
The date is determined by the operating system setting.
Time tool
Use the time tool to add fields that display the current time.
The time is determined by the operating system setting.
Page number Use the page number tool to add fields that display the
tool
current page number.
Picture tool
Line tool
The line tool is available for use only with graphics reports.
Use it to draw lines in the report layout.
Circle tool
The circle tool is available for use only with graphics reports.
Use it to draw circles in the report layout.
Rounded
rectangle
tool
Rectangle
tool
USERS
GUIDE
31
PA RT
C R E A TI N G
R E P O R T S
Size
Tool
Name
Description
Align to Top
Align to Left
Align to Right
Align to Bottom
Size to Shortest
Tile
32
U S E R S
G U I D E
Size to Widest
Size to Tallest
Size to Default
Tile Horizontally
Tile Vertically
C H A P T E R
R E P O R T
L AY O U T
Arranging objects cant be undone. Be sure to save your report layout before
arranging objects. If you arent satisfied with the result of an arrangement, you can
close the window without saving the changes.
When you open the Report Layout window, the name of the reports main
table will appear under the layout tools in a drop-down list, and the name
of each field in that table will appear in the fields list. You can change which
fields appear in the fields list by selecting a different entry from the list. The
choices in the drop-down list are Globals, Calculated Fields, Legends, and
the name of each table associated with the report.
The arrow tool is selected by default when you open the window. Use it to
select each desired field from the fields list and drag it to the report layout
area. If you inadvertently drag the wrong field to the layout area, select the
field using the arrow key, then press DELETE or BACKSPACE. This will remove
the field from the layout area without affecting the field in the table.
Refer to Part 3, Gathering Data, for information about finding the data you want
to include in your report.
If you add an array field to the layout, the Report Field Options window
will appear, allowing you to specify the element of the field being placed on
the report. In the Array Index field, enter the number of the array element,
and then click OK. If necessary, you can use the Report Field Options
window to change the array index to a different element of the array.
Fields placed in the layout area will automatically appear sized according
to the maximum keyable length of the field. You can resize each field as you
wish; however, if you shorten a field, the information in that field may not
USERS
GUIDE
33
PA RT
C R E A TI N G
R E P O R T S
be displayed in its entirety when the report is printed. If you resize a field
by vertically enlarging it, the fields text will be centered. If you reduce a
fields height, it will not display properly.
You can click and drag with the Arrow tool to select multiple fields in the
layout. By default, the selection rectangle will be limited to the current
group. Hold down the CTRL key to allow the selection rectangle to expand
beyond the current group.
In general, fields placed in the body of the report should be placed at the
very top of the body section, since any white space between the top of the
body and the field below it will be repeated for every record thats printed.
Similarly, once youve finished placing fields in the report body, you should
resize the body section so that excess space is removed from the bottom of
the section.
34
U S E R S
G U I D E
Settings box
C H A P T E R
R E P O R T
L AY O U T
Setting the property value involves choosing a value from a drop-down list,
typing a value, or using a lookup. Some properties listed cant have their
values changed.
Property type
Description
Some properties are set using a dropdown list.
Some properties have the value entered
directly.
Some properties use a lookup to retrieve
values.
Some properties cant be set.
Report properties
To view report properties, be sure the Properties window is open. Select the
arrow tool from the Toolbox and click anywhere in the background of the
layout area to select the report. The following table lists the report
properties.
Object
property
Description
DisplayName
MainTable
MainTableKey
MainTableName
MaxRecords
Name
Orientation
ReportID
Series
Type
USERS
GUIDE
35
PA RT
C R E A TI N G
R E P O R T S
Field properties
The following table lists the field properties.
Object
property
Description
ArrayIndex
DisplayType
Field
FieldID
FieldType
Format
FormatField
FormatFieldSrc
Section
Table
TableName
Visual
property
Description
Alignment
BackColor
Font
FontBold
FontColor
FontItalic
FontSize
FontUnderline
Pattern
PatternColor
Position-Left
36
U S E R S
G U I D E
C H A P T E R
R E P O R T
L AY O U T
Visual
property
Description
Position-Top
Size-Height
Size-Width
Visibility
Description
Section
Visual
property
Description
Alignment
For static text, indicates whether the text is left, center, or rightaligned.
Specifies the background color of the object.
Specifies the font used for static text.
If set to true, static text will be displayed in bold type.
For static text, specifies the color of the text.
If set to true, static text will be displayed in italic type.
For static text, specifies the size of the text, in points.
If set to true, static text will be underlined.
Specifies the color of the line used to draw the object.
Specifies the width of the line (in pixels) used to draw the object.
Specifies the pattern to apply to the background.
Specifies the color of the pattern that is applied to the background.
Indicates the position of the left edge of the object, measured in
points from the left edge of the report.
Indicates the position of the top edge of the object, measured in
points from the top edge of the report.
Specifies the shape of an item drawn with the shape tool.
Indicates the object height, measured in points.
Indicates the object width, measured in points.
BackColor
Font
FontBold
FontColor
FontItalic
FontSize
FontUnderline
LineColor
LineSize
Pattern
PatternColor
Position-Left
Position-Top
Shape
Size-Height
Size-Width
USERS
GUIDE
37
PA RT
C R E A TI N G
R E P O R T S
Booleans
When a boolean is added to a report, the string Yes is printed on the
report if the field contains the value true. The string No is printed on
the report if the field contains the value false.
Check boxes
When a check box is added to a report, an X is printed if the check box is
marked. Nothing is printed on the report if the check box is not marked.
Combo boxes
When a combo box field is added to a report, the text string selected or
entered in the field is printed on the report.
Dates
When a date field is added to a report, the short version of the date value is
printed on the report. The date value is formatted based on the regional
settings for the operating system.
Drop-down lists
When a drop-down list field is added to a report, the static text value
corresponding to the fields value is printed on the report. If the drop-down
list field doesnt have any static text items defined for its data type, no text
is displayed on the report. In this case, you must create a calculated field to
display a value based on the value of the drop-down list field.
List boxes
When a list box field is added to a report, the static text value
corresponding to the fields value is printed on the report. If the list box
field doesnt have any static text items defined for its data type, no text is
printed on the report. In this case, you must create a calculated field to
display a value based on the value of the list box field.
38
U S E R S
G U I D E
C H A P T E R
R E P O R T
L AY O U T
Pictures
Picture fields should not be added to the report layout.
Radio groups
When a radio group is added to a report, the integer value of the field is
printed on the report. If you want to display some other value in the report,
you must create a calculated field to display a value based on the value of
the radio group field.
Text fields
When you add text fields to a report layout, you should be aware that they
can display no more than 10K of data, even though text fields can hold up
to 32K of data. Text fields should only be placed in the body of a report.
Resizing a text field will have different results, depending on whether
the report is a graphics or text report. If you resize a text field in a graphics
report, data will be printed to fill the resized area. However, if the text field
is larger than the amount of data in that field for a given record, the unused
space for that field will still be included in the report. If you resize a text
field in a text report, the field width you specify will be used, but the field
height will be adjusted automatically to accommodate the text in the text
field, up to the 10K limit.
For example, you could resize a text field to be two inches wide and tall
enough to include 18 rows of data. If the data in that field for a given record
will fill only 12 rows, then only those 12 rows will be included if its a text
report, while those 12 rows plus 6 blank rows will be included if its a
graphics report. Similarly, if the data in that same field for a different record
contains 20K of data, up to 10K will be included if its a text report, while
only the first 18 rows will be included if its a graphics report.
Times
When a time field is added to a report, the time value is printed on the
report. The time value is formatted based on the regional settings for the
operating system.
Visual switches
If the visual switch field has static text values defined, the static text value
corresponding to the fields value is printed on the report. If the visual
switch field has picture or native picture static values defined, the integer
value of the field is printed on the report. If the visual switch field has no
static values defined, it cant be used on the report. Instead, you must create
a calculated field to display a value based on the value of the visual switch
field.
USERS
GUIDE
39
PA RT
C R E A TI N G
R E P O R T S
If several items are selected in the layout area when you open the Drawing
Options window, the options you specify will apply to all of them. If no
items are selected when you open this window, the options defined will be
applied to all new objects placed in the layout area.
For many objects, such as text, lines, and rectangles, you can open the Drawing
Options window by double-clicking the object.
Fonts
Use items in the Font section to specify font characteristics for items in the
report. For graphics reports, you can choose any font installed on the
current system.
Keep in mind that if the report is used on another system that doesnt have the
appropriate fonts installed, the missing fonts will be substituted.
Three generic fonts are always available for every report. These are:
40
U S E R S
G U I D E
Courier (generic)
Helvetica (generic)
Times (generic)
C H A P T E R
R E P O R T
L AY O U T
These fonts correspond to the fonts that were available in earlier versions of
the Report Writer. If you want your reports to be independent of the fonts
installed on a particular system, use these generic fonts.
If you are creating a text report and have marked the Variable Characters/
Inch option in the report definition, the Font section in the Drawing
Options window allows you to specify the characters per inch to use for
each line. Simply select a field in the line and display the Drawing Options
window. You can choose 5, 6, 10, 12, or 17 characters per inch.
If you mark the Variable
Characters/Inch option for a
text report, you can specify
the characters per inch for
each line of the report.
Once you set the characters per inch for a field on the report, any other field
you move to that line will also be printed in that size. To see how your text
report will appear when printed, be sure the Show Field Names item in the
Layout menu is not marked. The report will be displayed as it will appear
when printed.
Patterns
Use the Patterns section to select the fill pattern for fields, text items or
shapes in the layout.
Color
Use the Color section to select the font/line, background and foreground
colors of items youve added to the layout. The line color is used for lines
and field borders. The font color is used for text. The foreground color is
used to draw the pattern selected in the Patterns section. The background
color is used to fill in the remaining area of the object. The line size specifies
the size of the line used to draw lines, rectangles, circles, and other shapes.
When specifying colors, you can select one of the predefined colors in the
list. To use a custom color, select User Defined as the color and then click
More Colors to display the Color dialog. Select a color and click OK. The
color you selected will be applied to the current color selection.
Alignment
Use the Alignment setting to specify the horizontal alignment of text in
fields or of text items youve added using the text tool.
USERS
GUIDE
41
42
U S E R S
G U I D E
Chapter 5:
Sorting
There are two methods for specifying how the data in a report is sorted. In
the first method, the report is sorted based on a key you select for the main
table used for the report. In the second method, you create a sorting
definition based on the fields in the tables used for the report. Information
about sorting is divided into the following sections:
This is the preferred method for sorting the report, because an index
already exists for each table key. In effect, the order of the data is already
known. The Report Writer simply retrieves data from the primary table
using the key you specified.
USERS
GUIDE
43
PA RT
C R E A TI N G
R E P O R T S
To create a sorting definition, click the Sort button in the Report Definition
window to open the Sorting Definition window, shown in the following
illustration. Use this window to define a sorting order that includes fields
from any of the tables associated with the report.
From the Report Table drop-down list, select the table containing the field
you wish to use to specify the sorting order. The name of each field in the
selected table will appear in the Table Fields list. Select the desired field,
and click Insert. The field name will be added to the Sort By list.
Subsequently-added fields will be added to the top of the Sort By list, unless
an item in the list is selected. If an item is selected, newly-added fields will
be added below the selected item.
The sorting order will be based on the fields listed in the Sort By list. The
data will be sorted based on the first field, then, if a secondary sorting order
is needed, the second field, and so on. Be sure to include all fields necessary
to fully define the desired order.
For each field selected, you can specify whether you want the data to be
sorted in ascending or descending order (ascending is the default order)
and whether to ignore the case of any string fields used as sorting criteria. If
you ignore case, the strings will be sorted in strict alphabetical order. If you
dont ignore case and you are sorting in ascending order, all strings
beginning with lowercase letters will appear in alphabetical order, followed
by all strings beginning with uppercase letters, also in alphabetical order. In
descending order, all of the uppercase strings will appear before the
lowercase strings.
44
U S E R S
G U I D E
C H A P T E R
S O R T I N G
To select the Descending and/or Ignore Case options for a given field, select
the desired field in the Sort By list and check the appropriate sorting
options. Once you have specified all the sorting options, click OK to close
the Sorting Definition window.
If none of the fields used to define the sorting order are from a secondary table, the
report information drawn from that table will be sorted according to the key used to
define that secondary tables relationship with the reports main table.
Once you have created a sorting definition for a report, it will override the
sort order specified by the key selected for the reports main table. To use
the main tables key as the sorting method, you must remove all of the
items from the Sort By list in the Sorting Definition window.
USERS
GUIDE
45
46
U S E R S
G U I D E
Chapter 6:
Restrictions
Use restrictions to limit the amount and scope of data included in your
report. For example, you could create a report with a restriction based upon
the State field, so that the report will contain only sales data for a specific
state.
Information about restrictions is divided into the following sections:
Before defining a restriction, its a good idea to plan the restriction and write it out
completely. Decide which fields, operators, constants and functions youll need to
express the restriction properly. Some restrictions may require that the steps
defined below be performed in a slightly different order.
USERS
GUIDE
47
PA RT
C R E A TI N G
R E P O R T S
48
U S E R S
G U I D E
C H A PT E R
R E S T R I C TI O N S
Restriction functions
This section describes the functions available when defining a restriction for
a report. It includes a definition of each function, an example of how the
function is used in a restriction expression, and an explanation of how you
can use such an expression in a report. Also included is information about
the storage types that can be used with each function, since some functions
can be used only in expressions with fields of a certain storage type.
SUBSTRING and
WILDCARD are the
only functions that can
be used with table
fields from all report
tables.
Most of these functions can be used only with fields from a report table that
has a one-to-many relationship with another report table, such as a
secondary table with a one-to-many relationship with the reports main
table. Records in secondary tables with a one-to-many relationship with the
main table are sometimes referred to as detail records. Using one of these
functions with any other fields will cause an error at runtime. Only two
functions can be use with fields from any of the report tables: SUBSTRING
and WILDCARD.
AVERAGE
The AVERAGE function calculates the average of an expression for all
detail records. It can be used with expressions containing fields of all
storage types except strings.
Example
You can use the AVERAGE function to create a restriction on an invoice list
so that it will print only invoices for which the invoices items average a
markup of at least 20% over cost.
AVERAGE ((Item Price)  (Item Cost) / (Item Cost)) > .2
USERS
GUIDE
49
PA RT
C R E A TI N G
R E P O R T S
EXISTS
The EXISTS function ascertains whether at least one record in a group of
detail records makes the expression true. The expression the EXISTS
function evaluates should be a comparison as shown in the following
example. This function can be used with all boolean expressions.
You can use the NOT operator with this function to increase its scope and
create expressions restricting the information on your reports according to
expressions that arent true.
Example
You can use the EXISTS function to create a restriction on an order list to list
customers whose orders include at least one item over $100.
EXISTS (Item Price > 100)
FIRST
The FIRST function finds the first occurrence of an expression in a group of
detail records. It can be used with expressions containing fields of any
storage type.
Restrictions are evaluated before the report is sorted, so the item designated
by the FIRST function may not be the same as the first item in a group on
the report once its been sorted and printed. The first item will be the first
value in the table, sorted by the key used to link the secondary table to the
reports main table.
For example, you could print a report that lists invoices and corresponding
line items, then create a restriction to print only invoices for which the
first line items price was more than $1,000. If you then sort the report in
ascending order by line item price, the line item that the FIRST function
finds wont necessarily be the line item listed first on the report. It will be
the first line item in the table, which depends on the key used to create the
table relationship. If the key is composed of the invoice number and the line
item number, the first line item will be the item with the smallest (or largest,
depending upon the keys sorting method) line item number.
50
U S E R S
G U I D E
C H A PT E R
R E S T R I C TI O N S
The following example shows an invoice and its line items as theyre sorted
within the tables, by invoice number and by item number.
Records in the table are
sorted by the Invoice
Number and Item.
This is the record the FIRST
function will evaluate.
Invoice Number
Item
Price
5005
1201
$5,300.00
5005
1205
$3,900.00
5005
1211
$5,250.00
Since the line items are sorted by item and not by price, the record
identified by the FIRST function is item 1201. If you sort the report by the
price of each line item, thats how the information will appear on the report,
but the FIRST function will still identify item 1201 as the first item.
Invoice 5005
Item
Price
1205
$3,900.00
1211
$5,250.00
1201
$5,300.00
Example
The following example shows how to use the function to create the
expression explained in the previous paragraphs and illustrations.
FIRST (Item) > 1000
USERS
GUIDE
51
PA RT
C R E A TI N G
R E P O R T S
FORALL
The FORALL function prints only those records for which all of the detail
records meet the expressions requirements. This function can be used with
all boolean expressions.
You can use the NOT operator with this function to increase its scope and
create expressions restricting the information on your reports according to
expressions that arent true.
Example
You can use the FORALL function to create a restriction on an invoice list to
display only invoices containing items that all cost more than $500.
FORALL ((Item Price) > 500)
FREQUENCY
The FREQUENCY function counts the number of detail records. The
FREQUENCY function can be used with expressions containing fields of
any storage type.
Example
You can create a restriction on a customer order list to print only orders
containing more than five items.
FREQUENCY (Item Number) > 5
LAST
The LAST function finds the last occurrence of an expression in a group of
detail records. The LAST function can be used with expressions containing
fields of any storage type except string.
Restrictions are evaluated before the report is sorted, so the item designated
by the LAST function may not be the same as the last item in a group on the
report once its been sorted and printed. The last item will be the last value
in the table, sorted by the key used to link the secondary table to the
reports main table.
52
U S E R S
G U I D E
C H A PT E R
R E S T R I C TI O N S
For example, you could print a report that lists Salesperson IDs and
corresponding line items containing dates upon which theyve made sales
and the total amount of each sale. You could then create a restriction to
print only the records for salespeople whose most recent sale totaled more
than $1,000. If you then sort the report in ascending order by the amount of
the sale, the record that the LAST function finds wont necessarily be the
one listed last on the report. The last record on the report will be the item
with the largest total sale amount.
The following example shows the records for Salesperson ID 001 as theyre
sorted within the tables, by salesperson ID and sale date.
Salesperson ID
Sale Date
Sale Total
001
1/2/97
$1,200.00
001
2/4/97
$2,300.00
001
2/6/97
$1,400.00
001
4/12/97
$1,000.01
Since the salesperson records are sorted by sale date and not by sale total,
the record identified by the LAST function is the 4/12/97 sale. If you sort
the report by the sale total, that is how the information will appear on the
report, but the LAST function will still identify the 4/12/97 sale as the last
item.
Salesperson ID 001
Sale Date
Sale Total
4/12/97
$1,000.01
1/2/97
$1,200.00
2/6/97
$1,400.00
2/4/97
$2,300.00
Example
The following example shows how to use the function to create the
expression explained in the previous paragraphs and illustrations.
LAST (Sale Total) > 1000
USERS
GUIDE
53
PA RT
C R E A TI N G
R E P O R T S
MAXIMUM
The MAXIMUM function finds the detail record with the highest value that
satisfies the given expression. The MAXIMUM function can be used with
fields of any storage type except strings.
Example
You could create a restriction on an invoice list that prints only invoices that
include items priced over $100.
MAXIMUM (Item Price) > 100
MINIMUM
The MINIMUM function finds the detail record with the lowest value that
satisfies the given expression. The MINIMUM function can be used with
fields of any storage type except strings.
Example
You could create a restriction on an invoice list that prints only invoices that
include items priced under $100.
MINIMUM (Item Price) < 100
SUBSTRING
The SUBSTRING function is used to search fields with a string storage type
for a match to a specified pattern. The SUBSTRING function will find a
match if the specified pattern appears anywhere within the specified field.
It is case-sensitive.
Only the equality (=) and inequality (<>) operators can be used with the
SUBSTRING function. The data in the specified field either matches or
doesnt match the pattern. No other operators can be used.
This function is used to restrict the data on the report to information that
matches a set of characters specified as the search pattern. Three special
characters can be used in the search pattern to indicate the type of match
youre searching for: the asterisk (*), the question mark (?), and the
backslash (\).
54
U S E R S
G U I D E
C H A PT E R
R E S T R I C TI O N S
Any character
A group of characters
No characters
Example
You could use this function to print a list of companies in a particular sales
region whose names contain the string Johns. The following example
shows an expression for which Johns Fish Market and Mabel and Johns
Deli would both be valid matches.
SUBSTRING ("John\'s") = Company_Name
USERS
GUIDE
55
PA RT
C R E A TI N G
R E P O R T S
SUMMATION
The SUMMATION function calculates the sum of a specified expression for
each record in a set of detail records. The SUMMATION function can be
used with fields of any storage type except strings.
Example
You can use the SUMMATION function on a report listing invoices and the
items on each invoice to print only the invoices where the total of all item
extended prices is greater than $1,000. The extended price is the price of
each item multiplied by the number of items that were purchased. The
SUMMATION function would first calculate the extended price for each
item on the invoice, then sum those extended prices and compare the sum
to the specified $1,000 value. The following expression demonstrates how
this restriction would be written.
SUMMATION (Quantity Ordered * Item Price) > 1,000
WILDCARD
The WILDCARD function is used to search fields with a string storage type
for a match to a specified pattern. The WILDCARD function will find a
match only if the specified pattern appears in the specified field exactly as
stated. The asterisk, question mark and backslash special characters,
described in the explanation of the SUBSTRING function, can also be used
with this function.
By using these special characters, you can expand the scope of the search
conducted by the WILDCARD function. Without the special characters, the
specified field must contain exactly the specified pattern, and only the
specified pattern, for a match to occur. For example, the expression
WILDCARD (Apple) = Snack Type would not find a match if the value in
the Snack Type field was Apples.
Only the equality (=) and inequality (<>) operators can be used with the
WILDCARD function. The data in the specified field either matches or
doesnt match the pattern. No other operators can be used.
The WILDCARD function is case-sensitive.
Example
You could use this function to print a list of users whose IDs begin with the
letter A.
WILDCARD ("A*") = User ID
56
U S E R S
G U I D E
Chapter 7:
Calculated Fields
Calculated fields are a powerful tool you can use to manipulate data in
your report. Calculated fields are defined using fields, constants and
operators, as well as system-defined or user-defined functions. The
following illustration shows the Calculated Field Definition window.
USERS
GUIDE
57
PA RT
C R E A TI N G
R E P O R T S
58
U S E R S
G U I D E
C H A P T E R
C AL C U LA T ED
F IE LD S
Operators
Operators allow you to specify the relationships between the various
components of expressions. Some operators are only enabled if you are
creating a conditional expression.
Parentheses ()
Indicate the beginning and end of an expression that should be evaluated as
a unit, separate from the rest of the expression. In general, you should use
parentheses to enclose parts of the whole expression when youre using two
or more operators and you wish to control the order of evaluation.
Parentheses are automatically added to an expression when you insert a
function. The item following it, usually a field, is automatically placed
within the parentheses.
Addition (+)
Adds the value to the left of the addition operator to the value to the right
of the operator.
Subtraction (-)
Subtracts the value to the right of the operator from the value to the left of
the operator.
Multiplication (*)
Multiplies the value to the left of the operator by the value to the right of
the operator.
Division (/)
Divides the value to the left of the operator by the value to the right of the
operator.
USERS
GUIDE
59
PA RT
C R E A TI N G
R E P O R T S
CAT
Joins the data in two fields with a string storage type into one string of
characters. CAT stands for concatenate, and is symbolized by the pound
(#) sign when displayed in an expression. You may want to use the CAT
operator in conjunction with the STRIP function so that only the data in
each field is displayed, and not empty blanks following the data.
The following operators are enabled only when youre creating conditional
expressions.
Equality (=)
Indicates that if the two values to either side of the operator are equal, the
expression is true.
Inequality (<>)
Indicates that if the values to either side of the operator arent equal, the
expression is true.
AND
Joins a series of expressions within a conditional expression. All of the
expressions joined by an AND operator must be true for the entire
expression to be true.
OR
Joins a series of expressions within a whole condition or restriction. Only
one of these expressions must be true for the entire expression to be true.
60
U S E R S
G U I D E
C H A P T E R
C AL C U LA T ED
F IE LD S
NOT
Reverses the meaning of the expression following it. For example, the
following expressions are written differently but have the same result:
NOT(Account Balance < 5000)
Account Balance >= 5000
Fields tab
The Fields tab contains two drop-down lists: Resources and Field. Once a
resource is selected, the Field drop-down list is enabled, displaying all
available choices of the selected resource type. If there are no values for the
selected resource type, the Field drop-down list will remain disabled.
The Resources drop-down list always begins with four system entries:
Report Fields, Calculated Fields, RW Legends, and Globals. These are
followed by the name of each table associated with the current report. If a
table name is selected, each field in that table will be listed in the Field
drop-down list. The following describes each system entry, and what
appears in the Field drop-down list if that entry is selected.
Refer to Chapter 10,
Modifying Fields, for
information about
using the Report Field
Options window to
change a fields display
type.
Report Fields
Report Fields fills the Field drop-down list with all fields on the report that
have modified display types (fields for which the Report Field Options
window has been used to change the fields display type from Data to some
other type, such as Count). The display type, or an abbreviation of the type,
is listed first, followed by the name of the field to which it was applied. Use
the Report Field Options window to change a fields display type.
Calculated Fields
Calculated Fields fills the Field drop-down list with all calculated fields the
current calculated field can reference. Under special circumstances,
dependencies between calculated fields can that prevent them from being
used by the current calculated field. If a calculated field cant be used, it
wont be displayed in the list.
Refer to Chapter 9,
Legends, for more
information about
using legends in
reports.
RW Legends
RW Legends fills the Field drop-down list with one selection: Legend.
Selecting this value allows you to use one of the legend values passed into
the report by the application. When you click Add, a dialog box will appear,
prompting you to enter an index value indicating which legend value to
use. The legend will be added to the expression youre creating.
USERS
GUIDE
61
PA RT
C R E A TI N G
R E P O R T S
A legend is passed into the calculated field as a string. If you need the legend value
to have some other storage type, you will need to use one of the system-defined
functions to convert the legend value. System-defined functions are described in
System-defined functions on page 64.
Often, legends are used in a calculated field to specify the array index of an
array field. The following procedure describes how to use a legend to
specify the array index in a calculated field.
1. Add an array field to the expression.
Select an array field to add to the expression and click Add. A dialog
box will appear, prompting you to enter the array index. Enter any
number, then click OK.
2. Remove the array index.
Highlight the newly-entered index number in the expression, and then
click Remove.
3. Insert the appropriate conversion function.
Click the Functions tab, and select the STR_LNG system-defined
function. Click Add. This function will convert the legend (a string
value) value into a long integer so it can be used as the array index.
4. Add the legend.
Click the Fields tab. Select RW Legends from the Resources drop-down
list, and Legend from the Field drop-down list. Click Add; you will be
prompted to enter the array index. Enter the number corresponding to
the position of the desired legend value. For example, if four legend
values are passed to the report, enter an index of 1 to specify the first
legend, 2 to specify the second, and so on.
The value you passed to the first legend will specify which array element
value to display. If the value 1 is passed to the first legend, the first quarters
bonus value is displayed. If the value 2 is passed to the legend, the second
quarters value is displayed, and so on.
Globals
Globals populates the Field drop-down list with all of the fields declared as
global variables in the current dictionary.
62
U S E R S
G U I D E
C H A P T E R
C AL C U LA T ED
F IE LD S
Constants tab
Constants are values you set. Typically, they are used in the True Case and
False Case fields, or as a value against which fields are compared in the
expression. This tab contains two fields: the Type drop-down list and the
Constant field.
The Type drop-down list contains five choices: Integer, Currency, String,
Date, and Time. The value you are allowed to enter in the Constant field
depends on the constant type selected. For example, if you select Integer as
the constant type, you will be able to enter only numeric values in the
Constant field.
The following expression shows the use of two different constant types. The
12:00:00 PM value is a constant of the Time type, while the True Case and
False Case fields values of Morning and Afternoon are String type
constants.
Functions tab
Within the Functions tab, you must select the type of function you want to
use, either System-Defined or User-Defined. System-Defined is the default.
Depending on which type of function is selected, one or two drop-down
lists will appear below the radio group. If System-Defined is selected, the
Function drop-down list will appear, allowing you to choose one of the
predefined functions. If User-Defined is selected, two drop-down lists will
appear, Core and Function. To select a function youve created, you must
first select the core with which the function is associated. You can then
select the desired user-defined function from the Function drop-down list.
Many of the system-defined functions convert a fields storage type. For example,
the CUR_STR function converts a currency control type field to a string control
type field. The conversion doesnt affect the way the field is stored in the table, only
how its data is evaluated in the calculated or conditional expression.
USERS
GUIDE
63
PA RT
C R E A TI N G
R E P O R T S
System-defined functions
To use system-defined functions in expressions, select a function from the
drop-down list and click Add. Then, from the Fields tab, select the field you
wish to use with the function and click Add. The field will appear in the
expression, enclosed in parentheses.
You cant apply one system-defined function to another, or nest one
function within another. For example, if youre using the
CUR_STR function to convert a currency field to a string, you cant use the
STRIP function to remove extra spaces from the same field. For example,
the following is not permitted:
STRIP (CUR_STR ( Beginning Balance ) )
If the field you want to create requires using two system-defined functions,
first create a calculated field using the first function, then create another
calculated field that applies a second function to the first calculated field, as
in the following example:
Calculated field 1
Calculated field 2
CUR_STR
Converts a field with a currency storage type to a string.
DAY
Takes a date value and returns the day portion of the date. The integer
value returned will range from 1 to the maximum number of days in the
month.
DAY_NAME
Takes a date value and returns a string containing the name the day of the
week for the date value.
64
U S E R S
G U I D E
C H A P T E R
C AL C U LA T ED
F IE LD S
DOW
Takes a date value and returns an integer representing the day of the week
the specified date falls on. The following table lists the integer values and
the corresponding day:
Integer value
Day
Sunday
Monday
Tuesday
Wednesday
Thursday
Friday
Saturday
INT_STR
Converts a field with an integer storage type to a string type.
LFT_STR
Prints only the data that lies to the left of the caret (^) in a field with a string
storage type. If there is more than one caret in the field, the function will
print only the characters to the left of the leftmost caret. The caret must be
part of the field, not part of a format applied to the fields data type. If there
is no caret in the string, the entire string will be printed, provided enough
space is allocated in the layout area.
LNG_STR
Converts a field with an integer or long integer storage type to a string type.
MONTH
Takes a date value and returns the month portion of the date. The integer
value returned will range from 1 to 12.
MONTH_NAME
Takes a date value and returns a string containing the name of the month
for the date value.
POWER_10
Multiplies 10 to the power specified as this functions parameter. For
example, the value of POWER_10(2) is 10 to the power 2, or 100. This
function is useful for dealing with currency fields and decimal placement.
USERS
GUIDE
65
PA RT
C R E A TI N G
R E P O R T S
RGT_STR
Prints only the data that lies to the right of the caret (^) in a field with a
string storage type. If there is more than one caret in the field, the function
will print all the characters to the right of the leftmost caret. The caret must
be part of the field, not part of a format applied to the fields data type. If
there is no caret in the string, no data will be printed.
STR_DAT
Converts a field with a string storage type to a date. The string of characters
you convert to a date must be in MM/DD/YY format. If the year listed is 35
or less, the year will be preceded by 20, so that the year will be 2035, for
example, instead of 1935.
STR_CUR
Converts a field with a string storage type to a currency type. The current
control panel settings for the currency symbol, thousands separator,
decimal symbol, and negative currency format will be used as the basis for
analyzing the string. If the string cannot be properly interpreted based on
the current control panel settings, it will be interpreted using the following
rules:
No currency symbol
The current control panel setting for the decimal separator
No thousands separator
A minus sign as the negative indicator at the beginning of the value
STR_LEN
Counts the number of characters, excluding blanks at the end of the string
of characters, in a field with a string storage type. Blanks within a string are
counted.
STR_LNG
Converts a field with a string storage type to a long integer. This function
can be used to compare a string field to a long integer field. Since Report
Writer cant compare two fields with different storage types, using the
STR_LNG function to convert the string field to a long integer field allows
you to compare it to other long integer fields.
66
U S E R S
G U I D E
C H A P T E R
C AL C U LA T ED
F IE LD S
STR_VCUR
Converts a field with a string storage type to a variable currency type. The
string will be interpreted using the following rules:
No currency symbol
The current control panel setting for the decimal separator
No thousands separator
A minus sign as the negative indicator at the beginning of the value
STRIP
Removes trailing blank spaces from fields with string storage types. The
STRIP function can be used with the CAT operator, but cant be applied to
an expression containing the CAT operator.
For example, the following expression is valid:
STRIP (Cust_Name) # " has this address: " # STRIP (Address)
SUBSTRING
Searches fields of the string storage type for a match of the specified string
pattern, regardless of whether that match occurs at the beginning of or
within the string field. Searches are case-sensitive.
Three special characters can be used in the search pattern: the asterisk (*),
the question mark (?), and the backslash (\), as indicated in the following
table.
Character
Any character
Any group of characters
No characters
USERS
GUIDE
67
PA RT
C R E A TI N G
R E P O R T S
The following example checks the First_Name field for all names
containing the letter t separated from the letter n by one other
character. Names that would match this search include Astin, Barton,
and Antonette.
SUBSTRING ("t?n") = First_Name
UCASE
Prints the alphabetic characters in the specified string field in uppercase.
Numeric characters wont be affected.
68
U S E R S
G U I D E
C H A P T E R
C AL C U LA T ED
F IE LD S
WILDCARD
Searches fields of the string storage type for an exact match of the specified
string pattern. Searches are case-sensitive.
You can use the *, ?, or \ special characters to indicate the type of match
youre searching for. These special characters have the same effect as they
do with the SUBSTRING function.
Unlike the SUBSTRING function, this function does not implicitly add an
asterisk to the beginning and end of the pattern you specify. Therefore, this
function is useful when you want to search for strings that begin with a
certain character or set of characters.
The following example checks the First_Name field for all names beginning
with the letters To. Names that would match this search include Tony,
Tonya, and Tomas.
WILDCARD ("To*") = First_Name
The following example checks the Local_Businesses field for all stores
beginning with the string Tommys. Note that this search uses both the \
and * special characters. Business names that would match this search
include Tommys Pizzeria and Tommys Bait and Tackle Shop.
WILDCARD ("Tommy\'s*") = Local_Businesses
YEAR
Takes a date value and returns the year portion of the date. The integer
value returned will be a four-digit year, such as 2001.
User-defined functions
In addition to the system-defined functions, you can use functions that
have specifically been added to the application for use in calculated fields.
The names of user-defined functions intended for use in calculated fields
begin with the letters RW so they are recognized by the Report Writer.
A document with descriptions of the user-defined functions available for the Report
Writer is found in the Microsoft Dynamics GP SDK in the Procedures and
functions category. You can find the document by searching for Report Writer.
To add a user-defined function to an expression, select the core the function
is part of from the Core drop-down list. Once a core is selected, the Function
drop-down list will become active. You can then select the desired userdefined function from the Function drop-down list. Click Add to add the
function to the expression.
USERS
GUIDE
69
PA RT
C R E A TI N G
R E P O R T S
70
U S E R S
G U I D E
Chapter 8:
USERS
GUIDE
71
PA RT
C R E A TI N G
R E P O R T S
USER CLASSES
User Class:
Administrator
User ID
Margaret
Tracy
Data entry
Report body
Additional footer
Supervisor
User ID
Bill
Juanita
Julie
Kim
User ID
Rahul
Dan
Steve
72
U S E R S
G U I D E
C H A P T E R
AD DI TI O N AL
H EA D ER S
A N D
FO O T E R S
You can specify where an additional header or footer should appear. In the
Report Section Options window, highlight the additional header or footer
that should appear directly above the one youre adding, then create the
section as usual.
If you arent satisfied with the order of your additional headers or footers, you must
delete the header or footer you want to move, then re-create it in the desired
location.
Be sure to consider the reports sorting order when determining the
placement of your additional headers and footers. Remember that an
additional header or footer prints when the data in the field its based on
changes. For example, if the field that Header 2 is based on changes before
the field that Header 1 is based on, Header 2 will print first. Therefore, if
you always want Header 1 to appear before Header 2, be sure that the field
you base Header 1 upon appears in the sorting order before the field
Header 2 is based on.
USERS
GUIDE
73
PA RT
C R E A TI N G
R E P O R T S
74
U S E R S
G U I D E
C H A P T E R
AD DI TI O N AL
H EA D ER S
A N D
FO O T E R S
USERS
GUIDE
75
76
U S E R S
G U I D E
Chapter 9:
Legends
Legends are fields you can add to your report to display information that is
passed to the report when it is printed. Typically, legends are used to
display string values representing the sorting and restriction options
selected by the user running the report. Legend values can also be used as
elements in calculated fields.
Since legend values must be passed into the report by the application, they
are generally available only for modified reports. Any new reports you
create wont be able to use legends, unless you have Visual Basic for
Applications (VBA) and have set up scripts that set the legend values.
Information about legends is divided into the following sections:
Using legends
Legends example
Using legends
To add legends to the Report Layout area, follow these steps:
1. Select Legends from the drop-down list in the Layout tab of
the Toolbox.
The scrolling window below the list will be filled with the word Legend
followed by an array index (such as Legend[1] and Legend[2]).
2. Drag a legend to the layout area.
Add legends to the report layout area sequentially, beginning with
Legend[1]. You can add the same legend to report multiple times if you
want that legends value to appear in multiple locations on the report.
If you dont have specific information about the values passed into legends for a
report, you can find out how the legends are used. Add the legends to the report
layout and print the report. If legend values are passed into the report, they
will be printed on the report.
3. Add additional legends to the layout area.
You can add up to 255 legends the layout area. Add the first 30 legends
by selecting a legend from the scrolling window in the toolbox and
dragging it to the layout area.
USERS
GUIDE
77
PA RT
C R E A TI N G
R E P O R T S
To add additional legends, drag a legend from the toolbox to the layout
area, and double-click it to open the Report Field Options window. Use
this window to change the array index of the legend. To change the
array index, change the value of the Array Index field to appropriate
index number, and click OK.
Be sure to resize each of your legends to accommodate the largest amount of
information that could be included in it. If legends arent sized properly,
information will be truncated.
Legends example
The following illustration shows the Item List report. This report uses
legends to list the ranges of items that are included in the report. It also uses
a legend to indicate how items are sorted. Two other legends are used to
indicate whether discontinued items and vendor information are included
in the report.
78
U S E R S
G U I D E
Chapter 10:
Modifying Fields
Fields in the report layout can be modified in three ways: a format can be
applied to them, their visibility setting can be altered, and their display type
can be changed. Use the Report Field Options window, shown in the
following illustration, to make these modifications.
Field visibility
Specifying a format resource
Specifying a format field
Changing display types
Display type summary
Field visibility
Fields in the report layout area can have their visibility set to one of three
options: visible, invisible, and hide when empty. Fields added to the layout
area are automatically set to visible.
Visible fields are always displayed on the report, even if the field is blank
for a given record. If a visible field is blank but has a format applied to it,
the formatting will be displayed on the report without any data. For
example, a ZIP code field could be formatted to include a dash between the
fifth and sixth characters. If this field is included on a report and is visible,
and a given record has no ZIP code data, only a dash will appear in the ZIP
code field for that record on the report.
USERS
GUIDE
79
PA RT
C R E A TI N G
R E P O R T S
A hide when empty field will not be included on a report for a specific
record if the field is blank. For example, if a customer record doesnt
include a telephone number, and the phone number field is marked as hide
when empty, then for that customer record, the empty phone number field
and any related formatting wont be included on the report.
Selecting hide when empty prevents formatting from appearing on a report when
the field contains no data.
An invisible field will never be shown on the report output. When a field is
invisible, it will appear in the report layout in gray with a dashed border, as
shown in the following illustration:
Commonly, fields are marked as invisible when their values are needed for
use in calculated fields, but are not needed for display on the report. For
example, you may want to display a field on the report showing the
difference between the highest and lowest values of specific field. To
accomplish this, add the field to a footer in the report layout twice. Change
the display type of one instance to Minimum, and the display type of the
other to Maximum. Then, create a calculated field that subtracts the
minimum value from the maximum value. Since only the calculated field
needs to be displayed on the report, set the visibility of the minimum value
and maximum value fields to invisible.
80
U S E R S
G U I D E
You can apply formats created with the Format Definition window to
string, currency, composite, and numeric fields that appear in the report
layout. To apply a format to a field, click the Format lookup button in the
Report Field Options window to display a list of formats that can be
applied to the field. Select a format in this list, or click New to create a new
format. When you have finished, the name of the format applied will
appear in the Format field in the Report Field Options window.
C H A P T E R
1 0
M O D IFY IN G
F IE LD S
The formatting displayed for certain string and currency fields in Microsoft
Dynamics GP is based on the value of an integer field called a format field.
You specify a format field to use by selecting a field in the Format Field list
of the Report Field Options window. The integer value contained in the
selected format field specifies how to format the report field.
Dont apply a specific format to a report field and use the Report Field Options
window to specify a format field for the same report field; the format results will be
unpredictable.
Format
Integer
Format
10
$1,234.567
1,234
11
$1,234.5678
1,234.5
12
$1,234.56789
1,234.56
13
1,234%
1,234.567
14
1,234.5%
1,234.5678
15
1,234.56%
1,234.56789
16
1,234.567%
$1,234.
17
1,234.5678%
$1,234.5
18
1,234.56789%
$1,234.56
The integer value used to indicate the format used can be stored in a table
along with the currency field being formatted. When the record is retrieved
from the table, the currency field will display as it did when the record was
saved. The format field can also be used for a report, allowing the currency
field to appear in the report as it did when it was saved in the table.
Microsoft Dynamics GP can define its own formats, in addition to those shown in
the previous table. This capability is used to define currency format information for
multicurrency support.
USERS
GUIDE
81
PA RT
C R E A TI N G
R E P O R T S
82
U S E R S
G U I D E
A field in the report layout can have its display type changed to alter the
way in which data is displayed in the field. For example, you can add the
invoice_total field to the body of a report, then add it again to the reports
footer. By changing the display type of the invoice_total field located in the
report footer to Sum, that field will not display a specific invoices total.
Instead, it will display the sum of all instances of the invoice_total field
displayed in the body.
C H A P T E R
1 0
M O D IFY IN G
F IE LD S
To change a fields display type, select the desired type from the Display
Type list in the Report Field Options window. The following describes each
display type, including information about the storage types each type can
or cant be used with:
Average
Prints the average value of the data printed in a group or on a report. This
display type should not be used with fields having string, date, or time
storage types.
Control Count
Prints the number of times the additional footer immediately above the
footer containing the Control Count field is printed on a report. The Control
Count display type can be used only when youre printing information in
groups using additional footers. This display type should not be used with
fields having date or time storage types.
Count
Prints the number of times a field is printed in a group or on a report. This
display type can be used with fields of all storage types. If youre printing a
report with groups and counting categories, use the Control Count display
type instead.
Data
Prints data without modifications, as its stored in the table. All fields in the
body of the report whose display types have not been modified have the
display type Data. Calculated fields placed in footers should have their
display type changed from Last Occurrence to Data, so that the calculations
will perform properly. This display type can be used with fields of all
storage types.
The Report Writer allows you to assign the Data display type to fields other than
calculated fields in a footer; however, calculated fields are the only fields that should
have the Data display type in a footer. The Report Writer sets the default display
type for fields placed in footers to Last Occurrence. The Sum display type is another
display type commonly used in footers.
USERS
GUIDE
83
PA RT
C R E A TI N G
R E P O R T S
Last Occurrence
Prints the last value of the field that was printed in a group or on a report. It
also can be thought of as the current occurrence. All fields placed in footers
are automatically assigned a Last Occurrence display type. Calculated
fields placed in footers should have their display type changed from Last
Occurrence to Data, so that the calculations will perform properly. This
display type should not be used with fields having date, time, or text
storage types.
Maximum
Prints the greatest value of the field that was printed in a group or on a
report. This display type should not be used with fields having string, date,
or time storage types.
Minimum
Prints the smallest value of the field that was printed in a group or on a
report. This display type should not be used with fields having string, date,
or time storage types.
Previous Occurrence
Prints the value of the field printed immediately before the last occurrence
in a group or on a report. This display type should not be used with fields
having date or time storage types.
Running Sum
Prints the total of the fields values at the point where the field is placed
within the entire report. This display type should not be used with fields
having string, date, or time storage types.
Sum
Prints the sum within a group or on a report. This display type should not
be used with fields having string, date or time storage types.
84
U S E R S
G U I D E
C H A P T E R
1 0
M O D IFY IN G
F IE LD S
Average
Control Count
X
X
Report Footer
Page Footer
X
Count
Data
Additional Footers
Body
Additional Headers
Page Header
Report Header
The following table indicates which display types can be used in the
various sections of a report.
X
X
Last Occurrence
Maximum
Minimum
Previous Occurrence
X*
Running Sum
Sum
You can use a First Occurrence Only display type in the body of a report if
one of the following conditions in true:
The field is in the selected key for the main table of the report.
If you use an alternate sorting definition for the report, the field must be
one of the segments in the sorting definition.
The value of any report fields you use in the page header or page footer,
such as Average or Sum, will be based on records used for the body of the
report. They wont take into account records used for additional headers or
additional footers.
USERS
GUIDE
85
86
U S E R S
G U I D E
88
U S E R S
G U I D E
Chapter 12, Table Relationships, explains how to create and use table
relationships to gather data to use in a report.
Chapter 13, Virtual Tables, describes virtual tables and how to use
them for reports.
Chapter 11:
Data Storage
This portion of the documentation describes how data is stored in Microsoft
Dynamics GP. It also describes how to determine which tables you need to
use to gather the data for your report. Information is divided into the
following sections:
Terminology
Table names
Table types
Table groups
Terminology
The following terms describe the basic parts of a database. You should
become familiar with these terms to better understand how the accounting
system stores data.
Fields A field represents one category of information that can be stored in
a table, such as a customer name or a customer address. For instance, if you
were to track customer names and addresses, you could use the following
fields:
Fields
Customer ID
Customer
Name
Address
City
State
USERS
GUIDE
89
PA RT
G A T H E R I N G
D A TA
Customer ID
Record
Customer
Name
Address
City
State
C1002
Jean
Thompson
Kansas
City
C1392
Serge
Lemieux
11 Ash Lane
Edmonton
AB
C4432
Dan Smith
239 Hampton
Village
Fargo
ND
C4499
Cheryl Miner
9800 Woodland
Drive
Springfield
IL
MO
Customer ID
Customer
Name
Address
U S E R S
G U I D E
State
C1002
Jean
Thompson
Kansas
City
C1392
Serge
Lemieux
11 Ash Lane
Edmonton
AB
C4432
Dan Smith
239 Hampton
Village
Fargo
ND
C4499
Cheryl Miner
9800 Woodland
Drive
Springfield
IL
Table
90
City
MO
C H A P T E R
1 1
D A T A
S T O R A G E
Customer
Name
Address
City
State
Customer ID
Key 2
Record
Customer
Name
Address
City
State
C1002
Jean
Thompson
Kansas
City
C1392
Serge
Lemieux
11 Ash Lane
Edmonton
AB
C4432
Dan Smith
239 Hampton
Village
Fargo
ND
C4499
Cheryl Miner
9800 Woodland
Drive
Springfield
IL
MO
Table
USERS
GUIDE
91
PA RT
G A T H E R I N G
D A TA
This table has five fields: Customer ID, Customer Name, Address, City, and
State. It also has four records, each containing one Customer ID, Customer
Name, Address, City, and State field. The table has two keys. The first key is
composed of the Customer ID field. Because no two customers can have the
same Customer ID, this key ensures each customer is uniquely identified.
The second key is composed of the Customer Name field. This key allows a
customer record to be easily located, based upon the customers name.
Table Groups A table group is a group of logically-related tables. For
example, a customer master table, a customer address table, and a customer
history table all compose a table group. Every table in Microsoft Dynamics
GP is part of a table group.
Table names
You can use the Table
Descriptions window
to find the names of
tables.
Each table has three names: a display name, a technical name, and a physical
name.
Display name The display name is the name you see in a window, such
as Rebuild or Pathnames.
Technical name The technical name is used internally to refer to the
table.
Physical name The physical name is the name under which the table is
stored by the operating system or database.
The following table lists three names for one of the tables that stores
account category information.
92
U S E R S
G U I D E
Display name:
Technical name:
GL_Account_Category_MSTR
Physical name:
GL00102
C H A P T E R
1 1
D A T A
S T O R A G E
Table types
To work with the Microsoft Dynamics GP database, you need to know some
specific information about tables in the database. Most of the information
youll need to access when creating reports will be stored in one of the
following types of tables. Knowing which type of table contains the
information you want will help you find the data you need.
Setup tables contain all the default settings and module options youve
specified in the setup windows for each series.
Master tables contain all the permanent data about your business. These
may include information about accounts, vendors, customers, items, and so
on.
Work tables contain unposted batches of transactions entered using
transaction windows in the system. These transactions are temporary and
can be changed or deleted until they are posted to an open table.
Open tables contain posted transactions for the current year, of which
some may be unpaid. Information in open tables is moved to history tables
when the transactions are paid.
History tables contain paid transactions, or transactions from a previous
year.
Table groups
To create a report, you need to decide which tables data will come from. If
all the data for your report is stored in a single table, you can select the table
as the main table for the report and begin creating your report.
If a single table doesnt contain all the data you need for your report, you
must choose one table as the primary table, and then link additional tables
to it. You can select either the table that contains the majority of the fields
for your report or the table that contains the most general information as
your main table. Once youve selected a main table, link other tables to that
table as needed.
USERS
GUIDE
93
PA RT
G A T H E R I N G
D A TA
Transaction
Work
table
Transaction
Amounts
Work
table
Transaction
Clearing
Amounts
Work
table
Audit
Trail
Code
Temporary
table
In some cases, a table group will contain only one table. For many system
tables, the table group is made up of a single table with the same name as
the table group.
You can use the Software Development Kit (SDK) to find additional information
about tables in Microsoft Dynamics GP.
94
U S E R S
G U I D E
Chapter 12:
Table Relationships
Table relationships allow the Report Writer to gather data from related
tables and use the data in a single report. Information about table
relationships is divided into the following sections:
USERS
GUIDE
95
PA RT
G A T H E R I N G
D A TA
Customer_Master
one-to-one
relationship
Cust_ID
Name
Cust_ID
City
State
0001
Greg Wilson
0001
Valhalla
NY
0002
Pam Anderson
0002
Indianapolis
IN
0003
Jose Martin
0003
Phoenix
AZ
Customer_Master
one-to-many
relationship
Invoice_Data
Cust_ID
Name
Invoice_ID
Cust_ID
Invoice_Total
0001
Greg Wilson
31-1964
0001
223.75
0002
Pam Anderson
65-1296
0003
658.20
0003
Jose Martin
77-4538
0001
439.50
96
U S E R S
G U I D E
C H A P T E R
1 2
T A B L E
R E L A T I O N S H I P S
USERS
GUIDE
97
PA RT
G A T H E R I N G
D A TA
98
U S E R S
G U I D E
C H A P T E R
1 2
T A B L E
R E L A T I O N S H I P S
USERS
GUIDE
99
100
U S E R S
G U I D E
Chapter 13:
Virtual Tables
Virtual tables are special types of tables that allow data stored in separate
tables to be read as if it had been stored in a single table. Information about
virtual tables is divided into the following sections:
USERS
GUIDE
101
PA RT
G A T H E R I N G
D A TA
102
U S E R S
G U I D E
104
U S E R S
G U I D E
Chapter 14:
In this example, the report name is SOP Blank Back Order Form.
The sample reports included with Microsoft Dynamics GP are another excellent
source to learn about the reports included with the accounting system.
USERS
GUIDE
105
PA RT
M O D I F Y I N G
R EP O R T S
106
U S E R S
G U I D E
C H A P T E R
1 4
S E L EC TI N G
R E P O R T
T O
M O D I F Y
You can also click the Modify button to open the current report in the
Report Writer.
USERS
GUIDE
107
108
U S E R S
G U I D E
Chapter 15:
USERS
GUIDE
109
PA RT
M O D I F Y I N G
R EP O R T S
110
U S E R S
G U I D E
C H A PT E R
1 5
VI EW ING
MODI FI ED
R EP O RT
USERS
GUIDE
111
112
U S E R S
G U I D E
Chapter 16:
Common Modifications
Modifying existing reports is the most common task performed with the
Report Writer. This portion of the documentation describes some of the
common modifications, provides information about how to perform them,
and describes where you can access reports that have already been
modified. Information is divided into the following sections:
USERS
GUIDE
113
PA RT
M O D I F Y I N G
R EP O R T S
Adding fields
If the tables that contain the necessary fields are already part of the report,
adding fields to the report layout is as simple as dragging them from the
Toolbox to the Layout window. Just select the appropriate table in the
Toolbox and drag the fields to the appropriate section of the report layout.
If the necessary tables arent linked to the tables already used for report,
you will need to link them. Linking tables is described in Creating a new
report definition on page 19. If the appropriate table relationships arent set
up between the tables you need to link to your report, you will need to
create the relationships. This is described in Chapter 12, Table
Relationships.
The Knowledge Base at https://mbs.microsoft.com/CustomerSource contains
several entries that describe how to add specific fields to common reports.
114
U S E R S
G U I D E
C H A PT E R
1 6
C O M M O N
M O D I F I C A TI O N S
Removing fields
If a report contains fields you dont need, you may want to remove them
from the report layout. To ensure that the report continues to work
properly, we recommend that you dont remove fields from the report.
Rather, we suggest that you set the Field Options for the report to make the
field invisible.
Refer to the VBA Developers Guide for complete information about using
VBA with the Report Writer.
USERS
GUIDE
115
PA RT
M O D I F Y I N G
R EP O R T S
Reports Library
The Reports Library is a special area of the Microsoft Dynamics web site
that contains reports which have already had common modifications made
to them. Most of the reports available are graphic reports. You can access
the Reports Library at the following address:
https://mbs.microsoft.com/customersource/support/downloads/
reportslibrary/
Browse the Reports library and download the reports you want. Most of the
reports in the Reports Library are modified versions of existing reports. To
install a report from a package file, follow the procedure described in
Importing a package file on page 185. After you have used the Customization
Maintenance window to install the reports, use the Alternate/Modified
Forms and Reports window to provide access to them. Setting security for
modified reports is described in Chapter 31, Accessing Reports.
116
U S E R S
G U I D E
118
U S E R S
G U I D E
Chapter 17, Data Types, describes data types and how they control
characteristics of fields.
Chapter 18, Formats, describes how formats are used to control how
data appears when printed on reports.
Chapter 17:
Data Types
Data type resources specify the characteristics of all fields used in an
application. If you want to change the characteristics of a field, you need to
change its corresponding data type. Keep in mind that a single data type
can be used by multiple fields. When you change the data type, you change
the characteristics of all the fields that use it. Information about data types
is divided into the following sections:
The data types name appears at the top of the window. The Control Type
field specifies the function of the data type, indicating how it will display
and store data. The other fields in the window specify the additional
characteristics of the data type. The following sections describe the data
type characteristics you can change with the Report Writer.
USERS
GUIDE
119
PA RT
G L O B A L
M O D I F I C A TI O N S
Keyable length
The keyable length is the number of characters that can be displayed in a
field that uses this data type. Control types such as currency, integer, and
string have a keyable length. You can use the Report Writer to change the
keyable length. For example, you may want to increase the keyable length
for the STR10_Phone data type to allow the user to enter more digits. The
following table lists control types for which you can set the keyable length.
Control type
Combo box
Storage Size - 1
Currency
19
Integer
Long integer
10
String
Storage Size - 1
Text
32,000
Static values
Certain control types allow you to specify static values for the data type.
Static values are any text or pictures associated with a data type that are
displayed by a field using that data type. For example, the text on a push
button and the items in a list box are static values. To view the static values
for a data type, click the Static Values lookup button.
The following table lists the control types that use static text values which
can appear on reports.
Control type
120
U S E R S
G U I D E
Drop-down list
List box
Visual switch
C H A P T E R
1 7
DA TA
T Y P E S
The Static Text Values window is used to specify the static text for dropdown lists, list boxes, and visual switches.
To edit a static text value, select it in the Static Text Values list. Make the
appropriate changes in the New Value field, then click Replace.
Format
A format contains extra characters, spacing, and attributes that can be
applied to a data type when data is printed on a report. Refer to Chapter 18,
Formats, for more information.
USERS
GUIDE
121
122
U S E R S
G U I D E
Chapter 18:
Formats
Formats are the extra characters, spacing and attributes that can be applied
to a data type to format data when it is displayed or printed on a report. For
example, a string data type for a phone number can have a format applied
to it so a field using the data type will print a phone number as (555) 1234567 instead of 5551234567.
Formats are stored as separate resources, but are applied to data types to
help define how information is displayed. A single format resource can be
used by several data types. Perhaps the easiest way to understand what
formats are is to view them as data masks that simply change the look of
the information in a field without changing the actual information itself.
Information about formats is divided into the following sections:
Opening a format
Formatting options
Format string
Opening a format
To open a list of formats, choose Formats from the Resources menu. The
Formats window will appear. To create a new format, click New. To open an
existing format, select one in the list and click Open. The Format Definition
window will appear, as shown in the following illustration.
The format name is
entered here.
Each format has a name. Typically, the name indicates the data type the
format is applied to. For instance, the name STR_Employer_ID_Number
indicates a format that will be applied to a data type used for an Employer
ID number.
USERS
GUIDE
123
PA RT
G L O B A L
M O D I F I C A TI O N S
Formatting options
You can use several formatting options to change how specific types of data
will appear. You can use them to specify the following characteristics:
Negative Symbol
Alignment
Fill
Unsigned
Show Thousands
Separator
Currency formats
124
U S E R S
G U I D E
Decimal Digits
Negative Symbol
Alignment
Fill
Unsigned
Show Thousands
Separator
Relative Decimal
Position
Show Currency
Symbol
C H A P T E R
1 8
FORM AT S
Fill
Trailing Blanks
If marked, any spaces that follow the contents of the field will
be saved in the table. If the option isnt marked, any spaces
following the item in the field wont be saved. Leave unmarked
to ensure that the same entry made with or without trailing
blanks will be stored with the same value.
Leading Blanks
Numeric Only
Alphanumeric Only
Uppercase Only
Format string
The Format Definition window allows you to specify a format string for
string and composite data types.
String formats
Format strings are used with string data types to add static elements to a
field, such as parentheses or static text. The Report Writer uses the capital X
as a placeholder to represent alphanumeric characters that will appear in
the field. All other characters will be displayed as you type them.
Example 1
For instance, suppose youre using a specific data type to store information
entered in phone number fields. This Phone_Number data type uses a
format and a format string to determine how phone numbers will appear
on a report:
Format string
Data entered
Data displayed
(XXX) XXX-XXXX
7015550100
(701) 555-0100
ext. XXXX
6590
ext. 6590
USERS
GUIDE
125
PA RT
G L O B A L
M O D I F I C A TI O N S
The Xs are placeholders indicating where the digits will be displayed, while
the parentheses and dash are displayed just as you typed them. Also note
that a lowercase x is used in the ext. abbreviation in the second format
string. Only uppercase Xs are treated as placeholders, so the lowercase x is
displayed in the field, instead of being replaced when data is entered.
Static characters in a format string arent actually stored with the data in the table.
This allows you to change the format string without affecting how data is stored.
Composite formats
A format string is used with a composite data type to indicate the size and
order of the components of the composite, and to add static elements, such
as parentheses or static text. The numeric characters 1 through 9 are used to
represent the characters of each component of the composite. All other
characters will be displayed just as you type them.
Not all composites use a format string. Some composite fields, such as the Microsoft
Dynamics GP Account Number, have their format defined through program code.
Example 2
The following example shows the use of a format for a standard composite.
A composite must have a format and a format string. This composite
contains three parts, as indicated by the format string.
Format string
Data entered
Data displayed
1111-22-3333
1000ND5050
1000-ND-5050
126
U S E R S
G U I D E
Chapter 19:
Global Fields
Fields represent the individual pieces of information in an application.
They can appear in windows, be stored in tables, and appear on reports.
Each field uses a data type to specify its characteristics. Information about
global fields is divided into the following sections:
You can also open the Global Field Definition window from the Layout
window. Choose the name of a table in the Toolbox to display the fields
from that table. Select a field name in the list and click Open.
USERS
GUIDE
127
PA RT
G L O B A L
M O D I F I C A TI O N S
128
U S E R S
G U I D E
Chapter 20:
Pictures
Pictures are typically used to display large graphics and logos in reports.
The Report Writer can convert Windows metafiles to a form that can be
stored in the picture library. Pictures up to 32K in size can be stored. Pictures
are stored only once, but can be placed in several reports by using the
picture tool from the Toolbox in the Layout window.
Information about pictures is divided into the following sections:
USERS
GUIDE
129
PA RT
G L O B A L
M O D I F I C A TI O N S
130
U S E R S
G U I D E
C H A P T E R
2 0
P IC T U R E S
In the Report Writer, the graphic will become a bitmap. To find out how
the graphic will appear when printed, try printing it from a paint
application such as Windows Paint.
Make the graphic as large as possible, staying within the 32k limit. This
allows the graphic to contain maximum detail. When you add the
graphic to a report, it will be very large. Scale the graphic down to the
desired size.
For example, the following illustration shows the Microsoft logo that
was added to a report in the Report Writer. The logo is black and white,
and is 1580 pixels wide and 267 pixels tall. After adding the logo, it
appeared at full size.
Once the logo was added to the report, the resize handles on the
graphic were used to reduce the size of the illustration to 2 inches wide,
or 144 pixels. This is shown in the following illustration.
USERS
GUIDE
131
PA RT
G L O B A L
M O D I F I C A TI O N S
You can use the horizontal and vertical size indication in the Toolbox to
maintain the aspect ratio of the logo when you reduce its size. For
example, when the Microsoft Business Solutions logo was reduced
from 1580 to 144 pixels wide, the corresponding height was reduced
from 267 to 25 pixels.
132
U S E R S
G U I D E
Chapter 21:
Strings
A string is a sequence of up to 79 characters that doesnt contain carriage
returns. Strings are used throughout the accounting system for window
names, field prompts, static text values, and text that appears in reports.
Information about strings is divided into the following sections:
Using strings
Modifying a string
Using strings
The strings resource allows you to update all occurrences of a string in one
step instead of changing the same string in each place it occurs.
For example, to change all occurrences of the words Customer Name to
Client Name, you could select the Customer Name string and change it to
Client Name instead of changing each individual text value.
Note that changing a string with the Report Writer will change it only for reports.
The string wont be changed in any windows in the accounting system. To change
strings in windows, you must use the Modifier.
Modifying a string
Choose Strings from the Resources menu. The Strings window will open,
allowing you to select the string to edit.
The Microsoft Dynamics GP dictionary contains several thousand strings. The
Strings window may take a few moments to open.
1. Select the appropriate dictionary core.
String resources are divided into several cores, which are special
divisions in the dictionary. Microsoft Dynamics GP has a core for each
major module category. When locating a string, begin by choosing the
core that the string is most likely contained in. For example, the string
Customer is likely part of the Sales core, so begin looking there. If
you dont find a string in a particular core, look in the other available
cores.
USERS
GUIDE
133
PA RT
G L O B A L
M O D I F I C A TI O N S
134
U S E R S
G U I D E
Chapter 22:
Tables
Tables store data generated and used by applications. Tables use several
elements to store and access information properly, such as fields, keys and
table relationships. Information about tables is divided into the following
sections:
Table elements
Keys
Key segments
Key options
Segment options
Table elements
Each table has several names, a series, database type, table fields, keys, key
options, segment options, and table relationships. Use the Table Definition
window to view information about tables.
You can also use the Resource Descriptions tool to view information about tables.
Names
Three names are required for each table. The table name is the name that is
used in scripts to refer to the table.
The display name is the name that appears when the name of the table is
displayed on the screen in an application.
The physical name is the name under which the table is stored by the
operating system or database. The appropriate extension, if required, is
added automatically.
Table series
The table series groups related tables in the application together using
series categories like Sales, Financial, and System.
Database type
Tables can use the following database types: c-tree Plus, Pervasive.SQL, and
Microsoft SQL Server. If the setting Default is used, the application will
determine which database type to use at runtime, based upon several
system settings
USERS
GUIDE
135
PA RT
G L O B A L
M O D I F I C A TI O N S
Table fields
These are the fields that are stored in the table. The Record Size field in the
Table Definition window contains the total size of each record in the table.
Table relationships
Table relationships link related tables that share common information. Table
relationships are required to allow the Report Writer to access information
from multiple tables for a single report. Refer to Chapter 12, Table
Relationships, for more information about creating and using table
relationships.
Keys
A key is a field or combination of fields in a table used to sort and locate
specific records in the table. Typically, the value of the key field or fields is
unique for each record in a table so a specific record can be located. You will
use the keys for a table when you specify how report information is sorted.
You will also use keys when you create table relationships to link related
tables together.
Key segments
The Key Definition window shows the fields that make up the keys used to
sort, store, and retrieve records in each table. Each field in a key is referred
to as a key segment. Each table can have multiple keys, and each key can
have multiple segments.
For example, a customer table typically would have two keys defined for it.
One key could contain the Customer Name field, because this is the field a
user would most likely use to search for a record. However, a customer
name may not be unique. For instance, there may be more than one John
Smith. To avoid this problem, each customer could be assigned a unique
customer ID. A second key composed of the Customer ID field could be
added to the table. This key would uniquely identify customers, even if
they have the same name.
The Key Segments list displays the list of fields that will be used as
segments in the key. Records will be sorted primarily according to the first
key segment. Records that are identical for the first key segment will be
sorted again by the second key segment. For example, if the Key Segments
list contains two segments: [last_name, first_name], in that order,
records will be sorted primarily by the last name, and records with the same
last name entry would be sorted again by the first name.
136
U S E R S
G U I D E
C H A P T E R
2 2
T AB LE S
Key options
The database type specified for a table determines which sets of key options
are available for each key. The following key options are important to
understand in the Report Writer:
Duplicates Specifies whether multiple records in the table can have the
same key value. If this option is marked, new records that have the same
key values as records already in the table can be saved. If the option isnt
marked, new records with the same key values as existing records wont be
saved.
When you create a table relationship based a key that allows duplicate records, you
are creating a one-to-many relationship.
Create Index If this option for SQL tables is marked, an index in the SQL
database will be created for the table based upon this key definition. The
index contains a copy of the data in the keys key segments and pointers to
the associated records in the table. An index allows data to be retrieved
from the table more quickly.
If Create Index is marked, the following options are available:
Unique Marking this option ensures that the records in this table will
have unique values for this key.
Clustered Marking this option sorts and physically stores the data in
the table according to the order defined by this key. For example, the
Customer table has a key based upon the Customer Name field. If this
key was based on the Customer Name field, and the Clustered option
were marked for the key, the data in the Customer table would be physically stored in the order indicated by the key. Only one key per table
can have the Clustered option marked.
Segment options
The segment options specify how the key will handle the contents of the
selected key segment.
Descending This option specifies the order in which the records will be
sorted. If the option is marked, records will be sorted in order of highest
value to lowest (3, 2, 1 or c, b, a). If the option isnt marked, records will be
sorted lowest to highest (1, 2, 3 or a, b, c).
USERS
GUIDE
137
PA RT
G L O B A L
M O D I F I C A TI O N S
138
U S E R S
G U I D E
adams
Beaulieu
Beaulieu
JOHNSON
douglas
Jones
hagelle
Simpson
JOHNSON
adams
Jones
douglas
Simpson
hagelle
140
U S E R S
G U I D E
Chapter 24, Mailing Reports, describes how to mail reports you have
created to other users.
Chapter 23:
Printing Reports
After you have created or modified a report, you will want to print and use
the report output. Information about printing reports is divided into the
following sections:
Refer to the documentation for each module for detailed information about
printing specific reports.
USERS
GUIDE
141
PA RT
P R I N T IN G
A N D
M A I L I N G
R E P O R TS
142
U S E R S
G U I D E
C H A P T E R
2 3
P R I N TI N G
R E P O R T S
Choose Customized to
open the Custom
Reports window.
USERS
GUIDE
143
PA RT
P R I N T IN G
A N D
M A I L I N G
R E P O R TS
Report security
To be able to print a report from within the Report Writer, you must have
been granted access to the report. This includes any custom reports the user
has created. If access isnt granted, the user will encounter a privilege
error when they try to display the report. Refer to Accessing modified reports
on page 178 and Accessing custom reports on page 179 for details about
granting access to reports.
If a user will be creating or modifying numerous reports in the Report Writer, you
may want to assign the user the POWERUSER security role. This role grants them
access to all of the custom reports they are creating.
Temporary tables
Most reports read data directly from tables in the database for the
accounting system. However, some reports retrieve their data from special
temporary tables that are created by the accounting system. Reports that
read data directly from tables in the database can be viewed and printed
from within the Report Writer. Reports that use temporary tables cannot,
because the Report Writer has no way to add data to temporary tables.
If you have selected the modified report in the Report Writer window, but
the Print button is disabled, the report uses temporary tables. This means
you cant print the report from within the Report Writer, and must return to
the accounting system to print the report.
144
U S E R S
G U I D E
C H A P T E R
2 3
P R I N TI N G
R E P O R T S
Report differences
Reports printed from within the Report Writer may not have exactly the
same appearance they would printed from the accounting system. Some of
the differences when reports are printed from the Report Writer include:
USERS
GUIDE
145
146
U S E R S
G U I D E
Chapter 24:
Mailing Reports
You can send reports generated in Microsoft Dynamics GP to others as email attachments. Information about mailing reports is divided into the
following sections:
MAPI
Attachment types
Mailing a report
MAPI
The Report Writer allows you to mail reports using standard e-mail
applications. Microsoft Dynamics GP supports Microsofts Mail
Application Program Interface (MAPI), which allows you to send mail to
other users with a MAPI mailbox. If your workstation has one of these mail
systems enabled, you can mail reports from the Screen Output window.
Attachment types
Reports you send as e-mail attachments can be in text format or PDF
(Portable Document Format) format.
Text format
All reports can be mailed as a text attachment. The text representation of the
report generated by the Report Writer will match the report layout as
closely as possible. However, complex report layouts may not have an ideal
appearance. If you want to use the text attachment for reports you e-mail,
we suggest making a modified or custom report that is simplified and
designed to be represented with text.
PDF format
If you have the PDFWriter printer driver installed (included with Adobe
Acrobat 5 and earlier), or Acrobat Distiller from Acrobat 6 or later, you can
also mail the report as a PDF attachment. Information about Adobe Acrobat
is available at www.adobe.com. PDF provides a very accurate
representation of the report, and works well for graphics reports.
USERS
GUIDE
147
PA RT
P R I N T IN G
A N D
M A I L I N G
R E P O R TS
Mailing a report
To mail a report to another user, complete the following procedure:
1. Print the report to the screen.
Print the report as you normally would, but be sure to select the Screen
option in the Report Destination window when you print a report. The
Screen Output window will appear. If a users workstation has MAPI
enabled, the Send To button drop list will be enabled.
2. Choose to e-mail the report.
In the Send To button drop list, select the attachment type you want to
use. Text format will always be available. If you have the PDFWriter or
Acrobat Distiller installed, PDF format will also be enabled.
3. Address and send the message.
The report will have been attached to a new mail message. Address the
message and send the report.
If you chose a text attachment, the report will be sent with a .TXT
extension. The user receiving the report can use the application thats
associated with this extension to view the file. If you chose a PDF
attachment, the report can be read with Adobes Acrobat Reader.
148
U S E R S
G U I D E
Chapter 25:
Exporting Data
The Report Writer can be a useful tool for exporting data from the
accounting system to external files that can be used in other applications.
For example, a list of customer names and addresses could be exported to a
file for use with word processing software as a mailing list. Information
about exporting data is divided into the following sections:
Export formats
Creating reports for exporting
Export formats
The following export formats are available from the Report Writer:
Format
Description
Text file
Tab-delimited
Comma-delimited
HTML
PDF File
USERS
GUIDE
149
PA RT
P R I N T IN G
A N D
M A I L I N G
R E P O R TS
150
U S E R S
G U I D E
152
U S E R S
G U I D E
Chapter 26:
Report design
Optimizing reports
Report design
A report is a tool that turns data into useful information. Careful design can
greatly improve the utility of the reports you create. Keep the following
guidelines in mind when creating reports.
Purpose
Before you begin creating a report, clearly state what the purpose of the
report is. State who will use the report and what they will use the report for.
This will help you determine what information is needed for the report, and
which tables the information will come from. This process can also provide
an early indication that a report is becoming too complex, or is trying to
meet several needs that would be better met by separate reports.
Name
The reports name is the primary way that users will be able to find the
report. Be sure the name is descriptive, and that the report is assigned to a
an appropriate series in the accounting system.
USERS
GUIDE
153
PA RT
R E P O R T
D ES IG N
Determine whether the report should be printed in portrait or landscape mode, and be consistent with the layout.
If your report contains columns of information, be sure the data is properly aligned under the column headings.
154
U S E R S
G U I D E
Limit the number of fonts used for the report. Though you can use any
fonts installed on the current workstation, its best to limit the number
of fonts used to two.
Graphic elements, such as lines and boxes, can help group the items in
a report and make it easier to read.
C H A P T E R
2 6
R E P O R T
D E S I G N
G U I D EL I N E S
Optimizing reports
How you design and set up a report can directly impact the performance of
the report as its printed. Use the following guidelines to optimize the
reports you create.
Page layout
An efficient page layout can improve performance by reducing the total
number of pages used to print the report. Dont use a landscape layout
unless the information on the report requires the wider format. Using
columns can also increase the amount of information on a page.
USERS
GUIDE
155
156
U S E R S
G U I D E
Chapter 27:
Preprinted Forms
You may have existing forms that are already printed, but that you would
like to have filled out by the Report Writer. These are typically referred to as
preprinted forms. The most common preprinted forms are checks and
invoices, which are described in Chapter 29, Checks, Invoices, and
Labels. Information about setting up your own preprinted forms is
divided into the following sections:
USERS
GUIDE
157
PA RT
R E P O R T
D ES IG N
Report layout
Careful planning is required when creating a report layout for use with a
preprinted form. The following hints that can help ensure success.
Page size
Keep in mind the total size of the page when youre creating the layout for a
preprinted form. A report layout is based on 72 points per inch, and each
pixel on the report layout represents one point. If you are developing a
preprinted report for standard US Letter size page, the total size for each
page of the report must be 612 by 792 points (8.5 inches by 11 inches).
Remember that there are no built-in margins for a preprinted report, so you must
account for any margins you need for your report.
To determine the total size for each page of a report, add up the sizes of
each section of the report. You can find the height of a report section by
clicking the handle for the section in the Report Layout window, and
viewing the section size at the bottom of the Toolbox.
If the total size of a page for a report is larger than the maximum page size,
extra pages will be generated when the report is printed. If a page only
slightly exceeds the maximum size, an extra blank page may appear in the
printed output. If the total size of a page for a report is smaller than the
maximum page size, the report may creep as it is printed. When a report
creeps, information on subsequent pages of the report will tend to move up
as pages are printed.
158
U S E R S
G U I D E
C H A P T E R
2 7
PRE P R I N TE D
F O RM S
Report sections
If the report for a preprinted form contains additional headers and footers,
its important to know exactly when these headers and footers will be
printed. If an additional header or additional footer is printed at an
unexpected time, your report may print extra pages or exhibit page creep. If
this occurs, check each section of the report to verify that they are printed
when expected.
You can use the Records Per Report Body setting in the Header Options or
Footer Options for a section to specify the total number of times the
additional header or footer will appear for each report body printed. This
setting limits the number of times a report section can print on a specific
page, and will also fill the page with the appropriate number of empty
sections to reach the number specified. This setting is useful for reports that
contain a fixed number of line items, such as invoices.
Special characters
For some preprinted reports, you may want to print special characters such
as Xs. To do this, you will need to create calculated fields that will print the
appropriate characters, based on field values for the report. Refer to
Chapter 7, Calculated Fields, for more information about creating
calculated fields.
USERS
GUIDE
159
PA RT
R E P O R T
D ES IG N
The horizontal and vertical alignment settings apply only to reports that
have the Preprinted option marked in the report definition. Other reports
arent affected by these settings.
A separate set of alignment settings for each printer you access is saved in
the DEX.INI file on each workstation, so you dont need to type in the
alignment settings each time you print a preprinted report. Because all
preprinted reports will use the same alignment settings for the selected
printer, its a good idea to use consistent left and top margins for all of the
preprinted reports you create. That way, users wont have to change the
alignment settings depending on the report being printed.
160
U S E R S
G U I D E
Chapter 28:
Groups
One way a report can transform data into useful information is by grouping
it into meaningful categories. For example, customer classes, credit limits,
or transaction amounts are just some of the ways you could group
information. Information about groups is divided into the following
sections:
Group overview
Sorting for groups
Group headers
Group footers
Counting items in a group
Counting groups
Totaling and subtotaling
Advanced groups
Group overview
To group information on a report, you will do the following:
Sort the report data in an order appropriate for creating the group. You
need to sort the data for the report so that the report items appear in an
order that allows them to be grouped.
Create additional footers to summarize the group information. Additional footers for the report can perform summary actions such as totaling or subtotaling for each group.
USERS
GUIDE
161
PA RT
R E P O R T
D ES IG N
For optimal performance when printing the report, you should use an
existing key from the primary table to specify how the data for the report is
sorted. However, when you are creating groups for a report, there often
isnt a key available for the primary table that sorts the data appropriately.
This is especially true when you want to create groups based on data in
secondary tables for the report. In this case, you must create a sort order to
indicate how to sort the data for the report. This is described in Chapter 5,
Sorting.
Group headers
To add header information to a group, create an additional header for the
report. Refer to Chapter 8, Additional Headers and Footers, for more
information about creating additional headers. The additional header
contains the field or fields that each group is based on, and will be printed
once for each group on the report. It also typically contains descriptive
column headers for the information that appears in each group.
162
U S E R S
G U I D E
C H A P T E R
2 8
G R O U P S
For example, the following illustration shows the layout for the User
Classes report. Notice that user information is grouped according to the
User Class, and then Account Access, and so on. An additional header is
used for each group category for the report.
Group footers
Use footers for groups to add summary information for the group, such as
totals, subtotals, or average values. To add footer information to a group,
create an additional footer for the report. Refer to Chapter 8, Additional
Headers and Footers, for more information about creating additional
footers.
Any additional footers for a group should typically break on the same
field as any additional headers for the group. This keeps the headers and
footers with the group, and allows the items in the group to be counted.
When you add a field to an additional footer, it is automatically assigned
the Last Occurrence display type. If you dont use the Last Occurrence
display type, the field will appear to be looking ahead to the next record for
the report. This occurs because the next record for the report has already
been read to determine whether a group should be considered complete.
If you place calculated fields in footers, you change their display type from
Last Occurrence to Data, so that the calculations are performed properly.
USERS
GUIDE
163
PA RT
R E P O R T
D ES IG N
Counting groups
If you have several groups on a report, you may find it useful to count the
individual types of groups. To count the number of groups in a report, you
need to use a Control Count field.
A Control Count field is designed to count the number of times an
additional footer appears in a report. This means that the group you are
counting must have an additional footer that indicates the end of the group.
Next, create an additional footer immediately below the additional footer
that indicates the end of the group. This additional footer must contain an
instance of the field on which the group you are counting is based, and you
must set the fields type to Control Count.
164
U S E R S
G U I D E
C H A P T E R
2 8
G R O U P S
For example, the Customers by City and State report groups all of the
customers by State, and then further groups them by City. To count the
number of cities in each state, an additional footer is used that appears at
the end of each City group. Another additional footer is added that will
contain the City field, but with the display type set to Control Count. This
field will count the number of times the additional footer at the end of the
City group appears, which is the same as the number of cities for each state.
The field to which you apply the Control Count display type must be the same field
that the footer immediately above the footer containing the Control Count field
breaks on.
Sum fields
Fields with the Sum display type print the total of the fields values within a
group, or within the entire report. If you add a Sum field to an additional
footer for a group, it will total the items for the group. Adding Sum fields to
the report footer will total all values for the entire report.
USERS
GUIDE
165
PA RT
R E P O R T
D ES IG N
Advanced groups
Some groups for reports may be too complex to be implemented with the
basic additional header and additional footer capabilities of the Report
Writer. If you have the Modifier with VBA, you can use VBA (Visual Basic
for Applications) code to further control when additional headers and
footers appear in a report. Refer to the VBA Developers Guide for more
information about using VBA with the Report Writer.
166
U S E R S
G U I D E
Chapter 29:
Checks
Invoices
Labels
Checks
Depending on the design of the checks you are using, the check layout can
be simple, or very complex. A basic check layout doesnt have a check stub,
or has the check stub either above or below the check. A complex check
layout has a check stub both above and below the check.
Check types
Microsoft Dynamics GP has separate check layouts for Payables
Management and for Payroll. For Payables Management, the following
table lists the check formats that are available, along with the corresponding
report used for the check.
Check Format
Report
No Stub
Stub on Top
Stub on Bottom
User-Defined Check 1
User-Defined Check 1
User-Defined Check 2
User-Defined Check 2
USERS
GUIDE
167
PA RT
R E P O R T
D ES IG N
For Payroll, the following table lists the check formats that are available,
along with the corresponding report used for the check.
Check Format
Report
Stub on Top and Bottom - Single Feed Employee Checks Stub on Top and Bottom-L
Other - Continuous
168
U S E R S
G U I D E
Avoid editing the layout for any Stub on Top and Bottom check. The
layout for these checks is hard-coded to the software, which prevents
most modifications from working properly. You can make some
cosmetic modifications to these check layouts, such as adding graphics
or text.
When modifying checks, dont move fields from one section of a report
to another. This can cause the checks to not print properly.
Dont remove fields from the check layout. When youre modifying
checks, use the Report Field Options window to set a field to be invisible, rather than removing the field from the report. Removing fields can
prevent a check from printing properly.
C H A PT E R
2 9
C H E C K S ,
I N V O I C E S ,
A N D
L AB EL S
Invoices
Invoices are some of the most complex reports that are commonly modified.
They use several additional headers and additional footers to display line
items. Invoices must also print properly when they require only a single
page or span multiple pages.
Because of the complexity of modifying invoices, Microsoft has created
several modified versions of the invoices available in Microsoft Dynamics
GP. You can access these modified invoices in the Reports Library, which
contains reports have already had common modifications made to them.
You can access the Reports Library at the Microsoft Dynamics web site and
browse the modified invoices that are available there. Refer to Reports
Library on page 116 for more information about using the Reports Library.
Labels
Microsoft Dynamics GP can produce several types of labels, such as those
for customers, vendors, or employees. You can print labels by choosing
Company in the Reports menu, and then choosing Mailing Labels. The
Mailing Labels window will appear, allowing you select the labels you
want to print.
When you create the report option for the mailing labels, you must select
the format to use for the labels. You can choose Continuous or Laser. If you
choose Continuous, you can select the number of labels that will be printed
across the page. This value will range from 1 to 5. If you choose Laser, the
report will be printed with two labels across each page.
To have labels print properly on your printer and with your label stock, you
may need to make modifications to the layouts for the reports used to print
labels. The following table lists the reports that correspond the Format and
Number Across options you can specify in the Mailing Label Report
Options window.
Format
Number Across
Report
Continuous
Continuous
Continuous
Continuous
Continuous
Laser
N/A
USERS
GUIDE
169
PA RT
R E P O R T
D ES IG N
To easily select the appropriate mailing label report to modify, print the mailing
labels to the screen, and then choose to modify the current report.
If you are using the Laser format, and want to have more than two labels
across the page, you will need to use the Divider tool to add additional
columns to the report layout.
Record 1
Record 2
Record 3
Record 4
Record 5
Record 6
Record 7
Record 8
Record 9
When setting up mailing labels the first time, it is useful to test the layout
on blank paper before you print the actual labels. Its also a good idea to
print several pages of labels to verify that the labels arent creeping up or
down as multiple pages are printed. If this occurs, you will need to modify
the report layout to add or remove space from the report section containing
the labels.
170
U S E R S
G U I D E
172
U S E R S
G U I D E
Chapter 30, Storing Reports, explains how new and modified reports
are stored and describes two common Report Writer configurations.
Chapter 32, Packaging Reports, explains how you can package and
distribute modifications to other users.
Chapter 30:
Storing Reports
All new reports and modifications you make with the Report Writer are
stored in the Reports dictionary. Information about storing reports is
divided into the following sections:
Reports dictionary
Launch file
Report Writer configurations
Reports dictionary
All changes and additions you make using the Report Writer are stored in
the reports dictionary for the application. By storing the new and modified
resources in a separate dictionary, the integrity of the main dictionary can
be maintained. For example, the following illustration shows the dictionary
for Microsoft Dynamics GP and its associated reports dictionary.
New and modified
resources are stored in
the reports dictionary.
Dynamics
Reports.dic
When you access the Report Writer for the first time, all of the core resources
for the application dictionary are copied to the reports dictionary. Core
resources include strings, data types, and global fields that are used by
several parts of the system. Once core resources have been copied to the
Reports dictionary, the runtime engine will look there first when it retrieves
resources from the dictionary. Any additions or modifications you make to
core resources will be stored in the reports dictionary. The modifications
will be accessed automatically when you use Microsoft Dynamics GP.
When you create a new report, or select a report to modify, that report is
copied into the reports dictionary. Any modifications or additions you
make to that report will be stored only in the reports dictionary. To access
the modifications you make to reports, you must set security in the
accounting system to access the modified report. This is described in
Chapter 31, Accessing Reports.
USERS
GUIDE
173
PA RT
S T O R I N G
A N D
A C C E S S I N G
R EP O R T S
Launch file
When you start Microsoft Dynamics GP, you use the launch file that tells the
runtime engine which dictionaries will be used by the application. The
launch file stores the location of the application dictionary as well as the
names and locations of any forms or reports dictionaries.
By default, the reports dictionary is named Reports.dic and is located in the
Data folder for the Microsoft Dynamics GP installation. You can use the
Edit Launch File window to change the name or location of the reports
dictionary.
To update the launch file, you must have appropriate user privileges. Typically, this
means being part of the Administrators group or the Power Users group on
Windows XP. On operating systems with User Account Control (UAC), it means
launching Microsoft Dynamics GP with Administrative privileges.
To display this window, choose Microsoft Dynamics GP >> Tools >> Setup
>> System >> Edit Launch File.
174
U S E R S
G U I D E
C H A P T E R
3 0
S T O R I N G
R E P O R T S
Each workstation can have its own unique set of new and modified
reports.
The same new and modified reports are available to all users.
Only one user can access the Report Writer at one time.
USERS
GUIDE
175
PA RT
S T O R I N G
A N D
A C C E S S I N G
R EP O R T S
The configuration you choose depends on how many reports you want to
modify, whether individual users will be creating new reports or modifying
existing reports, and how you want to share new and modified reports
among users.
176
U S E R S
G U I D E
Chapter 31:
Accessing Reports
You can control access to the Report Writer and which new and modified
reports specific users will be able to use. Information about controlling
access is divided into the following sections:
USERS
GUIDE
177
PA RT
S T O R I N G
A N D
A C C E S S I N G
R EP O R T S
178
U S E R S
G U I D E
C H A P T E R
3 1
A C C E S S I N G
R E P O R T S
USERS
GUIDE
179
PA RT
S T O R I N G
A N D
A C C E S S I N G
R EP O R T S
To open this window, choose Microsoft Dynamics GP menu >> Tools >>
Setup >> System >> Security Tasks. Name the new security task. Select the
product for which the custom report was defined. Select Custom Reports as
the resource type, and choose the series. The custom reports in the selected
series will be shown. Mark the custom reports to include in the new task.
Once the task is defined, you can assign it to a new or existing security role.
Any user assigned to that role will be able to access the custom report.
Be sure to activate security by marking the Security option in the Company Setup
window in Microsoft Dynamics GP.
Modified reports
Any modifications you make to the reports for a third-party product will be
stored in a separate reports dictionary for that product. To access these
modified reports, you must select the third-party product in the Alternate/
Modified Forms and Reports window. You can then choose to use the
modified version of the report.
180
U S E R S
G U I D E
C H A P T E R
3 1
A C C E S S I N G
R E P O R T S
Alternate reports
Some third-party developers create alternate reports. These are Microsoft
Dynamics GP reports that the third-party developer has enhanced and
transferred to their own dictionary. By choosing the third-party dictionary
when you start the Report Writer, you can make modifications to these
alternate reports.
When using the Alternate/Modified Forms and Reports window to set
access to these reports, choose the modified version of the alternate report
to display the modifications you made. For example, the following
illustration shows how you would display a modified version of the
alternate Purchase Order History Report provided by the Purchase Order
Enhancements dictionary.
USERS
GUIDE
181
PA RT
S T O R I N G
A N D
A C C E S S I N G
R EP O R T S
182
U S E R S
G U I D E
Chapter 32:
Packaging Reports
When you have finished modifying existing reports or creating new
reports, you may want to distribute them to other users. This portion of the
documentation describes how you can use package files to distribute new
and modified reports. Information is divided into the following sections:
Package files
Exporting a package file
Importing a package file
Package file import/export issues
Package files
Package files are special text files that are used to deliver customizations
made with the Modifier, VBA, and the Report Writer. A developer can
create a package file that contains their customizations, move the package
file to the destination workstation, then import the customizations into the
installation.
A package file can contain the following items:
Modified forms Forms that have been customized with the Modifier.
New or modified reports Reports that have been created or
customized with the Report Writer.
VBA forms Forms that have VBA code attached.
VBA reports Reports that have VBA code attached.
VBA components User forms, code modules, or class modules created
with the VBA development environment.
References References to external components used by VBA. A package
file cannot contain the actual components referenced by the VBA
customization. Those components must be delivered separately.
USERS
GUIDE
183
PA RT
S T O R I N G
A N D
A C C E S S I N G
R EP O R T S
To select non-contiguous items in the list, hold down the CTRL key and click the
items.
Click Export. A file dialog will appear, allowing you to specify the
name of the package file. Be sure the file has the .package extension.
The results of the export operation will be displayed in the status area
at the bottom of the window.
184
U S E R S
G U I D E
C H A PT E R
3 2
P AC K AG I N G
R E P O R T S
Note that some global changes you make with the Modifier and Report Writer
cant be included in a package file. For instance, changes to picture resources or
global data types wont be included in package files.
USERS
GUIDE
185
PA RT
S T O R I N G
A N D
A C C E S S I N G
R EP O R T S
Click OK to start the import process. If any errors occur during the
import process, the Errors window will be displayed. The results of the
import operation will also be displayed in the status bar of the
Customization Maintenance window. To view the list of the last errors
that occurred, click the Errors button in the status bar.
4. Set access to any modified forms or reports that are part of
the customization.
If necessary, use the security features in Microsoft Dynamics GP to
grant access to any modified forms or modified reports that are part of
your customization.
186
U S E R S
G U I D E
Chapter 33:
Importing Reports
In versions of the Report Writer prior to Release 6, the only way to move a
report from one reports dictionary to another was to use the Import Reports
capability. Information about importing reports is divided into the
following sections:
USERS
GUIDE
187
PA RT
S T O R I N G
A N D
A C C E S S I N G
R EP O R T S
Validating reports
After you have imported reports from another reports dictionary, its
important to verify that the reports references to tables and other resources
are still valid. To validate a report, use the following procedure:
1. Select the report.
In the Report Writer window, select the report to validate in the
Modified Reports list.
2. Validate the report.
Click Validate in the Report Writer window to validate the selected
report.
188
U S E R S
G U I D E
C H A P T E R
3 3
I M P O R TI N G
R E P O R T S
Cause
Report XXX: Expression XXX references A table field thats used as part of a
a field that does not exist in table XXX. calculated or conditional expression no
longer exists in the specified table.
Report XXX: Field XXX in sort segment
not in table XXX.
USERS
GUIDE
189
190
U S E R S
G U I D E
192
U S E R S
G U I D E
Chapter 39, Troubleshooting Templates, provides solutions to common problems when you are working with report document templates.
Chapter 34:
Template-enabled reports
Report definition
Report template document
How Word Templates are processed
Capabilities of Word templates
Template-enabled reports
Template-enabled reports are Report Writer reports that can have Microsoft
Word report template documents associated with them. When these
template-enabled reports are printed, the appropriate Microsoft Word
report template document is retrieved and used to render the output in
Microsoft Word format. The template-enabled reports are listed in the
Reports window in Microsoft Dynamics GP.
USERS
GUIDE
193
PA RT
WO R D
TE M P L AT E S
Report definition
A report that is rendered as a Microsoft Word document is still based on a
standard report definition in the Report Writer. The report definition is
needed for things like:
Microsoft Word does not perform any of these standard report actions. It is
used only to display the report that has been rendered in Microsoft Word
format.
194
U S E R S
G U I D E
C H A P T E R
3 4
O V E R V I EW
O F
W O R D
T EM PL AT E S
XML Document
Contains Report Definition
and Data
Template Processing
Engine
Completed Report in
Microsoft Word
USERS
GUIDE
195
PA RT
WO R D
TE M P L AT E S
The Microsoft Dynamics GP runtime uses the report definition for the
report to generate an XML document that contains both the report
definition and the data for the report. The appropriate Microsoft Word
report template document that was created for the report is retrieved. This
template document defines how the data in the report is to be rendered. The
XML and template documents are passed to the Template Processing
Engine, which combines them to produce the completed Microsoft Word
document for the report.
Portability of the report. Any user with Microsoft Word can view the
report.
Microsoft Word is not designed to have the features of a report writer. The
following is a list of the capabilities of the Microsoft Dynamics GP Report
Writer rendering engine that are not available in the reports generated in
Microsoft Word format:
196
U S E R S
G U I D E
No page headers or page footers in the report. All page headers and
page footers must be implemented using feature provided by Microsoft
Word.
Chapter 35:
After installing the Microsoft Word add-in, you access it through the
Developer tab in the Ribbon. To display the Developer tab, go to the Office
menu and choose Word Options. In the Word Options window, select the
Popular category. Mark Show Developer Tab in the Ribbon, and then click
OK.
USERS
GUIDE
197
PA RT
WO R D
TE M P L AT E S
The following illustration shows the group that is added to the Ribbon.
198
U S E R S
G U I D E
C H A P T E R
3 5
S ET T I N G
U P
M I C R O S O F T
W O R D
Display options
In the Word Options window, select the Display category. Mark the
following options:
Paragraph marks
Hidden text
Object anchors
Advanced options
In the Word Options window, select the Advanced category. Mark the
following options:
Show bookmarks
Show text boundaries
USERS
GUIDE
199
200
U S E R S
G U I D E
Chapter 36:
Document structure
Creating a report template layout with tables
Fields, captions, and legends
Bookmarks
Company image
Tips for working with report template documents
Common report template patterns
Document structure
The report template document is a standard Microsoft Word document.
When it is created from with Microsoft Dynamics GP, the additional
information about the report definition is embedded into the document.
The document is a single-sided, which means that there are no left-hand or
right-hand pages.
Several tables in the report template document define the overall structure.
All of the content that is displayed in the generated Word document is
placed inside these tables. The following illustration shows the structure of
a report template document.
Page Header
Report Header
Body
Report Footer
Page Footer
USERS
GUIDE
201
PA RT
WO R D
TE M P L AT E S
Any text that is not within one of these single-cell tables will not be
included in the generated Microsoft Word document for the report. It is
common to add text to the document in the areas outside of the single-cell
tables to describe the report template.
Body table
The body table is a table that is located after the report header table of the
Microsoft Word document. It contains the main content of the report. This
includes the report body content, any additional headers, and any
additional footers.
202
U S E R S
G U I D E
C H A P T E R
3 6
R E PO R T
T EM PL AT E
D ES IG N
USERS
GUIDE
203
PA RT
WO R D
TE M P L AT E S
Body table
The body table is located between the report header and report footer tables
in the Microsoft Word report template document. It contains values from
the Body section, and from any additional header and additional footer
sections of the report definition.
The body table has multiple rows. The table has one row for the actual
report body. There is also one row for each additional header and one row
for each additional footer. There can also be a rows that are used for
captions, such as column headers.
Typically, additional tables are used within the rows of the body table to create the
layout for the row.
A basic body table is shown in the following illustration. The first row in
this body table contains captions for the column headings. The next row
contains data for an additional header. The third row contains data from the
report body. The last row contains data for an additional footer.
The row of the body table that contains items from the report body must
have a special Microsoft Word bookmark that the template processing
engine in Microsoft Dynamics GP uses to identify this row. You can see this
bookmark located on the left side of the body row in the previous
illustration. Refer to Bookmarks on page 207 for details about adding
bookmarks to the report template document.
As Microsoft Dynamics GP processes the report, it examines the report data
to determine when the rows from the body table are included in the
generated output for the report. For example, when the data for an
additional header is encountered for a report, that row is included in the
generated output.
If the body table contains a row with column headers, this row of the body
table should be set to repeat as the header row at the top of each page. This
is a Microsoft Word feature that is applied to a specific row of the body
table.
204
U S E R S
G U I D E
C H A P T E R
3 6
R E PO R T
T EM PL AT E
D ES IG N
Adding an item
To add a field, caption, or legend, complete the following steps:
1. Display the Developer tab.
2. Click Field List in the Microsoft Dynamics GP group.
The Custom XML Mapping pane will be displayed. This pane provides
access to the report definition data that was embedded into the report
template document when it was created.
3. Select an XML resource.
In the drop-down list in the Custom XML Mapping pane, select the
XML resource for the report. Typically, there is only one XML resource.
The Report Section list will be filled with the sections in the report.
4. Select a report section.
Select the section of the report from which you want to add items. The
Fields list will be filled with the fields, captions, and legends that are
contained in that section from the report definition.
USERS
GUIDE
205
PA RT
WO R D
TE M P L AT E S
ReportHeader
ReportHeader
Body table
Body
AdditionalHeaders
AdditionalFooters
ReportFooter
ReportFooter
If you place items from the field list into an inappropriate location in the report
template, their values will not appear in the generated report.
6. Specify the appearance of the item.
Use the standard features of Microsoft Word to specify characteristics
like the font, style, and alignment.
Removing an item
To remove a field, caption, or legend, complete the following steps:
1. Click on the item in the document.
The tag containing the name of the field will be displayed.
206
U S E R S
G U I D E
C H A P T E R
3 6
R E PO R T
T EM PL AT E
D ES IG N
Bookmarks
Microsoft Word bookmarks are used to identify three of the tables that
define the structure of the report template document. The following table
lists these bookmarks.
Bookmark
Description
StartTemplateDocumentHeaderBookmark
StartTemplateSectionRepeating
EndTemplateDocumentFooterBookmark
USERS
GUIDE
207
PA RT
WO R D
TE M P L AT E S
These bookmarks
must be defined in
Microsoft Word.
Company image
Each company in Microsoft Dynamics GP can have an image assigned that
is to be displayed on the Microsoft Word template reports. When you run
the report for a specific company, the image assigned for that company will
be displayed on the generated document. Typically, this logo is placed in
the Page Header table for the report template document. To add a company
image to a report template, complete the following steps:
1. Create a cell to contain the image.
In the report template document, create a table cell in the location
where you want the image to appear.
208
U S E R S
G U I D E
C H A P T E R
3 6
R E PO R T
T EM PL AT E
D ES IG N
Click OK.
Get the basic report template layout working first. Do the intricate
layout work such removing extra space and aligning data values after
the report template is retrieving data and displaying it correctly.
Press and hold the Alt key when moving table borders to prevent them
from snapping to the grid in Microsoft Word.
Use the Design Mode that can be activated from the Developer tab to
see quickly which sections the items in the report template layout come
from.
Make regular backups of your template as you are working, in case you
make a change that you would like to revert.
USERS
GUIDE
209
PA RT
WO R D
TE M P L AT E S
Form pattern
In the form pattern, the data is displayed as a block of values for each
record in the table. The block typically contains several pairs of labels and
data values that are arranged in the block. The following illustration shows
this pattern.
StartTemplateSectionRepeating
bookmark
Nested table inside the
Body table, with multiple
rows and columns
containing the data from
each record.
xxx
xx
xxx
xxxxx
xx
xxxxx
x
xx
xxxx xxxxx
xxx xxx
The Body table has another table nested in it that contains the rows and
columns that define the layout of the data.
The captions and fields for the report are placed in the cells of the
nested table.
The Body table may also have rows for additional headers and additional
footers. The Report Footer table and Page Footer table are optional in this
pattern.
210
U S E R S
G U I D E
C H A P T E R
3 6
R E PO R T
T EM PL AT E
D ES IG N
Column pattern
In the column pattern, the data for the report is divided into columns, with
one row for each record in the table. A set of column headers appears at the
top of each page. The following illustration shows this pattern.
xxxx
xxxxx
xxx
xxx
xxx
xxxxx
xxxxx
Body table
The first row of the Body table is divided into columns that contain the
captions for the values in the report. The properties for the row are set
in Microsoft Word to make the column repeat at the beginning of each
page.
The Body table can contain rows for additional header data and
additional footer data.
The Body table has a row that contains a nested table. This nested table
is divided into columns, and the fields for the report are placed in these
columns.
The Report Footer table and Page Footer table are optional in this pattern.
USERS
GUIDE
211
212
U S E R S
G U I D E
Chapter 37:
USERS
GUIDE
213
PA RT
WO R D
TE M P L AT E S
Click Select.
3. Create a new report template document.
In the Report Template Maintenance window, click New to create a
new report template document for the report.
4. Specify the details of the new report template document.
In the New Template window, specify how the new report template
document will be created.
214
U S E R S
G U I D E
For reports that have existing report template documents, the new
template can be created based on the template you select. In most
cases, you will choose to create the template based on an existing
template, because then you dont have to re-create the report
template layout.
C H A P T E R
3 7
C R E AT IN G
R E P O R T
T EM PL AT E S
You must also supply a name for the report template you are creating.
The name should indicate how the report template is intended to be
used.
Click Create.
5. Modify the new report template.
In the Report Template Maintenance window, select the new report
template you created, and then click Modify. The report template will
be opened in Microsoft Word.
Using the techniques and guidelines described in Chapter 36, Report
Template Design, add to or modify the report template document as
needed.
6. Save the new report template.
In Microsoft Word, save the new report template document to a
convenient location where you can easily find it.
7. Close the new report template.
In Microsoft Word, close the new report template document.
USERS
GUIDE
215
PA RT
WO R D
TE M P L AT E S
216
U S E R S
G U I D E
Chapter 38:
USERS
GUIDE
217
PA RT
WO R D
TE M P L AT E S
This calculated field with the e-mail address is added to the report layout,
as shown in the following illustration.
This EMailAddress calculated field was added to both the Report Header
and Page Header sections of the report layout.
Click Select.
218
U S E R S
G U I D E
C H A P T E R
3 8
R E P O R T
T EM PL AT E S
FO R
M O DI FIE D
R E P O R T S
Click Create.
5. Modify the new report template.
In the Report Template Maintenance window, select the new report
template for the modified report, and then click Modify. The report
template document will be opened in Microsoft Word.
6. Display the field list for the report.
In Microsoft Word, select the Developer tab. In the Microsoft Dynamics
GP Templates group, click Field List.
USERS
GUIDE
219
PA RT
WO R D
TE M P L AT E S
220
U S E R S
G U I D E
C H A P T E R
3 8
R E P O R T
T EM PL AT E S
FO R
M O DI FIE D
R E P O R T S
USERS
GUIDE
221
PA RT
WO R D
TE M P L AT E S
222
U S E R S
G U I D E
C H A P T E R
3 8
R E P O R T
T EM PL AT E S
FO R
M O DI FIE D
R E P O R T S
The XML data file for the report has two main sections. The first section
contains the report definition information, while the second section has
actual data for the report. The updated report definition section is what
must be embedded into the report template document.
USERS
GUIDE
223
PA RT
WO R D
TE M P L AT E S
224
U S E R S
G U I D E
Chapter 39:
Troubleshooting Templates
Use the following information to help you troubleshoot issues you may
encounter when working with report template documents. The following
items are discussed:
Verify that the standard version of the report is working correctly. If the
standard version of the report isnt displaying data correctly, the
template version will not either. This problem is more likely to occur if
you have made a modified version of a report.
Be sure the bookmarks for the report template document are defined
with the correct names.
Verify that the bookmarks are not located inside of a field you added to
the report template document. If they are, the template processing
engine wont be able to find the bookmarks.
Verify the item was dragged to the report template document from the
appropriate report section of the XML data. If the item comes from the
wrong section, it will not contain any data.
Be sure that you have all of the tables needed for the report template
document. Data values may not appear in a report if the report is
missing one of the standard tables, such as the Report Header table.
USERS
GUIDE
225
PA RT
WO R D
TE M P L AT E S
Be sure that an image has been assigned for the company. You may also
want to run another report for the company to verify that the image is
displayed.
Be sure that the Picture Content Control has been properly defined. If
the properties for that control are not set to the proper values, the
template processing engine will not be able to find the control.
226
U S E R S
G U I D E
C H A PT E R
3 9
T R O U B L E S HO O T I N G
T EM PL AT E S
USERS
GUIDE
227
228
U S E R S
G U I D E
APPENDIX
Appendix
This manual has the following appendix:
230
U S E R S
G U I D E
Appendix A:
User-defined Functions
This appendix describes the common user-defined functions that are
available for use in calculated fields. The following functions are described:
RW_Address
RW_CityStateZip
RW_GetAccountNumber
A document with descriptions of the user-defined functions available for the Report
Writer is found in the Microsoft Dynamics GP SDK in the Procedures and
functions category. You can find the document by searching for Report Writer.
RW_Address
Most addresses in Microsoft Dynamics GP allow up to three address lines.
In some cases, you may want to suppress the address lines that are empty,
and have the remaining lines of the address move up to occupy the unused
space. In earlier versions of the Report Writer, you needed several
calculated fields to accomplish this. The RW_Address user-defined function
provides this functionality with only four calculated fields, one for each line
of the address. The function takes the following parameters:
in
in
in
in
in
in
in
integer Line_Number
string Line1
string Line2
string Line3
string City
string State
string PostalCode
USERS
GUIDE
231
A P P E N D I X
U S E R - D EF I N E D
F U N C TI O N S
The following calculated field is used to display the second line of the
address. Notice that the first parameter is the integer value 2, indicating this
is the second line of the address. All of the other parameters remain the
same.
FUNCTION_SCRIPT(RW_Address 2 RM_Customer_MSTR.Address 1
RM_Customer_MSTR.Address 2 RM_Customer_MSTR.Address 3
RM_Customer_MSTR.City RM_Customer_MSTR.State RM_Customer_MSTR.Zip )
The third and fourth calculated fields are similar. The only difference is the
first parameter is either the integer value 3 or 4, indicating the third or
fourth line of the address. When all of the calculated fields are complete,
add them to the report layout in place of the standard address fields.
RW_CityStateZip
The RW_CityStateZip user-defined function strips the space from between
the City, State, and Zip Code fields of an address. It takes the following
parameters:
in string City
in string State
in string ZipCode
The following calculated field uses the function to remove the extra spaces
from the City, State, and Zip fields retrieved from the RM_Customer_MSTR
table:
FUNCTION_SCRIPT(RW_CityStateZip RM_Customer_MSTR.City
RM_Customer_MSTR.State RM_Customer_MSTR.Zip )
232
U S E R S
G U I D E
A P P E N D I X
U S ER - D E F I N E D
F U N C TI O N S
RW_GetAccountNumber
The RW_GetAccountNumber user-defined function retrieves an account
number based on the account index. This allows you to retrieve an account
number without having to link the Account Master table to your report.
The function takes the following parameter:
in string AccountIndex
USERS
GUIDE
233
234
U S E R S
G U I D E
Glossary
Additional headers and footers
Report sections that are printed when a
specified field changes. Additional
headers and footers are created using the
Report Options and Header/Footer
Options windows.
Alphanumeric
A combination of numbers and letters.
Array field
A field containing multiple occurrences
of the same type of information. The
individual pieces of information stored
by an array field are called elements. For
example, a seven-element array field
could be used to store daily sales totals
instead of seven individual fields.
Array index
The number designating a specific
element within an array field. Each
component field within an array field has
an array index.
Boolean expression
An expression that results in a value of
true or false.
Break on field
A field on a report, that when the value
changes, causes an additional header or
additional footer to be printed.
Calculated field
A field containing an expression that
combines fields in a reports table, report
fields,
constants,
functions,
and
operators. The result of the calculation is
displayed in the field if the field is placed
on the report. Calculated fields are
created in the Calculated Field Definition
window.
Check box
A control type used to define data types
that allow users to mark or unmark an
option. Check boxes have boolean
storage types.
Combo box
A control type used to define data types
that allow users to enter a text value or
choose that value from a list. The items in
the list are determined by the static text
values in the data type definition.
Component
One field of a composite field.
Composite
A group of fields and their associated
data types that form a single data type.
Composite data types are defined by the
composite control type and the fields that
make up the composite.
Concatenate
To connect two strings to form a single
string.
Conditional expression
A boolean expression used to print the
corresponding true or false case in a
calculated field. Conditional expressions
are written in the Calculated Field
Definition window.
Control type
The main characteristic of a data type,
controlling the type of information that
can be stored in fields that use that data
type, and some aspects of how the
information will be displayed.
Custom report
A new report that you make. You can
start with a blank report, or you can start
by making a copy of a report that already
exists.
Defaults file
A file that stores information specific to
the current workstation. This file is
named DEX.INI for Windows.
Definition window
A window that allows you to create a
resource and specify its functional
characteristics.
DEX.INI file
A file that stores information specific to
the current workstation. Also referred to
as the defaults file.
Dictionary
A group of resources that, when
interpreted by the runtime engine,
present
a
complete
functioning
application. See also Reports dictionary.
Drop-down list
A control type used to define data types
that allow users to select one item from a
list. The integer value corresponding to
the position of the item chosen, not the
items static text value, is stored when the
users selection is saved.
Expression
A sequence of operands and operators
that are evaluated to return a value.
Field
A field contains a single piece of
information used by the application
dictionary.
Footer
A report section that is printed at the
bottom of a report, page, or group.
Reports can include report footers, page
footers and additional footers.
Format
The extra characters, spacing, and
attributes that can be applied to a data
type when data is displayed.
Format field
An integer field that specifies the format
to use for a string or currency field.
Format string
A data mask used for string and
composite formats. The format string
allows extra characters to appear in a
field without affecting the way data in
the field is stored.
USERS
GUIDE
235
GLOS SA RY
Global variable
MAPI
Graphics report
A report on which graphics, colors (if the
printer has color capabilities), patterns,
and fonts other than the default font can
be printed.
Header
A report section that is printed at the top
of a report, page, or group. Reports can
include report headers, page headers,
and additional headers.
HTML
HyperText Markup Language. Reports
created with the Report Writer can be
exported to HTML files.
Key
Modified reports
A copy of an original report that you
have made changes to. Modified reports
are stored in the Reports dictionary. A
modified report can be substituted for an
original report in the accounting system.
Numeric expression
An expression that results in a numeric
value.
One-to-many
Key segment
One field of a group of fields that
compose a key.
Keyable length
The number of characters that can be
displayed by a field.
Launch file
A file that is used to start an application
with the runtime engine. This file stores
the location of the dictionaries that will
be used, including the application
dictionary and the reports dictionary.
Layout window
A window that allows you to design the
layout of a report.
List box
A control type used to define data types
that allow users to select one static text
value from a list.
236
U S E R S
G U I D E
One-to-one
A type of relationship between two
tables. For every record in the first table,
there is only one corresponding record
that is related to it in the second table.
The relation between two tables is
viewed or defined in the Table
Relationship Definition window.
Operand
An item in an expression that is acted on
by an operator.
Operator
A symbol that indicates the action to
perform on the operands in an
expression.
Order of precedence
The order in which the operations are
carried out for an expression. The
traditional order of precedence for
numeric expressions is: first unary
minus, then exponentiation, followed by
multiplication, division, and modulus,
then addition and subtraction, and finally
shift, equality, and logical operations.
This is also referred to as the order of
evaluation.
Original report
A report that was provided with the
accounting system. You can make
modified versions of original reports.
Overflow
The condition that occurs in a numeric
expression when an intermediate or final
result of the expression is too large to be
stored by the type of data used in the
expression.
Package files
Special text files that are used to deliver
customizations made with the Modifier,
VBA, and the Report Writer.
Picture library
A feature in the Report Writer that allows
you to store graphics in a generic format
that can be used on any supported
platforms.
Pixel
The smallest graphical element displayed
on a monitor. The pixel is the smallest
unit of measurement in layout windows.
You can move objects one pixel at a time
within a layout window by using the
arrow keys on the keyboard.
Point size
The vertical size of a font. There are 72
points to an inch.
G L O S S A R Y
Precedence
The order in which operations are
performed for a type of expression. See
also Order of precedence.
Radio button
A control type used to define data types
that allow a single selection to be made
from a group of two or more selections.
Radio buttons must be used with a radio
group.
Radio group
A control type thats used to group
related radio buttons and store the value
of the selected button. A radio groups
value is stored as an integer
corresponding to the selected radio
buttons position in the tab sequence,
beginning with 0. For instance, if the
second radio button in the tab sequence
is selected, the radio groups value is 1.
Record
A collection of data made up of one
instance of each field in a table.
Relationship
See Table relationship.
Report field
In the Calculated Field Definition
window, a report field is a field with a
modified display type. Report fields can
be used in conditional and calculated
expressions in calculated fields.
Reports dictionary
The dictionary that stores modified
reports from the main dictionary and
new reports created with the Report
Writer. The reports dictionary is created
when the Report Writer is accessed for
the first time. All reports you modify or
create with the Report Writer are stored
in the reports dictionary.
Reports Library
A special web site that contains reports
have already had common modifications
made to them.
Resource
An object such as a field, string, native
picture, table, window, or script that can
be used to create applications in
Dexterity.
Runtime engine
An application thats used to interpret a
dictionary. When a user starts an
application, the runtime engine uses the
resources in the dictionary to present a
functioning application.
Series
A predefined category to which report
and table resources are assigned. Series
allow categorization of resources.
Storage type
One of the standard forms used to store
the data in a field. The storage types are:
boolean, integer, long, currency, variable
currency, string, text, date, and time. The
control type determines which storage
type is used to store the data in the field.
String
A sequence of up to 255 ASCII characters.
See also String resources.
String resources
Sequences of up to 79 characters used
throughout an application dictionary for
window names, field prompts, static text
values, and report text.
Table
A collection of related data formatted in
rows. Each row represents a separate
record, and each column represents a
separate field.
Table relationship
A link between tables that have fields in
common. These relationships allow the
Report Writer to select fields from all of
the related tables and use them on a
single report. Table relationships are set
up using the Table Relationship
Definition window.
Template-enabled report
A report that can have Microsoft Word
report template documents associated
with it, and generate the report output in
Microsoft Word format.
Text report
A report that can display only characters
in a native printer font.
Toolbox
A window that opens in conjunction with
the Report Layout window. It contains
tools used to place and arrange items in
the layout area.
Virtual table
A special type of table that allows data
stored in separate tables to be read as if it
had been stored in a single table.
Visual
(VBA)
Basic
for
Applications
String expression
An expression that results in a string
value.
USERS
GUIDE
237
GLOS SA RY
WYSIWYG
An acronym meaning what you see is
what you get. This applies to intuitive
design tools used to create reports in the
Report Writer.
238
U S E R S
G U I D E
Index
C
Calculated Field Definition window 57
calculated fields
adding fields to the expression 61
calculated expressions 57
chapter 57-70
concatenating in 60
conditional expressions 57
creating, procedure 58-59
defined 235
described 57
nesting system-defined functions
64
operators used in 59-61
result type restrictions 57
using constants in 63
using global variables in 62
using legends in 61
using other calculated fields in 61
using report fields in 61
using system-defined functions in
63
using user-defined functions 63, 69
Cancel button, how used in Report
Writer 15
captions, adding to report template
documents 205
CAT operator, use in calculated fields
60
characters per inch, for report text 40
charts
composite format options 125
currency format options 124
drawn object properties 37
field properties 36
formats for currency fields 81
numeric format options 124
report sections 28
report template item placement
206
standard buttons in the Report
Writer 15
static text values 120
string format options 125
USERS
GUIDE
239
I N D E X
check boxes
defined 235
use in reports 38
checks
modifying 168
overview 167
printing 167
types of 167
Checks, Invoices and Labels, chapter
167-170
circle tool, using in report layout 31
Clear, menu item 12
Clustered, key option 137
clustered keys 137
colorizing report sections 28
colors
custom colors for reports 41
for report items 41
column pattern, for report document
templates 211
columns, adding to mailing labels 170
combo boxes
defined 235
use in reports 38
comma-delimited files, saving reports
to 149
Common Modifications, chapter
113-116
company image
in Word Template reports 208
not displaying in Word output 226
components, defined 235
composite formats
example 126
format options 125
composites
defined 235
formatting 126
concatenating
defined 235
in reports 60
conditional expression, defined 235
configurations, for Report Writer 175
constants, using in calculated fields 63
Contents, menu item 13
Control Count
described 164
240
U S E R S
G U I D E
D
Data, report display type 83
data source in report template
document, updating 223
Data Storage, chapter 89-94
data storage, terminology 89
Data Type Definition window 119
data types
chapter 119-121
characteristics 119
described 119
format 121
keyable length 120
opening 119
opening from global fields 128
static values 120
database types, for tables 135
date tool, using in report layout 31
dates, use in reports 38
DAY calculated field function 64
DAY_NAME, calculated field function
64
defaults file, defined 235
definition windows
defined 235
described 14
Delete button, how used in Report
Writer 16
deleting modified reports 182
Descending, key segment option 137
designing reports 153
DEX.INI
defined 235
ExportOneLineBody 150
dictionaries, defined 235
display names
described 92
for tables 135
display types
for reports 82
use in report sections 85
DisplayName, report property 35
DisplayType, field property 36
distributing reports 183
divider tool, using in report layout 31
division operator, use in calculated
fields 59
documentation, symbols and
conventions 3
DOW, calculated field function 65
Drawing Options window 40
drawn objects, properties, list 37
drop-down lists
defined 235
I N D E X
E
Edit Launch File window 174
Edit menu, described 12
elements of arrays, specifying 33
EndTemplateDocumentFooterBookma
rk, described 207
equality operator, use in calculated
fields 60
EXISTS, report restriction function 50
Exit, menu item 12
Exporting Data, chapter 149-150
exporting data with reports 149
exporting package files 184
ExportOneLineBody, DEX.INI setting
150
expressions, defined 235
F
Field, field property 36
Field Definition window 127
Field Descriptions, menu item 12
field properties, list 36
FieldID, field property 36
fields
adding to report template
documents 205
adding to reports 30, 33, 114
adding to the calculated field
expression 61
chapter 127-128
characteristics on reports 38
defined 235
described 89, 127
formatting 80
hiding on report layout 79
in graphics reports, applying
drawing options 40
object properties 36
opening 127
opening data type 128
properties, list 36
fields (continued)
removing from report template
documents 206
removing from reports 115
FieldType, field property 36
files, sending reports to 149
FIRST, report restriction function 50
First Item In Group, report display
type 83
First Occurrence Only, report display
type 84
Font
drawn object property 37
field property 36
FontBold
drawn object property 37
field property 36
FontColor
drawn object property 37
field property 36
FontItalic
drawn object property 37
field property 36
fonts
design issues 154
for graphics reports 40
for text reports 41
generic fonts for reports 40
specifying color for reports 40
specifying size for reports 40
substituting in reports 40
FontSize
drawn object property 37
field property 36
FontUnderline
drawn object property 37
field property 36
Footer Options window 73
footers
see also additional footers
defined 235
for groups 163
FORALL, report restriction function 52
form pattern, for report document
templates 210
Format, field property 36
Format Definition window 123
format fields
defined 235
described 81
example 82
use 82
format strings
composite formats 126
defined 235
described 125
example 125, 126
string formats 125
using to add static elements 125
FormatField, field property 36
FormatFieldSrc, field property 36
formats
aligning field information 124
applying to report fields 80, 81
chapter 123-126
composite formats 125, 126
currency, format options 124
defined 235
described 123
format strings 125
naming 123
numeric, format options 124
opening 123
options 124
string formats 125
FREQUENCY, report restriction
function 52
functions, see restriction functions,
system-defined functions,
user-defined functions
G
Gathering Data, part 88-102
Generate Resource Reports, menu item
11
generic fonts, for reports 40
Getting Started with the Report Writer,
chapter 7-9
global fields
chapter 127-128
opening 127
opening data type 128
Global Modifications, part 118-138
USERS
GUIDE
241
I N D E X
global variables
defined 236
using in calculated fields 62
graphics
design issues 154
in Word Template reports 208
graphics reports
aligning text items 41
applying drawing options 40
defined 236
tools specific to, described 30
greater than operator, use in calculated
fields 60
greater than or equal to operator, use in
calculated fields 60
groups
advanced groups 166
chapter 161-166
counting 164
counting items in 164
creating in reports using headers
and footers 71
described 71, 161
footers 163
headers 162
sorting information for 162
H
Header Options window 73
headers
see also additional headers
defined 236
for groups 162
Help menu, described 13
history tables, described 93
horizontal alignment, for preprinted
reports 159
HTML
defined 236
saving reports to 149
I
Ignore Case, key segment option 138
images, in Word Template reports 208
Import Package File window 185
Import Reports window 188
importing
package files 185
242
U S E R S
G U I D E
importing (continued)
reports from other dictionaries 187
validating results 188
Importing Reports, chapter 187-189
indexes, for tables 137
inequality operator, use in calculated
fields 60
Insert button, how used in Report
Writer 16
INT_STR, calculated field function 65
invoices
overview 169
printing 169
K
key segments
defined 236
described 136
options 137
keyable length
defined 236
described 120
keys
creating indexes for 137
defined 236
described 91, 136
example 136
key segments, described 136
multisegment keys, described 136
options 137
L
labels
adding columns 170
overview 169
printing 169
landscape pages, for reports 22
LAST, report restriction function 52
Last Occurrence, report display type 84
launch files
defined 236
described 174
layout
design issues 154
for preprinted forms 158
issues for report template
documents 225
modifying for reports 113
M
Macro menu, described 12
mailing labels 169
mailing reports
chapter 147-148
procedure 148
MainTable, report property 35
MainTableKey, report property 35
I N D E X
package files
contents 183
defined 236
described 183
exporting 184
import/export issues 186
importing 185
overwriting customizations 186
Packaging Reports, chapter 183-186
page creep, described 158
Page Footer table
in report template document 202
layout of 203
page footers, use in reports 29
Page Header table
example 203
in report template document 202
layout of 203
page headers, use in reports 29
page number tool, using in report
layout 31
O
object properties, for fields 36
offsets, for preprinted reports 159
OK button, how used in Report Writer
15
one-to-many relationship
defined 236
described 95
one-to-one relationship
defined 236
USERS
GUIDE
243
I N D E X
244
U S E R S
G U I D E
procedures (continued)
Printing modified reports 141-142
Removing an item from a report
template document 206-207
Starting the Report Writer 9
Updating the data source for a
report template 223-224
Using a modified report template
document 221-222
Using a picture from the picture
library 130
Using legends 77-78
Validating reports 188-189
Viewing from the Report Writer
109-110
Viewing virtual table information
101-102
Process Monitor, menu item 12
processing issues, for report template
documents 226
product support, for Report Writer 3
products, selecting product to modify 9
properties
for drawn objects 37
for fields 36
setting 35
Properties window, using 34
R
radio buttons, defined 237
radio groups
defined 237
use in reports 39
records
defined 237
described 89
maximum number for a report 21
skipping blank records 22
rectangle tool, using in report layout 31
Remove button, how used in Report
Writer 16
removing modified reports 182
report definition
chapter 19-25
creating 19
described 19
for Word Template reports 194
I N D E X
reports
adding fields 30, 33
adding pictures to 31
adding tables to 20
additional footers 29
additional headers 29
aligning fields 32
arranging items in layout area,
described 32-33
body, described 29
changing field types 82
common modifications 113
defining, procedure 20-25
empty fields, hiding 79
exporting to a file 149
field characteristics 38
finding report names 105
footer printing options 24
for exporting data 150
format options 22
formatting fields 80, 81
generating as Microsoft Word
documents 193
generic fonts 40
groups 161
header printing options 24
hiding fields in layout 79
importing from other dictionaries
187
layout window
described 27
illustration 27
sections 28
legends 77-78
limiting the records included 21
mailing 147
main table for report 20
modified reports 105
modifying report layout 113
optimizing 155
packaging 183
page footers, described 29
page headers, described 29
page orientation 22
positioning items in 33
printing
on preprinted forms 24
USERS
GUIDE
245
I N D E X
reports (continued)
printing
options 24
overview 141
printing report definition 25
report footers, described 29
report headers, described 29
report sections, chart 28
restrictions
defining 47-48
described 47
restriction functions 49-56
secondary tables 97
series 20
sizing items in 33
sorting
using a sorting definition 43
using main table key 43
storing 8, 173
table relationships
defining 96-99
described 95
illustration 96
template-enabled 193
text report options 23
tile tools used in layout 32
totaling and subtotaling 165
using report footers 25
validating 188
viewing modified reports 109
reports dictionary
changing location 174
changing name 174
core resources 173
default location 174
default name 174
defined 237
described 173
launch file 174
modified reports 173
storing locally 175
storing on network 175
Reports Library
defined 237
described 116
Reports on the web, see Reports Library
Reports window 193, 214, 218
246
U S E R S
G U I D E
S
scaling graphics and logos 131
Screen Output window 107
Search for Help On, menu item 13
Section
drawn object property 37
field property 36
sections
colorizing 28
in reports 28
security
accessing custom reports 179
accessing modified reports 178
accessing the Report Writer 177
accessing third-party reports 180
setting access to customized
resources 186
Security Role Setup window 177
Security Task Setup window 180
segment options, for key segments 137
Select All, menu item 12
I N D E X
suppressing
additional footers 74, 75
additional headers 74
symbols in documentation 3
system-defined functions
CUR_STR, described 64
DAY, described 64
DAY_NAME, described 64
DOW, described 65
INT_STR, described 65
LFT_STR, described 65
LNG_STR, described 65
MONTH, described 65
MONTH_NAME, described 65
nesting in calculated field 64
POWER_10, described 65
RGT_STR, described 66
STR_CUR, described 66
STR_DAT, described 66
STR_LEN, described 66
STR_LNG, described 66
STR_VCUR, described 67
STRIP, described 67
SUBSTRING, described 67
UCASE, described 68
using in calculated fields 63
WILDCARD, described 69
YEAR, described 69
T
tab-delimited files, saving reports to
149
Table, field property 36
Table Descriptions, menu item 12
table groups
described 92, 93
example 94
purpose 94
Table Relationship Definition window
97
Table Relationship window 97
table relationships
chapter 95-99
creating, procedure 96-99
defined 237
described 95
for virtual tables 102
USERS
GUIDE
247
I N D E X
U
UCASE, calculated field function 68
Undo, menu item 12
Unique, key option 137
user-defined functions
common functions 231
using for reports 69
using in calculated fields 63, 69
V
validating reports 188
VBA
defined 237
setting report legends 77
using to modify reports 115
vertical alignment, for preprinted
reports 159
248
U S E R S
G U I D E
W
warning symbol 3
WILDCARD
calculated field function 69
report restriction function 56
window controls
lookup button 15
standard buttons in Report Writer
15
Window Descriptions, menu item 12
Window Help, menu item 13
windows in Microsoft Dynamics GP
Alternate/Modified Forms and
Reports 110, 178
Edit Launch File 174
New Template 215, 219
Report Destination 195, 223
Reports 193, 214, 218
Security Role Setup 177
Security Task Setup 180
windows in Report Writer
Calculated Field Definition 57
Data Type Definition 119
Drawing Options 40
Field Definition 127
Format Definition 123
Import Reports 188
Picture Definition 129
Print Report Definition 25
Properties 34
Report Definition 19
Report Field Options 79
Report Restriction Definition 47
Y
YEAR calculated field function 69