Versions Compared
Key
- This line was added.
- This line was removed.
- Formatting was changed.
Overview
Dimensions allow you to link multiple Resource, Staff or Group records to a single Reservation, and actually plot that Reservation to all the related records' calendars. The process of achieving this is twofold:
- create lookups on the Reservation object, linking the Object you want to link (Resource, Staff of Group)
- define Dimension Fields on that corresponding Dimension, to tell Booker25 that these fields should be plotted
- define Dimension Junctions on the Dimension to tell Booker25 that you have related lists that should be plotted
Dimension
Dimensions are a way to let Booker25 know which objects related to a reservation are important.
Field | Type | Required | Description |
---|---|---|---|
Dimension Object Name | Text | Yes | The API name of an object to which reservations are related. |
Availability Lookup | Text | No | The API name of a lookup from Availability to the dimension object. |
Dimension Field
Dimensions Fields are a way to let Booker25 know which lookups on a reservation are important.
Field | Type | Required | Description | ||||
---|---|---|---|---|---|---|---|
Dimension | Lookup | Yes | The Dimension record that is the parent of this Dimension Field. | ||||
Dimension Field Name | Text | Yes | The API name of a lookup field on Reservation. | ||||
Enable Advanced Lookup Filtering | Checkbox | No | Enables the advanced lookup filter on the reservation form for this dimension field. The advanced lookup filter allows you to use autocomplete to search through valid related records. It will only show records in which the current reservation will be valid. So for example meeting rooms in closed buildings or staff that are unavailable because of holiday or sick leave will not be shown. Or if you have added a service to the reservation, it will only show records in which that service is actually available during the time of the reservation. A known limitation of the advanced lookup filter is that it doesn't support custom lookup filters. | ||||
Auto Populate on Calendar | Picklist | Yes | Controls if this dimension field gets populated with the related record id when creating a new reservation on the calendar. Options:
| Enforce Double Booking Check | Checkbox | No | When checked, Booker25 will prevent the related record from being double booked|
Availability Checking | Picklist | Yes | Defines the behavior when Reservations are saved outside of the available times for the related dimension record.
For more information, see this article about Conflict Checking, and this article about Availabilities | ||||
Double Booking Checking | Picklist | Yes | Defines the behavior when double bookings are detected for Reservations in this Dimension.
For more information, see this article about Conflict Checking. | ||||
Dimension Allow Double Booking Field | Text | No | The API name of a checkbox field1 on the related dimension object. When Enforce Double Booking Check is enabled, but this field on the related record equals true, the double booking is allowed. | ||||
Reservation Allow Double Booking Field | Text | No | The API name of a checkbox field1 on reservation. When Enforce Double Booking Check is enabled, but this field on the reservation equals true, the double booking is allowed. | ||||
Enforce Capacity CheckChecking | CheckboxPicklist | No | When checked, Booker25 will prevent the capacity of the related record from being exceededYes | Defines the behavior when a Reservation's quantity exceeds the Dimension's capacity.
For more information, see this article about Conflict Checking. | |||
Dimension Capacity Field | Text | No2 | The API name of a number field3 on the related object, which holds the capacity of the related record. This capacity can't be exceeded if Enforce Capacity Check is enabled. | ||||
Reservation Quantity Field | Text | No2 | The API name of a number field3 on the reservation, which holds the quantity of the reservation. This quantity is checked to not exceed the related record's capacity if Enforce Capacity Check is enabled. | ||||
Reservation Skip Capacity Check Field | Text | No | The API name of a checkbox field1 on reservation. When Capacity Checking is set to 'Soft' or 'Hard', but this field on the related record equals true, the reservation will be saved normally. |
1: Can also be a cross-object reference or a checkbox formula on Reservation. However the latter will not be set yet when working from the Reservation Form UI.
2: Required when Enforce Capacity Check is enabled.
3: Can also be a number formula, and can also be a cross-object reference.
Dimension Junction
Dimensions Junctions are a way to let Booker25 know which junctions between a dimension and a reservation are important.
Info |
---|
A junction object is an object that sits in between two other objects (i.e. it has a lookup to each of the two objects). This creates a many-to-many relationship between those objects. For more information, see https://help.salesforce.com/articleView?id=relationships_manytomany.htm&type=5 |
An example of this would be a contact list, where you link multiple contacts to a reservation. Using dimension junctions you can:
- Make this list visible on the reservation form
- Make the reservation visible on the contact calendar for each contact in the list
- (Optional) Make Booker25 detect and prevent double bookings for these contacts.
Field | Type | Required | Description | ||||
---|---|---|---|---|---|---|---|
Dimension | Lookup | Yes | The Dimension record that is the parent of this Dimension Junction. | ||||
Dimension Junction Name | Text | Yes | The API name of an object. This object should be a junction between reservation and the dimension. | ||||
Reservation Lookup API Name | Text | Yes | The API name of a field on the object. This field should be a lookup (or master-detail) to Reservation. | ||||
Dimension Lookup API Name | Text | Yes | The API name of a field on the object. This field should be a lookup (or master-detail) to the dimension. | Enforce Double Booking Check | Checkbox | No | When checked, Booker25 will prevent the related record from being double booked|
Availability Checking | Picklist | Yes | Defines the behavior when Reservations are saved outside of the available times for the related dimension record.
For more information, see this article about Conflict Checking, and this article about Availabilities | ||||
Double Booking Checking | Picklist | Yes | Defines the behavior when double bookings are detected for Reservations in this Dimension.
For more information, see this article about Conflict Checking. | ||||
Dimension Allow Double Booking Field | Text | No | The API name of a checkbox field1 on the dimension. When Enforce Double Booking Check is enabled, but this field on the related record equals true, the double booking is allowed. | ||||
Reservation Allow Double Booking Field | Text | No | The API name of a checkbox field1 on reservation. When Enforce Double Booking Check is enabled, but this field on the reservation equals true, the double booking is allowed. | ||||
Junction Allow Double Booking Field | Text | No | The API name of a checkbox field1 on the object itself. When Enforce Double Booking Check is enabled, but this field equals true, the double booking is allowed. |
1: Can also be a cross-object reference or a checkbox formula on Reservation. However the latter will not be set yet when working from the Reservation Form UI.
Trigger
Info |
---|
For every Dimension Junction you create, make sure you also create a Trigger for its object, which calls the following method: B25.DimensionJunctionTriggerHook.execute() This makes Booker25 check permissions on the object. |
Conflict checking
Dimensions allow you to define how Booker25 detects conflicts between reservations (double bookings), and how to detect capacity problems.
Configuring Double Booking Checks
Let's say you use Booker25 for planning team projects. You have a custom object called Team__c, and a lookup on reservation to Team: Assigned_Team__c.
Now let's assume you have a business rule that says that a Team can only be assigned to one project. We can configure this in the following way:
- Create a Dimension record named Team__c. This lets Booker25 know that an object related to reservation called Team__c exists.
- Create a Dimension Field named Assigned_Team__c. This lets Booker25 know that a lookup field called Assigned_Team__c exists.
On this new Dimension Field record, set the checkbox Enforce Double Booking Check to true.
Now, if you create a reservation and set the Assigned Team, Booker25 will give you an error if that Team has already been assigned to another project at the same time.
Configuring Exceptions to Double Booking Checks
The Dimension Field object gives you two additional fields in the Double Booking section that allow you to further fine-tune the double booking behavior: The Dimension Allow Conflict Field and the Reservation Allow Conflict Field. These two fields are optional, but when filled in, they must contain the API name of a checkbox fieldon |
the |
Let's say we have some teams that are so good, they can handle multiple projects at once. If we have a checkbox on team called Is_Dream_Team__c, we can fill in this name in the Dimension Allow Conflict Field and Booker25 will not give you an error if you're trying to assign multiple projects to a team that has this checkbox enabled.
The API name does not have to be a checkbox directly on the record itself. It can also be a checkbox on a relatedobject |
. |
Configuring Capacity Checks
For our next example, let's say we have the business rule that a team has a max workload number (captured in the field Max_Workload__c), and that a team's assigned projects Workload__c can never exceed this max workload at any given time. We would do this by checking Enforce Capacity Check on the Dimension Field record, and filling in the two fields just below: Dimension Capacity Field and Reservation Quantity Field. These two must be filled in when Enforce Capacity Check is enabled, and must contain the API names of number fields on the related record and the reservation itself, respectively. So in our example we would fill in the values Max_Workload__c and Workload__c respectively.
Related articles
Filter by label (Content by label) | ||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Page Properties | ||
---|---|---|
| ||
|
Panel | ||
---|---|---|
| ||
|