Browse Source

Feb 23 : [ADD] Initial Commit 'payment_status_in_sale'

pull/254/merge
RisvanaCybro 1 year ago
parent
commit
9deade43b0
  1. 46
      payment_status_in_sale/README.rst
  2. 23
      payment_status_in_sale/__init__.py
  3. 42
      payment_status_in_sale/__manifest__.py
  4. 6
      payment_status_in_sale/doc/RELEASE_NOTES.md
  5. 23
      payment_status_in_sale/models/__init__.py
  6. 140
      payment_status_in_sale/models/sale_order.py
  7. BIN
      payment_status_in_sale/static/description/assets/icons/check.png
  8. BIN
      payment_status_in_sale/static/description/assets/icons/cogs.png
  9. BIN
      payment_status_in_sale/static/description/assets/icons/consultation.png
  10. BIN
      payment_status_in_sale/static/description/assets/icons/ecom-black.png
  11. BIN
      payment_status_in_sale/static/description/assets/icons/education-black.png
  12. BIN
      payment_status_in_sale/static/description/assets/icons/hotel-black.png
  13. BIN
      payment_status_in_sale/static/description/assets/icons/license.png
  14. BIN
      payment_status_in_sale/static/description/assets/icons/lifebuoy.png
  15. BIN
      payment_status_in_sale/static/description/assets/icons/logo.png
  16. BIN
      payment_status_in_sale/static/description/assets/icons/manufacturing-black.png
  17. BIN
      payment_status_in_sale/static/description/assets/icons/pos-black.png
  18. BIN
      payment_status_in_sale/static/description/assets/icons/puzzle.png
  19. BIN
      payment_status_in_sale/static/description/assets/icons/restaurant-black.png
  20. BIN
      payment_status_in_sale/static/description/assets/icons/service-black.png
  21. BIN
      payment_status_in_sale/static/description/assets/icons/trading-black.png
  22. BIN
      payment_status_in_sale/static/description/assets/icons/training.png
  23. BIN
      payment_status_in_sale/static/description/assets/icons/update.png
  24. BIN
      payment_status_in_sale/static/description/assets/icons/user.png
  25. BIN
      payment_status_in_sale/static/description/assets/icons/wrench.png
  26. BIN
      payment_status_in_sale/static/description/assets/modules/1.png
  27. BIN
      payment_status_in_sale/static/description/assets/modules/2.png
  28. BIN
      payment_status_in_sale/static/description/assets/modules/3.png
  29. BIN
      payment_status_in_sale/static/description/assets/modules/4.png
  30. BIN
      payment_status_in_sale/static/description/assets/modules/5.png
  31. BIN
      payment_status_in_sale/static/description/assets/modules/6.png
  32. BIN
      payment_status_in_sale/static/description/assets/screenshots/amount_due.png
  33. BIN
      payment_status_in_sale/static/description/assets/screenshots/not_paid.png
  34. BIN
      payment_status_in_sale/static/description/assets/screenshots/paid.png
  35. BIN
      payment_status_in_sale/static/description/assets/screenshots/partial.png
  36. BIN
      payment_status_in_sale/static/description/assets/screenshots/payment.png
  37. BIN
      payment_status_in_sale/static/description/assets/screenshots/payment_info.png
  38. BIN
      payment_status_in_sale/static/description/assets/screenshots/saleorder.gif
  39. BIN
      payment_status_in_sale/static/description/assets/screenshots/status.png
  40. BIN
      payment_status_in_sale/static/description/banner.jpg
  41. BIN
      payment_status_in_sale/static/description/icon.png
  42. 743
      payment_status_in_sale/static/description/index.html
  43. 86
      payment_status_in_sale/views/sale_order_views.xml

46
payment_status_in_sale/README.rst

