|
@ -1,4 +1,4 @@ |
|
|
# -*- encoding: utf-8 -*- |
|
|
|
|
|
|
|
|
# -*- coding: utf-8 -*- |
|
|
############################################################################## |
|
|
############################################################################## |
|
|
# |
|
|
# |
|
|
# Base Phone module for Odoo |
|
|
# Base Phone module for Odoo |
|
@ -19,7 +19,7 @@ |
|
|
# |
|
|
# |
|
|
############################################################################## |
|
|
############################################################################## |
|
|
|
|
|
|
|
|
from openerp.osv import orm, fields |
|
|
|
|
|
|
|
|
from openerp import models, fields, api, exceptions |
|
|
from openerp.tools.translate import _ |
|
|
from openerp.tools.translate import _ |
|
|
import logging |
|
|
import logging |
|
|
import phonenumbers |
|
|
import phonenumbers |
|
@ -27,43 +27,40 @@ import phonenumbers |
|
|
_logger = logging.getLogger(__name__) |
|
|
_logger = logging.getLogger(__name__) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class number_not_found(orm.TransientModel): |
|
|
|
|
|
|
|
|
class NumberNotFound(models.TransientModel): |
|
|
_name = "number.not.found" |
|
|
_name = "number.not.found" |
|
|
_description = "Number not found" |
|
|
_description = "Number not found" |
|
|
|
|
|
|
|
|
_columns = { |
|
|
|
|
|
'calling_number': fields.char( |
|
|
|
|
|
'Calling Number', size=64, readonly=True, |
|
|
|
|
|
help="Phone number of calling party that has been obtained " |
|
|
|
|
|
"from the telephony server, in the format used by the " |
|
|
|
|
|
"telephony server (not E.164)."), |
|
|
|
|
|
'e164_number': fields.char( |
|
|
|
|
|
'E.164 Number', size=64, |
|
|
|
|
|
help="E.164 equivalent of the calling number."), |
|
|
|
|
|
'number_type': fields.selection( |
|
|
|
|
|
[('phone', 'Fixed'), ('mobile', 'Mobile')], |
|
|
|
|
|
'Fixed/Mobile', required=True), |
|
|
|
|
|
'to_update_partner_id': fields.many2one( |
|
|
|
|
|
'res.partner', 'Partner to Update', |
|
|
|
|
|
help="Partner on which the phone number will be written"), |
|
|
|
|
|
'current_partner_phone': fields.related( |
|
|
|
|
|
'to_update_partner_id', 'phone', type='char', |
|
|
|
|
|
relation='res.partner', string='Current Phone', readonly=True), |
|
|
|
|
|
'current_partner_mobile': fields.related( |
|
|
|
|
|
'to_update_partner_id', 'mobile', type='char', |
|
|
|
|
|
relation='res.partner', string='Current Mobile', readonly=True), |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
calling_number = fields.Char(string='Calling Number', size=64, |
|
|
|
|
|
readonly=True, |
|
|
|
|
|
help="Phone number of calling party that has " |
|
|
|
|
|
"been obtained from the telephony server, in " |
|
|
|
|
|
"the format used by the telephony server " |
|
|
|
|
|
"(not E.164).") |
|
|
|
|
|
e164_number = fields.Char(string='E.164 Number', size=64, |
|
|
|
|
|
help="E.164 equivalent of the calling number.") |
|
|
|
|
|
number_type = fields.Selection(selection=[ |
|
|
|
|
|
('phone', 'Fixed'), |
|
|
|
|
|
('mobile', 'Mobile') |
|
|
|
|
|
], string='Fixed/Mobile', required=True) |
|
|
|
|
|
to_update_partner_id = fields.Many2one(comodel_name='res.partner', |
|
|
|
|
|
string='Partner to Update', |
|
|
|
|
|
help="Partner on which the phone " |
|
|
|
|
|
"number will be written") |
|
|
|
|
|
current_partner_phone = fields.Char(related='to_update_partner_id.phone', |
|
|
|
|
|
string='Current Phone', readonly=True) |
|
|
|
|
|
current_partner_mobile = fields.Char(related='to_update_partner_id.mobile', |
|
|
|
|
|
string='Current Mobile', |
|
|
|
|
|
readonly=True) |
|
|
|
|
|
|
|
|
def default_get(self, cr, uid, fields_list, context=None): |
|
|
|
|
|
res = super(number_not_found, self).default_get( |
|
|
|
|
|
cr, uid, fields_list, context=context |
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
@api.model |
|
|
|
|
|
def default_get(self, fields_list): |
|
|
|
|
|
res = super(NumberNotFound, self).default_get(fields_list) |
|
|
if not res: |
|
|
if not res: |
|
|
res = {} |
|
|
res = {} |
|
|
if res.get('calling_number'): |
|
|
if res.get('calling_number'): |
|
|
convert = self.pool['res.partner']._generic_reformat_phonenumbers( |
|
|
|
|
|
cr, uid, None, {'phone': res.get('calling_number')}, |
|
|
|
|
|
context=context) |
|
|
|
|
|
|
|
|
convert = self.env['res.partner']._generic_reformat_phonenumbers( |
|
|
|
|
|
None, {'phone': res.get('calling_number')}) |
|
|
parsed_num = phonenumbers.parse(convert.get('phone')) |
|
|
parsed_num = phonenumbers.parse(convert.get('phone')) |
|
|
res['e164_number'] = phonenumbers.format_number( |
|
|
res['e164_number'] = phonenumbers.format_number( |
|
|
parsed_num, phonenumbers.PhoneNumberFormat.INTERNATIONAL) |
|
|
parsed_num, phonenumbers.PhoneNumberFormat.INTERNATIONAL) |
|
@ -74,15 +71,15 @@ class number_not_found(orm.TransientModel): |
|
|
res['number_type'] = 'phone' |
|
|
res['number_type'] = 'phone' |
|
|
return res |
|
|
return res |
|
|
|
|
|
|
|
|
def create_partner(self, cr, uid, ids, context=None): |
|
|
|
|
|
|
|
|
@api.multi |
|
|
|
|
|
def create_partner(self): |
|
|
'''Function called by the related button of the wizard''' |
|
|
'''Function called by the related button of the wizard''' |
|
|
if context is None: |
|
|
|
|
|
context = {} |
|
|
|
|
|
wiz = self.browse(cr, uid, ids[0], context=context) |
|
|
|
|
|
|
|
|
wiz = self[0] |
|
|
parsed_num = phonenumbers.parse(wiz.e164_number, None) |
|
|
parsed_num = phonenumbers.parse(wiz.e164_number, None) |
|
|
phonenumbers.number_type(parsed_num) |
|
|
phonenumbers.number_type(parsed_num) |
|
|
|
|
|
|
|
|
context['default_%s' % wiz.number_type] = wiz.e164_number |
|
|
|
|
|
|
|
|
context = dict(self._context or {}) |
|
|
|
|
|
context.update({'default_%s' % wiz.number_type: wiz.e164_number}) |
|
|
action = { |
|
|
action = { |
|
|
'name': _('Create New Partner'), |
|
|
'name': _('Create New Partner'), |
|
|
'view_mode': 'form,tree,kanban', |
|
|
'view_mode': 'form,tree,kanban', |
|
@ -91,18 +88,19 @@ class number_not_found(orm.TransientModel): |
|
|
'nodestroy': False, |
|
|
'nodestroy': False, |
|
|
'target': 'current', |
|
|
'target': 'current', |
|
|
'context': context, |
|
|
'context': context, |
|
|
} |
|
|
|
|
|
|
|
|
} |
|
|
return action |
|
|
return action |
|
|
|
|
|
|
|
|
def update_partner(self, cr, uid, ids, context=None): |
|
|
|
|
|
wiz = self.browse(cr, uid, ids[0], context=context) |
|
|
|
|
|
|
|
|
@api.multi |
|
|
|
|
|
def update_partner(self): |
|
|
|
|
|
wiz = self[0] |
|
|
if not wiz.to_update_partner_id: |
|
|
if not wiz.to_update_partner_id: |
|
|
raise orm.except_orm( |
|
|
|
|
|
_('Error:'), |
|
|
|
|
|
_("Select the Partner to Update.")) |
|
|
|
|
|
self.pool['res.partner'].write( |
|
|
|
|
|
cr, uid, wiz.to_update_partner_id.id, |
|
|
|
|
|
{wiz.number_type: wiz.e164_number}, context=context) |
|
|
|
|
|
|
|
|
raise exceptions.Warning( |
|
|
|
|
|
_('Error'), |
|
|
|
|
|
_('Select the Partner to Update.')) |
|
|
|
|
|
self.env['res.partner'].write( |
|
|
|
|
|
wiz.to_update_partner_id.id, |
|
|
|
|
|
{wiz.number_type: wiz.e164_number}) |
|
|
action = { |
|
|
action = { |
|
|
'name': _('Partner: %s' % wiz.to_update_partner_id.name), |
|
|
'name': _('Partner: %s' % wiz.to_update_partner_id.name), |
|
|
'type': 'ir.actions.act_window', |
|
|
'type': 'ir.actions.act_window', |
|
@ -111,23 +109,11 @@ class number_not_found(orm.TransientModel): |
|
|
'nodestroy': False, |
|
|
'nodestroy': False, |
|
|
'target': 'current', |
|
|
'target': 'current', |
|
|
'res_id': wiz.to_update_partner_id.id, |
|
|
'res_id': wiz.to_update_partner_id.id, |
|
|
'context': context, |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
'context': self._context, |
|
|
|
|
|
} |
|
|
return action |
|
|
return action |
|
|
|
|
|
|
|
|
def onchange_to_update_partner( |
|
|
|
|
|
self, cr, uid, ids, to_update_partner_id, context=None): |
|
|
|
|
|
res = {'value': {}} |
|
|
|
|
|
if to_update_partner_id: |
|
|
|
|
|
to_update_partner = self.pool['res.partner'].browse( |
|
|
|
|
|
cr, uid, to_update_partner_id, context=context) |
|
|
|
|
|
res['value'].update({ |
|
|
|
|
|
'current_partner_phone': to_update_partner.phone, |
|
|
|
|
|
'current_partner_mobile': to_update_partner.mobile, |
|
|
|
|
|
}) |
|
|
|
|
|
else: |
|
|
|
|
|
res['value'].update({ |
|
|
|
|
|
'current_partner_phone': False, |
|
|
|
|
|
'current_partner_mobile': False, |
|
|
|
|
|
}) |
|
|
|
|
|
return res |
|
|
|
|
|
|
|
|
@api.onchange('to_update_partner_id') |
|
|
|
|
|
def onchange_to_update_partner(self): |
|
|
|
|
|
self.current_partner_phone = self.to_update_partner.phone or False |
|
|
|
|
|
self.current_partner_mobile = self.to_update_partner.mobile or False |