Skip to Content
Menu
You need to be registered to interact with the community.
This question has been flagged
1 Odgovori
5908 Prikazi

Hi Forum!

I have a computed field called 'remain', but the problem with it is that it doesn't seem to call the function it uses.

What could be the problem?


remain = fields.Integer(string='Remain', compute='_compute_remain', store=True)
working_days = fields.Integer(compute='_compute_working_days_count')
yearly = fields.Integer(string='Yearly pool')

@api.multi
@api.depends('yearly', 'working_days')
def _compute_remain(self):
for record in self:
record.remain = record.yearly - record.working_days

Thank you for your help!


Regards,

Steven


Avatar
Opusti
Best Answer

Hello Steven,

please make working_days compute field to store=True

hope this will help you

Thanks & regards

Ankit Vaghela

Avatar
Opusti
Avtor

Thanks for the quick response! Looks like the problem is solved!

Regards,
Steven

Avtor

Thank you very much!

Regards,
Steven

Avtor

now there would be a problem with working_days not updating when it gets a new value, what could be the problem?

Working_days compute field method:
@api.multi
def _compute_working_days(self):
for record in self:
record.working_days = sum(record.holidays_ids.mapped('working_days'))

@api.multi
@api.depends('holidays_ids')
def _compute_working_days(self):
for record in self:
record.working_days = sum(record.holidays_ids.mapped('working_days'))

Try this hope this will work

Avtor

I try this, but it's not working.
Here are all the fields:

yearly_pool = fields.Integer(string='Yearly pool')
working_days = fields.Integer(string='Wordkdays count', compute='_compute_working_days', store=True)
remaining = fields.Integer(string='Remaining', compute='_compute_remaining', store=True)
holidays_ids = fields.Many2many('hr.holidays', string='Freedoms allowed ', compute='_compute_holidays_ids')

Field methods:

remaining:

@api.multi
@api.depends('yearly_pool', 'working_days')
def _compute_remaining(self):
for record in self:
record.remaining = record.yearly_pool - record.working_days

working_days:

@api.multi
@api.depends('holidays_ids')
def _compute_working_days(self):
for record in self:
record.working_days = sum(record.holidays_ids.mapped('working_days'))

holiday_ids:

@api.multi
def _compute_holidays_ids(self):
for record in self:
record.holidays_ids = self.env['hr.holidays'].search([
('employee_id', '=', record.employee_id.id),
('year', '=', record.year),
('state', '=', 'validate'),
])

Related Posts Odgovori Prikazi Aktivnost
0
dec. 16
3466
2
mar. 24
2453
0
dec. 23
1240
1
jul. 22
2218
1
okt. 21
2226