summaryrefslogtreecommitdiff
path: root/indoteknik_custom/models/sale_order.py
diff options
context:
space:
mode:
authorAzka Nathan <darizkyfaz@gmail.com>2023-07-12 09:03:33 +0700
committerAzka Nathan <darizkyfaz@gmail.com>2023-07-12 09:03:33 +0700
commitf9874dc8419c35737fb96b8aa8480f0d60e47e1d (patch)
treef39312737e19e0841cc02e82dd196826a26eccb4 /indoteknik_custom/models/sale_order.py
parentba2bd3f91857cf6085eb760451ec695182dd1a3a (diff)
revisi due extension
Diffstat (limited to 'indoteknik_custom/models/sale_order.py')
-rwxr-xr-xindoteknik_custom/models/sale_order.py51
1 files changed, 30 insertions, 21 deletions
diff --git a/indoteknik_custom/models/sale_order.py b/indoteknik_custom/models/sale_order.py
index 5a3cada9..7c60d20c 100755
--- a/indoteknik_custom/models/sale_order.py
+++ b/indoteknik_custom/models/sale_order.py
@@ -8,6 +8,7 @@ import string
import requests
import math
import json
+from datetime import timedelta, date
_logger = logging.getLogger(__name__)
@@ -389,27 +390,35 @@ class SaleOrder(models.Model):
if self.due_id and self.due_id.is_approve == False:
raise UserError('Document Over Due Yang Anda Buat Belum Di Approve')
- if not self.env.user.is_leader and not self.env.user.is_sales_manager:
- query = [
- ('partner_id', '=', parent_id),
- ('state', '=', 'posted'),
- ('move_type', '=', 'out_invoice'),
- ('amount_residual_signed', '>', 0)
- ]
- invoices = self.env['account.move'].search(query, order='invoice_date')
- due_extension = self.env['due.extension'].create([{
- 'partner_id': parent_id,
- 'day_extension': '3',
- 'order_id': self.id,
- }])
- due_extension.generate_due_line()
- self.due_id = due_extension.id
- if len(self.due_id.due_line) > 0:
- return True
- else:
- due_extension.unlink()
- return False
-
+ query = [
+ ('partner_id', '=', parent_id),
+ ('state', '=', 'posted'),
+ ('move_type', '=', 'out_invoice'),
+ ('amount_residual_signed', '>', 0)
+ ]
+ invoices = self.env['account.move'].search(query, order='invoice_date')
+
+ for invoice in invoices:
+ invoice_due_extension = invoice.due_extension
+ new_due = invoice.invoice_date_due + timedelta(days=invoice_due_extension)
+
+ current_time = date.today()
+ if invoices:
+ if current_time > new_due:
+ if not self.env.user.is_leader and not self.env.user.is_sales_manager:
+ due_extension = self.env['due.extension'].create([{
+ 'partner_id': parent_id,
+ 'day_extension': '3',
+ 'order_id': self.id,
+ }])
+ due_extension.generate_due_line()
+ self.due_id = due_extension.id
+ if len(self.due_id.due_line) > 0:
+ return True
+ else:
+ due_extension.unlink()
+ return False
+
def _notification_margin_leader(self):
if self.total_percent_margin <= 15 and not self.env.user.is_leader:
return True