Manoj Kumar
Aug 30, 2011
  5594
(0 votes)

EPIServer XForm Data Retrieving

XForms contains logic to store and present forms and data posted from forms. Together with the forms editor in EPiServer CMS 6 Edit mode, it enables editors to create and modify forms and to view form data. The XForms architecture enables customization, allowing developers to adapt the XForms functionality. You can get more info on the following link EPI Server Tech Note.

XForms uses the Dynamic data store to save the form data. Retrieving of data can be done using the XFormData class.  Below setup() function is called on initialization of form.

 

Retrieving data -

private void SetupForm() 
{
FormControl.FormDefinition = Form;
FormControl.AfterSubmitPostedData += 
new SaveFormDataEventHandler(FormControl_AfterSubmitPostedData); 
List<string> lstxd = new List<string>(); 
foreach(XFormData xd in Form.GetPostedData()) 
{
lstxd.Add(xd.Data.InnerXml);
}
this.GridView1.DataSource = lstxd; 
this.GridView1.DataBind(); 
}
 

The highlighted code is added by me to retrieval the data in xml format.

Below is data grid showing the output of data entered in the form.

image

 

What happens when I edit the form in edit mode -

 

(I) Adding a new field and then retrieving the data-

 image

 

 

 

image

Adding new field column and then inserting a record results in new empty field node added to xml for old data and new data node will contain the value.

 

(II) Removing the field and then retrieving the data -

 

image

Removing the field column from xForm and then retrieving the data results in removal of the field specific node from xml.  But the data previously posted is still available in the store you can retrieve it. I retrieved it again adding the same field column in the form. You can also retrieve it programmatically using XFormData class.

like retrieving and inserting we can do the other CRUD operation using XFormData class.

 

 

Other feature -

 

personalization can be used with xForm:-

 

image

 

Integration of xForm with other EPI Server feature -

You can use xForm as dynamic content. Mixing XForm, Dynamic data content and visitor group features you can created powerful forms.

The other thing I wanted to do is integrate xForm and globalization feature. I wanted a regional page having xForm with field called “country” that has a default value like “UK” in case of “en-gb” page. Unfortunately I was not able to set the default values to text field in xForm in edit mode.

Aug 30, 2011

Comments

Please login to comment.
Latest blogs
Opti ID overview

Opti ID allows you to log in once and switch between Optimizely products using Okta, Entra ID, or a local account. You can also manage all your use...

K Khan | Jul 26, 2024

Getting Started with Optimizely SaaS using Next.js Starter App - Extend a component - Part 3

This is the final part of our Optimizely SaaS CMS proof-of-concept (POC) blog series. In this post, we'll dive into extending a component within th...

Raghavendra Murthy | Jul 23, 2024 | Syndicated blog

Optimizely Graph – Faceting with Geta Categories

Overview As Optimizely Graph (and Content Cloud SaaS) makes its global debut, it is known that there are going to be some bugs and quirks. One of t...

Eric Markson | Jul 22, 2024 | Syndicated blog

Integration Bynder (DAM) with Optimizely

Bynder is a comprehensive digital asset management (DAM) platform that enables businesses to efficiently manage, store, organize, and share their...

Sanjay Kumar | Jul 22, 2024

Frontend Hosting for SaaS CMS Solutions

Introduction Now that CMS SaaS Core has gone into general availability, it is a good time to start discussing where to host the head. SaaS Core is...

Minesh Shah (Netcel) | Jul 20, 2024

Optimizely London Dev Meetup 11th July 2024

On 11th July 2024 in London Niteco and Netcel along with Optimizely ran the London Developer meetup. There was an great agenda of talks that we put...

Scott Reed | Jul 19, 2024