Custom Forms
The plugin previously known as Dataverse Integration has been renamed to DataPress. This change reflects our commitment to enhancing user experience and aligning with our evolving product vision. All references to Dataverse Integration in the documentation, user interface will be updated to DataPress.
Design forms with Twig and HTML and capture submissions into your Dataverse instance.
Introduction
Using PowerApps or Dynamics 365 forms is not the only way to capture submissions from your WordPress website. You can use Twig and HTML forms syntax to create custom form layouts.
Custom forms are a feature provided in the free DataPress (Dataverse Integration) plugin at wordpress.org.
Use Twig to design a form
DataPress (Dataverse Integration) provides a pair of Twig tags, {% form %}{% endform %}
, to define a form. {% form %}
tag accepts the following parameters:
entity
-- (string, required) logical name of the target table.mode
-- (string, required)create
for creation forms.update
for update forms.record
-- (EntityReference) row (record) GUID, or EntityReference, or Table to update. Used inupdate
mode.recaptcha
-- (boolean) whether reCAPTCHA validation is required. See Protect form submissions with reCAPTCHA.redirect
-- (string) URL to redirect to after a successful submission.message
-- (string) custom message to show after a successful submission.messages
-- (object) custom messages to show after a form submission. For example,{ "success": "Thanks for a submission!", "failure": "Failed to submit the form. Try again later, please." }
keep
-- (boolean) whether to keep the form visible after a successful submission.false
is the default value and the form is collapsed.keep_data
-- (boolean) whether to keep values entered into form inputs after a successful submission.false
is the default value and all values are removed.
When the premium add-on is installed, the {% form %}
acts as a PowerApps form tag if the id
parameter is specified. See PowerApps forms documentation.
{% form entity="contact" mode="update" record=record|to_entity_reference %}
<form>
<div class="form-group">
<label>
First Name:
<input class="form-control" name="firstname" value="{{ record["firstname"] }}">
</label>
</div>
<div class="form-group">
<label>
Last Name:
<input class="form-control" name="lastname" value="{{ record["lastname"] }}">
</label>
</div>
<div class="form-group">
<label>
Email:
<input class="form-control" name="emailaddress1" value="{{ record["emailaddress1"] }}">
</label>
</div>
<div class="form-group">
<label>
Phone:
<input class="form-control" name="telephone1" value="{{ record["telephone1"] }}">
</label>
</div>
<div class="form-group">
<button type="submit" class="btn btn-primary">Send</button>
</div>
</form>
{% endform %}
Make sure to define your form between the <form></form>
tags. The form submission will be handled on the submit
event.
To link a form control to a corresponding table column, specify the logical name of the column in the HTML column name
, e.g. emailaddress1
for Email.
Read more about a form with a lookup
Protect form submissions with reCAPTCHA
To prevent spam submissions from getting into your CRM, add reCAPTCHA to your form. Add recaptcha=true
to the list of {% raw %}{% form %}{% endraw %}
parameters, and add the <recaptcha>
placeholder to a desired place in your form.
Before you start using reCAPTCHA in your forms, please configure reCAPTCHA in the plugin settings interface.
Example
{% set useRecaptcha = true %}
{% form entity="lead" mode="create" recaptcha=useRecaptcha %}
<form>
<div class="form-group">
<label>
First Name:
<input class="form-control" name="firstname">
</label>
</div>
<div class="form-group">
<label>
Last Name:
<input class="form-control" name="lastname">
</label>
</div>
<div class="form-group">
<label>
Email:
<input class="form-control" name="emailaddress1">
</label>
</div>
<div class="form-group">
<recaptcha>
</div>
<div class="form-group">
<button type="submit" class="btn btn-primary">Send</button>
</div>
</form>
{% endform %}
Create a Contact Us form
The plugin provides a Gutenberg block, "Dataverse Plain". It accepts Twig code and renders it as HTML at front-end. Custom forms allow creating new Dataverse / Dynamics 365 rows, as well as updating existing rows.
{% form entity="lead" mode="create" recaptcha=true %}
<form>
<div class="form-group">
<label>
First Name:
<input class="form-control" name="firstname">
</label>
</div>
<div class="form-group">
<label>
Last Name:
<input class="form-control" name="lastname">
</label>
</div>
<div class="form-group">
<label>
Email:
<input class="form-control" name="emailaddress1">
</label>
</div>
<div class="form-group">
<recaptcha>
</div>
<div class="form-group">
<button type="submit" class="btn btn-primary">Send</button>
</div>
</form>
{% endform %}
The {% form %}
Twig tag lets you configure the form settings, such as target table, submission mode (create or update), etc.
Form control name
columns refer to the corresponding table columns, such as firstname
, lastname
and emailaddress1
. Put the <recaptcha>
placeholder where you want to put reCAPTCHA control if you enable reCAPTCHA on your form. Before you use reCAPTCHA, please configure it in plugin settings.
Date Time and Date Only fields in custom forms
For example, you have several custom fields: cr1d1_dateonly
- Date Only format, cr1d1_datetime
- Date Time format.
{% form entity="contact" mode="create" record=record|to_entity_reference %}
<form>
<div class="form-group">
<label>
Account Name:
<input class="form-control" name="name" value="{{ record["name"] }}">
</label>
</div>
<div class="form-group">
<label>
Date Only field:
<input class="vdatetime" name="cr1d1_dateonly" value="{{ record["cr1d1_dateonly"] }}">
</label>
</div>
<div class="form-group">
<label>
Date Time field:
<input class="vdatetime" name="cr1d1_datetime" value="{{ record["cr1d1_datetime"] }}">
</label>
</div>
<div class="form-group">
<button type="submit" class="btn btn-primary">Send</button>
</div>
</form>
{% endform %}
Then you view page with this template. To fill in this form you should type content in Date only field in yyyy-mm-dd
or yyyy/mm/dd
format (like 2023-01-20
or 2023/01/20
), Date Time field in yyyy-mm-ddThh:mm
format (like 2023-01-20T12:30
).
Getting row GUID
After the row has been successfully created, you can get the guid using the redirect setting with the %s parameter.
For example, /?id=%s
will be replaced by /?id=00000000-0000-0000-0000-000000000000