__init__.py 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  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. 'warehouses': warehouses
  65. }
  66. if mode == 'product_taking':
  67. data = {
  68. 'stockPickings': get_pickings()
  69. }
  70. return make_gzip_response(data)
  71. def process_data(data=None):
  72. if not data:
  73. return {}
  74. def drafting_order(currency_id, supplier_id, cart_items, date_now, payment_term_id, warehouse_id):
  75. pricelist_id = get_pricelist_id(currency_id)
  76. order = create_purchase_order(supplier_id, cart_items, date_now, currency_id, pricelist_id, payment_term_id, warehouse_id)
  77. return order.id, currency_id
  78. def making_order(order_id):
  79. if not order_id:
  80. return None
  81. order = get_purchase_order(order_id)
  82. confirm_purchase_order(order.id)
  83. return order.id
  84. def paying_order(order_id, supplier_invoice_number=None, supplier_id=None, cart_items=None, date_now=None, payment_term_id=None):
  85. invoice = None
  86. if order_id:
  87. order = get_purchase_order(order_id)
  88. invoice = order.invoice_ids
  89. if not invoice:
  90. invoice = create_invoice(supplier_id, cart_items, currency_id, payment_term_id, supplier_invoice_number)
  91. invoice_ids = invoice.mapped(lambda x: x.id)
  92. prepare_invoice(invoice_ids, currency_id, date_now)
  93. move_lines = create_invoice_move_lines(invoice_ids, payment, date_now)
  94. account_move = create_account_move(invoice_ids, move_lines)
  95. validate_invoice(invoice_ids, mode)
  96. account_voucher = create_account_voucher(account_move.id, journal_id, currency_id, payment)
  97. close_invoice(invoice_ids)
  98. statement_lines = create_bank_statement_lines(account_voucher.id)
  99. bank_statement = create_bank_statement(account_voucher.id, statement_lines, date_now)
  100. return bank_statement.id
  101. def complete_order(order_id):
  102. if not order_id:
  103. return None
  104. force_assign_picking(order_id)
  105. done_picking(order_id)
  106. date_now = get_date()
  107. mode = data.get('mode')
  108. currency_id = data.get('currencyId')
  109. journal_id = data.get('journalId')
  110. supplier_id = data.get('supplierId')
  111. supplier_invoice_number = data.get('supplierInvoiceNumber', None)
  112. cart_items = data.get('items')
  113. payment_term_id = data.get('paymentTermId')
  114. warehouse_id = data.get('warehouseId', None)
  115. payment = float(data.get('payment', 0.0))
  116. if mode not in ('product_picking', 'payment', 'product_taking'):
  117. order_id = None
  118. if mode == 'purchase':
  119. order_id, currency_id = drafting_order(currency_id, supplier_id, cart_items, date_now, payment_term_id)
  120. making_order(order_id)
  121. complete_order(order_id)
  122. else:
  123. paying_order(order_id)
  124. if mode == 'product_picking':
  125. order_id, currency_id = drafting_order(currency_id, supplier_id, cart_items, date_now, payment_term_id, warehouse_id)
  126. confirm_purchase_order(order_id)
  127. if mode == 'payment':
  128. order_id = data.get('purchaseOrderId', None)
  129. if not order_id:
  130. return
  131. paying_order(order_id, supplier_invoice_number, supplier_id, cart_items, date_now, payment_term_id)
  132. if mode == 'picking':
  133. order_id = data.get('orderId')
  134. complete_order(order_id)
  135. # prepare_invoice(invoice_ids, currency_id, date_now)
  136. # move_lines = create_invoice_move_lines(invoice_ids, payment, date_now)
  137. # account_move = create_account_move(invoice_ids, move_lines)
  138. #
  139. # validate_invoice(invoice_ids, mode)
  140. #
  141. # account_voucher = create_account_voucher(account_move.id, journal_id, currency_id, payment)
  142. # close_invoice(invoice_ids)
  143. #
  144. # statement_lines = create_bank_statement_lines(account_voucher.id)
  145. # create_bank_statement(account_voucher.id, statement_lines, date_now)
  146. # invoice = None
  147. #
  148. # if mode == 'purchase':
  149. # purchase_order = create_purchase_order(supplier_id, cart_items, date_now, currency_id, pricelist_id, payment_term_id)
  150. # confirm_purchase_order(purchase_order.id)
  151. #
  152. # invoice = purchase_order.invoice_ids
  153. # invoice.write({
  154. # 'supplier_invoice_number': supplier_invoice_number
  155. # })
  156. # else:
  157. # invoice = create_invoice(supplier_id, cart_items, currency_id, payment_term_id, supplier_invoice_number)
  158. #
  159. # invoice_ids = invoice.mapped(lambda x: x.id)
  160. #
  161. # prepare_invoice(invoice_ids, currency_id, date_now)
  162. # move_lines = create_invoice_move_lines(invoice_ids, payment, date_now)
  163. # account_move = create_account_move(invoice_ids, move_lines)
  164. #
  165. # validate_invoice(invoice_ids, mode)
  166. #
  167. # account_voucher = create_account_voucher(account_move.id, journal_id, currency_id, payment)
  168. # close_invoice(invoice_ids)
  169. #
  170. # statement_lines = create_bank_statement_lines(account_voucher.id)
  171. # create_bank_statement(account_voucher.id, statement_lines, date_now)
  172. return {
  173. 'status': 'ok'
  174. }