warehouse_inbound.py 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  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 pandas as pd
  22. import traceback
  23. router = APIRouter()
  24. @router.post("/create")
  25. async def create_pattern(
  26. user_id=Depends(valid_access_token),
  27. body = Depends(remove_xss_json),
  28. db: Session = Depends(get_db)
  29. ):
  30. try:
  31. new_inbound = ResourceProvisionInboundBasic(
  32. # id = new_guid(),
  33. warehouse_id=body['warehouse_id'],
  34. purchase_order_number=body['purchase_order_number'],
  35. is_donation=body['is_donation'],
  36. transport_order_number=body['transport_order_number'],
  37. donator_phone=body['donator_phone'],
  38. donator_name=body['donator_name'],
  39. reviewer=body['reviewer'],
  40. enterprise_name=body['enterprise_name'],
  41. enterprise_code=body['enterprise_code'],
  42. grading_info=body['grading_info'],
  43. type=body['type'],
  44. supplier_name=body['supplier_name'],
  45. remark=body['remark'],
  46. supplier_code=body['supplier_code'],
  47. completion_time=body['completion_time'],
  48. planned_completion_time=body['planned_completion_time'],
  49. room_id=body['room_id'],
  50. # inbound_order_number=body['inbound_order_number'],
  51. create_by = user_id
  52. )
  53. db.add(new_inbound)
  54. db.commit()
  55. new_inbound.inbound_order_number= f'{time.strftime("%Y%m%d", time.localtime())}1{str(new_inbound.id).zfill(7)}'
  56. filePath = f'/data/upload/mergefile/uploads/{body["filename"]}'
  57. movementData = pd.read_excel(filePath).to_dict(orient='records')
  58. create_movement(db, movementData, new_inbound.inbound_order_number, 'I', user_id)
  59. db.commit()
  60. return {"code": 200, "msg": "创建成功", "data": None}
  61. except Exception as e:
  62. traceback.print_exc()
  63. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  64. # @router.put("/update/{id}")
  65. # async def update_pattern(
  66. # id :str ,
  67. # user_id=Depends(valid_access_token),
  68. # body=Depends(remove_xss_json),
  69. # db: Session = Depends(get_db)
  70. # ):
  71. # try:
  72. # info = warehouse_room_id_get_warehouse_room_info(db,id)
  73. # if not info:
  74. # return JSONResponse(status_code=404,content={"code":404,"msg":"warehouse room not found"})
  75. # info.room_name = body['room_name']
  76. # info.warehouse = body['warehouse_id']
  77. # info.room_area = body['room_area']
  78. # info.available_area = body['available_area']
  79. # info.height = body['height']
  80. # info.room_volume = body['room_volume']
  81. # info.available_volume = body['available_volume']
  82. # info.storage_type = body['storage_type']
  83. # info.level = body['level']
  84. # info.storage_type_code = body['storage_type_code']
  85. # info.last_inventory_time = body['last_inventory_time']
  86. # info.update_by = user_id
  87. # db.commit()
  88. # return {"code": 200, "msg": "更新成功"}
  89. # except Exception as e:
  90. # traceback.print_exc()
  91. # raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  92. @router.get("/info/{id}")
  93. async def get_pattern_info(
  94. id: str,
  95. db: Session = Depends(get_db)
  96. ):
  97. try:
  98. info = inbound_id_get_inbound_info(db,id)
  99. if not info:
  100. return JSONResponse(status_code=404,content={"code":404,"msg":"warehouse room not found"})
  101. warehouse_info = warehouse_id_get_warehouse_info(db,info.warehouse_id)
  102. if warehouse_info:
  103. warehouse_name = warehouse_info.warehouse_name
  104. else:
  105. warehouse_name = None
  106. room_info = warehouse_room_id_get_warehouse_room_info(db,info.room_id)
  107. if room_info:
  108. room_name = room_info.room_name
  109. else:
  110. room_name = None
  111. data = {
  112. "id":info.id,
  113. "warehouse_id": info.warehouse_id,
  114. "warehouse_name": warehouse_name,
  115. "room_id": info.room_id,
  116. "room_name": room_name,
  117. "purchase_order_number": info.purchase_order_number,
  118. "is_donation": info.is_donation,
  119. "transport_order_number": info.transport_order_number,
  120. "donator_phone": info.donator_phone,
  121. "donator_name": info.donator_name,
  122. "reviewer": info.reviewer,
  123. "grading_info": info.grading_info,
  124. "enterprise_name": info.enterprise_name,
  125. "enterprise_code": info.enterprise_code,
  126. "type": info.type,
  127. "supplier_name": info.supplier_name,
  128. "creation_time": info.creation_time,
  129. "remark": info.remark,
  130. "supplier_code": info.supplier_code,
  131. "completion_time": info.completion_time,
  132. "inbound_order_number":info.inbound_order_number,
  133. "new_time":info.new_time,
  134. "create_time":info.create_time}
  135. return {"code": 200, "msg": "获取成功", "data": data}
  136. except Exception as e:
  137. traceback.print_exc()
  138. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  139. @router.get("/list")
  140. async def get_pattern_list(
  141. # warehouse_id: str = Query(None, description='名称'),
  142. page: int = Query(1, gt=0, description='页码'),
  143. pageSize: int = Query(100, gt=0, description='每页条目数量'),
  144. db: Session = Depends(get_db)
  145. ):
  146. try:
  147. query = db.query(ResourceProvisionInboundBasic)
  148. query = query.filter_by(del_flag='0')
  149. # if warehouse_id:
  150. # query = query.filter(ResourceProvisionWarehouseInfo.warehouse_id==warehouse_id)
  151. total_items = query.count()
  152. # 排序
  153. query = query.order_by(ResourceProvisionInboundBasic.create_time.desc())
  154. # 执行分页查询
  155. lists = query.offset((page - 1) * pageSize).limit(pageSize).all()
  156. data = []
  157. for info in lists:
  158. warehouse_info = warehouse_id_get_warehouse_info(db, info.warehouse_id)
  159. if warehouse_info:
  160. warehouse_name = warehouse_info.warehouse_name
  161. else:
  162. warehouse_name = None
  163. room_info = warehouse_room_id_get_warehouse_room_info(db, info.room_id)
  164. if room_info:
  165. room_name = room_info.room_name
  166. else:
  167. room_name = None
  168. data.append({
  169. "id":info.id,
  170. "warehouse_id": info.warehouse_id,
  171. "warehouse_name": warehouse_name,
  172. "room_id": info.room_id,
  173. "room_name": room_name,
  174. "purchase_order_number": info.purchase_order_number,
  175. "is_donation": info.is_donation,
  176. "transport_order_number": info.transport_order_number,
  177. "donator_phone": info.donator_phone,
  178. "donator_name": info.donator_name,
  179. "reviewer": info.reviewer,
  180. "grading_info": info.grading_info,
  181. "enterprise_name": info.enterprise_name,
  182. "enterprise_code": info.enterprise_code,
  183. "type": info.type,
  184. "supplier_name": info.supplier_name,
  185. "creation_time": info.creation_time,
  186. "remark": info.remark,
  187. "supplier_code": info.supplier_code,
  188. "completion_time": info.completion_time,
  189. "inbound_order_number":info.inbound_order_number,
  190. "new_time":info.new_time,
  191. "create_time":info.create_time} )
  192. return {"code": 200, "msg": "查询成功", "data": data,
  193. "total": total_items,
  194. "page": page,
  195. "pageSize": pageSize,
  196. "totalPages": (total_items + pageSize - 1) // pageSize
  197. }
  198. except Exception as e:
  199. traceback.print_exc()
  200. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  201. # @router.delete("/delete/{id}")
  202. # async def delete_pattern(
  203. # id: str,
  204. # db: Session = Depends(get_db)
  205. # ):
  206. # try:
  207. # # 检查图案是否存在
  208. # info = warehouse_room_id_get_warehouse_room_info(db, id)
  209. # if not info:
  210. # return JSONResponse(status_code=404, content={"code": 404, "msg": "warehouse room not found"})
  211. # info.del_flag='2'
  212. # db.commit()
  213. # return {"code": 200, "msg": "删除成功"}
  214. # except Exception as e:
  215. # traceback.print_exc()
  216. # raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")