02.02.26
This commit is contained in:
@@ -310,7 +310,7 @@ class AutomationCron(ModelSQL, ModelView):
|
|||||||
ShipmentIn.save([shipment])
|
ShipmentIn.save([shipment])
|
||||||
shipment._create_lots_from_fintrade()
|
shipment._create_lots_from_fintrade()
|
||||||
shipment.controller = shipment.get_controller()
|
shipment.controller = shipment.get_controller()
|
||||||
shipment.instructions = shipment.get_instructions()
|
shipment.instructions = shipment.get_instructions_html()
|
||||||
ShipmentIn.save([shipment])
|
ShipmentIn.save([shipment])
|
||||||
trans_shipment.commit()
|
trans_shipment.commit()
|
||||||
successful_shipments += 1
|
successful_shipments += 1
|
||||||
|
|||||||
@@ -23,6 +23,9 @@ import io
|
|||||||
import base64
|
import base64
|
||||||
import logging
|
import logging
|
||||||
import json
|
import json
|
||||||
|
import re
|
||||||
|
import html
|
||||||
|
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
@@ -462,26 +465,46 @@ class ShipmentIn(metaclass=PoolMeta):
|
|||||||
for c in controllers:
|
for c in controllers:
|
||||||
if c.party.IsAvailableForControl(self):
|
if c.party.IsAvailableForControl(self):
|
||||||
return c.party
|
return c.party
|
||||||
|
|
||||||
def get_instructions(self):
|
def get_instructions_html(self):
|
||||||
lines = [
|
lines = [
|
||||||
"Hi,",
|
"<p>Hi,</p>",
|
||||||
"",
|
"<p>Please find details below for the requested control</p>",
|
||||||
"Please find details below for the requested control",
|
f"<p><strong>BL number:</strong> {self.bl_number}</p>",
|
||||||
f"BL number: {self.bl_number}",
|
|
||||||
""
|
|
||||||
]
|
]
|
||||||
|
|
||||||
if self.incoming_moves:
|
if self.incoming_moves:
|
||||||
for m in self.incoming_moves:
|
for m in self.incoming_moves:
|
||||||
if m.lot:
|
if m.lot:
|
||||||
lines.append(
|
lines.append(
|
||||||
f"Lot nb: {m.lot.lot_name} | "
|
"<p>"
|
||||||
f"Net Qt: {m.lot.get_current_quantity()} {m.lot.lot_unit.symbol} | "
|
f"<strong>Lot nb:</strong> {m.lot.lot_name} | "
|
||||||
f"Gross Qt: {m.lot.get_current_gross_quantity()} {m.lot.lot_unit.symbol}"
|
f"<strong>Net Qt:</strong> {m.lot.get_current_quantity()} {m.lot.lot_unit.symbol} | "
|
||||||
|
f"<strong>Gross Qt:</strong> {m.lot.get_current_gross_quantity()} {m.lot.lot_unit.symbol}"
|
||||||
|
"</p>"
|
||||||
)
|
)
|
||||||
|
|
||||||
return "\n".join(lines)
|
return "".join(lines)
|
||||||
|
|
||||||
|
# def get_instructions(self):
|
||||||
|
# lines = [
|
||||||
|
# "Hi,",
|
||||||
|
# "",
|
||||||
|
# "Please find details below for the requested control",
|
||||||
|
# f"BL number: {self.bl_number}",
|
||||||
|
# ""
|
||||||
|
# ]
|
||||||
|
|
||||||
|
# if self.incoming_moves:
|
||||||
|
# for m in self.incoming_moves:
|
||||||
|
# if m.lot:
|
||||||
|
# lines.append(
|
||||||
|
# f"Lot nb: {m.lot.lot_name} | "
|
||||||
|
# f"Net Qt: {m.lot.get_current_quantity()} {m.lot.lot_unit.symbol} | "
|
||||||
|
# f"Gross Qt: {m.lot.get_current_gross_quantity()} {m.lot.lot_unit.symbol}"
|
||||||
|
# )
|
||||||
|
|
||||||
|
# return "\n".join(lines)
|
||||||
|
|
||||||
def _create_lots_from_fintrade(self):
|
def _create_lots_from_fintrade(self):
|
||||||
t = Table('freight_booking_lots')
|
t = Table('freight_booking_lots')
|
||||||
@@ -653,6 +676,12 @@ class ShipmentIn(metaclass=PoolMeta):
|
|||||||
|
|
||||||
return sale_line
|
return sale_line
|
||||||
|
|
||||||
|
def html_to_text(self,html_content):
|
||||||
|
text = re.sub(r"<br\s*/?>", "\n", html_content, flags=re.IGNORECASE)
|
||||||
|
text = re.sub(r"</p\s*>", "\n\n", text, flags=re.IGNORECASE)
|
||||||
|
text = re.sub(r"<[^>]+>", "", text)
|
||||||
|
return html.unescape(text).strip()
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
@ModelView.button
|
@ModelView.button
|
||||||
def send(cls, shipments):
|
def send(cls, shipments):
|
||||||
@@ -668,7 +697,7 @@ class ShipmentIn(metaclass=PoolMeta):
|
|||||||
payload = {
|
payload = {
|
||||||
"to": [contact[0].value],
|
"to": [contact[0].value],
|
||||||
"subject": "Request for control",
|
"subject": "Request for control",
|
||||||
"body": sh.instructions,
|
"body": sh.html_to_text(sh.instructions),
|
||||||
# "attachments": [
|
# "attachments": [
|
||||||
# {
|
# {
|
||||||
# "filename": "instruction.pdf",
|
# "filename": "instruction.pdf",
|
||||||
|
|||||||
@@ -125,7 +125,7 @@ this repository contains the full copyright notices and license terms. -->
|
|||||||
<field name="result"/>
|
<field name="result"/>
|
||||||
<newline/>
|
<newline/>
|
||||||
<label name="instructions"/>
|
<label name="instructions"/>
|
||||||
<field name="instructions" widget="email" colspan="4" height="100"/>
|
<field name="instructions" widget="richtext" colspan="4" height="100"/>
|
||||||
<newline/>
|
<newline/>
|
||||||
<label name="returned_id"/>
|
<label name="returned_id"/>
|
||||||
<field name="returned_id"/>
|
<field name="returned_id"/>
|
||||||
|
|||||||
Reference in New Issue
Block a user