Introduction
When creating subdirectories in SharePoint Library, you can’t submit directly to one the sub directories. Also when users add or change the subdirectories, how to handle this in InfoPath.
Compatibility
InfoPath 2003 and 2007: Full Support
Form Serices: No Support
Designing the Form Template
- Create the Receiving Data Connection
- Go to Menu Tools ->Data Connections
- Click the Add button
- Select Receive data
- Select SharePoint library or list
- Enter the path to your SharePoint Site
- Select the Library
- Select Item and Content Type
Figure 1: Select Item and Content Type
- Set the name to SubDirectories
- Add the Dropdown list to your form
- Add a dropdown list box to the form
- Double-Click the newly added list box, to open the Properties Dialog Box
- Select ‘Look up values in a data connection ,….’ In the list box entries section
- Select SubDirectories in the Data Connection Dropdown listbox
- Click on the ‘Select xPath’ button next to the Entries textbox
- Select the repeating node from the list (= SharePoint Library Name)
- Click on the Filter Data button
- Select Content_Type in the first dropdown list box
- Enter the text Folder in the third dropdown list box
Figure 2: Filter Data settings
- Click 3x the Ok button
- Set Value and Display Name to @Item
- Click the Ok button
- Test the form
Submitting the form to the selected sub directory
- Create a Submit Connection to the main SharePoint Directory
- Go to Menu Tools ->Data Connections
- Click the Add button
- Select Submit data
- Select To a SharePoint library
- Enter the Path of the Main SharePoint Library
- Set the file name
- Click the Finish button
- Set the submitting options
- Go to Menu Tools ->Submitting forms
- Select Enable Submit Commands and buttons
- Select Custom Submit using form Code in the Submit to dropdown list box
- Select Edit Form Code
- Click the Ok button
The Microsoft script editor will open
Point f : is the code using InfoPath 2003
Poit g : is the code using InfoPath 2007
//-- Create string objects for each field we will use to modify the FolderUrl –
var xnLocation = XDocument.DOM.selectSingleNode("my:myFields/my:DynamicInfo/my:xnLocation").text;
//-- Get a reference to the submit data connection –
var fc = XDocument.DataAdapters["Submit"];
//-- Modify the Submit connection URL we want to submit to by concatenating the //-- xnLocation and xnFolderName values –
fc.FolderURL = fc.FolderURL + "/" + xnLocation;
//-- Execute the submit connection –
try
{
fc.Submit();
eventObj.ReturnStatus = true;
}
catch(ex)
{
eventObj.ReturnStatus = false;
}
- Add the following code to the FormEvents_Submit function
Code for InfoPath 2007
try
{
// Get a reference to the form's XmlNamespaceManager object.
XmlNamespaceManager ns = this.NamespaceManager;
// Create an XPathNavigator object for the form's main data
// source.
XPathNavigator xnDoc = this.MainDataSource.CreateNavigator();
XPathNavigator xnCountry =
xnDoc.SelectSingleNode("/my:myFields/my:country", ns);
if (xnCountry != null)
{
FileSubmitConnection dc =
(FileSubmitConnection)this.DataConnections["Main submit"];
if (dc != null)
{
dc.FolderUrl = dc.FolderUrl + "/" + xnCountry.Value;
dc.Execute();
e.CancelableArgs.Cancel = false;
}
}
}
catch (Exception ex)
{
e.CancelableArgs.Message = "There was a problem submitting the
form:\n\n" + ex.Message;
e.CancelableArgs.Cancel = true;
}
- Save and Close the Microsoft Script Editor
- Finish the InfoPath 2003 form with the other business requirements
- Publish the Form Template to the SharePoint document library or document libraries
1 comment:
Post a Comment