1 # -*- coding: utf-8 -*-
2 ##############################################################################
4 # Remembership module for OpenERP, Overload membership module
5 # Copyright (C) 2012 L'Heureux Cyclage (<http://www.heureux-cyclage.org>) Ludovic CHEVALIER
7 # This file is a part of Remembership
9 # Remembership is free software: you can redistribute it and/or modify
10 # it under the terms of the GNU General Public License as published by
11 # the Free Software Foundation, either version 3 of the License, or
12 # (at your option) any later version.
14 # Remembership is distributed in the hope that it will be useful,
15 # but WITHOUT ANY WARRANTY; without even the implied warranty of
16 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 # GNU General Public License for more details.
19 # You should have received a copy of the GNU General Public License
20 # along with this program. If not, see <http://www.gnu.org/licenses/>.
22 ##############################################################################
25 from osv
import fields
29 class Partner(osv
.osv
):
30 _inherit
= 'res.partner'
33 'member_ident': fields
.char('Member identifier', size
=64),
34 'associate_members': fields
.one2many('res.partner', 'associate_member', 'Associate members', help='Members who are associated to this partner.'),
38 ('member_ident_uniq', 'unique(member_ident, company_id)', 'The member identifier must be unique !'),
44 class Product(osv
.osv
):
45 _inherit
= 'product.product'
48 'membership_grouped': fields
.boolean('Grouped membership product', help='Check if it\'s a grouped membership product.'),
49 'membership_date2date': fields
.boolean('Date to date membership product', required
=False, help='Check if it\'s a date to date membership product.'),
55 class account_invoice_line(osv
.osv
):
56 _inherit
= 'account.invoice.line'
59 def write(self
, cr
, uid
, ids
, vals
, context
=None):
60 member_line_obj
= self
.pool
.get('membership.membership_line')
61 res
= super(account_invoice_line
, self
).write(cr
, uid
, ids
, vals
, context
=context
)
62 for line
in self
.browse(cr
, uid
, ids
, context
=context
):
63 if line
.invoice_id
.type == 'out_invoice':
64 ml_ids
= member_line_obj
.search(cr
, uid
, [('account_invoice_line', '=', line
.id)], context
=context
)
65 if line
.product_id
and line
.product_id
.membership
:
66 date_from
= line
.product_id
.membership_date_from
67 date_to
= line
.product_id
.membership_date_to
68 if line
.invoice_id
.date_invoice
> date_from
and line
.invoice_id
.date_invoice
< date_to
:
69 date_from
= line
.invoice_id
.date_invoice
70 if line
.product_id
.membership_grouped
:
71 if line
.invoice_id
.partner_id
.associate_members
:
72 for associate_member
in line
.invoice_id
.partner_id
.associate_members
:
73 member_line_obj
.create(cr
, uid
, {
74 'partner': associate_member
.id,
75 'membership_id': line
.product_id
.id,
76 'member_price': line
.price_unit
,
77 'date': time
.strftime('%Y-%m-%d'),
78 'date_from': date_from
,
80 'account_invoice_line': line
.id,
83 print("DEV: mettre une contrainte pour l'objet\
84 membership.membership_line interdisant les\
85 adhésions groupées reliées à des partenaires\
86 sans membres associés")
88 associate_ml_ids
= member_line_obj
.search(cr
, uid
, [('account_invoice_line', '=', line
.id), ('partner', '!=', line
.invoice_id
.partner_id
.id)], context
=context
)
89 member_line_obj
.unlink(cr
, uid
, associate_ml_ids
, context
=context
)
91 #Define member ident if it's necessary
92 partners
= [line
.invoice_id
.partner_id
]
93 if line
.invoice_id
.partner_id
.associate_members
:
94 partners
.extend(line
.invoice_id
.partner_id
.associate_members
)
96 if not i
.member_ident
:
97 mbr_id
= self
.pool
.get('ir.sequence').get(cr
, uid
, 'member_ident')
98 self
.pool
.get('res.partner').write(cr
, uid
, i
.id, {'member_ident': mbr_id
})
99 if line
.product_id
and not line
.product_id
.membership
and ml_ids
:
100 # Product line has changed to a non membership product
101 member_line_obj
.unlink(cr
, uid
, ml_ids
, context
=context
)
104 def create(self
, cr
, uid
, vals
, context
=None):
105 member_line_obj
= self
.pool
.get('membership.membership_line')
106 res
= super(account_invoice_line
, self
).create(cr
, uid
, vals
, context
=context
)
107 line
= self
.browse(cr
, uid
, res
, context
=context
)
109 if line
.invoice_id
.type == 'out_invoice' and line
.product_id
and line
.product_id
.membership
:
110 date_from
= line
.product_id
.membership_date_from
111 date_to
= line
.product_id
.membership_date_to
112 if line
.invoice_id
.date_invoice
> date_from
and line
.invoice_id
.date_invoice
< date_to
:
113 date_from
= line
.invoice_id
.date_invoice
114 partners
= [line
.invoice_id
.partner_id
]
115 if line
.product_id
.membership_grouped
and line
.invoice_id
.partner_id
.associate_members
:
116 partners
.extend(line
.invoice_id
.partner_id
.associate_members
)
117 #Adding membership lines just for associate partners
118 for associate_member
in line
.invoice_id
.partner_id
.associate_members
:
119 member_line_obj
.create(cr
, uid
, {
120 'partner': associate_member
.id,
121 'membership_id': line
.product_id
.id,
122 'member_price': line
.price_unit
,
123 'date': time
.strftime('%Y-%m-%d'),
124 'date_from': date_from
,
126 'account_invoice_line': line
.id,
128 #Define member ident if it's necessary
130 if not i
.member_ident
:
131 mbr_id
= self
.pool
.get('ir.sequence').get(cr
, uid
, 'member_ident')
132 self
.pool
.get('res.partner').write(cr
, uid
, i
.id, {'member_ident': mbr_id
})
135 account_invoice_line()
138 class pos_make_payment(osv
.osv_memory
):
139 _inherit
= 'pos.make.payment'
141 def check(self
, cr
, uid
, ids
, context
=None):
143 Auto invoice orders. Temporarly solution before make partner members just with orders, without invoice.
145 res
= super(pos_make_payment
, self
).check(cr
, uid
, ids
, context
=context
)
147 order_obj
= self
.pool
.get('pos.order')
148 order_obj
.action_invoice(cr
, uid
, ids
, context
=context
)
154 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: