__init__.py 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. # -*- coding: utf-8 -*-
  2. from account_bank_statement import create_bank_statement, create_bank_statement_lines
  3. from account_invoice import create_invoice, prepare_invoice, validate_invoice, close_invoice
  4. from account_journal import get_journals, get_currencies_from_journal
  5. from account_move import create_invoice_move_lines, create_account_move
  6. from account_payment_term import get_payment_terms
  7. from account_voucher import create_account_voucher
  8. from http_response import make_gzip_response
  9. from product_pricelist import get_pricelist_id
  10. from product_template import get_products
  11. from purchase_order import (get_purchase_orders, get_purchase_order, create_purchase_order, confirm_purchase_order, force_assign_picking, done_picking)
  12. from res_bank_cheque_type import get_cheque_types
  13. from res_bank_payments_type import get_bank_payment_types
  14. from res_bank import get_banks
  15. from res_currency import check_base_currency, get_base_currency
  16. from res_partner import get_suppliers
  17. from res_users import get_current_user
  18. from server_date import get_date
  19. from stock_picking_type import get_picking_types
  20. from stock_picking import get_pickings
  21. from stock_warehouse import get_warehouses
  22. def get_data(mode=None):
  23. data = {}
  24. check_base_currency()
  25. warehouses = get_warehouses()
  26. location_ids = map(lambda x: x.get('locationStock').get('id'), warehouses)
  27. currencies = get_currencies_from_journal()
  28. if len(currencies) == 0:
  29. currencies = [get_base_currency()]
  30. if mode == 'purchase' or mode == 'expense':
  31. data = {
  32. 'date': get_date(),
  33. 'user': get_current_user(),
  34. 'currencies': currencies,
  35. 'journals': get_journals(),
  36. 'suppliers': get_suppliers(),
  37. 'products': get_products(mode, location_ids),
  38. 'pickingTypes': get_picking_types(),
  39. 'paymentTerms': get_payment_terms(),
  40. 'banks': get_banks(),
  41. 'bankPaymentTypes': get_bank_payment_types(),
  42. 'chequeTypes': get_cheque_types(),
  43. 'warehouses': warehouses
  44. }
  45. if mode == 'product_picking':
  46. data = {
  47. 'date': get_date(),
  48. 'user': get_current_user(),
  49. 'currencies': currencies,
  50. 'suppliers': get_suppliers(),
  51. 'products': get_products('purchase', location_ids),
  52. 'warehouses': warehouses
  53. }
  54. if mode == 'payment':
  55. data = {
  56. 'purchaseOrders': get_purchase_orders(),
  57. 'currencies': currencies,
  58. 'suppliers': get_suppliers(),
  59. 'journals': get_journals(),
  60. 'paymentTerms': get_payment_terms(),
  61. 'banks': get_banks(),
  62. 'bankPaymentTypes': get_bank_payment_types(),
  63. 'chequeTypes': get_cheque_types(),
  64. }
  65. if mode == 'product_taking':
  66. data = {
  67. 'stockPickings': get_pickings()
  68. }
  69. return make_gzip_response(data)
  70. def process_data(data=None):
  71. if not data:
  72. return {}
  73. def drafting_order(currency_id, supplier_id, cart_items, date_now, payment_term_id, warehouse_id):
  74. pricelist_id = get_pricelist_id(currency_id)
  75. order = create_purchase_order(supplier_id, cart_items, date_now, currency_id, pricelist_id, payment_term_id, warehouse_id)
  76. return order.id, currency_id
  77. def making_order(order_id):
  78. if not order_id:
  79. return None
  80. order = get_purchase_order(order_id)
  81. confirm_purchase_order(order.id)
  82. return order.id
  83. def paying_order(
  84. order_id,
  85. supplier_invoice_number=None,
  86. supplier_id=None,
  87. cart_items=None,
  88. date_now=None,
  89. payment_term_id=None,
  90. warehouse_id=None
  91. ):
  92. invoice = None
  93. if order_id:
  94. order = get_purchase_order(order_id)
  95. invoice = order.invoice_ids
  96. if not invoice:
  97. invoice = create_invoice(supplier_id, cart_items, currency_id, payment_term_id, supplier_invoice_number)
  98. invoice_ids = invoice.mapped(lambda x: x.id)
  99. prepare_invoice(invoice_ids, currency_id, date_now)
  100. move_lines = create_invoice_move_lines(invoice_ids, payment, date_now)
  101. account_move = create_account_move(invoice_ids, move_lines)
  102. validate_invoice(invoice_ids, mode)
  103. account_voucher = create_account_voucher(account_move.id, journal_id, currency_id, payment)
  104. close_invoice(invoice_ids)
  105. statement_lines = create_bank_statement_lines(account_voucher.id)
  106. bank_statement = create_bank_statement(account_voucher.id, statement_lines, date_now)
  107. return bank_statement.id
  108. def complete_order(order_id):
  109. if not order_id:
  110. return None
  111. force_assign_picking(order_id)
  112. done_picking(order_id)
  113. date_now = get_date()
  114. mode = data.get('mode')
  115. currency_id = data.get('currencyId')
  116. journal_id = data.get('journalId')
  117. supplier_id = data.get('supplierId')
  118. supplier_invoice_number = data.get('supplierInvoiceNumber', None)
  119. cart_items = data.get('items')
  120. payment_term_id = data.get('paymentTermId')
  121. warehouse_id = data.get('warehouseId', None)
  122. payment = float(data.get('payment', 0.0))
  123. if mode not in ('product_picking', 'payment', 'product_taking'):
  124. order_id = None
  125. if mode == 'purchase':
  126. order_id, currency_id = drafting_order(currency_id, supplier_id, cart_items, date_now, payment_term_id)
  127. making_order(order_id)
  128. complete_order(order_id)
  129. else:
  130. paying_order(order_id)
  131. if mode == 'product_picking':
  132. order_id, currency_id = drafting_order(currency_id, supplier_id, cart_items, date_now, payment_term_id, warehouse_id)
  133. confirm_purchase_order(order_id)
  134. if mode == 'payment':
  135. order_id = data.get('orderId')
  136. paying_order(order_id, supplier_invoice_number)
  137. if mode == 'picking':
  138. order_id = data.get('orderId')
  139. complete_order(order_id)
  140. # prepare_invoice(invoice_ids, currency_id, date_now)
  141. # move_lines = create_invoice_move_lines(invoice_ids, payment, date_now)
  142. # account_move = create_account_move(invoice_ids, move_lines)
  143. #
  144. # validate_invoice(invoice_ids, mode)
  145. #
  146. # account_voucher = create_account_voucher(account_move.id, journal_id, currency_id, payment)
  147. # close_invoice(invoice_ids)
  148. #
  149. # statement_lines = create_bank_statement_lines(account_voucher.id)
  150. # create_bank_statement(account_voucher.id, statement_lines, date_now)
  151. # invoice = None
  152. #
  153. # if mode == 'purchase':
  154. # purchase_order = create_purchase_order(supplier_id, cart_items, date_now, currency_id, pricelist_id, payment_term_id)
  155. # confirm_purchase_order(purchase_order.id)
  156. #
  157. # invoice = purchase_order.invoice_ids
  158. # invoice.write({
  159. # 'supplier_invoice_number': supplier_invoice_number
  160. # })
  161. # else:
  162. # invoice = create_invoice(supplier_id, cart_items, currency_id, payment_term_id, supplier_invoice_number)
  163. #
  164. # invoice_ids = invoice.mapped(lambda x: x.id)
  165. #
  166. # prepare_invoice(invoice_ids, currency_id, date_now)
  167. # move_lines = create_invoice_move_lines(invoice_ids, payment, date_now)
  168. # account_move = create_account_move(invoice_ids, move_lines)
  169. #
  170. # validate_invoice(invoice_ids, mode)
  171. #
  172. # account_voucher = create_account_voucher(account_move.id, journal_id, currency_id, payment)
  173. # close_invoice(invoice_ids)
  174. #
  175. # statement_lines = create_bank_statement_lines(account_voucher.id)
  176. # create_bank_statement(account_voucher.id, statement_lines, date_now)
  177. return {
  178. 'status': 'ok'
  179. }