@ -0,0 +1,46 @@
.. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: https://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
Sale Order Payment Status
=========================
* This module provides sale order payment details such as invoice status, amount due, date of payment and amount etc.
Configuration
=============
* No additional configuration is needed to use this module.
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
License
=======
GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3)
(https://www.gnu.org/licenses/agpl-3.0-standalone.html)
Credits
-------
* Developer: (V15) Shyamgeeth PP, Contact : odoo@cybrosys.com
Contacts
--------
* Mail Contact : odoo@cybrosys.com
* Website : https://cybrosys.com
Bug Tracker
-----------
Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported.
Maintainer
==========
.. image:: https://cybrosys.com/images/logo.png
:target: https://cybrosys.com
This module is maintained by Cybrosys Technologies.
For support and more information, please visit `Our Website <https://cybrosys.com/>`__
Further information
===================
HTML Description: `<static/description/index.html>`__

23
payment_status_in_sale/__init__.py

@ -0,0 +1,23 @@
# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright(C) 2023-TODAY Cybrosys Technologies (<https://www.cybrosys.com>).
# Author: Shyamgeeth P.P (<https://www.cybrosys.com>)
#
# This program is free software: you can modify
# it under the terms of the GNU Affero General Public License (AGPL) as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# 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 for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
################################################################################
from . import models

42
payment_status_in_sale/__manifest__.py

@ -0,0 +1,42 @@
# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Shyamgeeth P.P (<https://www.cybrosys.com>)
#
# This program is free software: you can modify
# it under the terms of the GNU Affero General Public License (AGPL) as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# 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 for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
################################################################################
{
'name': 'Sale Order Payment Status',
'version': '15.0.1.0.0',
'category': 'Sales',
'summary': 'Sale order payment status, payment details and amount due',
'description': """This module used to get the information regarding invoice
of the corresponding sale order in the sale order page. It includes sale
order payment status, payment details and amount due.""",
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': 'https://www.cybrosys.com',
'depends': ['sale_management', 'account'],
'data': ['views/sale_order_views.xml'],
'images': ['static/description/banner.jpg'],
'license': 'AGPL-3',
'installable': True,
'auto_install': False,
'application': False,
}

6
payment_status_in_sale/doc/RELEASE_NOTES.md

@ -0,0 +1,6 @@
## Module <payment_status_in_sale>
#### 06.01.2024
#### Version 15.0.1.0.0
##### ADD
- Initial commit for Sale Order Payment Status.

23
payment_status_in_sale/models/__init__.py

@ -0,0 +1,23 @@
# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright(C) 2023-TODAY Cybrosys Technologies (<https://www.cybrosys.com>).
# Author: Shyamgeeth P.P (<https://www.cybrosys.com>)
#
# This program is free software: you can modify
# it under the terms of the GNU Affero General Public License (AGPL) as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# 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 for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
################################################################################
from . import sale_order

140
payment_status_in_sale/models/sale_order.py

@ -0,0 +1,140 @@
# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright(C) 2023-TODAY Cybrosys Technologies (<https://www.cybrosys.com>).
# Author: Shyamgeeth P.P (<https://www.cybrosys.com>)
#
# This program is free software: you can modify
# it under the terms of the GNU Affero General Public License (AGPL) as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# 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 for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
################################################################################
import json
from odoo import api, fields, models, _
class SaleOrder(models.Model):
"""Sale order model inherited for adding status of payment of sales."""
_inherit = "sale.order"
payment_status = fields.Char(string="Payment Status",
compute="_compute_payment_status",
help="Field to check the payment status of the"
" sale order")
payment_details = fields.Text(string="Payment Details",
compute="_compute_payment_details",
help="Shows the payment done details"
" including date and amount")
amount_due = fields.Float(string="Amount Due",
compute='_compute_amount_due',
help="Shows the amount that in due for the "
"corresponding sale order")
invoice_state = fields.Char(string="Invoice State",
compute="_compute_invoice_state",
help="Field to check the invoice state of "
"sale order")
@api.depends('invoice_ids')
def _compute_payment_status(self):
""" The function will compute the payment status of the sale order,
if an invoice is created for the corresponding sale order.Payment
status will be either in paid,not paid,partially paid, reversed etc."""
for order in self:
order.payment_status = 'No invoice'
payment_states = order.invoice_ids. \
filtered(lambda i: i.state == 'posted').mapped('payment_state')
status_length = len(payment_states)
if status_length != 0:
if 'partial' in payment_states:
order.payment_status = 'Partially Paid'
elif 'not_paid' in payment_states and status_length == 1:
order.payment_status = 'Not Paid'
elif 'not_paid' in payment_states and order.amount_due != \
order.amount_total and status_length > 1:
order.payment_status = 'Partially Paid'
elif 'paid' in payment_states and status_length == \
payment_states.count('paid') and order.amount_due == 0:
order.payment_status = 'Paid'
elif 'paid' in payment_states and status_length == \
payment_states.count('paid') and order.amount_due != 0:
order.payment_status = 'Partially Paid'
elif 'in_payment' in payment_states and \
status_length == payment_states.count('in_payment'):
order.payment_status = 'In Payment'
elif 'reversed' in payment_states and \
status_length == payment_states.count('reversed'):
order.payment_status = 'Reversed'
else:
order.payment_status = 'No invoice'
@api.depends('invoice_ids')
def _compute_invoice_state(self):
"""The function will compute the state of the invoice ,
Once an invoice is existing in a sale order."""
for rec in self:
rec.invoice_state = 'No invoice'
for order in rec.invoice_ids:
if order.state == 'posted':
rec.invoice_state = 'posted'
elif order.state != 'posted':
rec.invoice_state = 'draft'
else:
rec.invoice_state = 'No invoice'
@api.depends('invoice_ids')
def _compute_amount_due(self):
"""The function is used to compute the amount due from the invoice and
if payment is registered."""
for rec in self:
amount_due = 0
for order in rec.invoice_ids:
amount_due = amount_due + order.amount_residual
rec.amount_due = amount_due
@api.depends('invoice_ids')
def _compute_payment_details(self):
"""Compute the payment details from invoices and added into the
sale order form view."""
for rec in self:
payment = []
rec.payment_details = False
for order in rec.invoice_ids:
if order.invoice_payments_widget != 'false':
for pay in json.loads(order.invoice_payments_widget)[
'content']:
payment.append(pay)
for order in rec.invoice_ids:
if order.invoice_payments_widget != 'false':
payment_line = json.loads(order.invoice_payments_widget)
payment_line['content'] = payment
rec.payment_details = json.dumps(payment_line)
break
def action_register_payment(self):
""" Open the account.payment.register wizard to pay the selected
journal entries.
:return: An action opening the account.payment.register wizard.
"""
self.ensure_one()
return {
'name': _('Register Payment'),
'res_model': 'account.payment.register',
'view_mode': 'form',
'context': {
'active_model': 'account.move',
'active_ids': self.invoice_ids.ids,
},
'target': 'new',
'type': 'ir.actions.act_window',
}

BIN
payment_status_in_sale/static/description/assets/icons/check.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

BIN
payment_status_in_sale/static/description/assets/icons/cogs.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

BIN
payment_status_in_sale/static/description/assets/icons/consultation.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

BIN
payment_status_in_sale/static/description/assets/icons/ecom-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

BIN
payment_status_in_sale/static/description/assets/icons/education-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

BIN
payment_status_in_sale/static/description/assets/icons/hotel-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

BIN
payment_status_in_sale/static/description/assets/icons/license.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
payment_status_in_sale/static/description/assets/icons/lifebuoy.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
payment_status_in_sale/static/description/assets/icons/logo.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

BIN
payment_status_in_sale/static/description/assets/icons/manufacturing-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

BIN
payment_status_in_sale/static/description/assets/icons/pos-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

BIN
payment_status_in_sale/static/description/assets/icons/puzzle.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

BIN
payment_status_in_sale/static/description/assets/icons/restaurant-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

BIN
payment_status_in_sale/static/description/assets/icons/service-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

BIN
payment_status_in_sale/static/description/assets/icons/trading-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

BIN
payment_status_in_sale/static/description/assets/icons/training.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

BIN
payment_status_in_sale/static/description/assets/icons/update.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
payment_status_in_sale/static/description/assets/icons/user.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

BIN
payment_status_in_sale/static/description/assets/icons/wrench.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
payment_status_in_sale/static/description/assets/modules/1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 60 KiB

BIN
payment_status_in_sale/static/description/assets/modules/2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 62 KiB

BIN
payment_status_in_sale/static/description/assets/modules/3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 60 KiB

BIN
payment_status_in_sale/static/description/assets/modules/4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 62 KiB

BIN
payment_status_in_sale/static/description/assets/modules/5.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 62 KiB

BIN
payment_status_in_sale/static/description/assets/modules/6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 58 KiB

BIN
payment_status_in_sale/static/description/assets/screenshots/amount_due.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 86 KiB

BIN
payment_status_in_sale/static/description/assets/screenshots/not_paid.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 88 KiB

BIN
payment_status_in_sale/static/description/assets/screenshots/paid.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 86 KiB

BIN
payment_status_in_sale/static/description/assets/screenshots/partial.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

BIN
payment_status_in_sale/static/description/assets/screenshots/payment.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 96 KiB

BIN
payment_status_in_sale/static/description/assets/screenshots/payment_info.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 85 KiB

BIN
payment_status_in_sale/static/description/assets/screenshots/saleorder.gif

Binary file not shown.

After

Width:  |  Height:  |  Size: 296 KiB

BIN
payment_status_in_sale/static/description/assets/screenshots/status.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 322 KiB

BIN
payment_status_in_sale/static/description/banner.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 71 KiB

BIN
payment_status_in_sale/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.4 KiB

743
payment_status_in_sale/static/description/index.html

@ -0,0 +1,743 @@
<div class="container"
style="padding: 1rem !important; margin-bottom: 1rem !important;">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between"
style="border-bottom: 1px solid #d5d5d5;">
<div class="my-3">
<img
src="./assets/icons/logo.png"
style="width: auto !important; height: 40px !important;"/>
</div>
<div class="my-3 d-flex align-items-center">
<div
style="background-color: #7C7BAD !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Community
</div>
<div
style="background-color: #875A7B !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
</div>
</div>
</div>
</div>
<div class="container" style="padding: 0rem 1.5rem 4rem !important">
<div class="row" style="height: 900px !important;">
<div class="col-sm-12 col-md-12 col-lg-12"
style="padding: 4rem 1rem !important; background-color: #714B67 !important; height: 600px !important; border-radius: 20px !important;">
<h1
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #FFFFFF !important; font-size: 3.5rem !important; text-align: center !important;">
Sale Order Payment Status</h1>
<p
style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">
Shows the payment status of the sale order</p>
<img src="./assets/screenshots/saleorder.gif" class="img-responsive"
width="100%" height="auto"/>
</div>
</div>
<br/><br/><br/><br/>
<br/>
<br/>
<br/>
<div class="row">
<div class="col-md-12"
style="border-bottom: 1px solid #d5d5d5 !important; margin-bottom: 2rem !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-compass mr-2"></i>Explore this module
</h2>
</div>
<div class="col-md-6">
<a href="#overview" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Overview</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
Learn more about this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right"
style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
<div class="col-md-6">
<a href="#features" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Features</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
View features of this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right"
style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
<div class="col-md-6">
<a href="#screenshots" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Screenshots</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
See key screenshots of this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right"
style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
</div>
<div class="row" id="overview">
<div class="col-md-12"
style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-pie-chart mr-2"></i>Overview
</h2>
</div>
<div class="col-mg-12 pl-3">
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important; line-height: 30px !important;">
The module will enables you to check the payment status on Sales
page.</p>
</div>
</div>
<div class="row" id="features">
<div class="col-md-12"
style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-star mr-2"></i>Features
</h2>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4 style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Shows Payment Status in Sale Order tree view.</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4 style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Shows Amount Due in Sale Order form.</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4 style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Shows Payment Details in the Sale Order form.</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4 style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Payment can do from Sale Order form</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4 style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Shows Payment Status in the Sale Order form view</h4>
</div>
</div>
</div>
<div class="row" id="screenshots">
<div class="col-md-12"
style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-image mr-2"></i>Screenshots
</h2>
</div>
<div class="col-lg-12 my-2">
<h4 class="mt-2"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
1.SHOWS PAYMENT STATUS IN SALE ORDER TREE VIEW</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
This module will display the Payment Status in tree view of Sales.
</p>
<img src="assets/screenshots/status.png"
class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
2.SHOWS AMOUNT DUE IN SALE ORDER FORM.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
Once an invoice is created, the payment status is changed
to "Not Paid", and Amount due is showed in the form.
</p>
<img src="assets/screenshots/amount_due.png"
class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
3.SHOWS PAYMENT DETAILS IN THE SALE ORDER FORM.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
After an invoice is generated,user can register the payment using
"REGISTER PAYMENT" Button. Status is changed to "PAID" or "PARTIALLY PAID" state
and Payment Details will showed in the form.
</p>
<img src="assets/screenshots/payment_info.png"
class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
4.PAYMENT CAN DO FROM SALE ORDER FORM.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
Once an invoice is created and confirmed. Then the "REGISTER PAYMENT" button enable on the Sale Order
form view and user can register the payment using that button.
</p>
<img src="assets/screenshots/payment.png"
class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
5.SHOWS PAYMENT STATUS IN THE SALE ORDER FORM VIEW.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
Once an invoice is created and confirmed, it will shows the
Payment status on the Sale Order form view.
</p>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
Example 1 : PAID
</p>
<img src="assets/screenshots/paid.png"
class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
Example 2 : NOT PAID
</p>
<img src="assets/screenshots/not_paid.png"
class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
Example 3 : PARTIALLY PAID
</p>
<img src="assets/screenshots/partial.png"
class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
</div>
<!-- SUGGESTED PRODUCTS -->
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center"
style="text-align: center; padding: 2.5rem 1rem !important;">
<h2 style="color: #212529 !important;">Suggested
Products.</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/>
<div class="row">
<div class="col-sm-12">
<div id="demo1" class="row carousel slide"
data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner" style="padding: 30px;">
<div class="carousel-item"
style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/sale_discount_total/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/1.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/barcode_scanning_sale_purchase/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/2.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/sale_purchase_previous_product_cost/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/3.png">
</div>
</a>
</div>
</div>
<div class="carousel-item active"
style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/sales_person_signature/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/4.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/margin_product_sale_invoice/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/5.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/sale_product_image/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/6.png">
</div>
</a>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1"
data-slide="prev"
style="width:35px; color:#000"> <span
class="carousel-control-prev-icon"><i
class="fa fa-chevron-left"
style="font-size:24px"></i></span>
</a> <a class="carousel-control-next" href="#demo1"
data-slide="next"
style="width:35px; color:#000">
<span class="carousel-control-next-icon"><i
class="fa fa-chevron-right"
style="font-size:24px"></i></span>
</a>
</div>
</div>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1"
data-slide="prev"
style="left:-25px;width: 35px;color: #000;">
<span class="carousel-control-prev-icon"><i
class="fa fa-chevron-left"
style="font-size:24px"></i></span> </a>
<a class="carousel-control-next" href="#demo1"
data-slide="next"
style="right:-25px;width: 35px;color: #000;">
<span class="carousel-control-next-icon"><i
class="fa fa-chevron-right"
style="font-size:24px"></i></span>
</a>
<!-- END OF SUGGESTED PRODUCTS -->
<!-- OUR SERVICES -->
<section class="container" style="margin-top: 6rem !important;">
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Our Services</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/cogs.png"
class="img-responsive" height="48px"
width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Customization</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/wrench.png"
class="img-responsive" height="48px"
width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/lifebuoy.png"
class="img-responsive" height="48px"
width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Support</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/user.png"
class="img-responsive" height="48px"
width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Hire
Odoo
Developer</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/puzzle.png"
class="img-responsive" height="48px"
width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Integration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/update.png"
class="img-responsive" height="48px"
width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Migration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/consultation.png"
class="img-responsive" height="48px"
width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Consultancy</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/training.png"
class="img-responsive" height="48px"
width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/license.png"
class="img-responsive" height="48px"
width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Licensing Consultancy</h6>
</div>
</div>
</section>
<!-- OUR INDUSTRIES -->
<section class="container" style="margin-top: 6rem !important;">
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Our
Industries</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/trading-black.png"
class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Trading
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easily procure
and
sell your products</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/pos-black.png"
class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
POS
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easy
configuration
and convivial experience</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/education-black.png"
class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Education
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
A platform for
educational management</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/manufacturing-black.png"
class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Manufacturing
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Plan, track and
schedule your operations</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/ecom-black.png"
class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
E-commerce &amp; Website
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Mobile
friendly,
awe-inspiring product pages</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/service-black.png"
class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Service Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Keep track of
services and invoice</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/restaurant-black.png"
class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Restaurant
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Run your bar or
restaurant methodically</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/hotel-black.png"
class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Hotel Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
An
all-inclusive
hotel management application</p>
</div>
</div>
</div>
</section>
<!-- END OF OUR INDUSSTRIES -->`
<!-- FOOTER -->
<!-- Footer Section -->
<section class="container" style="margin: 5rem auto 2rem;">
<div class="row" style="max-width:1540px;">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Need Help?</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/>
</div>
</div>
<!-- Contact Cards -->
<div class="row d-flex justify-content-center align-items-center"
style="max-width:1540px; margin: 0 auto 2rem auto;">
<div class="col-lg-12"
style="padding: 0rem 3rem 2rem; border-radius: 10px; margin-right: 3rem; ">
<div class="row mt-4">
<div class="col-lg-6">
<a href="mailto:odoo@cybrosys.com"
target="_blank"
class="btn btn-block mb-2 deep_hover"
style="text-decoration: none; background-color: #4d4d4d; color: #FFF; border-radius: 4px;"><i
class="fa fa-envelope mr-2"></i>odoo@cybrosys.com</a>
</div>
<div class="col-lg-6">
<a href="https://api.whatsapp.com/send?phone=918606827707"
target="_blank"
class="btn btn-block mb-2 deep_hover"
style="text-decoration: none; background-color: #25D366; color: #FFF; border-radius: 4px;"><i
class="fa fa-whatsapp mr-2"></i>WhatsApp</a>
</div>
</div>
</div>
</div>
<!-- End of Contact Cards -->
</section>
<!-- Footer -->
<section class="oe_container" style="padding: 2rem 3rem 1rem;">
<div class="row"
style="max-width:1540px; margin: 0 auto; margin-right: 3rem; ">
<!-- Logo -->
<div class="col-lg-12 d-flex justify-content-center align-items-center"
style="margin-top: 3rem;">
<img src="https://www.cybrosys.com/images/logo.png"
width="200px" height="auto"/>
</div>
<!-- End of Logo -->
<div class="col-lg-12">
<hr
style="margin-top: 3rem;background: linear-gradient(90deg, rgba(2,0,36,0) 0%, rgba(229,229,229,1) 33%, rgba(229,229,229,1) 58%, rgba(0,212,255,0) 100%); height: 2px; border-style: none;">
<!-- End of Footer Section -->
</div>
</div>
</section>
<!-- END OF FOOTER -->
</div>

86
payment_status_in_sale/views/sale_order_views.xml

@ -0,0 +1,86 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- Sale Order form view inherited -->
<record id="view_order_form" model="ir.ui.view">
<field name="name">sale.order.view.form.inherit.payment.status.in
.sale
</field>
<field name="model">sale.order</field>
<field name="inherit_id" ref="sale.view_order_form"/>
<field name="arch" type="xml">
<xpath expr="//field[@name='payment_term_id']" position="after">
<field name="payment_status" invisible="0"/>
<field name="invoice_state" invisible="1"/>
<field name="payment_details" widget="payment"
style="width: 60%"/>
<field name="amount_due"/>
</xpath>
<xpath expr="//sheet//div[hasclass('oe_button_box')]"
position="after">
<widget name="web_ribbon" title="Not Paid"
bg_color="bg-danger"
attrs="{'invisible': [('payment_status', '!=', 'Not Paid')]}"/>
<widget name="web_ribbon" title="Paid"
bg_color="bg-success"
attrs="{'invisible': [('payment_status', '!=', 'Paid')]}"/>
<widget name="web_ribbon" title="Partially Paid"
bg_color="bg-warning"
attrs="{'invisible': [('payment_status', '!=', 'Partially Paid')]}"/>
<widget name="web_ribbon" title="In Payment"
bg_color="bg-info"
attrs="{'invisible': [('payment_status', '!=', 'In Payment')]}"/>
<widget name="web_ribbon" title="Reversed"
bg_color="bg-success"
attrs="{'invisible': [('payment_status', '!=', 'Reversed')]}"/>
</xpath>
<xpath expr="//button[@name='action_confirm']"
position="after">
<button name="action_register_payment"
string="Register Payment" class="btn-primary"
type="object"
attrs="{'invisible': ['|', '|', ('state', '!=', 'sale'),
('invoice_state', '!=', 'posted'),('payment_status', 'not in',
('Not Paid', 'Partially Paid'))]}"/>
</xpath>
</field>
</record>
<!-- Sale Order tree view inherited -->
<record id="view_order_tree" model="ir.ui.view">
<field name="name">sale.order.view.tree.inherit.payment.status.in
.sale
</field>
<field name="model">sale.order</field>
<field name="inherit_id" ref="sale.view_order_tree"/>
<field name="arch" type="xml">
<xpath expr="//field[@name='invoice_status']" position="after">
<field name="payment_status" optional="show"
decoration-success="payment_status in ['Paid', 'Reversed']"
decoration-danger="payment_status == 'Not Paid'"
decoration-info="payment_status == 'In Payment'"
decoration-bf="payment_status == 'No invoice'"
decoration-warning="payment_status == 'Partially Paid'"
widget="badge"/>
</xpath>
</field>
</record>
<!-- Quotation tree view inherited -->
<record id="view_quotation_tree_with_onboarding" model="ir.ui.view">
<field name="name">sale.order.view.tree.inherit.payment.status
.in.sale
</field>
<field name="model">sale.order</field>
<field name="inherit_id"
ref="sale.view_quotation_tree_with_onboarding"/>
<field name="arch" type="xml">
<xpath expr="//field[@name='invoice_status']" position="after">
<field name="payment_status" optional="show"
decoration-success="payment_status in ['Paid', 'Reversed']"
decoration-danger="payment_status == 'Not Paid'"
decoration-info="payment_status == 'In Payment'"
decoration-bf="payment_status == 'No invoice'"
decoration-warning="payment_status == 'Partially Paid'"
widget="badge"/>
</xpath>
</field>
</record>
</odoo>
Loading…
Cancel
Save