merge
[odoo/odoo.git] / bin / addons / base / res / res_company.py
index e241f0c..acd1e85 100644 (file)
+# -*- coding: utf-8 -*-
 ##############################################################################
+#    
+#    OpenERP, Open Source Management Solution
+#    Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
 #
-# Copyright (c) 2004-2006 TINY SPRL. (http://tiny.be) All Rights Reserved.
-#                    Fabien Pinckaers <fp@tiny.Be>
+#    This program is free software: you can redistribute it and/or modify
+#    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.
 #
-# WARNING: This program as such is intended to be used by professional
-# programmers who take the whole responsability of assessing all potential
-# consequences resulting from its eventual inadequacies and bugs
-# End users who are looking for a ready-to-use solution with commercial
-# garantees and support are strongly adviced to contract a Free Software
-# Service Company
+#    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 Affero General Public License for more details.
 #
-# 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 2
-# 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.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+#    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"
-
-       _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'),
-               '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_footer2': fields.char('Report Footer 2', size=200),
-               'currency_id': fields.many2one('res.currency', 'Currency', required=True),
-       }
-       
-       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)
-               return ids
-
-       def _get_company_children(self, cr, uid=None, company=None):
-               if not company:
-                       return []
-               ids =  self.search(cr, uid, [('parent_id','child_of',[company])])
-               return ids
-       _get_company_children = tools.cache()(_get_company_children)
-
-       def _get_partner_hierarchy(self, cr, uid, company_id, context={}):
-               if company_id:
-                       parent_id = self.browse(cr, uid, company_id)['parent_id']
-                       if parent_id:
-                               return self._get_partner_hierarchy(cr, uid, parent_id.id, context)
-                       else:
-                               return self._get_partner_descendance(cr, uid, company_id, [], context)
-               return []
-
-       def _get_partner_descendance(self, cr, uid, company_id, descendance, context={}):
-               descendance.append(self.browse(cr, uid, company_id).partner_id.id)
-               for child_id in self._get_company_children(cr, uid, company_id):
-                       if child_id != company_id:
-                               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 create(self, *args, **argv):
-               self.cache_restart()
-               return super(res_company, self).create(*args, **argv)
-
-       def write(self, *args, **argv):
-               self.cache_restart()
-               # Restart the cache on the company_get method
-               self.pool.get('ir.rule').domain_get()
-               return super(res_company, self).write(*args, **argv)
-
-       def _get_euro(self, cr, uid, context={}):
-               try:
-                       return self.pool.get('res.currency').search(cr, uid, [('rate', '=', 1.0),])[0]
-               except:
-                       return 1
-       
-       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))+')')
-                       ids = filter(None, map(lambda x:x[0], cr.fetchall()))
-                       if not level:
-                               return False
-                       level -= 1
-               return True
-       
-       _defaults = {
-               'currency_id': _get_euro,
-       }
-
-       _constraints = [
-               (_check_recursion, 'Error! You can not create recursive companies.', ['parent_id'])
-       ]
+    _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', '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_footer2': fields.char('Report Footer 2', size=200),
+        'rml_header' : fields.text('RML Header'),
+        '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)
+        return ids
+
+    def _get_company_children(self, cr, uid=None, company=None):
+        if not company:
+            return []
+        ids =  self.search(cr, uid, [('parent_id','child_of',[company])])
+        return ids
+    _get_company_children = tools.cache()(_get_company_children)
+
+    def _get_partner_hierarchy(self, cr, uid, company_id, context={}):
+        if company_id:
+            parent_id = self.browse(cr, uid, company_id)['parent_id']
+            if parent_id:
+                return self._get_partner_hierarchy(cr, uid, parent_id.id, context)
+            else:
+                return self._get_partner_descendance(cr, uid, company_id, [], context)
+        return []
+
+    def _get_partner_descendance(self, cr, uid, company_id, descendance, context={}):
+        descendance.append(self.browse(cr, uid, company_id).partner_id.id)
+        for child_id in self._get_company_children(cr, uid, company_id):
+            if child_id != company_id:
+                descendance = self._get_partner_descendance(cr, uid, child_id, descendance)
+        return descendance
+
+    #
+    # This function restart the cache on the _get_company_children method
+    #
+    def cache_restart(self, cr):
+        self._get_company_children.clear_cache(cr.dbname)
+
+    def create(self, cr, *args, **argv):
+        self.cache_restart(cr)
+        return super(res_company, self).create(cr, *args, **argv)
+
+    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.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))+')')
+            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>
+        <pageTemplate>
+        <frame id="first" x1="1.3cm" y1="1.5cm" width="18.4cm" height="26.5cm"/>
+        <pageGraphics>
+        <fill color="black"/>
+        <stroke color="black"/>
+        <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="DejaVu Sans Bold" size="10"/>
+        <drawString x="9.8cm" y="28.3cm">[[ company.partner_id.name ]]</drawString>
+        <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"/>
+        <lines>1.3cm 28.1cm 20cm 28.1cm</lines>
+        </pageGraphics>
+        </pageTemplate>
+</header>"""
+    def _get_header(self,cr,uid,ids):
+        try :
+            return tools.file_open(os.path.join('base', 'report', 'corporate_rml_header.rml')).read()
+        except:
+            return """
+    <header>
+    <pageTemplate>
+        <frame id="first" x1="1.3cm" y1="2.5cm" height="23.0cm" width="19cm"/>
+        <pageGraphics>
+            <!-- You Logo - Change X,Y,Width and Height -->
+        <image x="1.3cm" y="27.6cm" height="40.0" >[[company.logo]]</image>
+            <setFont name="DejaVu Sans" size="8"/>
+            <fill color="black"/>
+            <stroke color="black"/>
+            <lines>1.3cm 27.7cm 20cm 27.7cm</lines>
+
+            <drawRightString x="20cm" y="27.8cm">[[ company.rml_header1 ]]</drawRightString>
+
+
+            <drawString x="1.3cm" y="27.2cm">[[ company.partner_id.name ]]</drawString>
+            <drawString x="1.3cm" y="26.8cm">[[ company.partner_id.address and company.partner_id.address[0].street or  '' ]]</drawString>
+            <drawString x="1.3cm" y="26.4cm">[[ company.partner_id.address and company.partner_id.address[0].zip or '' ]] [[ company.partner_id.address and company.partner_id.address[0].city or '' ]] - [[ company.partner_id.address and company.partner_id.address[0].country_id and company.partner_id.address[0].country_id.name  or '']]</drawString>
+            <drawString x="1.3cm" y="26.0cm">Phone:</drawString>
+            <drawRightString x="7cm" y="26.0cm">[[ company.partner_id.address and company.partner_id.address[0].phone or '' ]]</drawRightString>
+            <drawString x="1.3cm" y="25.6cm">Mail:</drawString>
+            <drawRightString x="7cm" y="25.6cm">[[ company.partner_id.address and company.partner_id.address[0].email or '' ]]</drawRightString>
+            <lines>1.3cm 25.5cm 7cm 25.5cm</lines>
+
+            <!--page bottom-->
+
+            <lines>1.2cm 2.15cm 19.9cm 2.15cm</lines>
+
+            <drawCentredString x="10.5cm" y="1.7cm">[[ company.rml_footer1 ]]</drawCentredString>
+            <drawCentredString x="10.5cm" y="1.25cm">[[ company.rml_footer2 ]]</drawCentredString>
+            <drawCentredString x="10.5cm" y="0.8cm">Contact : [[ user.name ]] - Page: <pageNumber/></drawCentredString>
+        </pageGraphics>
+    </pageTemplate>
+</header>"""
+    _defaults = {
+        'currency_id': _get_euro,
+        'rml_header':_get_header,
+        'rml_header2': _get_header2
+    }
+
+    _constraints = [
+        (_check_recursion, 'Error! You can not create recursive companies.', ['parent_id'])
+    ]
 
 res_company()
 
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+