main.py 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. # -*- coding: utf-8 -*-
  2. from openerp import http
  3. from openerp.http import request
  4. from http_response import make_gzip_response
  5. import logging
  6. LOGGER = logging.getLogger(__name__)
  7. class PosSales(http.Controller):
  8. #################
  9. # ╦ ╔═╗╔═╗ #
  10. # ║ ║ ║║ ╦ #
  11. # ╩═╝╚═╝╚═╝ #
  12. #################
  13. def make_info_log(self, log):
  14. LOGGER.info('\033[1;34m[INFO] --> \033[m{}'.format(log))
  15. #####################################
  16. # ╦╔╗╔╦╔╦╗ ╔═╗╦═╗╔═╗╔═╗╔═╗╔═╗╔═╗ #
  17. # ║║║║║ ║ ╠═╝╠╦╝║ ║║ ║╣ ╚═╗╚═╗ #
  18. # ╩╝╚╝╩ ╩ ╩ ╩╚═╚═╝╚═╝╚═╝╚═╝╚═╝ #
  19. #####################################
  20. @http.route('/eiru_sales/init', auth='user', methods=['GET'], cors='*')
  21. def _init_sale(self, **kw):
  22. self.make_info_log('Sending JSON response')
  23. # Imports
  24. from server_datetime import get_datetime
  25. from res_currency import check_base_currency
  26. from res_config import get_pos_config
  27. from res_users import get_current_user
  28. from account_journal import get_journals, get_currencies_from_journals
  29. from res_partner import get_customers
  30. from product_template import get_products
  31. from account_payment_term import get_payment_terms
  32. from res_bank import get_banks
  33. from res_bank_payment_type import get_bank_payment_types
  34. from res_bank_cheque_type import get_cheque_types
  35. from res_store import get_stores
  36. from sale_order import get_sale_orders
  37. # Logic
  38. check_base_currency()
  39. config = get_pos_config()
  40. mode = kw.get('mode', 'unknown')
  41. data = {}
  42. # Take all data
  43. if mode == 'sale':
  44. data = {
  45. 'settings': config,
  46. 'date': get_datetime(),
  47. 'user': get_current_user(),
  48. 'currencies': get_currencies_from_journals(),
  49. 'journals': get_journals(),
  50. 'customers': get_customers(image_type=config.get('imageType')),
  51. 'products': get_products(image_type=config.get('imageType')),
  52. 'paymentTerms': get_payment_terms(),
  53. 'banks': get_banks(),
  54. 'bankPaymentTypes': get_bank_payment_types(),
  55. 'chequeTypes': get_cheque_types(),
  56. 'stores': get_stores()
  57. }
  58. # Take data for picking
  59. if mode == 'product_picking':
  60. data = {
  61. 'settings': config,
  62. 'date': get_datetime(),
  63. 'user': get_current_user(),
  64. 'currencies': get_currencies_from_journals(),
  65. 'customers': get_customers(image_type=config.get('imageType')),
  66. 'products': get_products(image_type=config.get('imageType'))
  67. }
  68. # Take data for payment
  69. if mode == 'payment':
  70. data = {
  71. 'saleOrders': get_sale_orders(),
  72. 'currencies': get_currencies_from_journals(),
  73. 'journals': get_journals(),
  74. 'paymentTerms': get_payment_terms(),
  75. 'banks': get_banks(),
  76. 'bankPaymentTypes': get_bank_payment_types(),
  77. 'chequeTypes': get_cheque_types(),
  78. 'stores': get_stores()
  79. }
  80. # Take data for delivery
  81. if mode == 'product_delivery':
  82. data = {}
  83. return make_gzip_response(data)
  84. #####################################################################
  85. # ╔═╗╔═╗╔╦╗ ╔═╗╦═╗╔═╗╔╦╗╦ ╦╔═╗╔╦╗╔═╗ ╔╦╗╔═╗╔╦╗╔═╗ ╔═╗╔╗╔╦ ╦ ╦ #
  86. # ║ ╦║╣ ║ ╠═╝╠╦╝║ ║ ║║║ ║║ ║ ╚═╗ ║║╠═╣ ║ ╠═╣ ║ ║║║║║ ╚╦╝ #
  87. # ╚═╝╚═╝ ╩ ╩ ╩╚═╚═╝═╩╝╚═╝╚═╝ ╩ ╚═╝ ═╩╝╩ ╩ ╩ ╩ ╩ ╚═╝╝╚╝╩═╝╩ #
  88. #####################################################################
  89. @http.route('/eiru_sales/get_images', auth='user', methods=['GET'], cors='*')
  90. def _get_images_only(self, **kw):
  91. image_type = str(get_pos_config().get('imageType'))
  92. # Imports
  93. from res_partner import get_customers
  94. from product_template import get_products
  95. return make_gzip_response({
  96. 'customers': get_customers(image_type=image_type),
  97. 'products': get_products(image_type=image_type)
  98. })
  99. #################################################################################################
  100. # ╔═╗╦═╗╔═╗╔═╗╔╦╗╔═╗ ╔═╗╦ ╦╔═╗╔╦╗╔═╗╔╦╗╔═╗╦═╗ ╔═╗╔╗╔╔╦╗ ╦═╗╔═╗╔╦╗╦ ╦╦═╗╔╗╔ ╔╦╗╔═╗╔╦╗╔═╗ #
  101. # ║ ╠╦╝║╣ ╠═╣ ║ ║╣ ║ ║ ║╚═╗ ║ ║ ║║║║║╣ ╠╦╝ ╠═╣║║║ ║║ ╠╦╝║╣ ║ ║ ║╠╦╝║║║ ║║╠═╣ ║ ╠═╣ #
  102. # ╚═╝╩╚═╚═╝╩ ╩ ╩ ╚═╝ ╚═╝╚═╝╚═╝ ╩ ╚═╝╩ ╩╚═╝╩╚═ ╩ ╩╝╚╝═╩╝ ╩╚═╚═╝ ╩ ╚═╝╩╚═╝╚╝ ═╩╝╩ ╩ ╩ ╩ ╩ #
  103. #################################################################################################
  104. @http.route('/eiru_sales/create_customer', type='json', auth='user', methods=['POST'], cors='*')
  105. def _create_customer(self, **kw):
  106. from res_partner import create_customer
  107. self.make_info_log('Creating customer')
  108. return create_customer(kw)
  109. #############################################
  110. # ╔═╗╔═╗╦ ╦╔═╗ ╔═╗╔═╗╔╦╗╔╦╗╦╔╗╔╔═╗╔═╗ #
  111. # ╚═╗╠═╣╚╗╔╝║╣ ╚═╗║╣ ║ ║ ║║║║║ ╦╚═╗ #
  112. # ╚═╝╩ ╩ ╚╝ ╚═╝ ╚═╝╚═╝ ╩ ╩ ╩╝╚╝╚═╝╚═╝ #
  113. #############################################
  114. @http.route('/eiru_sales/save_settings', type='json', auth='user', methods=['POST'], cors='*')
  115. def _save_config(self, **kw):
  116. from res_config import save_pos_config
  117. self.make_info_log('save settings')
  118. return save_pos_config(kw)
  119. #############################################################################################
  120. # ╔═╗╦═╗╔═╗╔═╗╔╦╗╔═╗ ╔═╗╦═╗╔═╗╔╦╗╦ ╦╔═╗╔╦╗ ╔═╗╔╗╔╔╦╗ ╦═╗╔═╗╔╦╗╦ ╦╦═╗╔╗╔ ╔╦╗╔═╗╔╦╗╔═╗ #
  121. # ║ ╠╦╝║╣ ╠═╣ ║ ║╣ ╠═╝╠╦╝║ ║ ║║║ ║║ ║ ╠═╣║║║ ║║ ╠╦╝║╣ ║ ║ ║╠╦╝║║║ ║║╠═╣ ║ ╠═╣ #
  122. # ╚═╝╩╚═╚═╝╩ ╩ ╩ ╚═╝ ╩ ╩╚═╚═╝═╩╝╚═╝╚═╝ ╩ ╩ ╩╝╚╝═╩╝ ╩╚═╚═╝ ╩ ╚═╝╩╚═╝╚╝ ═╩╝╩ ╩ ╩ ╩ ╩ #
  123. #############################################################################################
  124. @http.route('/eiru_sales/create_product', type='json', auth='user', methods=['POST'], cors='*')
  125. def _create_product(self, **kw):
  126. from product_template import create_product
  127. return create_product(kw)
  128. #############################################
  129. # ╔═╗╦╔╗╔╦╔═╗╦ ╦ ╔═╗╦═╗╔═╗╔═╗╔═╗╔═╗╔═╗ #
  130. # ╠╣ ║║║║║╚═╗╠═╣ ╠═╝╠╦╝║ ║║ ║╣ ╚═╗╚═╗ #
  131. # ╚ ╩╝╚╝╩╚═╝╩ ╩ ╩ ╩╚═╚═╝╚═╝╚═╝╚═╝╚═╝ #
  132. #############################################
  133. @http.route('/eiru_sales/finish', type='json', auth='user', methods=['POST'], cors='*')
  134. def _finish(self, **kw):
  135. self.make_info_log('Finishing...')
  136. # Imports
  137. from server_datetime import get_date, get_datetime
  138. '''
  139. ╔═╗╦╔╗╔╦╔═╗╦ ╦ ╔╗ ╦ ╦╔╦╗╔═╗╔═╗╔╦╗ ╔═╗╔═╗╔═╗ ╔═╗╦═╗╔═╗╔═╗╔═╗╔╦╗╦ ╦╦═╗╔═╗
  140. ╠╣ ║║║║║╚═╗╠═╣ ╠╩╗║ ║ ║║║ ╦║╣ ║ ╠═╝║ ║╚═╗ ╠═╝╠╦╝║ ║║ ║╣ ║║║ ║╠╦╝║╣
  141. ╚ ╩╝╚╝╩╚═╝╩ ╩ ╚═╝╚═╝═╩╝╚═╝╚═╝ ╩ ╩ ╚═╝╚═╝ ╩ ╩╚═╚═╝╚═╝╚═╝═╩╝╚═╝╩╚═╚═╝
  142. '''
  143. def finish_budget_pos(journal_id, customer_id, cart_items, date_now, payment_term_id):
  144. # Imports
  145. from account_journal import get_currency
  146. from sale_order import create_sale_from_cart
  147. # Get currency
  148. currency_id = get_currency(journal_id)
  149. self.make_info_log('[OK] Getting journal')
  150. # Create sale order
  151. sale_order = create_sale_from_cart(customer_id, cart_items, date_now, currency_id, payment_term_id)
  152. self.make_info_log('[OK] Creating sale order')
  153. return (sale_order.id, currency_id)
  154. '''
  155. ╔═╗╦╔╗╔╦╔═╗╦ ╦ ╔═╗╔═╗╦ ╔═╗ ╔═╗╔═╗╔═╗ ╔═╗╦═╗╔═╗╔═╗╔═╗╔╦╗╦ ╦╦═╗╔═╗
  156. ╠╣ ║║║║║╚═╗╠═╣ ╚═╗╠═╣║ ║╣ ╠═╝║ ║╚═╗ ╠═╝╠╦╝║ ║║ ║╣ ║║║ ║╠╦╝║╣
  157. ╚ ╩╝╚╝╩╚═╝╩ ╩ ╚═╝╩ ╩╩═╝╚═╝ ╩ ╚═╝╚═╝ ╩ ╩╚═╚═╝╚═╝╚═╝═╩╝╚═╝╩╚═╚═╝
  158. '''
  159. def finish_sale_pos(journal_id, customer_id, cart_items, date_now, payment_term_id, payment, payment_method, bank_payment_data):
  160. # Create budget
  161. sale_order_id, currency_id = finish_budget_pos(journal_id, customer_id, cart_items, date_now, payment_term_id)
  162. # Imports
  163. from sale_order import confirm_sale_order
  164. from account_invoice import (
  165. create_invoice,
  166. create_invoice_move_lines,
  167. number_invoice,
  168. close_invoice
  169. )
  170. from account_move import create_account_move
  171. from account_voucher import create_account_voucher
  172. from account_bank_statement import create_bank_statement
  173. from res_bank_payment import create_bank_payment_statement
  174. # Confirm sale
  175. confirm_sale_order(sale_order_id)
  176. self.make_info_log('[OK] Confirm sale order')
  177. # Create invoice
  178. invoice = create_invoice(sale_order_id, currency_id, date_now)
  179. self.make_info_log('[OK] Creating invoice')
  180. # Create invoice move lines
  181. invoice_move_lines = create_invoice_move_lines(invoice.id, payment, date_now)
  182. self.make_info_log('[OK] Creating invoice move lines')
  183. # Create account move
  184. account_move = create_account_move(invoice.id, invoice_move_lines)
  185. self.make_info_log('[OK] Creating account move')
  186. # Number invoice
  187. number_invoice(invoice.id)
  188. self.make_info_log('[OK] Number invoice')
  189. # Create account voucher
  190. account_voucher = create_account_voucher(account_move.id, journal_id, currency_id, payment)
  191. self.make_info_log('[OK] Creating account voucher')
  192. # Close invoice
  193. close_invoice(invoice.id)
  194. self.make_info_log('[OK] Closing invoice')
  195. # Create bank statement
  196. create_bank_statement(account_voucher.id, date_now)
  197. self.make_info_log('[OK] Creating account bank statement')
  198. # Create bank payment statement
  199. if payment_method == 'Banco':
  200. create_bank_payment_statement(bank_payment_data, invoice.id, account_voucher.id)
  201. self.make_info_log('[OK] Creating bank payment statement')
  202. '''
  203. ╔═╗╦╔╗╔╦╔═╗╦ ╦ ╔═╗╦═╗╔═╗╔╦╗╦ ╦╔═╗╔╦╗ ╔═╗╦╔═╗╦╔═╦╔╗╔╔═╗
  204. ╠╣ ║║║║║╚═╗╠═╣ ╠═╝╠╦╝║ ║ ║║║ ║║ ║ ╠═╝║║ ╠╩╗║║║║║ ╦
  205. ╚ ╩╝╚╝╩╚═╝╩ ╩ ╩ ╩╚═╚═╝═╩╝╚═╝╚═╝ ╩ ╩ ╩╚═╝╩ ╩╩╝╚╝╚═╝
  206. '''
  207. def finish_process_picking(journal_id, customer_id, cart_items, date_now, payment_term_id):
  208. sale_order_id, _ = finish_budget_pos(journal_id, customer_id, cart_items, date_now, payment_term_id)
  209. # Imports
  210. from sale_order import confirm_sale_order, force_assign_picking
  211. # Confirm sale
  212. confirm_sale_order(sale_order_id)
  213. self.make_info_log('[OK] Confirm sale order')
  214. # Force assign picking
  215. force_assign_picking(sale_order_id)
  216. self.make_info_log('[OK] Pick assign')
  217. '''
  218. ╔═╗╦╔╗╔╦╔═╗╦ ╦ ╔═╗╔═╗╦ ╦╔╦╗╔═╗╔╗╔╔╦╗
  219. ╠╣ ║║║║║╚═╗╠═╣ ╠═╝╠═╣╚╦╝║║║║╣ ║║║ ║
  220. ╚ ╩╝╚╝╩╚═╝╩ ╩ ╩ ╩ ╩ ╩ ╩ ╩╚═╝╝╚╝ ╩
  221. '''
  222. def finish_payment():
  223. pass
  224. '''
  225. ╔═╗╦╔╗╔╦╔═╗╦ ╦ ╔═╗╦═╗╔═╗╔╦╗╦ ╦╔═╗╔╦╗ ╔╦╗╔═╗╦ ╦╦ ╦╔═╗╦═╗╦ ╦
  226. ╠╣ ║║║║║╚═╗╠═╣ ╠═╝╠╦╝║ ║ ║║║ ║║ ║ ║║║╣ ║ ║╚╗╔╝║╣ ╠╦╝╚╦╝
  227. ╚ ╩╝╚╝╩╚═╝╩ ╩ ╩ ╩╚═╚═╝═╩╝╚═╝╚═╝ ╩ ═╩╝╚═╝╩═╝╩ ╚╝ ╚═╝╩╚═ ╩
  228. '''
  229. def finish_product_delivery():
  230. pass
  231. '''
  232. ╔═╗╦═╗╔═╗╔═╗╔═╗╔═╗╔═╗ ╔═╗╦╔╗╔╦╔═╗╦ ╦ ╔╦╗╔═╗╔═╗╦╔═╗╦╔═╗╔╗╔
  233. ╠═╝╠╦╝║ ║║ ║╣ ╚═╗╚═╗ ╠╣ ║║║║║╚═╗╠═╣ ║║║╣ ║ ║╚═╗║║ ║║║║
  234. ╩ ╩╚═╚═╝╚═╝╚═╝╚═╝╚═╝ ╚ ╩╝╚╝╩╚═╝╩ ╩ ═╩╝╚═╝╚═╝╩╚═╝╩╚═╝╝╚╝
  235. '''
  236. data = kw.get('data', [])
  237. date_now = get_date()
  238. for row in data:
  239. mode = row.get('mode', 'sale')
  240. journal_id = row.get('journalId', None)
  241. customer_id = row.get('customerId', None)
  242. cart_items = row.get('items', [])
  243. payment_term_id = row.get('paymentTermId', None)
  244. payment = float(row.get('payment', 0.0))
  245. payment_method = row.get('paymentMethod', 'Efectivo')
  246. bank_payment_data = row.get('bankPaymentData', {})
  247. if mode == 'budget':
  248. finish_budget_pos(journal_id, customer_id, cart_items, date_now, currency_id, payment_term_id)
  249. if mode == 'sale':
  250. finish_sale_pos(journal_id, customer_id, cart_items, date_now, payment_term_id, payment, payment_method, bank_payment_data)
  251. if mode == 'product_picking':
  252. finish_process_picking(journal_id, customer_id, cart_items, date_now, payment_term_id)
  253. if mode == 'payment':
  254. finish_payment()
  255. if mode == 'product_delivery':
  256. finish_product_delivery()
  257. return {
  258. 'process': True,
  259. 'date': get_datetime()
  260. }