warehouse_root.py 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. from fastapi import APIRouter, Request, Depends, Query, HTTPException, status,WebSocket,WebSocketDisconnect
  4. from common.security import valid_access_token,valid_websocket_token
  5. from fastapi.responses import JSONResponse
  6. from sqlalchemy.orm import Session
  7. from sqlalchemy.sql import func
  8. from common.auth_user import *
  9. from sqlalchemy import text
  10. from pydantic import BaseModel
  11. from common.BigDataCenterAPI import *
  12. from database import get_db
  13. from typing import List
  14. from models import *
  15. from utils import *
  16. from utils.spatial import *
  17. from utils.ry_system_util import *
  18. from utils.resource_provision_util import *
  19. from common.websocketManager import *
  20. import json
  21. import traceback
  22. router = APIRouter()
  23. @router.post("/create")
  24. async def create_pattern(
  25. user_id=Depends(valid_access_token),
  26. body = Depends(remove_xss_json),
  27. db: Session = Depends(get_db)
  28. ):
  29. try:
  30. new_type = ResourceProvisionWarehouseRoomInfo(
  31. id = new_guid(),
  32. room_name=body['room_name'],
  33. warehouse=body['warehouse_id'],
  34. room_area=body['room_area'],
  35. available_area=body['available_area'],
  36. height=body['height'],
  37. room_volume=body['room_volume'],
  38. available_volume=body['available_volume'],
  39. storage_type=body['storage_type'],
  40. level=body['level'],
  41. storage_type_code=body['storage_type_code'],
  42. last_inventory_time=body['last_inventory_time'],
  43. create_by = user_id
  44. )
  45. db.add(new_type)
  46. db.commit()
  47. return {"code": 200, "msg": "创建成功", "data": None}
  48. except Exception as e:
  49. traceback.print_exc()
  50. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  51. @router.put("/update/{id}")
  52. async def update_pattern(
  53. id :str ,
  54. user_id=Depends(valid_access_token),
  55. body=Depends(remove_xss_json),
  56. db: Session = Depends(get_db)
  57. ):
  58. try:
  59. info = warehouse_room_id_get_warehouse_room_info(db,id)
  60. if not info:
  61. return JSONResponse(status_code=404,content={"code":404,"msg":"warehouse room not found"})
  62. info.room_name = body['room_name']
  63. info.warehouse = body['warehouse_id']
  64. info.room_area = body['room_area']
  65. info.available_area = body['available_area']
  66. info.height = body['height']
  67. info.room_volume = body['room_volume']
  68. info.available_volume = body['available_volume']
  69. info.storage_type = body['storage_type']
  70. info.level = body['level']
  71. info.storage_type_code = body['storage_type_code']
  72. info.last_inventory_time = body['last_inventory_time']
  73. info.update_by = user_id
  74. db.commit()
  75. return {"code": 200, "msg": "更新成功"}
  76. except Exception as e:
  77. traceback.print_exc()
  78. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  79. @router.get("/info/{id}")
  80. async def get_pattern_info(
  81. id: str,
  82. db: Session = Depends(get_db)
  83. ):
  84. try:
  85. info = warehouse_room_id_get_warehouse_room_info(db,id)
  86. if not info:
  87. return JSONResponse(status_code=404,content={"code":404,"msg":"warehouse room not found"})
  88. warehouse_info = warehouse_id_get_warehouse_info(db,info.warehouse)
  89. print(info.warehouse,warehouse_info)
  90. if warehouse_info:
  91. warehouse_name = warehouse_info.warehouse_name
  92. else:
  93. warehouse_name = None
  94. data = {
  95. "id":info.id,
  96. "warehouse_id": info.warehouse,
  97. "warehouse_name": warehouse_name,
  98. "room_name": info.room_name,
  99. "room_area": info.room_area,
  100. "available_area": info.available_area,
  101. "height": info.height,
  102. "room_volume": info.room_volume,
  103. "available_volume": info.available_volume,
  104. "storage_type": info.storage_type,
  105. "level": info.level,
  106. "storage_type_code": info.storage_type_code,
  107. "last_inventory_time": info.last_inventory_time,
  108. "create_time":info.create_time}
  109. return {"code": 200, "msg": "获取成功", "data": data}
  110. except Exception as e:
  111. traceback.print_exc()
  112. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  113. @router.get("/list")
  114. async def get_pattern_list(
  115. warehouse_id: str = Query(None, description='名称'),
  116. page: int = Query(1, gt=0, description='页码'),
  117. pageSize: int = Query(100, gt=0, description='每页条目数量'),
  118. db: Session = Depends(get_db)
  119. ):
  120. try:
  121. query = db.query(ResourceProvisionWarehouseRoomInfo)
  122. query = query.filter_by(del_flag='0')
  123. if warehouse_id:
  124. query = query.filter(ResourceProvisionWarehouseInfo.warehouse_id==warehouse_id)
  125. total_items = query.count()
  126. # 排序
  127. query = query.order_by(ResourceProvisionWarehouseRoomInfo.create_time.desc())
  128. # 执行分页查询
  129. lists = query.offset((page - 1) * pageSize).limit(pageSize).all()
  130. data = []
  131. for info in lists:
  132. warehouse_info = warehouse_id_get_warehouse_info(db, info.warehouse)
  133. if warehouse_info:
  134. warehouse_name = warehouse_info.warehouse_name
  135. else:
  136. warehouse_name = None
  137. data.append({
  138. "id":info.id,
  139. "warehouse_id": info.warehouse,
  140. "warehouse_name": warehouse_name,
  141. "room_name": info.room_name,
  142. "room_area": info.room_area,
  143. "available_area": info.available_area,
  144. "height": info.height,
  145. "room_volume": info.room_volume,
  146. "available_volume": info.available_volume,
  147. "storage_type": info.storage_type,
  148. "level": info.level,
  149. "storage_type_code": info.storage_type_code,
  150. "last_inventory_time": info.last_inventory_time,
  151. "create_time":info.create_time} )
  152. return {"code": 200, "msg": "查询成功", "data": data,
  153. "total": total_items,
  154. "page": page,
  155. "pageSize": pageSize,
  156. "totalPages": (total_items + pageSize - 1) // pageSize
  157. }
  158. except Exception as e:
  159. traceback.print_exc()
  160. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  161. @router.delete("/delete/{id}")
  162. async def delete_pattern(
  163. id: str,
  164. db: Session = Depends(get_db)
  165. ):
  166. try:
  167. # 检查图案是否存在
  168. info = warehouse_room_id_get_warehouse_room_info(db, id)
  169. if not info:
  170. return JSONResponse(status_code=404, content={"code": 404, "msg": "warehouse room not found"})
  171. info.del_flag='2'
  172. db.commit()
  173. return {"code": 200, "msg": "删除成功"}
  174. except Exception as e:
  175. traceback.print_exc()
  176. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  177. @router.get('/treeselect')
  178. async def gettreeselect(request: Request,room_name: str = Query(None, description='名称'),material_type_name: str = Query(None, description='名称'),db: Session = Depends(get_db), user_id: int = Depends(valid_access_token)):
  179. query = db.query(ResourceProvisionWarehouseInfo)
  180. query = query.filter_by(del_flag='0')
  181. query = query.filter_by(status='1')
  182. query = query.order_by(ResourceProvisionWarehouseInfo.create_time.desc())
  183. lists = query.all()
  184. data = []
  185. for info in lists:
  186. data_info = {"id": info.warehouse_id,
  187. "label": info.warehouse_name,
  188. "isWarehouse": True}
  189. # material_list = warehouse_id_get_material_list(db,info.warehouse_id)
  190. query1 = db.query(ResourceProvisionWarehouseRoomInfo)
  191. query1 = query1.filter_by(warehouse=info.warehouse_id, del_flag='0')
  192. if room_name:
  193. query1 = query1.filter(ResourceProvisionWarehouseRoomInfo.room_name.like(f'%{room_name}%'))
  194. room_list= query1.all()
  195. if room_list:
  196. data_info['children'] = []
  197. for room in room_list:
  198. data_info['children'].append({"id": room.id,
  199. "label": room.room_name,
  200. "warehouse_id": info.warehouse_id,
  201. "warehouse_name":info.warehouse_name,
  202. "isWarehouse": False})
  203. data.append(data_info)
  204. return {
  205. "code": 200,
  206. "msg": "操作成功",
  207. "data": data
  208. }