only logic with the below formula is , first check if last invoice date to selected customer is less than selected invoice date, if yes then check if last issued bill was paid by him on or before last invoice due date, if yes, then current_lps = 0 , if not then current_lps = amount_payable * 0.15.
Problem: the field is showing empty didn't do any calculations nor any error has been face.
class CurrentLPS(models.Model):
_inherit = 'account.move'
current_lps = fields.Float(string='Current LPS', store=True, help='Place to store the amount',readonly=True)
@api.depends('partner_id', 'invoice_date')
def _compute_current_lps(self):
for move in self:
last_invoice = move.env['account.move'].search([
('partner_id', '=', move . partner_id. id),
('move_type', '=', 'out_invoice'),
], order='invoice_date desc, id desc', limit=1)
if last_invoice and last_invoice.invoice_date < move.invoice_date:
# Find the last payment for the last invoice
last_payment = self.env['account.payment'].search([
('partner_id', '=', move,partner_id,id),
('communication', '=', last_invoice.invoice_payment_term_id),
('payment_date', '<=', last_invoice.invoice_date_due),
], order='payment_date desc', limit=1)
if last_payment and last_payment.state == 'posted':
move.current_lps = 0.0
else:
move.current_lps = move.amount_payable * 0.15
else:
move.current_lps = move.amount_payable * 0.15
Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:
- ลูกค้าสัมพันธ์
- e-Commerce
- ระบบบัญชี
- สินค้าคงคลัง
- PoS
- Project
- MRP
คำถามนี้ถูกตั้งค่าสถานะ
2411
มุมมอง
สนุกกับการพูดคุยนี้ใช่ไหม? เข้าร่วมเลย!
สร้างบัญชีวันนี้เพื่อเพลิดเพลินไปกับฟีเจอร์พิเศษและมีส่วนร่วมกับคอมมูนิตี้ที่ยอดเยี่ยมของเรา!
ลงชื่อRelated Posts | ตอบกลับ | มุมมอง | กิจกรรม | |
---|---|---|---|---|
|
0
พ.ค. 24
|
1257 | ||
|
2
มี.ค. 24
|
2301 | ||
|
2
มิ.ย. 23
|
8777 | ||
|
0
พ.ค. 23
|
90 | ||
what is a suspense account?
แก้ไขแล้ว
|
|
4
ส.ค. 25
|
26768 |