169 lines
6.3 KiB
Python
169 lines
6.3 KiB
Python
from fastapi import Request
|
||
from sqlalchemy.ext.asyncio import AsyncSession
|
||
from typing import List
|
||
from config.constant import CommonConstant
|
||
from exceptions.exception import ServiceException
|
||
from module_admin.entity.vo.common_vo import CrudResponseModel
|
||
from module_admin.service.dict_service import DictDataService
|
||
from module_admin.system.dao.test_eut_dao import Test_eutDao
|
||
from module_admin.system.entity.vo.test_eut_vo import DeleteTest_eutModel, Test_eutModel, Test_eutPageQueryModel
|
||
from utils.common_util import CamelCaseUtil
|
||
from utils.excel_util import ExcelUtil
|
||
|
||
|
||
class Test_eutService:
|
||
"""
|
||
产品管理模块服务层
|
||
"""
|
||
|
||
@classmethod
|
||
async def get_test_eut_list_services(
|
||
cls, query_db: AsyncSession, query_object: Test_eutPageQueryModel, is_page: bool = False, order_id_from_work_order: int = None
|
||
):
|
||
"""
|
||
获取产品管理列表信息service
|
||
|
||
:param query_db: orm对象
|
||
:param query_object: 查询参数对象
|
||
:param is_page: 是否开启分页
|
||
:param order_id_from_work_order: 通过工单的order_id查询样品(用于从工单生成的订单)
|
||
:return: 产品管理列表信息对象
|
||
"""
|
||
test_eut_list_result = await Test_eutDao.get_test_eut_list(query_db, query_object, is_page, order_id_from_work_order)
|
||
|
||
return test_eut_list_result
|
||
|
||
|
||
@classmethod
|
||
async def add_test_eut_services(cls, query_db: AsyncSession, page_object: Test_eutModel):
|
||
"""
|
||
新增产品管理信息service
|
||
|
||
:param query_db: orm对象
|
||
:param page_object: 新增产品管理对象
|
||
:return: 新增产品管理校验结果
|
||
"""
|
||
try:
|
||
await Test_eutDao.add_test_eut_dao(query_db, page_object)
|
||
await query_db.commit()
|
||
return CrudResponseModel(is_success=True, message='新增成功')
|
||
except Exception as e:
|
||
await query_db.rollback()
|
||
raise e
|
||
|
||
@classmethod
|
||
async def edit_test_eut_services(cls, query_db: AsyncSession, page_object: Test_eutModel):
|
||
"""
|
||
编辑产品管理信息service
|
||
|
||
:param query_db: orm对象
|
||
:param page_object: 编辑产品管理对象
|
||
:return: 编辑产品管理校验结果
|
||
"""
|
||
edit_test_eut = page_object.model_dump(
|
||
exclude_unset=True,
|
||
exclude={'eut_type_name', 'test_flow_name'}
|
||
)
|
||
test_eut_info = await cls.test_eut_detail_services(query_db, page_object.id)
|
||
if test_eut_info.id:
|
||
try:
|
||
await Test_eutDao.edit_test_eut_dao(query_db, edit_test_eut)
|
||
await query_db.commit()
|
||
return CrudResponseModel(is_success=True, message='更新成功')
|
||
except Exception as e:
|
||
await query_db.rollback()
|
||
raise e
|
||
else:
|
||
raise ServiceException(message='产品管理不存在')
|
||
|
||
@classmethod
|
||
async def delete_test_eut_services(cls, query_db: AsyncSession, page_object: DeleteTest_eutModel):
|
||
"""
|
||
删除产品管理信息service
|
||
|
||
:param query_db: orm对象
|
||
:param page_object: 删除产品管理对象
|
||
:return: 删除产品管理校验结果
|
||
"""
|
||
if page_object.ids:
|
||
id_list = page_object.ids.split(',')
|
||
try:
|
||
for id in id_list:
|
||
await Test_eutDao.delete_test_eut_dao(query_db, Test_eutModel(id=id))
|
||
await query_db.commit()
|
||
return CrudResponseModel(is_success=True, message='删除成功')
|
||
except Exception as e:
|
||
await query_db.rollback()
|
||
raise e
|
||
else:
|
||
raise ServiceException(message='传入产品ID为空')
|
||
|
||
@classmethod
|
||
async def test_eut_detail_services(cls, query_db: AsyncSession, id: int):
|
||
"""
|
||
获取产品管理详细信息service
|
||
|
||
:param query_db: orm对象
|
||
:param id: 产品ID
|
||
:return: 产品ID对应的信息
|
||
"""
|
||
test_eut = await Test_eutDao.get_test_eut_detail_by_id(query_db, id=id)
|
||
if test_eut:
|
||
result = Test_eutModel(**CamelCaseUtil.transform_result(test_eut))
|
||
else:
|
||
result = Test_eutModel(**dict())
|
||
|
||
return result
|
||
|
||
@classmethod
|
||
async def get_test_flow_list_services(cls, query_db: AsyncSession):
|
||
"""
|
||
获取测试流程列表service
|
||
|
||
:param query_db: orm对象
|
||
:return: 测试流程列表
|
||
"""
|
||
return await Test_eutDao.get_test_flow_list(query_db)
|
||
|
||
@classmethod
|
||
async def get_eut_type_list_services(cls, query_db: AsyncSession):
|
||
"""
|
||
获取产品类别列表service
|
||
|
||
:param query_db: orm对象
|
||
:return: 产品类别列表
|
||
"""
|
||
return await Test_eutDao.get_eut_type_list(query_db)
|
||
|
||
@staticmethod
|
||
async def export_test_eut_list_services(request: Request, test_eut_list: List):
|
||
"""
|
||
导出产品管理信息service
|
||
|
||
:param test_eut_list: 产品管理信息列表
|
||
:return: 产品管理信息对应excel的二进制数据
|
||
"""
|
||
# 创建一个映射字典,将英文键映射到中文键
|
||
mapping_dict = {
|
||
'id': '产品ID',
|
||
'testOrderId': '订单ID',
|
||
'testFlowName': '流程名称',
|
||
'eutTypeName': '产品类别名称',
|
||
'sn': 'sn号',
|
||
'batchNo': '批次号',
|
||
'version': '版本号',
|
||
'sampleAppearance': '外观',
|
||
'memo': '备注说明',
|
||
}
|
||
sys_sample_appearance_list = await DictDataService.query_dict_data_list_from_cache_services(
|
||
request.app.state.redis, dict_type='sys_sample_appearance'
|
||
)
|
||
sys_sample_appearance_option = [dict(label=item.get('dictLabel'), value=item.get('dictValue')) for item in sys_sample_appearance_list]
|
||
sys_sample_appearance_option_dict = {item.get('value'): item for item in sys_sample_appearance_option}
|
||
for item in test_eut_list:
|
||
if str(item.get('sampleAppearance')) in sys_sample_appearance_option_dict.keys():
|
||
item['sampleAppearance'] = sys_sample_appearance_option_dict.get(str(item.get('sampleAppearance'))).get('label')
|
||
binary_data = ExcelUtil.export_list2excel(test_eut_list, mapping_dict)
|
||
|
||
return binary_data
|