Pricefx Classic UI is no longer supported. It has been replaced by Pricefx Unity UI.

 

Configure Denial Reasons

When creating a workflow, it is possible to define denial reasons. The reasons are predefined options for the approvers to choose from or a free text field. Providing the denial reasons can be optional or mandatory.

There are two ways to define the denial reasons: 

  • Within a workflow logic using the withDenialReason method. This is applicable for all of the approvable documents. For details see the section 100658295. 
  • Price Grid Items can have denial reasons configured even if they do not use workflow. (This is the case of Live Price Grids where the individual items can be approved/denied without an approval workflow – approvability is a property of the LPG items.) Denial reasons for Price Grid Items are defined in Configuration > Price Setting > Price Grid Denial Reasons.

Denial Reasons in Workflow

To define denial reasons for an approval workflow, use the following method in your workflow logic:

withDenialReasons(List<String> denialReasons, boolean isDenialReasonOptional)

This method can be added both on the workflow and workflow step level. If there is no denial reason specified on the workflow step level, the algorithm checks the parent workflow for denial reasons. The free text field Other is added automatically.

Once the denial reason is specified, you will get a dialog like this after you click the Deny icon:

If 'isDenialReasonOptional' is set to 'false' (denial reason is mandatory), you must select or enter a reason to be able to proceed. The denial reason is stored in the comment field.

Examples

Example 1 – Defining Global Reasons for the Whole Workflow

workflow.withDenialReasons(["Reason1", "Reason2", "Reason3"], false)
workflow.addApprovalStep("step1").setReason("My Reason").withApprover("admin")
workflow.addApprovalStep("step2").setReason("My Reason2").withApprover("admin")

Here we have two steps, both inheriting the denial reasons from the workflow itself. The denial reason is mandatory. This configuration is shown in the screenshot above.

Example 2 – Defining Global Reasons with an Override on Workflow Step Level

workflow.withDenialReasons(["Reason1", "Reason2", "Reason3"], false)
workflow.addApprovalStep("step1").setReason("My Reason").withApprover("admin")
workflow.addApprovalStep("step2").setReason("My Reason2").withApprover("admin").withDenialReasons(["ReasonStep1", "ReasonStep2", "ReasonStep3"], false)

Here we have two steps, first one inheriting the denial reasons from the workflow itself, the second one has its own denial reason which has a higher priority. The denial reason is mandatory.

Example 3 – Defining Single Step Reasons

workflow.addApprovalStep("step1").setReason("My Reason").withApprover("admin")
workflow.addApprovalStep("step2").setReason("My Reason2").withApprover("admin").withDenialReasons(["ReasonStep1", "ReasonStep2", "ReasonStep3"], false)

Here we have two steps, first one has no denial reasons defined, so there is no user input needed during denial. The second one has its own denial reasons. The denial reason is mandatory.

Found an issue in documentation? Write to us.

Â