Commit e5f71ee2 authored by Rafael Monnerat's avatar Rafael Monnerat

slapos_accounting: Set proper start/stop date on Transactions generated from the builders

parent 381b1614
from Products.ERP5Type.Message import translateString from Products.ERP5Type.Message import translateString
payment_transaction = context payment_transaction = context
invoice = context.getCausalityValue()
context.setStartDate(invoice.getStartDate())
context.setStopDate(invoice.getStopDate())
comment = translateString("Initialised by Order Builder.") comment = translateString("Initialised by Order Builder.")
payment_transaction.confirm(comment=comment) payment_transaction.confirm(comment=comment)
......
...@@ -10,16 +10,13 @@ invoice = context ...@@ -10,16 +10,13 @@ invoice = context
price_currency = invoice.getPriceCurrency() price_currency = invoice.getPriceCurrency()
if invoice.getResource() != price_currency: if invoice.getResource() != price_currency:
invoice.setResource(price_currency) invoice.setResource(price_currency)
if invoice.getPaymentMode("") == "": if invoice.getPaymentMode("") == "":
invoice.setPaymentModeValue(invoice.getPortalObject().portal_categories.payment_mode.payzen) invoice.setPaymentModeValue(invoice.getPortalObject().portal_categories.payment_mode.payzen)
comment = translateString('Initialised by Delivery Builder.')
if invoice.portal_workflow.isTransitionPossible(invoice, 'plan'):
invoice.plan(comment=comment)
if invoice.portal_workflow.isTransitionPossible(invoice, 'confirm'):
invoice.confirm(comment=comment)
causality_list = [] causality_list = []
min_start_date = None
max_stop_date = None
for line in invoice.objectValues(): for line in invoice.objectValues():
related_delivery = line.getDeliveryRelatedValue() related_delivery = line.getDeliveryRelatedValue()
if related_delivery is not None: if related_delivery is not None:
...@@ -29,6 +26,37 @@ for line in invoice.objectValues(): ...@@ -29,6 +26,37 @@ for line in invoice.objectValues():
if causality is not None and causality not in causality_list: if causality is not None and causality not in causality_list:
causality_list.append(causality) causality_list.append(causality)
if min_start_date is None:
min_start_date = line.getStartDate()
elif line.getStartDate() < min_start_date:
min_start_date = line.getStartDate()
if max_stop_date is None:
max_stop_date = line.getStopDate()
elif line.getStopDate() > max_stop_date:
max_stop_date = line.getStopDate()
if context.getStartDate() is None:
if min_start_date is None:
min_start_date = DateTime().earliestTime()
context.setStartDate(min_start_date)
if max_stop_date is None:
if min_start_date is not None:
max_stop_date = min_start_date
else:
max_stop_date = DateTime().earliestTime()
context.setStopDate(max_stop_date)
if context.getCausalityState() == 'draft':
context.startBuilding()
comment = translateString('Initialised by Delivery Builder.')
if invoice.portal_workflow.isTransitionPossible(invoice, 'plan'):
invoice.plan(comment=comment)
if invoice.portal_workflow.isTransitionPossible(invoice, 'confirm'):
invoice.confirm(comment=comment)
invoice.setCausalityList(causality_list) invoice.setCausalityList(causality_list)
invoice.startBuilding(comment=comment) invoice.startBuilding(comment=comment)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment