forked from Yaltik/golem
Fabien BOURGEOIS
d82babaa25
* Refactor days from m2m to o2m ; * Allow better flow for filling ; * Check date coherence.
82 lines
3.2 KiB
Python
82 lines
3.2 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
# Copyright 2017-2018 Fabien Bourgeois <fabien@yaltik.com>
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Affero General Public License as
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
# License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Affero General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
""" GOLEM Payment models """
|
|
|
|
from odoo import models, fields, api, _
|
|
from odoo.exceptions import ValidationError
|
|
from odoo.tools import formatLang
|
|
|
|
class AccountPayment(models.Model):
|
|
""" Add number bank check"""
|
|
_inherit = 'account.payment'
|
|
reference = fields.Char(string='Payment reference')
|
|
|
|
class GolemPaymentScheduleDay(models.Model):
|
|
""" Schedule day simple model """
|
|
_name = 'golem.payment.schedule.day'
|
|
_rec_name = 'day'
|
|
_order = 'schedule_id asc,day asc'
|
|
_sql_constraints = [('golem_payment_schedule_day_uniq',
|
|
'UNIQUE (day, schedule_id)',
|
|
_('Day must be unique.'))]
|
|
|
|
day = fields.Date(required=True)
|
|
schedule_id = fields.Many2one('golem.payment.schedule', required=True,
|
|
auto_join=True)
|
|
|
|
|
|
class GolemPaymentSchedule(models.Model):
|
|
""" GOLEM Payment Schedule """
|
|
_name = 'golem.payment.schedule'
|
|
_description = 'GOLEM Payment Schedule'
|
|
_order = 'season_id desc'
|
|
|
|
name = fields.Char(required=True)
|
|
day_ids = fields.One2many('golem.payment.schedule.day', 'schedule_id',
|
|
string='Days')
|
|
day_display = fields.Char(compute='_compute_day_display', string='Days')
|
|
occurences = fields.Integer(compute='_compute_occurences')
|
|
season_id = fields.Many2one('golem.season', 'Season', required=True)
|
|
|
|
@api.depends('day_ids')
|
|
def _compute_day_display(self):
|
|
""" Computes day display """
|
|
for schedule in self:
|
|
days = [fields.Date.from_string(d.day).strftime('%d/%m/%Y')
|
|
for d in schedule.day_ids]
|
|
schedule.day_display = u', '.join(days)
|
|
|
|
@api.depends('day_ids')
|
|
def _compute_occurences(self):
|
|
""" Computes number of occurences """
|
|
for schedule in self:
|
|
schedule.occurences = len(schedule.day_ids)
|
|
|
|
@api.constrains('day_ids', 'season_id')
|
|
def check_dates(self):
|
|
""" Check date coherence """
|
|
for schedule in self:
|
|
if schedule.season_id.date_start:
|
|
days = schedule.day_ids.mapped('day')
|
|
for day in days:
|
|
season = schedule.season_id
|
|
if (day < season.date_start or day > season.date_end):
|
|
verr = _('Day %s is out of season period (%s-%s)'% \
|
|
(day, season.date_start, season.date_end))
|
|
raise ValidationError(verr)
|