What is a custom data type?
A custom data type is used on a step property to render a specific field or set of fields. A data type might represent a simple text box field for input or a more complex popup UI for user selection.
Let's look at the configuration of the “Decision” step:
data:image/s3,"s3://crabby-images/8e644/8e6441116a4b0f7ffda5444f82e6a474991f469e" alt=""
Configuration of the “Decision” step looks as follows:
data:image/s3,"s3://crabby-images/f03de/f03de22ea10f9aab478d8bea91d5c0aefed0116b" alt=""
About the above diagram, the “Decision” step has one property called “condition,” which is a “string” data type. When the step is rendered within the process designer, the “condition” property is rendered as a textbox.
data:image/s3,"s3://crabby-images/75f77/75f7731ed15eeb31603ff954982da43283f25bbe" alt=""
Custom data types
Custom data types can be configured using the data type screen of the FlowWright Configuration Manager.
data:image/s3,"s3://crabby-images/ebb39/ebb39b7e920c5cbb5cc9e5aebc96a43807243b98" alt=""
Select the “string” data type from the table and click on the View - Render menu option.
data:image/s3,"s3://crabby-images/ea540/ea5403ae77cb083141f8866b09b0d69696479b88" alt=""
When the “string” data type is rendered, it looks as follows:
data:image/s3,"s3://crabby-images/0a40b/0a40b54ad0b002a33ead715cf32413d217e93d10" alt=""
Writing a custom data type
Implementing the “IFWDataType” interface makes creating a custom data type easy. The following code shows the actual code for the “string” data type.
Here's an example video of how to build a custom data type:
Here's the code that was used in the custom data type:
using FlowWright.Engine; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace FW10CustomItems { [DataTypeData("fwtextbox")] public class FWTextBox : IFWDataType { public string Render(FWDataTypeContext oDataTypeContext) { string sValue = ""; if (!string.IsNullOrWhiteSpace(oDataTypeContext.SelectedValue)) { sValue = oDataTypeContext.SelectedValue; } string sHTML = $"<input name='{oDataTypeContext.ControlID}' type='text' value='{sValue}' id='{oDataTypeContext.ControlID}'>"; return (sHTML); } } }