2018-02-19 23:58:50 +01:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
# Copyright 2018 Youssef El Ouahby <youssef@yaltik.com>
|
|
|
|
# Copyright 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/>.
|
|
|
|
|
|
|
|
from odoo import models, fields, api, _
|
2018-02-23 01:28:25 +01:00
|
|
|
from odoo.exceptions import ValidationError
|
2018-02-19 23:58:50 +01:00
|
|
|
|
|
|
|
class GolemActivity(models.Model):
|
|
|
|
""" GOLEM Activity adaptations """
|
|
|
|
_inherit = 'golem.activity'
|
|
|
|
|
|
|
|
|
2018-02-21 14:56:51 +01:00
|
|
|
#ajout d'un champs O2M vers activity_id de golem.activity.queue
|
2018-02-21 12:19:28 +01:00
|
|
|
activity_queue_ids = fields.One2many('golem.activity.queue',
|
|
|
|
'activity_id','Pending registration')
|
2018-02-22 22:59:10 +01:00
|
|
|
# un booleen pour determiner si une fille d'attente est autorisé
|
2018-02-19 23:58:50 +01:00
|
|
|
queue_allowed = fields.Boolean(default=True)
|
2018-02-22 22:59:10 +01:00
|
|
|
# un booleen pour automatisé l'inscription sur une activité depuis la file d'attente
|
|
|
|
automated_registration_from_queue = fields.Boolean(default=True)
|
2018-02-21 12:19:28 +01:00
|
|
|
#ajout d'un champs pour calculer le nombre d'inscription en file d'attente
|
|
|
|
queue_activity_number = fields.Integer(compute="_queue_activity_number",
|
|
|
|
store=True , string='Pending registration number')
|
|
|
|
|
|
|
|
|
2018-02-22 22:59:10 +01:00
|
|
|
#calculer le nombre d'inscription sur la file d'attente
|
2018-02-21 12:19:28 +01:00
|
|
|
@api.multi
|
2018-02-22 22:59:10 +01:00
|
|
|
@api.depends('activity_queue_ids')
|
2018-02-21 12:19:28 +01:00
|
|
|
def _queue_activity_number(self):
|
|
|
|
for activity in self:
|
|
|
|
activity.queue_activity_number = len(activity.activity_queue_ids)
|
2018-02-19 23:58:50 +01:00
|
|
|
|
2018-02-22 22:59:10 +01:00
|
|
|
#lancer une fenetre pour inscritpion en file d'attente
|
2018-02-20 17:44:40 +01:00
|
|
|
@api.multi
|
2018-02-19 23:58:50 +01:00
|
|
|
def queue_register(self):
|
2018-02-20 17:44:40 +01:00
|
|
|
self.ensure_one()
|
|
|
|
activity_id = self[0]
|
2018-02-19 23:58:50 +01:00
|
|
|
return {
|
|
|
|
'name' : _('Register in the queue'),
|
|
|
|
'type' : 'ir.actions.act_window',
|
|
|
|
'res_model' : 'golem.activity.queue',
|
2018-02-20 17:44:40 +01:00
|
|
|
'context' :{'default_activity_id' : activity_id.id},
|
|
|
|
'domain' : [('activity_id', '=', activity_id.id)],# activity_id.name)],#"('activity_id', '=', True)"
|
|
|
|
'view_mode': 'tree',
|
2018-02-20 13:01:04 +01:00
|
|
|
'flags': {'action_buttons': True},
|
2018-02-19 23:58:50 +01:00
|
|
|
'target': 'new',
|
|
|
|
}
|
|
|
|
|
2018-02-20 17:44:40 +01:00
|
|
|
|
|
|
|
|
2018-02-23 01:28:25 +01:00
|
|
|
#fonction enregistrement du premier element de la liste d'ttente en inscription
|
2018-02-22 22:59:10 +01:00
|
|
|
@api.multi
|
|
|
|
def register_from_queue(self):
|
2018-02-23 01:28:25 +01:00
|
|
|
|
2018-02-22 22:59:10 +01:00
|
|
|
for record in self:
|
2018-02-23 01:28:25 +01:00
|
|
|
print("________________________testuii____________________________________")
|
2018-02-22 22:59:10 +01:00
|
|
|
#recupérer la liste en file d'attente
|
|
|
|
queues = record.activity_queue_ids
|
|
|
|
#trier la liste selon l'id : récupérer l'ancien element
|
|
|
|
queues_sorted = sorted(queues, key=lambda k: k['id'])
|
2018-02-23 01:28:25 +01:00
|
|
|
membre_registred = True
|
|
|
|
for queue in queues_sorted:
|
|
|
|
membre_registred = False
|
|
|
|
registrations = record.activity_registration_ids
|
|
|
|
for registration in registrations:
|
|
|
|
if queue.member_id == registration.member_id:
|
|
|
|
membre_registred = True
|
|
|
|
break
|
|
|
|
if not membre_registred:
|
|
|
|
#valeures pour creer une inscritpion apartir de la file
|
|
|
|
values = {
|
|
|
|
'activity_id' : queue.activity_id,
|
|
|
|
'member_id' : queue.member_id
|
|
|
|
}
|
|
|
|
# creation d'inscription
|
|
|
|
record.activity_registration_ids = [(0, 0,values)]
|
|
|
|
#suppression de l'element de la file d'attente
|
|
|
|
record.activity_queue_ids = [(2, queue.id, 0)]
|
|
|
|
break
|
|
|
|
if membre_registred:
|
|
|
|
print "diknokemekrklekrlekr"
|
|
|
|
message = _('there is no member to register for this activity'
|
|
|
|
' from queue.')
|
|
|
|
raise ValidationError(message)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2018-02-22 22:59:10 +01:00
|
|
|
|
|
|
|
|
|
|
|
@api.multi
|
2018-02-19 23:58:50 +01:00
|
|
|
@api.onchange('activity_registration_ids')
|
2018-02-20 13:01:04 +01:00
|
|
|
def _checkRemain(self):
|
2018-02-22 22:59:10 +01:00
|
|
|
for record in self:
|
|
|
|
if len(record.activity_registration_ids) > record.places and record.queue_allowed:
|
|
|
|
message = _('No remaining place for the activity : {}, please'
|
|
|
|
' discard changes and register in the queue using'
|
|
|
|
' the button bellow')
|
|
|
|
return {
|
|
|
|
'warning' : {
|
|
|
|
'title' : _('Warning'),
|
|
|
|
'message': message.format(record.name),
|
|
|
|
}
|
2018-02-19 23:58:50 +01:00
|
|
|
}
|
2018-02-22 22:59:10 +01:00
|
|
|
elif len(record.activity_registration_ids) < record.places and record.queue_allowed and record.queue_activity_number > 0:
|
2018-02-19 23:58:50 +01:00
|
|
|
|
2018-02-22 22:59:10 +01:00
|
|
|
# passage de l'element depuis la file d'attente automatiquement
|
|
|
|
if record.automated_registration_from_queue:
|
|
|
|
#traitement qui bloque avec message d'erreur can't adapt activitiy_id to newId
|
|
|
|
"""
|
|
|
|
#recupérer la liste en file d'attente
|
|
|
|
queues = record.activity_queue_ids
|
|
|
|
#trier la liste selon l'id : récupérer l'ancien element
|
|
|
|
queues_sorted = sorted(queues, key=lambda k: k['id'])
|
|
|
|
#valeures pour creer une inscritpion apartir de la file
|
|
|
|
values = {
|
|
|
|
'activity_id' : queues_sorted[0].activity_id,
|
|
|
|
'member_id' : queues_sorted[0].member_id
|
|
|
|
}
|
|
|
|
# creation d'inscription
|
|
|
|
record.activity_registration_ids = [(0, 0,values)]
|
|
|
|
#suppression de l'element de la file d'attente
|
|
|
|
record.activity_queue_ids = [(2, queues_sorted[0].id, 0)]
|
|
|
|
"""
|
2018-02-19 23:58:50 +01:00
|
|
|
|
2018-02-22 22:59:10 +01:00
|
|
|
warningMessage = _('There is a free place for the activity'
|
|
|
|
' : {}, you can fill it from the queue'
|
|
|
|
' using the button bellow')
|
2018-02-19 23:58:50 +01:00
|
|
|
return {
|
2018-02-22 22:59:10 +01:00
|
|
|
'warning' : {
|
|
|
|
'title' : _('Warning'),
|
|
|
|
'message': warningMessage.format(record.name)
|
|
|
|
}
|
2018-02-19 23:58:50 +01:00
|
|
|
}
|
|
|
|
|
2018-02-22 22:59:10 +01:00
|
|
|
#traitement manuel pour le passage de la file d'attente en inscription : button sur queue
|
|
|
|
else :
|
|
|
|
warningMessage = _('There is a free place for the activity'
|
|
|
|
' : {}, you can fill it from the queue'
|
|
|
|
' using the button on queue tab')
|
|
|
|
return {
|
|
|
|
'warning' : {
|
|
|
|
'title' : _('Warning'),
|
|
|
|
'message': warningMessage.format(record.name)
|
|
|
|
}
|
|
|
|
}
|