forked from Yaltik/golem
[IMP]api.one if better than manual looping on recordset
This commit is contained in:
parent
5d7077efc3
commit
5045c2ff11
@ -67,9 +67,9 @@ class GolemActivity(models.Model):
|
|||||||
is_current = fields.Boolean('Current season?', store=True, default=False,
|
is_current = fields.Boolean('Current season?', store=True, default=False,
|
||||||
compute='_compute_is_current')
|
compute='_compute_is_current')
|
||||||
|
|
||||||
|
@api.one
|
||||||
@api.depends('season_id')
|
@api.depends('season_id')
|
||||||
def _compute_is_current(self):
|
def _compute_is_current(self):
|
||||||
""" Checks if activity is active for current season """
|
""" Checks if activity is active for current season """
|
||||||
default_season = self._default_season()
|
default_season = self._default_season()
|
||||||
for a in self:
|
self.is_current = (default_season == self.season_id)
|
||||||
a.is_current = (default_season == a.season_id)
|
|
||||||
|
@ -84,14 +84,14 @@ class GolemActivitySession(models.Model):
|
|||||||
session_name = fields.Char('Name', compute='_compute_full_name',
|
session_name = fields.Char('Name', compute='_compute_full_name',
|
||||||
store=True, index=True)
|
store=True, index=True)
|
||||||
|
|
||||||
|
@api.one
|
||||||
@api.depends('name', 'default_code')
|
@api.depends('name', 'default_code')
|
||||||
def _compute_full_name(self):
|
def _compute_full_name(self):
|
||||||
""" Provide a better displayed name """
|
""" Provide a better displayed name """
|
||||||
for s in self:
|
session_name = unicode(self.name)
|
||||||
session_name = unicode(s.name)
|
if self.default_code:
|
||||||
if s.default_code:
|
session_name = u'[{}] {}'.format(self.default_code, session_name)
|
||||||
session_name = u'[{}] {}'.format(s.default_code, session_name)
|
self.session_name = session_name
|
||||||
s.session_name = session_name
|
|
||||||
|
|
||||||
member_ids = fields.Many2many('golem.member', string='Members')
|
member_ids = fields.Many2many('golem.member', string='Members')
|
||||||
type_of = fields.Selection([('activity', _('Activity')),
|
type_of = fields.Selection([('activity', _('Activity')),
|
||||||
@ -109,10 +109,10 @@ class GolemActivitySession(models.Model):
|
|||||||
|
|
||||||
places_used = fields.Integer('Places used', compute='_compute_places_used')
|
places_used = fields.Integer('Places used', compute='_compute_places_used')
|
||||||
|
|
||||||
|
@api.one
|
||||||
@api.depends('member_ids')
|
@api.depends('member_ids')
|
||||||
def _compute_places_used(self):
|
def _compute_places_used(self):
|
||||||
for s in self:
|
self.places_used = len(self.member_ids)
|
||||||
s.places_used = len(s.member_ids)
|
|
||||||
|
|
||||||
# TODO: to link with calendar.event
|
# TODO: to link with calendar.event
|
||||||
activity_id = fields.Many2one('golem.activity', string='Activity',
|
activity_id = fields.Many2one('golem.activity', string='Activity',
|
||||||
@ -195,11 +195,11 @@ class GolemActivitySession(models.Model):
|
|||||||
places_remain = fields.Integer('Remaining places', store=True,
|
places_remain = fields.Integer('Remaining places', store=True,
|
||||||
compute='_compute_places_remain')
|
compute='_compute_places_remain')
|
||||||
|
|
||||||
|
@api.one
|
||||||
@api.depends('places', 'member_ids')
|
@api.depends('places', 'member_ids')
|
||||||
def _compute_places_remain(self):
|
def _compute_places_remain(self):
|
||||||
for s in self:
|
used = len(self.member_ids)
|
||||||
used = len(s.member_ids)
|
self.places_remain = self.places - used
|
||||||
s.places_remain = s.places - used
|
|
||||||
|
|
||||||
@api.constrains('places_remain')
|
@api.constrains('places_remain')
|
||||||
def _check_remaining_places(self):
|
def _check_remaining_places(self):
|
||||||
|
@ -26,14 +26,14 @@ class GolemActivitySession(models.Model):
|
|||||||
is_overbooked = fields.Boolean('Allow overbook?', default=False)
|
is_overbooked = fields.Boolean('Allow overbook?', default=False)
|
||||||
places_overbooked = fields.Integer('Places with overbook', default=0)
|
places_overbooked = fields.Integer('Places with overbook', default=0)
|
||||||
|
|
||||||
|
@api.one
|
||||||
@api.depends('places', 'is_overbooked', 'places_overbooked', 'member_ids')
|
@api.depends('places', 'is_overbooked', 'places_overbooked', 'member_ids')
|
||||||
def _compute_places_remain(self):
|
def _compute_places_remain(self):
|
||||||
for s in self:
|
used = len(self.member_ids)
|
||||||
used = len(s.member_ids)
|
if not self.is_overbooked:
|
||||||
if not s.is_overbooked:
|
self.places_remain = self.places - used
|
||||||
s.places_remain = s.places - used
|
else:
|
||||||
else:
|
self.places_remain = self.places_overbooked - used
|
||||||
s.places_remain = s.places_overbooked - used
|
|
||||||
|
|
||||||
@api.onchange('is_overbooked', 'places')
|
@api.onchange('is_overbooked', 'places')
|
||||||
def onchange_is_overbooked(self):
|
def onchange_is_overbooked(self):
|
||||||
|
@ -78,13 +78,14 @@ class GolemMember(models.Model):
|
|||||||
'UNIQUE (number_manual)',
|
'UNIQUE (number_manual)',
|
||||||
_('This member number has already been used.'))]
|
_('This member number has already been used.'))]
|
||||||
|
|
||||||
|
@api.one
|
||||||
@api.depends('season_ids')
|
@api.depends('season_ids')
|
||||||
def _compute_is_current(self):
|
def _compute_is_current(self):
|
||||||
""" Computes is current according to seasons """
|
""" Computes is current according to seasons """
|
||||||
default_s = self._default_season()
|
default_s = self._default_season()
|
||||||
for m in self:
|
self.is_current = default_s in self.season_ids
|
||||||
m.is_current = default_s in m.season_ids
|
|
||||||
|
|
||||||
|
@api.one
|
||||||
@api.depends('number')
|
@api.depends('number')
|
||||||
def _compute_is_number_manual(self):
|
def _compute_is_number_manual(self):
|
||||||
conf = self.env['ir.config_parameter']
|
conf = self.env['ir.config_parameter']
|
||||||
@ -183,10 +184,10 @@ class GolemMemberNumber(models.Model):
|
|||||||
auto_join=True)
|
auto_join=True)
|
||||||
number = fields.Char('Number', index=True, readonly=True)
|
number = fields.Char('Number', index=True, readonly=True)
|
||||||
|
|
||||||
|
@api.one
|
||||||
@api.depends('season_id')
|
@api.depends('season_id')
|
||||||
def _compute_name(self):
|
def _compute_name(self):
|
||||||
for row in self:
|
self.name = self.season_id.name
|
||||||
row.name = row.season_id.name
|
|
||||||
|
|
||||||
|
|
||||||
class GolemNumberConfig(models.TransientModel):
|
class GolemNumberConfig(models.TransientModel):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user