Quote of the day
“Personalization means different things to different people.” – Ken Moss
No EV-DO
I forgot to check at the airport, so I’ll do that when I leave on Wednesday. But sadly, I’ve yet to see the big 1X icon change to a beautiful Ev (signifying a 500kbps data connection) on my phone anywhere. Oh well, at least we know it’s coming J
A frequent question from InfoPath users is “How can I pass parameters to a new InfoPath form when it is created?”
Unfortunately, there’s no built-in functionality for passing command-line parameters to infopath.exe.
BUT, that doesn’t mean it can’t be done J
Note that the solution below requires the InfoPath SP-1 Preview.
Solution:
Jscript files can instantiate InfoPath with a new form from a template using NewFromSolution(). Jscript can also access the InfoPath DOM and pass parameters to it. And finally, Jscript files can also accept command-line parameters.
Usage:
In my case, I wanted my C# application to pass parameters to a new Form. Basically, the user (running my App) searches the SQL database for a customer (in my case, patient) account. They can then view/edit all of that account’s data right in the app. The user can then select a date and time for an appointment and click “Create Encounter.” This button calls my jscript file, passing it the ID number, date, and time that were selected. The Jscript file creates a new InfoPath form from the template, and fills in the ID number, date, and time. The Form Template has the “AfterChange” event for the ID number text box set so that it queries the database with that ID number, which returns that customer/patient’s information and populates all relevant fields in the Form. It then closes InfoPath, and my application simply says “Encounter file created.”
The form’s submit code puts it in a SharePoint library with a unique filename generated from the ID number and date/time of the appointment.
Calling the script:
In VB .NET, this is a simple matter of:
Dim ProcID As Integer
Dim Proc As Process
ProcID = Shell("cscript script.js " + IDnum + " " + Date+ " " +Time + " " + AMPM)
Proc = Process.GetProcessById(ProcID)
Proc.WaitForExit(3000)
MsgBox("Form created.")
The Script:
//myscript.js
//parse parameters
if(WScript.Arguments.count()==4)
{
var param1 = WScript.Arguments.Item(0);
var param2 = WScript.Arguments.Item(1);
var param3 = WScript.Arguments.Item(2);
var param4 = WScript.Arguments.Item(3);
}
//Start the application
var oApp = new ActiveXObject("InfoPath.Application");
WScript.Echo("InfoPath Version: " + oApp.Version);
//Open an InfoPath document from the published template
var oXDocumentCollection = oApp.XDocuments;
var oXDocument = oXDocumentCollection.NewFromSolution("http://server/Forms/template.xsn";;);
// Get pointers to the target fields
var oID = oXDocument.DOM.selectSingleNode("//ID");
var oDate = oXDocument.DOM.selectSingleNode("//my:Date")
var oTime = oXDocument.DOM.selectSingleNode("//my:Time")
var oAMPM = oXDocument.DOM.selectSingleNode("//my:AMPM")
//Update the fields
oID.text = param1;
oDate.text = param2;
oTime.text = param3;
oAMPM.text = param4;
//Submit the Form
oXDocument.Submit();
//Close up shop
oXDocumentCollection = null;
oApp.Quit();
oApp = null;
This is a ready-to-go script file and all you need to change is A) The number of parameters B) The location of your template and C) The names of the fields you wish to populate. You also may not want to submit the file or close InfoPath. Or you may want to use oXDocument.SaveAs();