correction in pg_create_quotation (use prefix for portal_id)

develop
Andreas Osim 2019-09-30 15:04:25 +02:00
parent cd4a666466
commit d169374ea1
1 changed files with 100 additions and 0 deletions

View File

@ -234,6 +234,11 @@ class SaleOrder(models.Model):
if not vals.get('portal_id', False):
raise ValidationError(
_("Der Kunde mit der Portal-ID \'%s\' kann nicht zugeordnet werden") % vals['portal_id'])
portal_prefix = self.env.user.company_id.portal_prefix
if portal_prefix:
vals['portal_id'] = portal_prefix + '.' + vals['portal_id']
partner = self.env['res.partner'].search([('portal_id', '=', vals['portal_id'])])
if not partner.parent_id:
raise ValidationError(
@ -318,6 +323,101 @@ class SaleOrder(models.Model):
order_id.action_confirm()
return {'id': order_id.id, 'name': order_id.name}
@api.model
def pg_create_quotation___1(self, vals):
"""
SST-3
:param vals:
:return:
"""
# print('1')
if not vals.get('portal_id', False):
raise ValidationError(
_("Der Kunde mit der Portal-ID \'%s\' kann nicht zugeordnet werden") % vals['portal_id'])
partner = self.env['res.partner'].search([('portal_id', '=', vals['portal_id'])])
if not partner.parent_id:
raise ValidationError(
_('Zu dem Kontakt mit der portal-ID %s existiert kein Unternehmen') % vals['portal_id'])
partner = partner.parent_id
vals['partner_id'] = partner.id
# print('2')
if not partner:
raise ValidationError(
_("Der Kunde mit der Portal-ID \'%s\' kann nicht zugeordnet werden") % vals['portal_id'])
del vals['portal_id']
delivery_partner = self.env['res.partner']
delivery_vals = {}
# print('3')
if vals.get('portal_delivery_id', False):
delivery_partner = self.env['res.partner'].search([('portal_id', '=', vals['portal_delivery_id'])])
delivery_vals['portal_id'] = vals['portal_delivery_id']
del vals['portal_delivery_id']
for key in list(vals.keys()):
if key.startswith('delivery_'):
delivery_vals[key.replace('delivery_', '')] = vals[key]
del vals[key]
# print('4')
delivery_partner.with_context(delivery_partner=True).check_not_specified_fields(delivery_vals)
delivery_vals = delivery_partner.correct_values(delivery_vals)
delivery_vals['parent_id'] = partner.id
if delivery_partner:
# print('4a')
allowed_update_keys = ['firstname', 'lastname', 'midname', 'email', 'phone']
for key in list(delivery_vals.keys()):
if key not in allowed_update_keys:
del delivery_vals[key]
# print('4a1')
delivery_partner.write(delivery_vals)
# print('4a2')
else:
# print('4b')
if not delivery_vals.get('type', False):
delivery_vals['type'] = 'delivery'
delivery_vals['property_delivery_carrier_id'] = partner.property_delivery_carrier_id.id
delivery_partner = delivery_partner.create(delivery_vals)
# print('5')
attachment_vals = vals.pop('attachment_ids', False)
order_line_vals = vals.get('order_lines', False)
# if 'attachment_ids' in vals: del vals['attachment_ids']
del vals['order_lines']
# print('6')
self.check_not_specified_fields(vals)
vals = self.correct_values(vals)
payment_term = partner.property_payment_term_id
if partner.retail_partner_id:
payment_term = partner.retail_partner_id.property_payment_term_id
addr = partner.address_get(['delivery', 'invoice'])
# print('7')
vals['partner_invoice_id'] = vals.setdefault('partner_invoice_id', addr['invoice'])
partner_invoice_id = self.env['res.partner'].browse([vals['partner_invoice_id']])
fiscal_position_id = False
# print('8')
if partner_invoice_id:
if partner_invoice_id.property_account_position_id:
fiscal_position_id = partner_invoice_id.property_account_position_id.id
vals.update({
'partner_id': partner.id,
'partner_invoice_id': partner_invoice_id.id,
'fiscal_position_id': fiscal_position_id,
'user_id': partner.user_id.id,
'payment_term_id': payment_term.id,
'partner_shipping_id': delivery_partner.id,
'incoterm': partner.sale_incoterm_id.id,
'carrier_id': delivery_partner.property_delivery_carrier_id.id
})
# print('9')
order_id = self.create(vals)
if attachment_vals:
order_id.pg_create_sale_order_attachments(attachment_vals)
if order_line_vals:
order_id.pg_create_order_lines(order_line_vals)
if vals.get('confirm_order'):
order_id.action_confirm()
return {'id': order_id.id, 'name': order_id.name}
@api.multi
def pg_create_sale_order_attachments(self, values):
self.ensure_one()