sale/wizard/payment_link_wizard.py

50 lines
2.0 KiB
Python

# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
from werkzeug import urls
from odoo import _, api, fields, models
from odoo.tools import format_amount
class PaymentLinkWizard(models.TransientModel):
_inherit = 'payment.link.wizard'
_description = 'Generate Sales Payment Link'
amount_paid = fields.Monetary(string="Already Paid", readonly=True)
confirmation_message = fields.Char(compute='_compute_confirmation_message')
@api.depends('amount')
def _compute_confirmation_message(self):
self.confirmation_message = False
for wizard in self.filtered(lambda w: w.res_model == 'sale.order'):
sale_order = wizard.env['sale.order'].sudo().browse(wizard.res_id)
if sale_order.state in ('draft', 'sent') and sale_order.require_payment:
remaining_amount = sale_order._get_prepayment_required_amount() - sale_order.amount_paid
if wizard.currency_id.compare_amounts(wizard.amount, remaining_amount) >= 0:
wizard.confirmation_message = _("This payment will confirm the quotation.")
else:
wizard.confirmation_message = _(
"Customer needs to pay at least %(amount)s to confirm the order.",
amount=format_amount(wizard.env, remaining_amount, wizard.currency_id),
)
def _get_additional_link_values(self):
""" Override of `payment` to add `sale_order_id` to the payment link values.
The other values related to the sales order are directly read from the sales order.
Note: self.ensure_one()
:return: The additional payment link values.
:rtype: dict
"""
res = super()._get_additional_link_values()
if self.res_model != 'sale.order':
return res
# Order-related fields are retrieved in the controller
return {
'sale_order_id': self.res_id,
}