修改登录退出逻辑

This commit is contained in:
dxc
2026-02-04 14:29:59 +08:00
parent 13590b1fac
commit fd5600b65b
12 changed files with 411 additions and 235 deletions

View File

@ -2,12 +2,8 @@
from app.extensions import db
from app.models.base import MaterialBase
# ==============================================================================
# ✅ 正确的引用方式
# ==============================================================================
from app.models.inbound.buy import StockBuy # 引用采购库存模型
from app.models.inbound.semi import StockSemi # 引用半成品库存模型
from app.models.inbound.buy import StockBuy
from app.models.inbound.semi import StockSemi
from sqlalchemy import or_
import traceback
@ -28,11 +24,12 @@ class MaterialBaseService:
if not keyword:
return []
# 搜索名称或规格型号,且必须是启用的
# ✅ 搜索范围增加 common_name (俗名)
query = MaterialBase.query.filter(
MaterialBase.is_enabled == True,
or_(
MaterialBase.name.ilike(f'%{keyword}%'),
MaterialBase.common_name.ilike(f'%{keyword}%'),
MaterialBase.spec_model.ilike(f'%{keyword}%')
)
).limit(20)
@ -42,6 +39,7 @@ class MaterialBaseService:
results.append({
'id': item.id,
'name': item.name,
'commonName': item.common_name, # ✅ 返回俗名
'spec': item.spec_model,
'category': item.category,
'unit': item.unit,
@ -62,12 +60,14 @@ class MaterialBaseService:
query = MaterialBase.query
if filters:
# 1. 关键词模糊搜索 (名称 或 规格型号)
# 1. 关键词模糊搜索 (名称 或 俗名 或 规格型号)
if filters.get('keyword'):
kw = f"%{filters['keyword']}%"
# ✅ 增加俗名搜索
query = query.filter(or_(
MaterialBase.name.like(kw),
MaterialBase.spec_model.like(kw)
MaterialBase.name.ilike(kw),
MaterialBase.common_name.ilike(kw),
MaterialBase.spec_model.ilike(kw)
))
# 2. 精确筛选
@ -101,6 +101,7 @@ class MaterialBaseService:
raise ValueError("名称和规格型号不能为空")
# 1. 查重 (名称+规格型号 唯一)
# 注意:俗名不参与唯一性校验,允许重复或为空
exist = MaterialBase.query.filter_by(
name=data['name'],
spec_model=data['spec']
@ -111,6 +112,7 @@ class MaterialBaseService:
# 2. 创建对象
new_material = MaterialBase(
name=data['name'],
common_name=data.get('commonName'), # ✅ 读取俗名
spec_model=data['spec'],
category=data.get('category'),
material_type=data.get('type'),
@ -139,6 +141,7 @@ class MaterialBaseService:
# 更新字段
if 'name' in data: material.name = data['name']
if 'commonName' in data: material.common_name = data['commonName'] # ✅ 更新俗名
if 'spec' in data: material.spec_model = data['spec']
if 'category' in data: material.category = data['category']
if 'type' in data: material.material_type = data['type']
@ -161,7 +164,6 @@ class MaterialBaseService:
def delete_material(m_id):
"""
删除基础信息 (带依赖检查)
✅ 已升级:同时检查采购库(Buy)和半成品库(Semi)
"""
try:
material = MaterialBase.query.get(m_id)