You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

90 lines
3.4 KiB

  1. # -*- encoding: utf-8 -*-
  2. ##############################################################################
  3. #
  4. # Asterisk click2dial CRM module for OpenERP
  5. # Copyright (c) 2011 Zikzakmedia S.L. (http://zikzakmedia.com)
  6. # Copyright (c) 2012-2014 Akretion (http://www.akretion.com)
  7. # Copyright (C) 2013 Invitu <contact@invitu.com>
  8. # @author: Jesús Martín <jmartin@zikzakmedia.com>
  9. # @author: Alexis de Lattre <alexis.delattre@akretion.com>
  10. #
  11. # This program is free software: you can redistribute it and/or modify
  12. # it under the terms of the GNU Affero General Public License as published
  13. # by the Free Software Foundation, either version 3 of the License, or
  14. # (at your option) any later version.
  15. #
  16. # This program is distributed in the hope that it will be useful,
  17. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  18. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  19. # GNU Affero General Public License for more details.
  20. #
  21. # You should have received a copy of the GNU Affero General Public License
  22. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  23. #
  24. ##############################################################################
  25. from openerp.osv import orm, fields
  26. class res_partner(orm.Model):
  27. _name = 'res.partner'
  28. _inherit = ['res.partner', 'phone.common']
  29. def action_dial(self, cr, uid, ids, context=None):
  30. '''
  31. This method open the phone call history when the phone click2dial
  32. button of asterisk_click2dial module is pressed
  33. :return the phone call history view of the partner
  34. '''
  35. if context is None:
  36. context = {}
  37. super(res_partner, self).action_dial(cr, uid, ids, context=context)
  38. user = self.pool['res.users'].browse(cr, uid, uid, context=context)
  39. context['partner_id'] = ids[0]
  40. action_start_wizard = {
  41. 'name': 'Create phone call in CRM',
  42. 'type': 'ir.actions.act_window',
  43. 'res_model': 'wizard.create.crm.phonecall',
  44. 'view_type': 'form',
  45. 'view_mode': 'form',
  46. 'nodestroy': True,
  47. 'target': 'new',
  48. 'context': context,
  49. }
  50. if user.context_propose_creation_crm_call:
  51. return action_start_wizard
  52. else:
  53. return True
  54. class res_users(orm.Model):
  55. _inherit = "res.users"
  56. _columns = {
  57. # Field name starts with 'context_' to allow modification by the user
  58. # in his preferences, cf server-61/openerp/addons/base/res/res_users.py
  59. # line 377 in "def write" of "class users"
  60. 'context_propose_creation_crm_call': fields.boolean(
  61. 'Propose to create a call in CRM after a click2dial'),
  62. }
  63. _defaults = {
  64. 'context_propose_creation_crm_call': True,
  65. }
  66. class crm_lead(orm.Model):
  67. _name = 'crm.lead'
  68. _inherit = ['crm.lead', 'phone.common']
  69. def create(self, cr, uid, vals, context=None):
  70. vals_reformated = self._generic_reformat_phonenumbers(
  71. cr, uid, vals, context=context)
  72. return super(crm_lead, self).create(
  73. cr, uid, vals_reformated, context=context)
  74. def write(self, cr, uid, ids, vals, context=None):
  75. vals_reformated = self._generic_reformat_phonenumbers(
  76. cr, uid, vals, context=context)
  77. return super(crm_lead, self).write(
  78. cr, uid, ids, vals_reformated, context=context)