In Wix Bookings, resources are anything you need to provide a service. It can be a staff member, a room, or a piece of equipment.
This tutorial focuses on creating staff resources, but apart from the “staff” tag, there is very little difference between types of resources. For the first part of this tutorial, we’ll create a staff resource with availability during the business's appointment hours. In the second part, we’ll create a staff resource with its own set of available hours. The available hours for a resource are the hours during which they can be booked for a service.
A resource is a simple object that has an ID, basic contact details, its schedule ID and a tags array.
You can use the tags array for grouping resource types. The Bookings app uses the tag "staff" to mark the resource as a staff member. This will make it show up in the Staff section of the Bookings app in the dashboard. The Bookings app creates a special resource with "business" in the tag and name properties. This special resource has a schedule that defines the business's appointment hours. Use the business resource's schedule to set up a staff or other resource's available hours to match the business's appointment hours.
A resource object looks like this:
Resources have schedules, which define when the resource is available. A basic resource schedule looks like this:
_id
is the unique schedule ID.scheduleOwnerID
is the ID of the entity that owns the schedule, in this case a resource.availability
object has the start
time from which the schedule begins, and an array of linked schedules.linkedSchedules
array contains a list of other schedules that add to this schedule’s availability. In this case we have the business's appointment hours that are stored in the bookings app as a schedule. By linking the business's appointment hours schedule to this resource’s schedule we are making the resource available during the business's appointment hours.Not all schedules have linked schedules. You can define custom hours for a resource by creating sessions. More on sessions later.
Before you try the code below, make sure to install the Bookings app if you haven't already. You can learn more about installing apps here (Wix Studio) or here (Wix Editor).
To create a staff resource that uses the business's appointment hours, we need to collect the following information:
For resource details, let's assume that we have a page containing a form. The form has fields for resource name, email, phone number, and a brief description.
The form also has a submit button that calls our backend function to create a resource, and passes the form details in an object.
The following frontend page code collects the input data from the form when the submit button is clicked and calls the createStaffWithBusinessHours function defined in the backend file "resources.web.js" that we will create.
Create a file called resources.web.js in the backend file section of your site. This file will contain all of the backend code used in this tutorial.
The code below has 2 functions:
The business's scheduleId is the ID of the schedule that contains the business's appointment hours. These hours can be set in the dashboard under Settings, Bookings, Appointment Hours.
To create a resource that uses the business's appointment hours, add the business resource's scheduleId
to the linkedSchedules
array of the new resource's schedule.
Get the business resource's schedule ID.
Line 1: Import Permissions
enum and webMethod
function from wix-web-module
.
Line 2: Import the resource APIs from the wix-bookings-backend module
.
Line 7: Using queryResourceCatalog
get the resource where the slugs name is "business".
Line 11: The query returns an array of items, each item containing a resource, schedule and slug object. We want the resource object from the first and only item in the array.
Line 12: From the resource, take the first ID in the scheduleIds
array.
Line 13: Return the schedule ID to the calling function.
Create the resource
Line 19: Call getBusinessSchedule()
to get the schedule ID for the business's appointment hours.
Line 22: Create the scheduleInfo
object using the business schedule ID in the linkedSchedules
array. This gives the resource the same available hours as defined for the business.
Line 30: Set the date for this schedule to start, in this case immediately.
Line 34: Create the resourceInfo
object using the values from the front-end form, and adding the tag "staff"
to the tags
array.
Line 42: Configure the options object to set supressAuth
to true
. This will suppress the checking of user permissions and let anyone execute the createResource
function.
Line 45: Call createResource
using the resourceInfo
, scheduleInfo
and options
objects.
Line 47: If the promise resolves, return the created resource to the front end.
Line 50: If the promise is rejected, log the error to the console, and return it to the front end.
See if it worked by looking at your site's dashboard.
In this part of the tutorial, we will create a resource that has its own custom working hours. We will make the resource available on Mondays, Wednesdays, and Fridays between 10 AM and 4 PM.
To create resource with its own custom hours, we need to do the following:
A session is a defined period of time on a schedule and is one of the following:
"EVENT"
: Reserved period of time on any schedule. For example, an appointment, class, or course. Events are visible in the Dashboard on the Bookings app's Booking Calendar page."WORKING_HOURS"
: Placeholder for available time on a resource’s schedule.In this tutorial we will create "WORKING_HOURS"
sessions to define the resource's availability.
A session can be an individual session or a recurring session. An individual session has a discrete start and end date, while a recurring session defines a series of repeating sessions. In this tutorial, when adding the sessions to the schedule, we will create recurring sessions using recurrence rules to specify how often each session repeats.
Create a function to manage the process.
First we need a function that will manage the process for us. This function will call the createStaffMember
function to create the resource, then use the new resource's scheduleId
to add sessions to the schedule.
Line 1: Import Permissions
enum and webMethod
function from wix-web-module
.
Line 2: Import both resources and sessions from wix-bookings-backend module
.
Line 5: createStaffWithCustomHours
takes staff information from the page form, and creates a resource. It then uses the new resource’s scheduleId
to create recurring sessions.
Line 8: Call createStaffMember
to create a new resource. Note that the resource variable is defined with var
so that it is visible outside the try/catch scope.
Line 16: Call createRecurringSessions
using the resource’s scheduleId.
Line 19: Create resourceSessions
as a return object consisting of the resource and an array of its sessions.
Line 23: Return the resourceSessions
object to the front end.
Creating the resource is the same as creating a resource with the business's appointment hours, but in this case we leave out the business schedule from the linkedSchedules array in the scheduleInfo object.
Line 5: Create the resourceInfo
object using the values from the front-end form, adding the tag "staff"
to the tags array.
Line 14: Create the scheduleInfo
object with an empty linkedSchedules
array and the current date and time for the start
date.
Line 22: Configure the options
object to set supressAuth
to true
. This will suppress the checking of user permissions and let anyone execute the createResource
function.
Line 25: Call createResource
using the resourceInfo
, scheduleInfo
and options
objects and return the result to the calling function.
Now that we have a resource and its schedule, we can add sessions to the schedule.
We are going to add recurring sessions that occur on Mondays Wednesdays and Fridays between 10 AM and 4 PM.
The recurrence rule for this as follows:
'FREQ=WEEKLY;INTERVAL=1;BYDAY=MO;UNTIL=20220101T000000Z'
FREQ=WEEKLY
: Repeat the sessions on a weekly basisINTERVAL=1
: Repeat the sessions every week. If you want to repeat every second week, set the interval to "2"BYDAY=MO
: The session occurs on Mondays.UNTIL=20220101T000000Z
: Repeat the sessions until midnight, January 1 2021We will have 3 recurrence rules. One for Monday, BYDAY=MO
, one for Wednesday, BYDAY=WE
, and one for Friday, BYDAY=FR.
The session type is set to 'WORKING_HOURS'
to tell the bookings backend that these sessions set the resource’s availability.
Line 8: Create the sessionInfo object using the scheduleId from the resource we created earlier.
Lines 10 and 19: Set the duration of the session by setting the start.locatDateTime
and end.localDateTime
properties.
Line 29: Set the session type to ”WORKING_HOURS”
. This tells the bookings app that these sessions set the resource’s availability.
Line 30: Define the recurrence
rule as a placeholder. We will populate this property with a set of recurrence rules.
Line 33: Declare an array to hold the sessions that we are going to create.
Line 37: Set the recurrence rule for the first recurring session to 'FREQ=WEEKLY;INTERVAL=1;BYDAY=MO;UNTIL=20220101T000000Z'
The rule defines sessions that will recur on a weekly basis, on a Monday, repeating until midnight, January 1, 2021.
Line 38: Call createSession
with the sessionInfo
and options
objects, storing the result in the resourceSessions
array that we created earlier.
Lines 40 to 44: Repeat the session creation, changing the recurrence rule each time to repeat on Wednesdays, then Fridays.
Line 46: Return the resourceSessions
array, containing three recurring sessions, to the createStaffWithCustomHours
function.
How do we check that this worked ? The easiest way is to go to the Staff page of the Bookings app in your site's dashboard.
You can also use the queyResourceCatalog() and use the resourceId or the resource's scheduleId in querySessions().
The Staff page in the dashboard.
Hover over a staff member and hit edit to see their available hours.
Click Edit Staff Availability. You can see if the staff member uses default or custom appointment hours.