Skip to content

DeputyApp/roster-autofill-recipes

Repository files navigation

Automagic Customization

Deputy Rostering AutoFill uses To give further directions/customizations on autofill. Some business have some real crazy stuff that we need to adhere to. E.g.

Resturants: part timers are cheapers but don’t give too many hours to them! Maintenance : Engineers that worked last weekend, should not work this weekend. Healthcare: Someone should be always be working with First Aid training

Where

When applying the AutoFill option, you can copy and paste one of the raw content of the json files in the advanced section.

Method

Works via defining a set of statements.. Statements that all has to be true for the whole roster. Each true score gets a point. you can customize the score. The higher the score, the better the outcome. You can also give “hints”. Hints are used for directly choosing employees at given position. You are breaking the “genetic search” and forcing specific options in there.

Statement Syntax

{ scorers: [scorer] }

scorer: [name:] , type: , params : , [score : 1] } # score is optional. default will be 1. You can set it to 0 or negative (discourage). Give result storing that can be used with other rules

Type: field_matches, script, employee_totals, overlap, apply_rest

params

for field_matches [{ field: , data: , type: }] for script scriptname for employee_totals {employeePropertyName: , employeePropertyMatch: , total: , type:} for overlap rule_names : [ rules that it should match] for apply_rest api_url: , api_post: , api_column_fetch: , type: , data: – make a deputy_rest call to url, post is a object here. It will get stringified and then Field Names will be searched and replaced

EXAMPLE

Salary people should work betweek 40 and 45 hours per week. Also don't ever make people work during early morning and late afternoon regardless of their stress profiles

{"scorers":[{"type":"employee_totals","score":10,"params":{"employee_property_name":"Agreement.ContractObject.BasePayRuleObject.RemunerationType","employee_property_match":"2","employee_property_match_type":"eq","compare_value":40,"compare_type":"ge","compare_total":"TotalTime"}},{"type":"employee_totals","score":-20,"params":{"employee_property_name":"Agreement.ContractObject.BasePayRuleObject.RemunerationType","employee_property_match":"2","employee_property_match_type":"eq","compare_value":45,"compare_type":"ge","compare_total":"TotalTime"}},{"type":"field_matches","score":0,"name":"morning_shifts","params":[{"field":"Shift.StartTimeQ.Hour","data":12,"type":"lt"}]},{"type":"field_matches","score":0,"name":"late_shifts","params":[{"field":"Shift.StartTimeQ.Hour","data":18,"type":"ge"}]},{"type":"overlap","score":-10,"params":{"rules":["morning_shifts","late_shifts"],"column":"Shift.Employee"}}]}

More examples to follow but feel free to contact

About

Scheduling Auto-Fill recipes for Deputy

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published