[IMP]GOLEM Resource Timetable : usage of default values for time_start/stop on contraint + requirement only on client side

This commit is contained in:
Fabien BOURGEOIS 2018-03-17 08:40:14 +01:00
parent 398a3e7f63
commit da00acea29
2 changed files with 13 additions and 15 deletions

View File

@ -40,22 +40,13 @@ class GolemTimetable(models.Model):
time_start = fields.Float(string='Start') time_start = fields.Float(string='Start')
time_stop = fields.Float(string='Stop') time_stop = fields.Float(string='Stop')
availibility_24 = fields.Boolean(string="All day") availibility_24 = fields.Boolean(string="All day")
@api.onchange('availibility_24') @api.onchange('availibility_24')
def onchange_availibility_24(self): def onchange_availibility_24(self):
""" fill time_start et time_stop if availibility_24 is True """ """ fill time_start et time_stop if availibility_24 is True """
for line in self: for line in self:
if line.availibility_24: if line.availibility_24:
line.time_start = 0.0 line.update({'time_start': 0.0, 'time_stop': 23.98})
line.time_stop = 23.98
@api.constrains('availibility_24')
@api.multi
def check_time_filling(self):
""" Check start and stop time filling out"""
for line in self:
if not line.availibility_24 and (not line.time_start or not line.time_stop):
raise ValidationError(_('Start and stop time should be filled out '
'if the 24 availibility is not checked.'))
@api.onchange('time_start') @api.onchange('time_start')
def onchange_time_start(self): def onchange_time_start(self):
@ -64,11 +55,18 @@ class GolemTimetable(models.Model):
if line.time_start and not line.time_stop: if line.time_start and not line.time_stop:
line.time_stop = line.time_start + 1 line.time_stop = line.time_start + 1
@api.constrains('availibility_24')
def check_avaibility24(self):
""" Checks hour consistency against avaibility 24 """
for line in self:
if line.availibility_24:
line.write({'time_start': 0.0, 'time_stop': 23.98})
@api.constrains('time_start', 'time_stop') @api.constrains('time_start', 'time_stop')
def _check_time_consistency(self): def _check_time_consistency(self):
""" Checks time consistency """ """ Checks time consistency """
for timetable in self: for line in self:
if timetable.time_stop <= timetable.time_start: if line.time_stop <= line.time_start:
raise ValidationError(_('End time should be after than start time')) raise ValidationError(_('End time should be after than start time'))
@api.constrains('time_start', 'time_stop') @api.constrains('time_start', 'time_stop')

View File

@ -28,9 +28,9 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
<field name="weekday" /> <field name="weekday" />
<field name="availibility_24"/> <field name="availibility_24"/>
<field name="time_start" string="Start hour" widget="float_time" <field name="time_start" string="Start hour" widget="float_time"
attrs="{'required' : [('availibility_24', '=', False)]}"/> required="1" />
<field name="time_stop" string="Stop hour" widget="float_time" <field name="time_stop" string="Stop hour" widget="float_time"
attrs="{'required' : [('availibility_24', '=', False)]}"/> required="1" />
</tree> </tree>
</field> </field>
</record> </record>