summaryrefslogtreecommitdiff
path: root/indoteknik_api/models/sale_order.py
diff options
context:
space:
mode:
authorRafi Zadanly <zadanlyr@gmail.com>2023-01-27 11:08:02 +0700
committerRafi Zadanly <zadanlyr@gmail.com>2023-01-27 11:08:02 +0700
commit39e27d0187d352dfea7db1bc1c9aece42e348caa (patch)
tree97aa953bbc865669f7f813e50024866e4d6b826d /indoteknik_api/models/sale_order.py
parente48e4626b94f7e09b3bab95937cf4b7a5ca07e40 (diff)
sale order and invoice api
Diffstat (limited to 'indoteknik_api/models/sale_order.py')
-rw-r--r--indoteknik_api/models/sale_order.py25
1 files changed, 23 insertions, 2 deletions
diff --git a/indoteknik_api/models/sale_order.py b/indoteknik_api/models/sale_order.py
index 3359ee6a..aa20ccdb 100644
--- a/indoteknik_api/models/sale_order.py
+++ b/indoteknik_api/models/sale_order.py
@@ -4,11 +4,32 @@ from odoo import models
class SaleOrder(models.Model):
_inherit = 'sale.order'
- def api_v1_single_response(self, sale_order):
+ def api_v1_single_response(self, sale_order, context=False):
data = {
'id': sale_order.id,
'name': sale_order.name,
'sales': sale_order.user_id.name,
- 'amount_total': sale_order.amount_total
+ 'amount_total': sale_order.amount_total,
+ 'purchase_order_name': sale_order.partner_purchase_order_name,
+ 'invoice_count': sale_order.invoice_count
}
+ if context:
+ if context == 'with_detail':
+ res_users = self.env['res.users']
+ data_with_detail = {
+ 'payment_term': sale_order.payment_term_id.name or '',
+ 'date_order': self.env['rest.api'].datetime_to_str(sale_order.date_order, '%d/%m/%Y %H:%M:%S'),
+ 'products': [],
+ 'address': {
+ 'customer': res_users.api_address_response(sale_order.partner_id),
+ 'invoice': res_users.api_address_response(sale_order.partner_invoice_id),
+ 'shipping': res_users.api_address_response(sale_order.partner_shipping_id)
+ },
+ 'invoices': [self.env['account.move'].api_v1_single_response(x) for x in sale_order.invoice_ids]
+ }
+ for line in sale_order.order_line:
+ product = self.env['product.product'].api_single_response(line.product_id)
+ product['quantity'] = line.product_uom_qty
+ data_with_detail['products'].append(product)
+ data.update(data_with_detail)
return data