Hi there!👋 We share practical and use-based tips on Documents & Forms automation. We talk about document creation, online forms, and forms for SharePoint, cover topics in general, and show real use cases in the example of Plumsail apps when possible and applicable so that all the readers can find new ideas and inspiration. Click the "subscribe" button above to stay tuned!
Before the holiday season kicks in, we'd love to share with you how to set up a SharePoint time-off request calendar for your employees with an approval process in Power Automate. We'll also use Plumsail Forms to customize the time-off request form, making the form more user-friendly, hiding the approval field from the user, and adding validation for leave dates ensuring that they are valid and do not conflict with already approved vacations.
In this article:
- Automate time-off requests in SharePoint
- Set up a SharePoint time-off request list
- Customize time-off request form
- Automate approvals for time-off request in SharePoint
- Set up a Power Automate flow
- Test the flow with SharePoint item
- Resources and final thoughts on time-off requests in SharePoint
Automate time-off requests in SharePoint
Let's get started with setting up a SharePoint time-off request list. Next, we'll turn the list view into a calendar, customize the form with validation, and set up an approval process in Power Automate to approve or delete requests, while notifying employees.
Set up a SharePoint time-off request list
First, set up a SharePoint List. You don't need many columns, we'll use basic ones:
- Title
- Start Date
- End Date
- Employee (Person)
- Department (Choice)
- Manager (Person)
- Approved (Yes/No)
We're also making most of the fields required as we'll need them for the approval process.
Inside the List, click Add view:
We'll setup a calendar view:
And we'll click add or remove fields:
To add the Approved column to the freshly created calendar view:
It will not appear in the view, but we can now use it to add conditional formatting and highlight approved requests with different colors:
Customize time-off request form
Customizing the form with Plumsail Forms for SharePoint is extremely easy. If you want to get started, check out the step-by-step installation guide in our documentation.
We'll just drag-n-drop fields onto the form:
It will look great and adjust to screens of all sizes. We'll also add a List or Library control to make existing requests visible to the user.
Finally, we'll play with some code, and we'll add custom validators for the Start and End dates: first of all, the Start Date should be before or equal to the End Date. Secondly, we'll add a form validator with pnpjs to check whether there is a conflict - an existing request from the same department that has been approved already, and if so - prevent the form from saving.
fd.spRendered(function() {
    fd.validators.push({
        name: 'Dates conflict validator',
        error: 'These dates are already taken by an employee from the same department',
        validate: function() {
            // check whether there are requests already
            return pnp.sp.web.lists.getByTitle('Time-off requests').items
                    .select('Title', 'Id', 'StartDate', 'EndDate')
                    .filter("Department eq '" + fd.field('Department').value + "' and Approved eq 1")
                    .get()
                    .then((items) => {
                        // see if we got something
                        if (items.length > 0) {
                            for(var i = 0; i < items.length; i++){
                                var item = items[i];
                                var startDate = new Date(item.StartDate);
                                var endDate = new Date(item.EndDate);
                                //check for conflict
                                if ((startDate < fd.field('StartDate').value && endDate < fd.field('StartDate').value) || 
                                   (startDate > fd.field('EndDate').value && endDate > fd.field('EndDate').value)){
                                   continue;
                                }
                                else {
                                    return false
                                }
                            }
                        }
                        return true;
                    });
        }
    });
    
    fd.field('StartDate').addValidator({
        name: 'StartDate validator',
        error: 'StartDate cannot be after End Date',
        validate: function(value) {
            if (fd.field('EndDate').value && value > fd.field('EndDate').value) {
                return false;
            }
            return true;
        }
    });
    
    fd.field('EndDate').addValidator({
        name: 'EndDate validator',
        error: 'EndDate cannot be before Start Date',
        validate: function(value) {
            if (fd.field('StartDate').value && value < fd.field('StartDate').value) {
                return false;
            }
            return true;
        }
    });
});Now, this code will ensure that the dates are specified properly and there is no conflict with existing approved requests.
Automate approvals for time-off request in SharePoint
With our setup, creating an approval flow in Power Automate is a straightforward and efficient process. It integrates seamlessly with advanced configurations to enhance usability and visibility for managing time-off requests.
Set up a Power Automate flow
First of all, we'll create an automated flow that is triggered whenever an item is created in our Time-off requests list:
We'll then use the information on the form to send an approval request to the manager, specified on the form with Start and wait for approval action:
Adding a Condition block will allow us to check the approval status by comparing Outcome to Approve:
If the request is approved, we'll update the item Approved field to Yes:
And we'll send an email to the employee, notifying them that their request was approved.
Now, if the request is not approved, we'll delete the item right away:
We'll also send an email to the employee, asking to contact the manager directly to discuss why the request got disapproved.
Test the flow with SharePoint item
We'll test the flow with a simple request:
Here's how it looks before approval:
We'll receive the following approval request in our inbox:
And if it's approved, that's what we see:
Comments