Monday, December 20, 2010
Difference between Sharepoint Document Library and List
Library: It store document/files.
List: It store data in table structure.
Library: It has versioning concept.
List: As it store only data, it doesn't have versioning concept.
Library: Think in terms of folder in your computer which store only files/images/pdf/media files.
List: Think in term of MS Excel and MS Access database; which store only data and not (Physical) file.
Hope this could be useful.
Friday, December 17, 2010
Failed to connect to an IPC Port: Access is denied
Doing some research for couple of days, i came to know that all forms are converted into jobs and all those jobs are executed by Timer service. So below command will run all pending sharepoint jobs on MOSS:
-- stsadm.exe -o execadmsvcjobs
Issue: Some how, maximum jobs got executed and few jobs failed with error: "Failed to connect to an IPC Port: Access is denied".
(After running above command, try to refresh page and check your form status. If its still in "Installing" Or "Upgrade" Or "Deleting" status, then you can read ahead...)
Again with my 2 days research, I got to know that jobs which failed needs to execute by Service Or System Account (Account which is created during Sharepoing installation). For me as a Sharepoint programmer at beginner level, I didn't got System account from my IT Service department. So, I thought to opt for another solution.
I found another solution: Solution Mangement Page on MOSS.
Now, every form template which is verify/uploaded onto server will generate unique ID and that ID will be stored in Solution Management. You can check it in Central Admin -> Operations.
This page will store all *.wsp (Sharepoint Solution Package) files.
If you are not sure which solution is associated with your uploaded form, then follow below steps:
- Open your server computer and check in "C:\Program Files\Common Files\Microsoft Shared\web server extensions\12\TEMPLATE\FEATURES".
- You can find folder name with non-user friendly name like "FT-01-4f0153a1-906a-7d5e-0e93-2d469bc3d0e4".
After you know your solution file, Click on your solution file (.wsp) on Solution Management page and click on "Deploy Solution" link. Don't be greedy. Yet your status has not changed yet. Again this deployement job needs to be executed by above command. Now, check your .wsp file status on Solution Management page. It should be "deployed" status and Deployed To should be "Globally Deployed" status. After this time, a folder will be created with *.wsp name onto your Server file system ("C:\Program Files\Common Files\Microsoft Shared\web server extensions\12\TEMPLATE\FEATURES")
Now, you can check your infopath file status on "Manage Form Templates" page.
Hope this could help you with the solution.
Do send me your feedback and query.
- Chintan
Thursday, December 9, 2010
Generate auto generate filename for infopath form
There are some situations where we need to auto generate an infopath filename instead of user giving their own filename and messing the work. Here we go.
Create a simple blank form with single textbox and single button (Save).
Create Filename field:
Infopath store all fields in “Main Data Source” data source. You can list all fields (text box, button, repeater control etc) in Main Data Source and all Data Connection which you create (to access external data source) are stored in “Secondary Data Source” data source. You can open Data Source with below steps:
2. Select Main Data Source from drop down and right click on myfields.
3. Click on Add and give filename as Filename in Name field with Text type.
- Tools -> Data Connections. This will open Data Connection window which will list all data connection in the form.
- Click on Add button to add new connection (Submit).
- Click on 'Submit data' option on 'Create new connection to' as we are submitting form onto form library and not receiving any data.
- Choose Microsoft sharepoint list as we are submitting infopath form onto sharepoint list.
- Give your respective form library path (where your form will save) in Document Library text box.
- Click on FX button (beside Filename textbox).
- Click on 'Insert Field or group' to choose Filename field (created above).
- Enter valid Data connection name.
- Click Finish button.
- Tools -> Data Connections. This will open Data Connection window which will list all data connection in the form.
- Click on Add button to add new connection.
- Click on 'Receive data' option on 'Create new connection to' as we getting count from respective form library. Note: Sharepoint define default column know as 'ID' which gives incremental value of forms in form library (same like SQL Server 2005 and later provides).
- Chose Microsoft sharepoint list because we will fetch total count from sharepoint list.
- Give your respective form library path (where you infopath will fetch total count of form in form library)
- Choose your respective Form Library.
- Uncheck all check box except ID (this field will give total count of rows in form library)
- Click next.
- Enter valid Data connection name.
- Click Finish button.
- Note: I assume you have created Form Library on your sharepoint site. This is the library where your form will be saved with auto generate filename when submit / Save button is clicked.
- Now, we have created 2 data connection: Submit & Generate ID. Now, we will bind this connection with Save button. So when Save button is clicked. We will perform two actions:
- · Generate ID data connection will get ID from form library and
- · Submit the form with metadata and save the form with format (Form-N). N value will be generated by Generate Id data connection.
Business logic on Save button:
- Double click on Save button to open its property window.
- Click on rules. Rules are event-handler which is executed when some action is perform by users when button is clicked. Every controls on the form are having its respective rules.
- Create Rules to generate auto generate filename: In this case, we should create 2 rules.
Rule-1: will execute when we save form for the first time. At this time, we should generate auto-generate filename with unique ID (Generate ID data connection will take care to provide us with unique ID).
Rule-2: will execute when filename is already exists and we just need to save the content back to form library.
Creating 1st Rule:
1. Double click Save button.
2. Click Rules button.
3. Add rules by adding Add button
4. Click Add button
5. Give your Rule name in Rule dialog box.
6. We should add one condition; whether we form filename exists or doesn’t exist. If it doesn’t exist then we should let form know this. So click on Set Condition… button.
7. Condition dialog box will open. Specify Filename field in 1st drop down. Select “is blank” in 2nd drop down.
8. Click Ok to apply this condition.
9. Now, we should set filename with user friendly name, let say filename should be “File-N” (N is auto increment value from document library) e.g. File-1, File-2… Click on “Add Action”. Action dialog box will open.
10. Select “Set a field’s value” from Action drop down.
11. Select Filename field from field drop down.
12. Set value in value drop down by clicking on FX button (beside value text box).
13. Click on Insert function button. Click on concat() function from the list.
14. Double click on 1st parameter in contact() function and add “File-“. As a second parameter, you can double click on it. Select Secondary data source from Data Source drop down and select ID field.
15. Bind ID field inside MAX() function.
16. Click Verify Formula button to verify for errors.
17. Click Ok.
18. It should look like below screen shot.
19. Click on Add Action button to add more action.
20. Select “Submit using data connection” from Action drop down.
21. Select your Data connection name where form will get submitted to forms library.
22. Ok
23. Click on Add Action button to add more action.
24. Select “Close the form” from Action drop down.
25. Ok
26. Ok
Creating 2nd Rule:
Add another rule when Filename already exists. This time we should not set any value in Filename field. But we should only save the content and close the form.
1. Click Rules button.
2. Add rules by adding Add button
3. Click Add button
4. Give your Rule name in Rule dialog box.
5. We should add one condition; whether filename exists or doesn’t exist. So click on Set Condition… button.
6. Select your filename field in 1st drop down and “is not blank” item in 2nd drop down.
7. Click on Add Action button to add more action.
8. Select “Submit using data connection” from Action drop down.
9. Select your Data connection name where form will get submitted to forms library.
10. Ok
11. Click on Add Action button to add more action.
12. Select “Close the form” from Action drop down.
13. Ok
14. Ok
Now, you are done with your stuffs. Execute the form by clicking on File -> Preview. Preview mode is almost same as if you are running form on MOSS. This is one of very good work by Microsoft. This help developer to save lots of time and help them to see the result in a click.