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.
76 lines
3.4 KiB
76 lines
3.4 KiB
# -*- coding: utf-8 -*-
|
|
##############################################################################
|
|
#
|
|
# Cybrosys Technologies Pvt. Ltd.
|
|
#
|
|
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
|
|
# Author: Aysha Shalin (odoo@cybrosys.com)
|
|
#
|
|
# you can modify it under the terms of the GNU AFFERO
|
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
|
|
#
|
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC
|
|
# LICENSE (AGPL v3) along with this program.
|
|
# If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
##############################################################################
|
|
from odoo.addons.payment.controllers import portal as payment_portal
|
|
|
|
from odoo.http import route, request
|
|
from odoo.tools import str2bool
|
|
|
|
|
|
class WebsiteSale(payment_portal.PaymentPortal):
|
|
@route('/shop/payment', type='http', auth='public', website=True, sitemap=False)
|
|
def shop_payment(self, try_skip_step=None, **post):
|
|
""" Payment step. This page proposes several payment means based on available
|
|
payment.provider. State at this point :
|
|
|
|
- a draft sales order with lines; otherwise, clean context / session and
|
|
back to the shop
|
|
- no transaction in context / session, or only a draft one, if the customer
|
|
did go to a payment.provider website but closed the tab without
|
|
paying / canceling
|
|
"""
|
|
try_skip_step = str2bool(try_skip_step or 'false')
|
|
order_sudo = request.website.sale_get_order()
|
|
|
|
checkout_page_values = self._prepare_checkout_page_values(order_sudo,
|
|
**post)
|
|
|
|
if redirection := self._check_cart_and_addresses(order_sudo):
|
|
return redirection
|
|
|
|
render_values = self._get_shop_payment_values(order_sudo, **post)
|
|
render_values['only_services'] = order_sudo and order_sudo.only_services
|
|
|
|
can_skip_delivery = True # Delivery is only needed for deliverable products.
|
|
if order_sudo._has_deliverable_products():
|
|
available_dms = order_sudo._get_delivery_methods()
|
|
checkout_page_values['delivery_methods'] = available_dms
|
|
if delivery_method := order_sudo._get_preferred_delivery_method(
|
|
available_dms):
|
|
rate = delivery_method.rate_shipment(order_sudo)
|
|
render_values['delivery_methods'] = checkout_page_values['delivery_methods']
|
|
if (
|
|
not order_sudo.carrier_id
|
|
or not rate.get('success')
|
|
or order_sudo.amount_delivery != rate['price']
|
|
):
|
|
order_sudo._set_delivery_method(delivery_method, rate=rate)
|
|
can_skip_delivery = self.can_skip_delivery_step(order_sudo,
|
|
available_dms)
|
|
|
|
if try_skip_step and can_skip_delivery:
|
|
return request.redirect('/shop/confirm_order')
|
|
|
|
if render_values['errors']:
|
|
render_values.pop('payment_methods_sudo', '')
|
|
render_values.pop('tokens_sudo', '')
|
|
|
|
return request.render("website_sale.payment", render_values)
|
|
|