Skip to main content

Shift Layout Constraint

Soft constraint

Deprecated constraint

The Shift Layout Constraint is being deprecated in favour of the RestBetweenShiftsConstraint (we are extending it with time off in terms of days). You should no longer build a new integration with this constraint.

Specify a break duration between each assigned shift of a given ID, type, or work type. This constraint applies to employees independently, meaning that the break duration does not apply if different employees are assigned to the given shift.

See the payload example below to get started and check out the API reference for full configurability of the constraint.

Payload example

The following defines a desired break time of two days between each shift_1 shift assigned to any specific employee.

{
"shiftLayoutConstraints": [
{
"id": "slc-123",
"weight": 100,
"minDaysBetweenShifts": 2,
"shiftIds": ["shift_1"]
}
]
}
Shift Layout Constraint in the request payload
id
required
string (constraintId)

The id of the constraint should be UNIQUE in the context of constraint type.

weight
integer (constraintWeightPositive) [ 0 .. 100 ]

Describes how much the constraint is taken into account when solving the schedule. The higher the value, the more solver will penalize the constraint violation. None of the weight values make it a hard constraint - even when weight is set to 100 it is not guaranteed that the constraint will be satisfied. The weight value is relative to other constraints.

object (constraintFairness)

Describes how much fairness is taken into account for the constraint.

minDaysBetweenShifts
required
integer >= 1

The minimum number of days between shifts indicated by shiftId or shiftTypeId.

shiftIds
Array of strings (constraintShiftIds) unique

If shiftIds are specified, shifts that has matching id are constrained.

shiftTypeIds
Array of strings (constraintShiftTypeIds) unique

If shiftTypeIds are specified, shifts that has matching shiftType are constrained.

workTypeIds
Array of strings (constraintWorkTypeIds) unique

If workTypeIds are specified, shifts that has matching workType are constrained.

employeeIds
Array of strings (constraintEmployeeIds) unique

List of employee ids for which the constraint applies. The employee ids must be present in the employee section. If not specified, the constraint will be applied to all employees.

{
  • "id": "string",
  • "weight": {
    },
  • "fairness": {
    },
  • "minDaysBetweenShifts": 1,
  • "shiftIds": {
    },
  • "shiftTypeIds": {
    },
  • "workTypeIds": {
    },
  • "employeeIds": {
    }
}