Display WordPress Form Submissions with DataKit

This feature is COMING SOON! Sign up for updates

DataViews is a WordPress component that provides an API to render datasets using different types of layouts (table, grid, list, etc.). DataViews is included with WordPress.

DataKit is a PHP SDK that allows you to easily create DataViews from a variety of data sources, including WS Form.

Demo

Tutorial

The DataKit plugin includes a WS Form data source which can be used to create DataViews that show WS Form submissions from any of your forms. Registering a DataView is achieved with some simple PHP code that can be added to functions.php or a code snippet plugin.

This tutorial explains how the above demo is achieved.

Install DataKit

To learn how to install the DataKit plugin, please refer to https://docs.datakit.org/.

Create Table Data Source

First create an instance of the WSFormDataSource class. In this example we create an instance for form ID 123. Change 123 to match your form ID.

// Create table data source
use DataKit\Plugin\Data\WSFormDataSource;

$dk_table_data_source = new WSFormDataSource( 123 );

Create Table Fields

Next we configure which fields we want to display in the data view. DataKit provides a variety of different field types. In this example we are going to display an image field for a WS Form File Upload field and text fields for the name, email and phone fields.

// Create table fields
use DataKit\DataViews\Field\ImageField;
use DataKit\DataViews\Field\TextField;

$dk_table_fields = array(

    // File Upload (ImageField)
    ImageField::create( 'field_1', 'Photo' )->not_sortable()->alt( 'My Image' )->size(50),

    // First Name (TextField)
    TextField::create( 'field_2', 'First Name' )->sortable()->always_visible(),

    // Last Name (TextField)
    TextField::create( 'field_3', 'Last Name' )->sortable()->always_visible(),

    // Email (TextField)
    TextField::create( 'field_4', 'Email' )->sortable(),

    // Phone (TextField)
    TextField::create( 'field_5', 'Phone' )->sortable(),
);

You can also include other submission meta data by changing the first parameter in the create method, for example:

  • id
  • date_added
  • date_updated
  • status
  • status_full
  • duration
  • tracking_remote_ip (Any tracking enabled is available as a meta key)

For security reasons, user data is not exposed publicly.

Create Table Data View

Next we create the table data view by using the table method of the DataView class. In this example, we are using the paginate method to set the rows per page to 5.

// Create table data view
use DataKit\DataViews\DataView\DataView;

$dk_table_data_view = DataView::table(

    // Table ID
    'ws-form-dataview',

    // Table data source
    $dk_table_data_source,

    // Table fields
    $dk_table_fields,

)->paginate(5);

Register Table Data View

Next, we register the table data view. This needs to occur when the WordPress init action runs.

// Register table data view
add_action( 'datakit/loaded', function() use ( $dk_table_data_view ) {

    do_action( 'datakit/dataview/register', $dk_table_data_view );
} );

Add Shortcode to Page

Once the table data view has been registered it can then be embedded into any page using the dataview shortcode.

[dataview id="ws-form-dataview"]

Tips

  • When using File Upload fields you should choose a public File Handler setting such as Media Library, otherwise the images won’t render in the DataView.

Further Reading