Creating an InfoPath Form
In this article we will learn how can we create and InfoPath Form in Microsoft Office 2007.
This article will discuss upon how Microsoft Office InfoPath Forms can be used. InfoPath forms can be used whenever there is a need of using custom template, such as Leave Application Form or Compensation Form etc.
Pre-requisites for InfoPath Form:
Developing an InfoPath Form:
- On the Server:
- Microsoft Office InfoPath 2007
- On the Client:
- Internet Browser
To develop an InfoPath Form Template, follow the following steps:
In my next article I will discuss on how can we publish an InfoPath Form to a SharePoint Server 2007.
- Open Microsoft Office InfoPath Form from Start-> All Programs-> Microsoft Office-> Microsoft Office InfoPath 2007.
- In the "Getting Started" dialog box that appears, choose "Design a Form Template".
- In the next dialog box that appears, choose a Blank Form Template. Also make sure that "Enable browser-compatible features only" check box is checked and click OK.
- A blank form template screen will appear. In the right hand side of the template screen, you will see Design Tasks Pane, if it doesn't appear, go to View-> Design Tasks. And click on "Layout".
- In the next pane that appears, select the Table layout. For this example, I will choose a Two- Column Table.
- A table with one row and two columns will be added in the Design Pane. Adjust the height and width of the table. To add a new row, select the existing row and in the right side pane, click on "Add Table row".
- Add the text to Left Column of the table and Controls to right column of the table. To add controls, click on the Controls option in the main Design Tasks Pane.
- Finally, the Form will resemble as follows:
- To change the name of the controls, select the control, right click on the Green Button and go to the Properties of the Control.
- In the dialog box that follows, put the desired field name.
- For Button Controls, select the Action as "Rules and Custom Code" and in Label, provide the desired name.
- Before starting any code for the Form Template, choose the language you want to code in VB or C#.
- To do so, go to Tools->Form Options, in the Category, select Programming and set the desired language and path where you want to save your InfoPath project.
- Now save the form before starting any code.
Note: To code the InfoPath Forms, you should have the "Microsoft Visual Studio Tools for Applications" options enabled. To do so, go to Control Panel->Add/Remove Programs->Microsoft Office Infopath 2007. Click on Change and enable the .NET Programmability Support.
- Now to code on the Button Click event, in the Button Properties Dialog Box, click on "Edit Form Codeâ€¦". A Visual studio project will open, with the Button Click Event.
- Code it in the same way as you code for any other C# project. The Submit_Clicked Event will resemble the following code:
public void Submit_Clicked(object sender, ClickedEventArgs e)
string _position = MainDataSource.CreateNavigator().SelectSingleNode
string _description = MainDataSource.CreateNavigator).SelectSingleNode
string _category = MainDataSource.CreateNavigator().SelectSingleNode
string _location = MainDataSource.CreateNavigator().SelectSingleNode
SqlCommand _oCommand = new SqlCommand();
_connstring = @"DataSource=./SQLExpress;Initial Catalog=My_DB;Integrated Security=SSPI";
_oConnection = new SqlConnection(_connstring);
_oCommand.Connection = _oConnection;
_oCommand.CommandType = CommandType.Text;
"INSERT INTO tbl_Position (Position,Description,Category,Location) values
('" + _position + "','" + _description + "','" + _category + "','" + _location + "')";
- The first parameter of the SelectSingleNode is an XPath value. To get the XPath value of a control, select "Data Source" from Design Tasks Pane.
- In the next pane that appears, right click on the name of the control, select "Copy XPath", and paste it in the Visual Studio Code.
- Build the project, when the status bar shows "Build Succeeded", close Visual Studio.
In this article we learnt how we can create an InfoPath Form.