Overview & Tutorial: User Defined Project Properties in a Work Order Based Report

Overview & Tutorial: User Defined Project Properties in a Work Order Based Report

This article explains how to use a single or multiple User Defined Project Property (UDPP) in a report based on a single work order. The issue that makes this a subject for training is the fact that the UDPP (User Defined Project Properties) are populated to a single table in the factory database, one that contains all the UDPP for all the projects in a specific configuration. It is not a matter of merely defining the data source for the report component. 

This article focuses on three ways to configure a report to consume the UDPP. One method to configure a report involves subreports and parameters. Another method is with subreports and event code. The third method is with a reverse database relationship and three extra databands. The method that you use will depend on how you want the data to be displayed, and whether you want all the properties to be displayed or only some of them. 

This article shows you how you can configure a report connecting to a work order database to consume one or more UDPP in 3 different ways. The issue to overcome is that a work order can be taken from multiple projects, but we want to display only the properties associated with a single work order and a single project.

One of the ways to accomplish this is to set up a reverse parent/child relationship in the report and add the appropriate databands. See the attached report named “Workorder Summary – ProjectProperties” as an example of how to accomplish this.

  1. The advantage of this method is that it is the simplest of the three methods.
  2. The UDPP are displayed as a simple list from top to bottom. This may be a limitation with this method, depending on your specific requirements.

The following tutorials assume that you have a basic knowledge of the report designer. If you don’t, click here for the Reporting Basics Course outline.

They also use only the default project properties with values given to those existing properties. No new properties were added.

Tutorial 1:

In this first of three tutorials, we will create a Shipping Manifest Report that contains all of the User Defined Project Properties using the reverse parent/child relationship, as mentioned above. We will start with the default Microvellum report Product Shipping Manifest.

  1. Open Toolbox and click: “Toolbox Setup > Design Reports > Design Manufacturing Report > New Report From Existing.”
  2. Select Product Shipping Manifest and change the name to “Product Shipping Manifest – Project Properties” in the Report Name box of Report Setup. Click Microvellum Factory under Database Types and tick the checkbox for the ProjectProperties database table, and click OK.
  3. Add a parent relation to the Projects table. Click the Dictionary tab in the lower right corner and expand “Data Sources > New Data Set > Projects.” Right-click Projects and left-click New Relation. Set the properties, as shown in Fig. 1 with Products as the parent, and Projects as the child. This is the reverse of how a database relation is normally setup but is necessary in this instance.

  4. Fig. 1

  5. Click the Page1 tab and add a Databand to the area of the report immediately below PageHeaderBand1. After placing it, double click it and set the Count Data property to a value of 1. Don’t set any other properties of that databand. Set the Name property of the databand to “DataProductsCount.”

  6. Fig. 2

  7. Add a second Databand immediately below that one and name it “DataProjects.” Set its Data Source to Projects, the Relation to Products, and the Master Component to “DataProductsCount.”
  8. Add a third Databand immediately below that one and name it “DataProjectProperties.” Set it Data Source to ProjectProperties, the Master Component to “DataProjects, and the filter to ProjectProperties.PropertyName -> NotContaining (the string) “user-defined property” as shown below.

  9. Fig. 3

  10. Add a text component to the databand named DataProjects to display the project name. The expression should be: “{Microvellum.Globalization.Culturestrings.PROJECTNAME}: {Projects.Name}.”
  11. Add two text components to the databand named DataProjectProperties to display the Project Property name and value. The expressions should be: “{ProjectProperties.PropertyName}” and “{ProjectProperties.PropertyValue}.”
  12. Click the Preview tab and correct any errors. The rendered report should appear similar to Fig. 4.

  13. Fig. 4

Tutorial 2:

