forked from Yaltik/golem
Ajout du fonction d'inscription automatique depuis attente en cas de desincription
This commit is contained in:
parent
83221ec706
commit
9d0ef62c0e
@ -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')
|
||||||
|
@ -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"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user