-# -*- encoding: utf-8 -*-
+# -*- coding: utf-8 -*-
##############################################################################
-#
-# OpenERP, Open Source Management Solution
-# Copyright (C) 2004-2008 Tiny SPRL (<http://tiny.be>). All Rights Reserved
-# $Id$
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
#
# This program is free software: you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
+# 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 General Public License for more details.
+# GNU Affero General Public License for more details.
#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
+# 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 osv import fields,osv
+from osv import osv
+from osv import fields
+import os
import tools
+from tools.translate import _
+
+
+class multi_company_default(osv.osv):
+ """
+ Manage multi company default value
+ """
+ _name = 'multi_company.default'
+ _description = 'Default multi company'
+ _order = 'company_id,sequence,id'
+
+ _columns = {
+ 'sequence': fields.integer('Sequence'),
+ 'name': fields.char('Name', size=32, required=True, help='Name it to easily find a record'),
+ 'company_id': fields.many2one('res.company', 'Main Company', required=True,
+ help='Company where the user is connected'),
+ 'company_dest_id': fields.many2one('res.company', 'Default Company', required=True,
+ help='Company to store the current record'),
+ 'object_id': fields.many2one('ir.model', 'Object', required=True,
+ help='Object affect by this rules'),
+ 'expression': fields.char('Expression', size=32, required=True,
+ help='Expression, must be True to match'),
+ }
+
+ _defaults = {
+ 'expression': lambda *a: 'True',
+ 'sequence': lambda *a: 100,
+ }
+
+ def copy(self, cr, uid, id, default=None, context=None):
+ """
+ Add (copy) in the name when duplicate record
+ """
+ if not context:
+ context = {}
+ if not default:
+ default = {}
+ company = self.browse(cr, uid, id, context=context)
+ default = default.copy()
+ default['name'] = company.name + _(' (copy)')
+ return super(multi_company_default, self).copy(cr, uid, id, default, context=context)
+
+multi_company_default()
+
class res_company(osv.osv):
_name = "res.company"
-
+ _description = 'Companies'
_columns = {
'name': fields.char('Company Name', size=64, required=True),
'parent_id': fields.many2one('res.company', 'Parent Company', select=True),
- 'child_ids': fields.one2many('res.company', 'parent_id', 'Childs Company'),
+ 'child_ids': fields.one2many('res.company', 'parent_id', 'Child Companies'),
'partner_id': fields.many2one('res.partner', 'Partner', required=True),
'rml_header1': fields.char('Report Header', size=200),
'rml_footer1': fields.char('Report Footer 1', size=200),
'rml_header2' : fields.text('RML Internal Header'),
'logo' : fields.binary('Logo'),
'currency_id': fields.many2one('res.currency', 'Currency', required=True),
+ 'currency_ids': fields.one2many('res.currency', 'company_id', 'Currency'),
+ 'user_ids': fields.many2many('res.users', 'res_company_users_rel', 'cid', 'user_id', 'Accepted Users')
}
-
+
+
+ def _company_default_get(self, cr, uid, object=False, context=None):
+ """
+ Check if the object for this company have a default value
+ """
+ if not context:
+ context = {}
+ proxy = self.pool.get('multi_company.default')
+ ids = proxy.search(cr, uid, [('object_id.model', '=', object)])
+ for rule in proxy.browse(cr, uid, ids, context):
+ user = self.pool.get('res.users').browse(cr, uid, uid)
+ if eval(rule.expression, {'context': context, 'user': user}):
+ return rule.company_dest_id.id
+ return self.pool.get('res.users').browse(cr, uid, uid).company_id.id
+
def _get_child_ids(self, cr, uid, uid2, context={}):
company = self.pool.get('res.users').company_get(cr, uid, uid2)
ids = self._get_company_children(cr, uid, company)
descendance = self._get_partner_descendance(cr, uid, child_id, descendance)
return descendance
- def __init__(self, *args, **argv):
- return super(res_company, self).__init__(*args, **argv)
-
#
# This function restart the cache on the _get_company_children method
#
- def cache_restart(self, uid=None):
- self._get_company_children()
+ def cache_restart(self, cr):
+ self._get_company_children.clear_cache(cr.dbname)
- def create(self, *args, **argv):
- self.cache_restart()
- return super(res_company, self).create(*args, **argv)
+ def create(self, cr, *args, **argv):
+ self.cache_restart(cr)
+ return super(res_company, self).create(cr, *args, **argv)
- def write(self, *args, **argv):
- self.cache_restart()
+ def write(self, cr, *args, **argv):
+ self.cache_restart(cr)
# Restart the cache on the company_get method
- self.pool.get('ir.rule').domain_get()
- return super(res_company, self).write(*args, **argv)
+ self.pool.get('ir.rule').domain_get.clear_cache(cr.dbname)
+ return super(res_company, self).write(cr, *args, **argv)
def _get_euro(self, cr, uid, context={}):
try:
return self.pool.get('res.currency').search(cr, uid, [])[0]
except:
return False
-
+
def _check_recursion(self, cr, uid, ids):
level = 100
while len(ids):
- cr.execute('select distinct parent_id from res_company where id in ('+','.join(map(str,ids))+')')
+ cr.execute('select distinct parent_id from res_company where id in ('+','.join(map(str, ids))+')')
ids = filter(None, map(lambda x:x[0], cr.fetchall()))
if not level:
return False
level -= 1
return True
-
+
def _get_header2(self,cr,uid,ids):
return """
<header>
<pageGraphics>
<fill color="black"/>
<stroke color="black"/>
- <setFont name="Helvetica" size="8"/>
+ <setFont name="DejaVu Sans" size="8"/>
<drawString x="1.3cm" y="28.3cm"> [[ formatLang(time.strftime("%Y-%m-%d"), date=True) ]] [[ time.strftime("%H:%M") ]]</drawString>
- <setFont name="Helvetica-Bold" size="10"/>
+ <setFont name="DejaVu Sans Bold" size="10"/>
<drawString x="9.8cm" y="28.3cm">[[ company.partner_id.name ]]</drawString>
- <setFont name="Helvetica" size="8"/>
+ <setFont name="DejaVu Sans" size="8"/>
<drawRightString x="19.7cm" y="28.3cm"><pageNumber/> / </drawRightString>
<drawString x="19.8cm" y="28.3cm"><pageCount/></drawString>
<stroke color="#000000"/>
</header>"""
def _get_header(self,cr,uid,ids):
try :
- return tools.file_open('custom/corporate_rml_header.rml').read()
+ return tools.file_open(os.path.join('base', 'report', 'corporate_rml_header.rml')).read()
except:
return """
<header>
<pageGraphics>
<!-- You Logo - Change X,Y,Width and Height -->
<image x="1.3cm" y="27.6cm" height="40.0" >[[company.logo]]</image>
- <setFont name="Helvetica" size="8"/>
+ <setFont name="DejaVu Sans" size="8"/>
<fill color="black"/>
<stroke color="black"/>
<lines>1.3cm 27.7cm 20cm 27.7cm</lines>
res_company()
-
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: