forked from Yaltik/golem
Code cleaning and finalizing
This commit is contained in:
parent
98c8ad3767
commit
a0af3a680a
@ -1,5 +1,6 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
# Copyright 2018 Youssef El Ouahby <youssef@yaltik.com>
|
||||||
# Copyright 2018 Fabien Bourgeois <fabien@yaltik.com>
|
# Copyright 2018 Fabien Bourgeois <fabien@yaltik.com>
|
||||||
#
|
#
|
||||||
# This program is free software: you can redistribute it and/or modify
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
# Copyright 2018 Youssef El Ouahby <youssef@yaltik.com>
|
||||||
# Copyright 2018 Fabien Bourgeois <fabien@yaltik.com>
|
# Copyright 2018 Fabien Bourgeois <fabien@yaltik.com>
|
||||||
#
|
#
|
||||||
# This program is free software: you can redistribute it and/or modify
|
# This program is free software: you can redistribute it and/or modify
|
||||||
@ -20,7 +21,7 @@
|
|||||||
'summary': 'GOLEM activities queue',
|
'summary': 'GOLEM activities queue',
|
||||||
'version': '10.0.2.1.0',
|
'version': '10.0.2.1.0',
|
||||||
'category': 'GOLEM',
|
'category': 'GOLEM',
|
||||||
'author': 'Youssef Elouahby',
|
'author': 'Youssef El Ouahby, Fabien Bourgeois',
|
||||||
'license': 'AGPL-3',
|
'license': 'AGPL-3',
|
||||||
'application': True,
|
'application': True,
|
||||||
'installable': True,
|
'installable': True,
|
||||||
|
@ -23,7 +23,7 @@ class GolemActivity(models.Model):
|
|||||||
_inherit = 'golem.activity'
|
_inherit = 'golem.activity'
|
||||||
|
|
||||||
|
|
||||||
#ajout d'un champs O2M vers activity_id
|
#ajout d'un champs O2M vers activity_id de golem.activity.queue
|
||||||
activity_queue_ids = fields.One2many('golem.activity.queue',
|
activity_queue_ids = fields.One2many('golem.activity.queue',
|
||||||
'activity_id','Pending registration')
|
'activity_id','Pending registration')
|
||||||
# un boolen pour determiner si une fille d'attente est autorisé
|
# un boolen pour determiner si une fille d'attente est autorisé
|
||||||
|
@ -22,20 +22,15 @@ class GolemMember(models.Model):
|
|||||||
""" GOLEM Member adaptations """
|
""" GOLEM Member adaptations """
|
||||||
_inherit = 'golem.member'
|
_inherit = 'golem.member'
|
||||||
|
|
||||||
|
#ajout d'un champs O2M vers member_id de golem.activity.queue
|
||||||
|
activity_queue_ids = fields.One2many('golem.activity.queue',
|
||||||
|
'member_id','Pending registration')
|
||||||
|
|
||||||
@api.onchange('activity_registration_ids')
|
@api.onchange('activity_registration_ids')
|
||||||
def _checkRemain(self):
|
def _checkRemain(self):
|
||||||
"""print "#####################################"
|
|
||||||
print len(self.activity_registration_ids)
|
|
||||||
for reservation in self.activity_registration_ids:
|
|
||||||
print reservation.activity_id.name"""
|
|
||||||
|
|
||||||
for reservation in self.activity_registration_ids:
|
for reservation in self.activity_registration_ids:
|
||||||
activity = reservation.activity_id
|
activity = reservation.activity_id
|
||||||
"""print activity.name
|
|
||||||
print activity.places
|
|
||||||
print len(activity.activity_registration_ids)"""
|
|
||||||
if len(activity.activity_registration_ids) > activity.places and activity.queue_allowed:
|
if len(activity.activity_registration_ids) > activity.places and activity.queue_allowed:
|
||||||
#print("##vert##################")
|
|
||||||
warning_message = _('This activity : {} is already full, please'
|
warning_message = _('This activity : {} is already full, please'
|
||||||
' remove your registration and register in'
|
' remove your registration and register in'
|
||||||
' the queue using the bellow button')
|
' the queue using the bellow button')
|
||||||
@ -45,27 +40,12 @@ class GolemMember(models.Model):
|
|||||||
'message': warning_message.format(activity.name),
|
'message': warning_message.format(activity.name),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
"""
|
|
||||||
|
|
||||||
print "######################################"
|
|
||||||
print reservation.activity_id.places
|
|
||||||
print "######################################"
|
|
||||||
print reservation.activity_id.places_remain
|
|
||||||
|
|
||||||
if len(self.activity_registration_ids) > self.places and self.queue_allowed:
|
|
||||||
return {
|
|
||||||
'warning' : {
|
|
||||||
'title' : _('Warning'),
|
|
||||||
'message': _('No remaining place, please register in the queue'),
|
|
||||||
}
|
|
||||||
}"""
|
|
||||||
|
|
||||||
def queue_register(self):
|
def queue_register(self):
|
||||||
return {
|
return {
|
||||||
'name' : _('Choose the activity to register in'),
|
'name' : _('Choose the activity to register in'),
|
||||||
'type' : 'ir.actions.act_window',
|
'type' : 'ir.actions.act_window',
|
||||||
'res_model' : 'golem.activity.queue.choose.wizard',
|
'res_model' : 'golem.activity.queue.choose.wizard',
|
||||||
'view_mode': 'form',#'context' :{'default_activity_id' : activity_id.id},
|
'view_mode': 'form',
|
||||||
'domain' : [('activity_id.places_remain', '=', 0)],# activity_id.name)],#"('activity_id', '=', True)"'flags': {'action_buttons': True},
|
|
||||||
'target': 'new',
|
'target': 'new',
|
||||||
}
|
}
|
||||||
|
@ -25,15 +25,17 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|||||||
<field name="model">golem.activity</field>
|
<field name="model">golem.activity</field>
|
||||||
<field name="inherit_id" ref="golem_activity.golem_activity_form" />
|
<field name="inherit_id" ref="golem_activity.golem_activity_form" />
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
|
<!--Ajout du case file sur activity form-->
|
||||||
<xpath expr="//field[@name='is_overbooked']" position="after">
|
<xpath expr="//field[@name='is_overbooked']" position="after">
|
||||||
<field name="queue_allowed"/>
|
<field name="queue_allowed"/>
|
||||||
</xpath>
|
</xpath>
|
||||||
|
<!--Ajout du bouton inscription en file d'attente sur activity form-->
|
||||||
<xpath expr="//field[@name='activity_registration_ids']" position="after">
|
<xpath expr="//field[@name='activity_registration_ids']" position="after">
|
||||||
<button class="oe_highlight" name="queue_register"
|
<button class="oe_highlight" name="queue_register"
|
||||||
string="Register in the queue" type="object"
|
string="Register in the queue" type="object"
|
||||||
attrs="{'invisible':[('places_remain','>', 0)]}"/>
|
attrs="{'invisible':[('places_remain','>', 0)]}"/>
|
||||||
</xpath>
|
</xpath>
|
||||||
<!--onglet queue sur activity-->
|
<!--Ajout onglet queue sur activity form-->
|
||||||
<page name="invoicing" position="before">
|
<page name="invoicing" position="before">
|
||||||
<page name="queue" string="Queue">
|
<page name="queue" string="Queue">
|
||||||
<group>
|
<group>
|
||||||
|
@ -22,15 +22,31 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|||||||
<!-- add the queue registration button to member form-->
|
<!-- add the queue registration button to member form-->
|
||||||
<record id="golem_member_form_inherit_golem_activity_queue"
|
<record id="golem_member_form_inherit_golem_activity_queue"
|
||||||
model="ir.ui.view">
|
model="ir.ui.view">
|
||||||
<field name="name">Add the queue registration button to member form</field>
|
<field name="name">Add the queue onglet and registration button to member form</field>
|
||||||
<field name="model">golem.member</field>
|
<field name="model">golem.member</field>
|
||||||
<field name="inherit_id" ref="golem_member.golem_member_form" />
|
<field name="inherit_id" ref="golem_member.golem_member_form" />
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
|
<!--Ajout bouton d'inscription en file d'attente sur member form-->
|
||||||
<xpath expr="//field[@name='activity_registration_ids']" position="after">
|
<xpath expr="//field[@name='activity_registration_ids']" position="after">
|
||||||
<group>
|
<group>
|
||||||
<button class="oe_highlight" name="queue_register" string="Register in the queue" type="object"/>
|
<button class="oe_highlight" name="queue_register" string="Register in the queue" type="object"/>
|
||||||
</group>
|
</group>
|
||||||
</xpath>
|
</xpath>
|
||||||
|
<!--Ajout onglet queue sur member form-->
|
||||||
|
<page name="activities" position="after">
|
||||||
|
<page name="queue" string="List of queues">
|
||||||
|
<group>
|
||||||
|
|
||||||
|
<field name="activity_queue_ids"
|
||||||
|
context="{'default_member_id': active_id}">
|
||||||
|
<tree>
|
||||||
|
<field name="activity_id" readonly="1" />
|
||||||
|
<field name="season_id" readonly="1" />
|
||||||
|
</tree>
|
||||||
|
</field>
|
||||||
|
</group>
|
||||||
|
</page>
|
||||||
|
</page>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
</data>
|
</data>
|
||||||
|
@ -26,6 +26,7 @@ class GolemActivityQueueChooseWizard(models.TransientModel):
|
|||||||
|
|
||||||
activity_id = fields.Many2one("golem.activity")
|
activity_id = fields.Many2one("golem.activity")
|
||||||
|
|
||||||
|
|
||||||
def ChooseActivity(self):
|
def ChooseActivity(self):
|
||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
activityQueue = self[0]
|
activityQueue = self[0]
|
||||||
@ -33,7 +34,8 @@ class GolemActivityQueueChooseWizard(models.TransientModel):
|
|||||||
'name' : _('Register in the queue'),
|
'name' : _('Register in the queue'),
|
||||||
'type' : 'ir.actions.act_window',
|
'type' : 'ir.actions.act_window',
|
||||||
'res_model' : 'golem.activity.queue',
|
'res_model' : 'golem.activity.queue',
|
||||||
'view_mode': 'tree',#'context' :{'default_activity_id' : activity_id.id},
|
'view_mode': 'tree',#
|
||||||
|
'context' :{'default_activity_id' : activityQueue.activity_id.id},
|
||||||
'domain' : [('activity_id', '=',activityQueue.activity_id.id )],# activity_id.name)],#"('activity_id', '=', True)"
|
'domain' : [('activity_id', '=',activityQueue.activity_id.id )],# activity_id.name)],#"('activity_id', '=', True)"
|
||||||
'flags': {'action_buttons': True},
|
'flags': {'action_buttons': True},
|
||||||
'target': 'new',
|
'target': 'new',
|
||||||
|
Loading…
x
Reference in New Issue
Block a user