Ajout du fonction d'inscription automatique depuis attente en cas de desincription

This commit is contained in:
eloyoussef 2018-02-23 17:54:27 +01:00
parent 83221ec706
commit 9d0ef62c0e
2 changed files with 82 additions and 10 deletions

View File

@ -36,6 +36,52 @@ class GolemActivity(models.Model):
store=True , string='Pending registration number') store=True , string='Pending registration number')
#contraint sur nombre d'inscription : une desincription declanche une inscription depuis attente
@api.multi
@api.constrains('activity_registration_ids')
def _automatedRegistrationFromQueue(self):
for record in self:
print "________________________stitot_________________"
if (len(record.activity_registration_ids) < record.places and
record.queue_activity_number > 0):
print("________________________testuiiautomated____________________________________")
#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'])
#suppose que le membre est enrigistré
membre_registred = True
#parcourir les element sur l'attente
for queue in queues_sorted:
print "_______queueu frome queues"
#inverse l'etat du memebre
membre_registred = False
#recuperer la liste des registration
registrations = record.activity_registration_ids
#parcourir les registration afin de vérifier si le memebre sur l'attente déja inscrit
for registration in registrations:
#compare le membre sur l'attente au membre sur l'inscription
if queue.member_id == registration.member_id:
#si membre trouvé on mentionne enregistré, on passe au registration suivante
membre_registred = True
break
#à la sortie de la boucle si le membre nest pas sur inscription faire une
if not membre_registred:
#valeures pour creer une inscritpion apartir de la file
print "____________________passage en cours"
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)]
#sortir de la boucle parcourissante la queue puisque inscription faite
break
#calculer le nombre d'inscription sur la file d'attente #calculer le nombre d'inscription sur la file d'attente
@api.multi @api.multi
@api.depends('activity_queue_ids') @api.depends('activity_queue_ids')
@ -69,21 +115,28 @@ class GolemActivity(models.Model):
#fonction enregistrement du premier element de la liste d'ttente en inscription #fonction enregistrement du premier element de la liste d'ttente en inscription
@api.multi @api.multi
def register_from_queue(self): def register_from_queue(self):
for record in self: for record in self:
print("________________________testuii____________________________________") print("________________________testuii____________________________________")
#recupérer la liste en file d'attente #recupérer la liste en file d'attente
queues = record.activity_queue_ids queues = record.activity_queue_ids
#trier la liste selon l'id : récupérer l'ancien element #trier la liste selon l'id : récupérer l'ancien element
queues_sorted = sorted(queues, key=lambda k: k['id']) queues_sorted = sorted(queues, key=lambda k: k['id'])
#suppose que le membre est enrigistré
membre_registred = True membre_registred = True
#parcourir les element sur l'attente
for queue in queues_sorted: for queue in queues_sorted:
#inverse l'etat du memebre
membre_registred = False membre_registred = False
#recuperer la liste des registration
registrations = record.activity_registration_ids registrations = record.activity_registration_ids
#parcourir les registration afin de vérifier si le memebre sur l'attente déja inscrit
for registration in registrations: for registration in registrations:
#compare le membre sur l'attente au membre sur l'inscription
if queue.member_id == registration.member_id: if queue.member_id == registration.member_id:
#si membre trouvé on mentionne enregistré, on passe au registration suivante
membre_registred = True membre_registred = True
break break
#à la sortie de la boucle si le membre nest pas sur inscription faire une
if not membre_registred: if not membre_registred:
#valeures pour creer une inscritpion apartir de la file #valeures pour creer une inscritpion apartir de la file
values = { values = {
@ -94,7 +147,9 @@ class GolemActivity(models.Model):
record.activity_registration_ids = [(0, 0,values)] record.activity_registration_ids = [(0, 0,values)]
#suppression de l'element de la file d'attente #suppression de l'element de la file d'attente
record.activity_queue_ids = [(2, queue.id, 0)] record.activity_queue_ids = [(2, queue.id, 0)]
#sortir de la boucle parcourissante la queue puisque inscription faite
break break
if membre_registred: if membre_registred:
print "diknokemekrklekrlekr" print "diknokemekrklekrlekr"
message = _('there is no member to register for this activity' message = _('there is no member to register for this activity'
@ -107,6 +162,7 @@ class GolemActivity(models.Model):
@api.multi @api.multi
@api.onchange('activity_registration_ids') @api.onchange('activity_registration_ids')
def _checkRemain(self): def _checkRemain(self):
@ -129,6 +185,16 @@ class GolemActivity(models.Model):
if record.automated_registration_from_queue: if record.automated_registration_from_queue:
#inscription automatique du 1er element de la file d'attente #inscription automatique du 1er element de la file d'attente
print("________________________testuii____________________________________") print("________________________testuii____________________________________")
warningMessage = _('There is a free place for the activity'
' : {}, you can fill it from the queue'
' using the button bellow')
return {
'warning' : {
'title' : _('Warning'),
'message': warningMessage.format(record.name)
}
}
"""
#recupérer la liste en file d'attente #recupérer la liste en file d'attente
queues = current_activity.activity_queue_ids queues = current_activity.activity_queue_ids
print "______________________test1" print "______________________test1"
@ -149,21 +215,26 @@ class GolemActivity(models.Model):
#valeures pour creer une inscritpion apartir de la file #valeures pour creer une inscritpion apartir de la file
print '_____________________creation' print '_____________________creation'
values = { values = {
'activity_id' : queue.activity_id, 'activity_id' : queue.activity_id.id,
'member_id' : queue.member_id 'member_id' : queue.member_id.id
} }
# creation d'inscription # creation d'inscription
record.places =55 record.places =100
record.activity_registration_ids = [(0, 0,values)] #current_activity.places_remain = 2
##current_activity.places_remain+
#reservation = self.env['golem.activity.registration'].create(values)
#record.activity_registration_ids = [(4, reservation.id,0)]
#suppression de l'element de la file d'attente #suppression de l'element de la file d'attente
record.activity_queue_ids = [(2, queue.id, 0)] #record.activity_queue_ids = [(2, queue.id, 0)]
break break
if membre_registred: if membre_registred:
message = _('there is no member to register for this activity' message = _('there is no member to register for this activity'
' from queue.') ' from queue.')
raise ValidationError(message) raise ValidationError(message)
""" """
"""
warningMessage = _('There is a free place for the activity' warningMessage = _('There is a free place for the activity'
' : {}, you can fill it from the queue' ' : {}, you can fill it from the queue'
' using the button bellow') ' using the button bellow')

View File

@ -25,9 +25,11 @@ class GolemActivityQueue(models.Model):
_name = 'golem.activity.queue' _name = 'golem.activity.queue'
_description = 'GOLEM Activity Queue' _description = 'GOLEM Activity Queue'
activity_id = fields.Many2one('golem.activity', required=True, ondelete='cascade') activity_id = fields.Many2one('golem.activity', required=True,
string='Activity', ondelete='cascade')
season_id = fields.Many2one(related='activity_id.season_id') season_id = fields.Many2one(related='activity_id.season_id')
member_id = fields.Many2one('golem.member', required=True, ondelete='cascade') member_id = fields.Many2one('golem.member', required=True,
string='Member', ondelete='cascade')
is_current = fields.Boolean('Current season?', is_current = fields.Boolean('Current season?',
related='activity_id.is_current', store=True) related='activity_id.is_current', store=True)
#nombre de place disponible sur activité liée #nombre de place disponible sur activité liée
@ -44,4 +46,3 @@ class GolemActivityQueue(models.Model):
record.is_activity_full = "Full activity" record.is_activity_full = "Full activity"
else: else:
record.is_activity_full = "Not full activity" record.is_activity_full = "Not full activity"