[MERGE] merge with main addons
[odoo/odoo.git] / addons / crm_fundraising / crm_fundraising.py
index 0050642..73f7297 100644 (file)
 #
 ##############################################################################
 
-from osv import fields, osv, orm
+from base_status.base_stage import base_stage
 from crm import crm
+from crm import wizard
+from osv import fields, osv
+from tools.translate import _
 
-class crm_fundraising(crm.crm_case, osv.osv):
+wizard.mail_compose_message.SUPPORTED_MODELS.append('crm.fundraising')
+
+class crm_fundraising(base_stage, osv.osv):
     """ Fund Raising Cases """
 
     _name = "crm.fundraising"
     _description = "Fund Raising"
     _order = "id desc"
-    _inherit = ['mailgate.thread']
+    _inherit = ['mail.thread']
     _columns = {
-            'id': fields.integer('ID'), 
+            'id': fields.integer('ID', readonly=True),
             'name': fields.char('Name', size=128, required=True),
-            'active': fields.boolean('Active', required=False), 
+            'active': fields.boolean('Active', required=False),
             'date_action_last': fields.datetime('Last Action', readonly=1),
-            'date_action_next': fields.datetime('Next Action', readonly=1), 
-            'description': fields.text('Description'), 
-            'create_date': fields.datetime('Creation Date' , readonly=True), 
-            'write_date': fields.datetime('Update Date' , readonly=True), 
-            'date_deadline': fields.date('Deadline'), 
-            'user_id': fields.many2one('res.users', 'Responsible'), 
+            'date_action_next': fields.datetime('Next Action', readonly=1),
+            'description': fields.text('Description'),
+            'create_date': fields.datetime('Creation Date' , readonly=True),
+            'write_date': fields.datetime('Update Date' , readonly=True),
+            'date_deadline': fields.date('Deadline'),
+            'user_id': fields.many2one('res.users', 'Responsible'),
             'section_id': fields.many2one('crm.case.section', 'Sales Team', \
-                            select=True, help='Sales team to which Case belongs to. Define Responsible user and Email account for mail gateway.'), 
-            'company_id': fields.many2one('res.company', 'Company'), 
-            'partner_id': fields.many2one('res.partner', 'Partner'), 
-            'partner_address_id': fields.many2one('res.partner.address', 'Partner Contact', \
-                                 domain="[('partner_id','=',partner_id)]"), 
-            'email_cc': fields.text('Watchers Emails', size=252 , help="These email addresses will be added to the CC field of all inbound and outbound emails for this record before being sent. Separate multiple email addresses with a comma"), 
-            'email_from': fields.char('Email', size=128, help="These people will receive email."), 
-            'date_closed': fields.datetime('Closed', readonly=True), 
-            'date': fields.datetime('Date'), 
-            'priority': fields.selection(crm.AVAILABLE_PRIORITIES, 'Priority'), 
+                            select=True, help='Sales team to which Case belongs to. Define Responsible user and Email account for mail gateway.'),
+            'company_id': fields.many2one('res.company', 'Company'),
+            'partner_id': fields.many2one('res.partner', 'Partner'),
+            'email_cc': fields.text('Watchers Emails', size=252 , help="These email addresses will be added to the CC field of all inbound and outbound emails for this record before being sent. Separate multiple email addresses with a comma"),
+            'email_from': fields.char('Email', size=128, help="These people will receive email."),
+            'date_closed': fields.datetime('Closed', readonly=True),
+            'date': fields.datetime('Date'),
+            'priority': fields.selection(crm.AVAILABLE_PRIORITIES, 'Priority'),
             'categ_id': fields.many2one('crm.case.categ', 'Category', \
                                 domain="[('section_id','=',section_id),\
-                                ('object_id.model', '=', 'crm.fundraising')]"), 
-            'planned_revenue': fields.float('Planned Revenue'), 
-            'planned_cost': fields.float('Planned Costs'), 
-            'probability': fields.float('Probability (%)'), 
-            'partner_name': fields.char("Employee's Name", size=64), 
-            'partner_name2': fields.char('Employee Email', size=64), 
-            'partner_phone': fields.char('Phone', size=32), 
-            'partner_mobile': fields.char('Mobile', size=32), 
-            'stage_id': fields.many2one ('crm.case.stage', 'Stage', \
-                             domain="[('section_id','=',section_id),\
-                            ('object_id.model', '=', 'crm.fundraising')]"), 
-            'type_id': fields.many2one('crm.case.resource.type', 'Fundraising Type', \
-                             domain="[('section_id','=',section_id),\
-                             ('object_id.model', '=', 'crm.fundraising')]"), 
-            'duration': fields.float('Duration'), 
-            'ref': fields.reference('Reference', selection=crm._links_get, size=128), 
-            'ref2': fields.reference('Reference 2', selection=crm._links_get, size=128), 
-            'canal_id': fields.many2one('res.partner.canal', 'Channel', \
-                        help="The channels represent the different communication \
- modes available with the customer."), 
-            'state': fields.selection(crm.AVAILABLE_STATES, 'State', size=16, readonly=True, 
-                                  help='The state is set to \'Draft\', when a case is created.\
-                                  \nIf the case is in progress the state is set to \'Open\'.\
-                                  \nWhen the case is over, the state is set to \'Done\'.\
-                                  \nIf the case needs to be reviewed then the state is set to \'Pending\'.'), 
-            'message_ids': fields.one2many('mailgate.message', 'res_id', 'Messages', domain=[('model','=',_name)]),
+                                ('object_id.model', '=', 'crm.fundraising')]"),
+            'planned_revenue': fields.float('Planned Revenue'),
+            'planned_cost': fields.float('Planned Costs'),
+            'probability': fields.float('Probability (%)'),
+            'partner_name': fields.char("Employee's Name", size=64),
+            'partner_name2': fields.char('Employee Email', size=64),
+            'partner_phone': fields.char('Phone', size=32),
+            'partner_mobile': fields.char('Mobile', size=32),
+            'stage_id': fields.many2one ('crm.case.stage', 'Stage', domain="[('section_ids', '=', section_id)]"), 
+            'type_id': fields.many2one('crm.case.resource.type', 'Campaign', \
+                             domain="[('section_id','=',section_id)]"),
+            'duration': fields.float('Duration'),
+            'ref': fields.reference('Reference', selection=crm._links_get, size=128),
+            'ref2': fields.reference('Reference 2', selection=crm._links_get, size=128),
+            'state': fields.related('stage_id', 'state', type="selection", store=True,
+                    selection=crm.AVAILABLE_STATES, string="State", readonly=True,
+                    help='The state is set to \'Draft\', when a case is created.\
+                        If the case is in progress the state is set to \'Open\'.\
+                        When the case is over, the state is set to \'Done\'.\
+                        If the case needs to be reviewed then the state is \
+                        set to \'Pending\'.'),
         }
 
     _defaults = {
-            'active': lambda *a: 1, 
-            'user_id': crm.crm_case._get_default_user, 
-            'partner_id': crm.crm_case._get_default_partner, 
-            'partner_address_id': crm.crm_case._get_default_partner_address, 
-            'email_from': crm.crm_case. _get_default_email, 
-            'state': lambda *a: 'draft', 
-            'section_id': crm.crm_case. _get_section, 
-            'company_id': lambda s, cr, uid, c: s.pool.get('res.company')._company_default_get(cr, uid, 'crm.case', context=c), 
-            'priority': lambda *a: crm.AVAILABLE_PRIORITIES[2][0], 
-            'probability': lambda *a:0.0, 
-            'planned_cost': lambda *a:0.0, 
-            'planned_revenue': lambda *a:0.0, 
-            }
+            'active': 1,
+            'user_id':  lambda s, cr, uid, c: s._get_default_user(cr, uid, c),
+            'partner_id':  lambda s, cr, uid, c: s._get_default_partner(cr, uid, c),
+            'email_from': lambda s, cr, uid, c: s._get_default_email(cr, uid, c),
+            'section_id': lambda s, cr, uid, c: s._get_default_section_id(cr, uid, c),
+            'company_id': lambda s, cr, uid, c: s.pool.get('res.company')._company_default_get(cr, uid, 'crm.case', context=c),
+            'priority': crm.AVAILABLE_PRIORITIES[2][0],
+            'probability': 0.0,
+            'planned_cost': 0.0,
+            'planned_revenue': 0.0,
+    }
+
+    def stage_find(self, cr, uid, cases, section_id, domain=[], order='sequence', context=None):
+        """ Override of the base.stage method
+            Parameter of the stage search taken from the lead:
+            - section_id: if set, stages must belong to this section or
+              be a default case
+        """
+        if isinstance(cases, (int, long)):
+            cases = self.browse(cr, uid, cases, context=context)
+        # collect all section_ids
+        section_ids = []
+        if section_id:
+            section_ids.append(section_id)
+        for case in cases:
+            if case.section_id:
+                section_ids.append(case.section_id.id)
+        # OR all section_ids and OR with case_default
+        search_domain = []
+        if section_ids:
+            search_domain += [('|')] * len(section_ids)
+            for section_id in section_ids:
+                search_domain.append(('section_ids', '=', section_id))
+        search_domain.append(('case_default', '=', True))
+        # AND with the domain in parameter
+        search_domain += list(domain)
+        # perform search, return the first found
+        stage_ids = self.pool.get('crm.case.stage').search(cr, uid, search_domain, order=order, context=context)
+        if stage_ids:
+            return stage_ids[0]
+        return False
+
+    def create(self, cr, uid, vals, context=None):
+        obj_id = super(crm_fundraising, self).create(cr, uid, vals, context)
+        self.create_send_note(cr, uid, [obj_id], context=context)
+        return obj_id
+
+    def message_new(self, cr, uid, msg, custom_values=None, context=None):
+        """Automatically called when new email message arrives"""
+        res_id = super(crm_fundraising,self).message_new(cr, uid, msg, custom_values=custom_values, context=context)
+        vals = {
+            'name': msg.get('subject'),
+            'email_from': msg.get('from'),
+            'email_cc': msg.get('cc'),
+            'description': msg.get('body_text'),
+        }
+        priority = msg.get('priority')
+        if priority:
+            vals['priority'] = priority
+        vals.update(self.message_partner_by_email(cr, uid, msg.get('from')))
+        self.write(cr, uid, [res_id], vals, context=context)
+        return res_id
+
+    # ---------------------------------------------------
+    # OpenChatter methods and notifications
+    # ---------------------------------------------------
+
+    def case_get_note_msg_prefix(self, cr, uid, id, context=None):
+        """ Override of default prefix for notifications. """
+        return 'Fundraising'
+
+    def create_send_note(self, cr, uid, ids, context=None):
+        msg = _('Fundraising has been <b>created</b>.')
+        self.message_append_note(cr, uid, ids, body=msg, context=context)
+        return True
+
+    def stage_set_send_note(self, cr, uid, ids, stage_id, context=None):
+        """ Override of the (void) default notification method. """
+        stage_name = self.pool.get('crm.case.stage').name_get(cr, uid, [stage_id], context=context)[0][1]
+        return self.message_append_note(cr, uid, ids, body= _("Stage changed to <b>%s</b>.") % (stage_name), context=context)
+
 
-crm_fundraising()
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: