Skip to Content
Menu
This question has been flagged
1 Reply
4874 Views

hello every one,

i need the python code to deduct the employee salary in following scenario.

salary  = 10000/-

employee joining date is 21/01/2017 (middle of the month or any date between in month)

I set the contract start date is 21/01/2017 and end date is 20/01/2018.

when i calculate the salary, Odoo is calculating the whole month salary (10000) instead of  10 days. (from 21 to 31th Jan of the month) how can i create the rule in this regard.


Muhammad Kamran

Avatar
Discard
Best Answer

Hi Kamran,

You have to use 

worked_days.WORK100.number_of_days

to get the number of days the employee worked and multiply that with the daily wage. Then you have to manage the weekends as well because while they are not working days but you must include them in the total wage.

Set the following Python Code in Basic Salary Rule:

daily = contract.wage/31
days = worked_days.WORK100.number_of_days
weekends = days/5
weekenddays = weekends*2

result = (weekenddays*daily)+(days*daily)

Avatar
Discard

What about the months 30 days and 28 days, can it be dynamic to calculate based on days of the month, instead of fixed 31 days

Related Posts Replies Views Activity
1
Jun 22
2997
0
Jan 20
2064
1
Jan 19
3390
2
Dec 24
10143
0
Nov 24
72