The second in the series of three tutorials will show you how to create a Work Order Summary that contains selected User Defined Project Properties using subreports and parameters, and that displays those properties in specific locations. We will start with the default Microvellum report Work Order Summary.

  1. Open Toolbox and click: “Toolbox Setup > Design Reports > Design Manufacturing Report > New Report From Existing.”
  2. Select Work Order Summary and change the name to “Work Order Summary – Project Properties(parameter)” in the Report Name box of Report Setup. Click Microvellum Factory under Database Types and tick the checkbox for the ProjectProperties database table, and click OK.
  3. Make sure you are working on Page1 of the report and click on the Group Header Band with the data source of Products.Projects.Name (GroupHeaderBand2), and if you’re working in Imperial, increase the height of the band to 1. This provides room to insert the subreports in the following steps.
  4. Click: “Components > Sub Report” to add a subreport to the GroupHeaderBand you modified above. Set the height to 0.65.”

  5. Fig. 5

    When the Sub Report box is displayed, click the tab Parameters, and then the Add button. In the Name box, enter the string “ProjectLinkIDParam” without the quotation marks. Then click the Fx formula button next to Expression and enter Products.LinkIDProject for this report. Alternatively, navigate to that field in the tree structure and double click it. Click OK after verifying that the parameter properties are identical to the sample below. If you need to reenter the subreport options box, double click on the subreport container on Page1.

    The tab name of each subreport corresponds with the Sub Report Page name defined for each subreport component.

    Fig. 6

  6. Repeat this step and add a second subreport with the same parameter. Make sure that the extents of the subreports are inside the extents of the group header band, as shown below.

  7. Fig. 7

  8. Click the Preview tab and correct any errors. Save your report.
  9. Click the tab for the first subreport and add a databand, 0.18” in height. Add a text component to that databand, and set it to the same height as the databand, with the Top property set to 0. Set the Data Source for that databand to be ProjectProperties and add a filter by clicking the Filters tab and selecting Expression in the Field Is dropdown list box. Click the Fx button and add the following expression there: 
    ProjectProperties.LinkIDProject = Me("ProjectLinkIDParam") AndAlso ProjectProperties.PropertyName.ToLower.Contains("scope of services")

    This filter, along with the parameter already defined for the subreport, will return only the Scope of Services project property.

  10. Once this first databand is set up as needed, copy and paste it, so you have a series of three identical databands. Modify the filter expression of the second databand to be: 
    ProjectProperties.LinkIDProject = Me("ProjectLinkIDParam") AndAlso ProjectProperties.PropertyName.ToLower.Contains("exclusions”)

    Modify the filter expression of the third databand to be: 

    ProjectProperties.LinkIDProject = Me("ProjectLinkIDParam") AndAlso ProjectProperties.PropertyName.ToLower.Contains("addendum”)
  11. Copy and paste the three databands from the first subreport into the second subreport. Do this by clicking on the first databand in the first subreport, and pressing Ctrl+C to copy. Then click the tab for the second subreport and press Ctrl+V to paste, and click in the grid area of that subreport. Repeat this series of steps for all three databands.

  12. Fig. 8

  13. Modify the filters expressions in the three databands you just copied. The filter expression for each databand should contain one of the expressions below:

    ProjectProperties.LinkIDProject = Me("ProjectLinkIDParam") AndAlso ProjectProperties.PropertyName.ToLower.Contains("date of drawings")

    ProjectProperties.LinkIDProject = Me("ProjectLinkIDParam") AndAlso ProjectProperties.PropertyName.ToLower.Contains("conditions”)

    ProjectProperties.LinkIDProject = Me("ProjectLinkIDParam") AndAlso ProjectProperties.PropertyName.ToLower.Contains("terms”)

  14. Click the Preview tab and correct any errors. Save your report. The rendered report should appear similar to Fig. 9.

  15. Fig. 9

Tutorial 3:

The third in the series of three tutorials will show you how to create a Work Order Summary that contains selected User Defined Project Properties using subreports and event code, and that displays those properties in specific locations. It also contains a combination of program-defined project properties and hard-locked values. We will start with the default Microvellum report Work Order Summary.

  1. Open Toolbox and click: “Toolbox Setup > Design Reports > Design Manufacturing Report > New Report From Existing.”
  2. Select Work Order Summary and change the name to “Work Order Summary – Project Properties(events)” in the Report Name box of Report Setup. Click Microvellum Factory under Database Types and tick the checkbox for the ProjectProperties database table, and click OK.
  3. Make sure you are working on Page1 of the report and click on the Group Header Band with the data source of Products.Projects.Name (GroupHeaderBand2), and if you’re working in Imperial, increase the height of the band to 1.45. This provides room to insert the subreports and various other fields discussed in the following steps.
  4. Add a report variable named “strProjectID.”
  5. Add a ReportTitleBand component and add the following code to Before Print event: 
    strProjectID = Products.Projects.LinkID
  6. Add text components and subreport components, as shown below.

  7. Fig. 10

  8. Add databands and text components in each subreport, as shown in the attached report sample. Add filters in each databand to limit the data returned to only what is needed.

    ProjectProperties.LinkIDProject = strProjectID AndAlso (Me.ToString(Me.ProjectProperties.PropertyName).ToLower.IndexOf(Me.ToString("date of drawings").ToLower) <> -1)

    ProjectProperties.LinkIDProject = strProjectID AndAlso (Me.ToString(Me.ProjectProperties.PropertyName).ToLower.IndexOf(Me.ToString("addendum").ToLower) <> -1)

  9. Click the Preview tab and correct any errors. Save your report. The rendered report should appear similar to Fig. 11. The yellow highlighting represents UDPP, the green represents program-defined project properties, and the blue represents hard-locked values.

  10. Fig. 11

    • Related Articles

    • Modify Work Order Interface

      As of build 20.1.608.641, there is a Modify Work Order interface that allows users to make changes to work orders more conveniently. Access the interface: Open a work order in the processing center. Select General > Modify Work Order. Fig. 01 – ...
    • Understanding the Work Order Creation Interface

      Once a new work order has been created, the Work Order Creation interface will be displayed. This interface will allow you to select products and set specific options and properties for the work order.  Configure Name – Allows you to change the name ...
    • Report Training Tutorial 1: Report Designer Basics

      This is the first of a series of five Reports Training Tutorial videos.  This video presents some basic concepts that will be useful for first-time users of Report Designer.  By the end of this video, you will have some familiarity with the user ...
    • Business Objects - Configuring in a Report Dataset

      This tutorial is the first in a series of three that demonstrates how to configure Microvellum Business Objects in a sample report dataset. Click here   for an overview of how they are intended to be used. We will set up the dataset to contain the ...
    • Work Order Naming

      Work Order Naming Work orders can be set up to use a standardized naming convention using variables (fields). You can also add a custom name for each work order created. Without setting this up, the default name will be a date/time stamp. When using ...
    • Recent Articles

    • Toolbox Release Notes | Build 25.1.0114.641

      The following release notes apply to Toolbox build 25.1.0114.641. UI Fixes Several issues were reported and discovered within the OEM 2025 user interface. The following issues have been resolved: Fig. 1: Excess commands on the tool strip being ...
    • Toolbox Release Notes | Build 25.1.102.641

      The following release notes apply to Toolbox build 25.1.102.641 Toolbox OEM 2025 Work smarter, and faster with Toolbox 2025 (OEM). With an OEM Subscription, you’ll gain access to the latest toolsets and innovative features of Toolbox 2025. ...
    • What’s New in Toolbox 2025 (OEM)

      Work smarter, faster with Toolbox 2025 (OEM). With an OEM Subscription, you’ll gain access to the latest toolsets and innovative features of Toolbox 2025. Improvements Toolbox UI Overhaul OEM 2025 introduces several updates to the appearance and ...
    • Toolbox Release Notes | Build 24.1.1206.641

      The following release notes apply to Toolbox build 24.1.1206.641 MV Server Nesting Fix There was a reported issue occurring when users attempted to remotely process work orders using a nesting station on MV Server. When attempting to process the work ...
    • Microvellum Foundation Library Release Notes | Build 24.1127

      The following release notes apply to Microvellum Foundation Library build 24.1127. Additions Added a new Soffit product to the Upper Cabinet Accessories category. Added the Top Filler (Ceiling Scribe) option to Upper and Tall cabinets. (Corner ...