account_invoice.py 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. # -*- coding: utf-8 -*-
  2. from openerp.http import request
  3. from openerp.tools import DEFAULT_SERVER_DATE_FORMAT, float_round
  4. from dateutil.parser import parse
  5. from dateutil.relativedelta import relativedelta as rd
  6. _MODEL = 'account.invoice'
  7. def create_invoice(sale_order_id, currency_id, date_today, picking_done=True):
  8. sale_order = request.env['sale.order'].browse(sale_order_id)
  9. invoice_id = sale_order.action_invoice_create()
  10. invoice = request.env[_MODEL].browse(invoice_id)
  11. for picking in sale_order.picking_ids:
  12. picking.force_assign()
  13. if picking_done:
  14. picking.action_done()
  15. date_due = parse(date_today) + rd(days=max(invoice.payment_term.line_ids.mapped(lambda x: x.days + x.days2)))
  16. invoice.write({
  17. 'currency_id': currency_id,
  18. 'date_invoice': date_today,
  19. 'date_due': date_due.strftime(DEFAULT_SERVER_DATE_FORMAT),
  20. 'state': 'open'
  21. })
  22. return invoice
  23. def create_invoice_move_lines(invoice_id, paid_amount, date_today):
  24. invoice = request.env[_MODEL].browse(invoice_id)
  25. context = dict(request.context, lang=invoice.partner_id.lang)
  26. invoice_move_lines = invoice._get_analytic_lines()
  27. decimal_precision = request.env['decimal.precision'].precision_get('Account')
  28. compute_taxes = request.env['account.invoice.tax'].compute(invoice.with_context(context))
  29. invoice.check_tax_lines(compute_taxes)
  30. invoice._recompute_tax_amount()
  31. invoice_move_lines += request.env['account.invoice.tax'].move_line_get(invoice.id)
  32. total, total_currency, invoice_move_lines = invoice.with_context(context).compute_invoice_totals(invoice.company_id.currency_id, invoice.reference, invoice_move_lines)
  33. paid_amount = float_round(paid_amount, precision_digits=decimal_precision)
  34. paid_percentage = paid_amount / float_round(total_currency, precision_digits=decimal_precision)
  35. distributed_percentage = -(paid_percentage / len(invoice.payment_term.line_ids))
  36. diff_currency = invoice.currency_id != invoice.company_id.currency_id
  37. if diff_currency:
  38. paid_amount = invoice.currency_id.compute(paid_amount, invoice.company_id.currency_id)
  39. payment_lines = []
  40. for line in invoice.payment_term.line_ids:
  41. date_due = (parse(date_today) + rd(days=line.days + line.days2)).strftime(DEFAULT_SERVER_DATE_FORMAT)
  42. if paid_percentage and paid_percentage < 1.0:
  43. payment_lines.append([date_today, paid_percentage])
  44. paid_percentage = paid_amount = 0
  45. if date_due == date_today and line.value_amount:
  46. distributed_percentage = -((payment_lines[0][1] - line.value_amount) / (len(invoice.payment_term.line_ids) - 1))
  47. continue
  48. if line.value != 'balance':
  49. payment_lines.append([date_due, line.value_amount + distributed_percentage])
  50. continue
  51. payment_lines.append([date_due, line.value_amount])
  52. for payment_line in payment_lines:
  53. current_price = float_round(total * payment_line[1], precision_digits=decimal_precision)
  54. if current_price < 0.0:
  55. continue
  56. paid_amount += current_price
  57. # Compute move line price
  58. if payment_line[1]:
  59. price = current_price
  60. else:
  61. price = float_round(total - paid_amount, precision_digits=decimal_precision) or total
  62. # Compute move line amount in currency
  63. if diff_currency:
  64. amount_currency = invoice.company_id.currency_id.with_context(context).compute(price, invoice.currency_id)
  65. else:
  66. amount_currency = False
  67. # Create invoice move live value
  68. invoice_move_lines.append({
  69. 'type': 'dest',
  70. 'name': '/',
  71. 'price': price,
  72. 'account_id': invoice.account_id.id,
  73. 'date_maturity': payment_line[0],
  74. 'amount_currency': amount_currency,
  75. 'currency_id': diff_currency and invoice.currency_id.id,
  76. 'ref': invoice.reference
  77. })
  78. payment_lines = []
  79. return invoice_move_lines
  80. def number_invoice(invoice_id):
  81. request.env[_MODEL].browse(invoice_id).action_number()
  82. def close_invoice(invoice_id):
  83. invoice = request.env[_MODEL].browse(invoice_id)
  84. if invoice.residual == 0:
  85. invoice.write({
  86. 'state': 'paid'
  87. })