EXPANDPROJECTHISTORY function
Created by Harry Lewis, Modified on Tue, 29 Oct, 2024 at 2:04 PM by Harry Lewis
Applies to:
- PM Module
- ERP: Acumatica, CEGID, Haufe x360, JAMIS Prime, MYOB Acumatica
TABLE OF CONTENTS
- Description
- Syntax
- Parameters
- What entities get returned by this function
- Ensuring no zero rows are returned
- Balance Types
- Examples
Description
The EXPANDPROJECTHISTORY function returns a list of only those projects and related entities that have non-zero Project Module amounts or quantities over the specified financial period range.
The main purpose of the function is to help you avoid zero balance/quantity rows in your project reports (similar to what ACCOUNTSWITHHISTORY does in the GL module). Configuring the BalanceTypesToLookAt parameter consistently with the Velixo project functions that you use can ensure there will not be a row where all "balance types to look at" are zero.
Syntax
EXPANDPROJECTHISTORY(Connection, Project, Task, ForecastRevision, AccountGroup, CostCode, InventoryItem, Branch, FromPeriod, ToPeriod, IncludeInactive, ExpansionOrder, BalanceTypesToLookAt)
Parameters
The EXPANDPROJECTHISTORY function uses the following parameters:
(see our article on filtering Velixo functions for information on how to include/exclude specific projects, tasks, revisions, account groups, cost codes, inventory items, and/or branches)
Parameter | Required/Optional | Description |
Connection | Required | The name of the connection as configured in the Connection Manager |
Project | Required | The Project(s) to check for project history. Default: all |
Task | Optional | The Task(s) to check for project history. Default: all |
ForecastRevision | Optional | The Project Forecast Revision name(s) to check for project history. Default: all |
AccountGroup | Optional | The Account Group(s) to check for project history. Default: all |
CostCode | Optional | The Cost Code(s) to check for project history. Default: all |
InventoryItem | Optional | The Inventory Item(s) to check for project history. Default: all |
Branch | Optional | The Branch(es) to check for the presence of project history. Default: all |
FromPeriod | Required
| The beginning financial period ID in MM-YYYY format |
ToPeriod | Required
| The ending financial period ID in MM-YYYY format |
IncludeInactive | Optional | TRUE/FALSE value indicating if inactive projects, tasks, account groups, cost codes, and inventory items are to be included in the results. Default: TRUE |
ExpansionOrder | Optional | Using the letters PTRACI, a list of the columns and their order to be included in the results. Default: PTRACI. See below for details |
BalanceTypesToLookAt | Optional | List of balance types (separated by commas) to be considered as "history". If left blank, any balance type with a non-zero amount or quantity will determine history presence |
What entities get returned by this function
The EXPANDPROJECTHISTORY function is able to return a table with the following columns, in the following default order:
Project code
Task code
Revision number of the project budget forecast
Account group code
Cost code
Inventory item ID
However, the columns (and the order) returned by this function can be controlled by using the ExpansionOrder parameter. Its default value is PTRACI, according to the first letters in the list above.
For example: specifying "PT" will only return those Project and Task codes (in that order) with non-zero balances.
Ensuring no zero rows are returned
If a particular combination of project, task, etc. is not returned by the function, it means that there are no project-related amounts or quantities of interest, as determined by the optional BalanceTypesToLookAt parameter.
However, by default, the function considers all project-related amounts and quantities, such as:
Any actual amounts or quantities
Any budgeted amounts or quantities
Any forecasted amounts or quantities, original and revised
Any committed amounts or quantities, original and revised, open and invoiced
Amounts to invoice
Change order amounts
Costs to complete and cost at completion
Important: Most of the time, your report will likely involve only some of these amounts and not all of them - for example, your report may only contain Velixo functions for actuals and budgets In such cases, to avoid zero rows in your report, we recommend that you use the BalanceTypesToLookAt parameter and synchronize it with the data that your report needs to display. This will allow you to narrow down the specific types of quantities and amounts that the function needs to consider when deciding whether to return a particular combination.
Balance Types
The following options are available for the BalanceTypesToLookAt parameter:
AmountToInvoice CommittedOpenAmount | CostAtCompletion, ForecastQuantity |
Examples
Here are a few simple examples to get you started. Explore the use of the various parameters to get exactly the data you are looking for.
Example 1 - return all project codes
=EXPANDPROJECTHISTORY("Demo","*",,,,,,,"01-2018","12-2019",,"P") Description Returns the Project Codes for all projects with activity (history) during the periods from 01-2018 to 12-2019 (inclusive)
Result (cell references have been used for some of the parameters in this example) |
Example 2 - return all project and task codes (sorted by project)
Description Returns the Project Codes and Task Codes for all tasks with activity (history) during the periods from 01-2018 to 12-2019 (inclusive). The only difference between this example and example 1 is ExpansionOrder parameter ("PT" instead of just "P").
Result (cell references have been used for some of the parameters in this example) |
Example 3 - return all project and task codes (sorted by task)
Description Returns the Task Codes and Project Codes (sorted by Task) for all tasks with activity (history) during the periods from 01-2018 to 12-2019 (inclusive). The only difference between this example and above example is the ExpansionOrder parameter ("TP" instead of "PT").
Result (cell references have been used for some of the parameters in this example) |
Example 4 - return all project and some task codes
Description Returns the Task Codes (excluding task 01), Account Groups, and Project Codes for all tasks with activity (history) during the periods from 01-2018 to 12-2019 (inclusive). Result Note that task 01 is not included: (cell references have been used for the parameters in this example) |
Example 5 - only consider TurnoverAmount and TurnoverQuantity balances
=EXPANDPROJECTHISTORY("Demo","*",,,,,,,"01-2018","12-2019",,"TAP","TurnoverAmount,TurnoverQuantity) Description Returns the Task Codes (excluding task 01), Account Groups, and Project Codes for all tasks with Turnover Amount or Turnover Quantity activity (history) during the periods from 01-2018 to 12-2019 (inclusive). The only difference between this example and the prior example is the use of the BalanceTypesToLookAt parameter. Result Note that, because only certain balances are being taken into consideration, the results are very different from the previous example: (cell references have been used for the parameters in this example) |
Was this article helpful?
That’s Great!
Thank you for your feedback
Sorry! We couldn't be helpful
Thank you for your feedback
Feedback sent
We appreciate your effort and will try to fix the article