半成品图像上传初实现,支持多图,检测报告的图片以及链接上传
This commit is contained in:
@ -1,12 +1,10 @@
|
||||
# app/services/inbound/semi_service.py
|
||||
from app.extensions import db
|
||||
from app.models.base import MaterialBase
|
||||
# ---------------------------------------------------------------------
|
||||
# ❌ 头部禁止导入 StockSemi,防止 Circular Import
|
||||
# ---------------------------------------------------------------------
|
||||
from datetime import datetime
|
||||
from sqlalchemy import or_, func, text
|
||||
import traceback
|
||||
import json
|
||||
|
||||
|
||||
class SemiInboundService:
|
||||
@ -42,7 +40,7 @@ class SemiInboundService:
|
||||
|
||||
@staticmethod
|
||||
def handle_inbound(data):
|
||||
# ✅ 【关键修复】局部导入 Model,解决循环引用
|
||||
# 局部导入 Model,解决循环引用
|
||||
from app.models.inbound.semi import StockSemi
|
||||
|
||||
try:
|
||||
@ -79,7 +77,6 @@ class SemiInboundService:
|
||||
except:
|
||||
pass
|
||||
|
||||
# ✅ 优化:处理 time_range 字符串,防止前端传数组导致存入 None
|
||||
time_range_str = None
|
||||
raw_range = data.get('production_time_range')
|
||||
if isinstance(raw_range, list):
|
||||
@ -94,9 +91,7 @@ class SemiInboundService:
|
||||
unit_total_cost = raw_cost + manual_cost
|
||||
total_value = unit_total_cost * in_qty
|
||||
|
||||
# ------------------------------------------------------------------
|
||||
# 4. 获取全局打印流水号 (跨表唯一)
|
||||
# ------------------------------------------------------------------
|
||||
# 4. 获取全局打印流水号
|
||||
next_global_id = 0
|
||||
try:
|
||||
seq_sql = text("SELECT nextval('global_print_seq')")
|
||||
@ -106,22 +101,25 @@ class SemiInboundService:
|
||||
print("❌ 数据库序列 global_print_seq 不存在,请执行SQL创建!")
|
||||
raise e
|
||||
|
||||
# ------------------------------------------------------------------
|
||||
# 5. 自动生成 SKU (格式: 00000001)
|
||||
# ------------------------------------------------------------------
|
||||
# 5. 自动生成 SKU
|
||||
generated_sku = str(next_global_id).zfill(10)
|
||||
final_sku = data.get('sku')
|
||||
if not final_sku:
|
||||
final_sku = generated_sku
|
||||
|
||||
# ------------------------------------------------------------------
|
||||
# 6. 条码逻辑处理
|
||||
# ------------------------------------------------------------------
|
||||
final_barcode = data.get('barcode')
|
||||
if not final_barcode:
|
||||
final_barcode = final_sku
|
||||
|
||||
# 7. 创建记录
|
||||
# 7. 图片列表转 JSON 字符串处理
|
||||
arrival_list = data.get('arrival_photo', [])
|
||||
quality_report_list = data.get('quality_report_link', [])
|
||||
|
||||
if not isinstance(arrival_list, list): arrival_list = []
|
||||
if not isinstance(quality_report_list, list): quality_report_list = []
|
||||
|
||||
# 8. 创建记录
|
||||
new_stock = StockSemi(
|
||||
base_id=material.id,
|
||||
global_print_id=next_global_id,
|
||||
@ -152,7 +150,10 @@ class SemiInboundService:
|
||||
manual_cost=manual_cost,
|
||||
total_price=total_value,
|
||||
|
||||
quality_report_link=data.get('quality_report_link'),
|
||||
# [核心修改] 将列表转为 JSON 字符串存储
|
||||
arrival_photo=json.dumps(arrival_list),
|
||||
quality_report_link=json.dumps(quality_report_list),
|
||||
|
||||
detail_link=data.get('detail_link'),
|
||||
remark=data.get('remark')
|
||||
)
|
||||
@ -190,7 +191,6 @@ class SemiInboundService:
|
||||
'bom_version': 'bom_version',
|
||||
'work_order_code': 'work_order_code',
|
||||
'production_manager': 'production_manager',
|
||||
'quality_report_link': 'quality_report_link',
|
||||
'detail_link': 'detail_link',
|
||||
'remark': 'remark'
|
||||
}
|
||||
@ -199,6 +199,17 @@ class SemiInboundService:
|
||||
if frontend_key in data:
|
||||
setattr(stock, db_attr, data[frontend_key])
|
||||
|
||||
# [核心修改] 图片字段更新 (List -> JSON String)
|
||||
if 'arrival_photo' in data:
|
||||
imgs = data['arrival_photo']
|
||||
if isinstance(imgs, list):
|
||||
stock.arrival_photo = json.dumps(imgs)
|
||||
|
||||
if 'quality_report_link' in data:
|
||||
imgs = data['quality_report_link']
|
||||
if isinstance(imgs, list):
|
||||
stock.quality_report_link = json.dumps(imgs)
|
||||
|
||||
# 时间处理
|
||||
if 'production_start_time' in data:
|
||||
try:
|
||||
@ -317,11 +328,9 @@ class SemiInboundService:
|
||||
items = []
|
||||
for item in current_items:
|
||||
stats = stock_map.get(item.base_id, {'total_stock': 0, 'total_avail': 0})
|
||||
|
||||
d = item.to_dict()
|
||||
d['sum_stock'] = stats['total_stock']
|
||||
d['sum_available'] = stats['total_avail']
|
||||
|
||||
items.append(d)
|
||||
|
||||
return {"total": pagination.total, "items": items}
|
||||
|
||||
Reference in New Issue
Block a user