Beginning a Simple Approval Workflow
To illustrate the concept of building a workflow for a form, let’s build a simple approval workflow for a bid request form. I will keep this process relatively simple while showing how easy it is for you to build workflows for your libraries.
To begin a new workflow, open SharePoint Designer from your Start menu. Before you can start a new workflow, you have to select the site where you want to work. If you have not used SharePoint Designer previously, you will have to open a site by selecting the option Open Site from the File menu. Otherwise, you may be able to select the site from the Recent Sites menu option, also in the File menu. If you do not see the site in Recent Sites, you may still see a reference to it in the Open Site option. In any case, you can use the Open Site option to enter the URL of the site to open it. For example, for my server, I might enter
http://stargazer/
Next, select New also from the File menu and select Workflow. Designer may display a message informing you that it is downloading necessary data from the server. This process can take a varying amount of time, depending on the speed of your network. This menu option opens the dialog box shown in Figure 1. In this menu, you must provide a name for the workflow. When you add a workflow to a SharePoint site using SharePoint Designer, you can attach it to a specific list, as you will do here. You can select in which list to install the workflow by selecting it from the drop-down of all the lists in the selected site.
Figure 1. Creating a new workflow using SharePoint Designer
The last section of this page lets you choose how and when you want to start the workflow for the selected list. If you check the first check box, the user must start the workflow manually for the item. Use this option only if you do not need to start the workflow when an item is added or changed, and only if the average user will know when to and when not to start a workflow. For example, you may want the user to be able to create items in a list or library while she works on them over several sessions without starting a workflow until she finishes working on the item. Only at that time will the user want to start the workflow on the completed item.
The second check box tells SharePoint to automatically start the workflow whenever someone creates a new item in the select list. This means that even if the user has not finished entering the item but wants to save what he did so he can finish at a later time, the mere fact that he saved his temporary work will fire off the workflow. If users typically complete the entry of all data for the form in a single session, maybe you do want to select this option to start the workflow when they create the item.
The third check box starts the workflow whenever an item changes. This feature can help ensure that users do not make changes to items without starting an approval process. Otherwise,users might submit an initial item, get it approved, and then return to edit the item without needing approval of their changes.
When you click Next, you can begin the first step of the workflow as shown in Figure 2.SharePoint Designer provides a default name for each step beginning with “Step” followed by a sequential number. However, you can change the step name to some more meaningful text such as Send E-mail to Approver.
Figure 2. Workflows have steps containing actions executed based on conditions.
Defining Workflow Details
Each step consists of one or more sets of details. Each detail consists of a condition and an action that you want the workflow to perform when the condition evaluates to True. Condition statements are optional. If you want to execute a specific action every time the workflow runs, you can skip the condition and go directly to the Actions button. Therefore, let’s first look at the Actions button. When you click the Actions button, a drop-down list of possible actions appears, as shown in Figure 3. As you can see from the list, you have quite a set of options available. In fact, there are so many options that the drop-down includes an option at the bottom to show more actions than you can see in the initial list.
Figure 3. Selecting from the available actions drop-down list
In this case, you want to build a simple approval workflow. Therefore, the first action you want the workflow to perform when a user saves a new item to the list is to send an e-mail to the approver for the list. Therefore, select the first option: Send an Email.
Configuring an E-mail Message
This option then displays the skeleton command for the e-mail action shown in Figure 4 in the text area to the right of the buttons. Each command has one or more placeholder text strings that you can replace with data. In this case, the placeholder contains the text Email this message. Notice that the words “this message” in the placeholder appear as a link. This formatting tells you that you can customize the information that appears at this point in the command.
Figure 4. Creating an action that sends an e-mail message
Clicking the link for this placeholder opens a dialog box to define the e-mail message shown in Figure 5. Here you can enter the e-mail address of a person directly, or you can click the button to the right of the text box on the To: line to select from the users or user groups known to the SharePoint site. For example, if you have a group defined as Approvers, you can select this SharePoint group, rather than the e-mail address of an individual, to receive the email.
This is usually the preferred solution over entering individual e-mail addresses as shown in this figure, because you can easily e-mail multiple people who have the approver permission, letting any one of them approve the item. Also, if you hard-code an individual’s e-mail address in a workflow, and that person leaves the organization, the workflow will fail until you edit the workflow and replace the invalid e-mail address with a new e-mail address. By referencing a group, you simply have to maintain the group’s membership. This also applies to the CC: line of the e-mail. By default, the FROM: address for the e-mail can be set in the Central Administration’s Operations page. Go to the Outgoing e-mail settings option and update the From Address field.
Next, you can enter a text string to appear in the Subject field. You can enter a simple text string as shown in Figure 10-42, or at any point within the text string, you can click the function button found to the right of the Subject field. This opens a dialog box that lets you look up a value from a variety of sources ranging from fields in the current item, to fields in other lists. If you choose to use a value from another list, you must identify the item and the field from the list that you want to use.In fact, the body of the message in Figure 5 shows several reference fields. In the first paragraph of the body, the string [%Request for Bids:RFB Number%] retrieves the value from the RFB Number column of the current item and inserts it into the string. Similarly, it also retrieves values from the column RFB Responder Name and the column Created By. In this way, you can create a custom message that tells the e-mail recipient more than just that she has something to approve on the portal. You can provide specific information to tell her exactly what she needs to approve. You can even provide a link to the list so that the user does not have to try to remember the URL and then navigate to the required list, all of which takes extra time for the approver. By displaying the URL in the e-mail to the approver, you increase the approver’s efficiency. When you click OK, SharePoint Designer returns you to the Step page, shown in Figure 6,where you can add more actions.
Figure 6. Actions without a condition always execute.
Adding Multiple Actions
You can have multiple steps each with individual actions, or you can have a single step with multiple actions. Suppose you decide to add another action to this step to log the workflow into the History list. To do this, click the Actions button a second time, and click the option Log to History List, as shown in Figure 7. For this action, you can specify the exact text you want to add to the log.
Figure 7. Adding actions from the full action list
Next, add a third action telling the workflow to wait until the approval process changes from Pending to another value. The need for this action may not be obvious until you consider that workflows execute from beginning to end once they start without pausing, unless you tell them to pause. In fact, currently the workflow defined here will execute as soon as an item is added or changed in the list where the workflow has been attached. It starts by sending an e-mail to the person or group defined in the TO: portion of the e-mail definition and then creates a log entry. In the next step, you want to determine whether the approver sets the item’s status to Approved or Rejected. If you do not put a pause or wait action at the end of step 1, step 2 will immediately execute without giving the approver time to even look at the item. Therefore, you need to add an action telling the workflow to wait at this point until the item’s status changes from its initial value of Pending.
Adding Conditions to Actions
To be complete, you can add a condition that defines when you want even the actions in step 1 to execute. In this case, you only want to send an e-mail to the approver when a document has the status of Pending. If you have a list with versioning turned on, this allows you to save intermediate values without triggering a workflow, because they have the status of Draft and only receive a status of Pending when the user submits them for approval. To add this condition, click the Conditions button for the first step. From the drop-down list, shown in Figure 8, select the option Compare Request for Bids field.
Figure 8. Conditions define when to execute the actions in the step.
When you select this option, the command skeleton in the condition that appears to the right of the condition button says
If field equals value
In this case, you see that SharePoint Designer underlines three of these words. When you click the first word, field, you can select which field you want to compare from the current list item. Depending on the field that you select, the drop-down list that appears when you click the word value changes. SharePoint Designer reads the definition of the list, and if the selected field has a limited number of possible values, it only displays those values. For fields that can have any value, SharePoint Designer lets you enter the value directly in the text box. You can even reference a value from another object such as another list on the site.Even the word equals between field and value can be changed by clicking it, providing you with different comparison options. If necessary, you can build multiple conditions in which you can connect each condition, using either an AND or an OR connection. Figure 9 shows one possible way to complete the first step of the approver workflow. It sends the approver an e-mail and logs the start of the workflow when a new or edited document with the status of Pending appears in the list.
Figure 9. One way to define the step to send an e-mail to an approver
Adding Additional Steps
By clicking the hyperlink Add workflow step in the panel on the right side of SharePoint Designer,which shows the Workflow Steps, you can define what you want the workflow to do when the approver changes the status of the item to either Approved or Rejected.
For this step in the workflow, let’s define a condition that checks whether the Approval Status field of the current item equals Approved. When it does, let’s send an e-mail back to the person who created the item, informing him that the item has been approved. Begin by clicking the Conditions button and select the option Compare Request for Bids field as you did for the condition in the first step of this workflow. Then select the field Approval Status and compare it to the value Approved. Next, create an action that sends an e-mail. In the e-mail dialog box, click the Select Users button on the far-right side of the To: field and select User who created current item from the list of available users and groups list, as shown in Figure 10.
Figure 10. Using dynamic properties to define an e-mail’s To: field
In this step, you need to have a second condition, because the approver can either accept or reject the item. The first condition/action set defines what to do when the approver approves the item. But next you must define what you want the workflow to do when the approver rejects the item. To do this, click the hyperlink Add ‘Else If’ Conditional Branch found at the bottom of the Specify Details panel. You will see a new Conditions and Actions set of buttons. Click the Conditions button and define the Boolean expression that compares the Approval Status to the value of Rejected. Next, click the Actions button to send the user who created the current item an e-mail informing him that the approver has rejected the item.
■Tip An interesting process you can create places all pending items of a specific type in an initial pending list. When a user creates an item in this list, it starts a modified approval workflow. In this workflow, add an action to the Approved step to copy the list item to a different list, an approved item list, followed by another action to delete the current item from the current list. If the approver rejects the item, you can leave the item in the pending list.
Figure 11 shows one possible way to build the second step in this approval workflow.
Figure 11. Defining the approver’s possible actions
■Tip If you ever create your workflow steps out of order, you can easily rearrange their order by positioning your mouse over the right side of the step name in the Workflow Steps panel until the drop-down arrow appears. Click this arrow, and then select either the Move Step Up option or the Move Step Down option.
■Tip If you miss a step, just add the step to the end of the steps. Then using the previous tip, move it up in the list of steps to the spot where it belongs.
■Tip If you decide you no longer need a workflow step, open the drop-down list of step options as described in the previous tips and select the Delete Step option.
Restructuring Your Conditions
If you add a conditional branch that you later decide you no longer need, you can click the down pointing arrow to the upper right of any of the existing conditional branches to display a drop-down menu. From this menu, you can move conditional branches up or down in the sequence of branches. Remember that workflows evaluate branches sequentially from top to bottom by default, with the first branch that returns a True result for its condition being chosen to execute its actions. You also have options in this menu to add new branches, delete the current branch, or change the way the workflow executes conditional branches to execute them all in parallel rather than sequentially.
If you have a condition or action with multiple statements, you can also change the order of these statements by clicking anywhere on the line of the statement other than on a hyperlink to select the condition or action. To the right appears a drop-down button that, when clicked, displays a menu letting you move the current action or condition up or down or even delete it.
Therefore, even if you miss a condition or action, you can simply add it to the bottom of the list of actions or conditions in the appropriate conditional branch, and then move it to the position where it needs to appear.
■Tip One of the conditions you can use compares the file size to a specific range in kilobytes. You can use this condition to automatically set the approval status to Approved or Rejected along with sending appropriate e-mail messages to users attempting to add large files to lists.
■Tip Another condition you can use compares the file type to a specific type. By including a series of conditions joined with an OR connector, you can limit the ability of users from uploading specific file types to lists and libraries.
When you finish defining the steps in your workflow, save the workflow by clicking the Finish button in the lower-right corner of the SharePoint Designer. This action saves the workflow to SharePoint and specifically attaches it to the list specified when you started the workflow definition. The next time a user adds an item to the list, the workflow initiates and sends an e-mail,
such as the one shown in Figure 12, to the person or group defined in the To: field.
Figure 12. An example of the e-mail received by the approver
While this section introduces you to the ability of SharePoint Designer to create workflows, you can create workflows quite a bit more complex than the one shown here. If you find that you need to perform actions that SharePoint Designer does not support, you can also create workflows using Visual Studio and add custom coding for individual forms; in addition, you can create workflows that can be installed at the site’s collection level and then applied across multiple lists and libraries.
1 comment:
Very information and useful post. I have carefully understood the complete information that you have shared above. Thank you for informative post!
electronic signature Microsoft
Post a Comment