procurement.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322
  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. dept_info = user_id_get_user_info(db,user_id)
  31. new_declaration = ResourceProvisionProcurementDeclaration(
  32. id = new_guid(),
  33. declaration_amount=body['declaration_amount'],
  34. declaration_person=user_id,
  35. declaration_unit=dept_info.dept_id,
  36. declaration_details = '1',
  37. create_by = user_id
  38. )
  39. db.add(new_declaration)
  40. for info in body['detail']:
  41. new_detail = ResourceProvisionProcurementDeclarationDetail(
  42. id=new_guid(),
  43. serial_number=info['serial_number'],
  44. declaration_id = new_declaration.id,
  45. warehouse_id = info['warehouse_id'],
  46. material_type = info['material_type'],
  47. material_code = info['material_code'],
  48. material_quantity = info['material_quantity'],
  49. material_unit_price = info['material_unit_price'],
  50. material_purpose = info['material_purpose'],
  51. create_by = user_id
  52. )
  53. db.add(new_detail)
  54. db.commit()
  55. return {"code": 200, "msg": "创建成功", "data": None}
  56. except Exception as e:
  57. traceback.print_exc()
  58. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  59. @router.put("/update/{id}")
  60. async def update_pattern(
  61. id :str ,
  62. user_id=Depends(valid_access_token),
  63. body=Depends(remove_xss_json),
  64. db: Session = Depends(get_db)
  65. ):
  66. try:
  67. update_declaration = declaration_id_get_declaration_info(db,id)
  68. if not update_declaration:
  69. return JSONResponse(status_code=404,content={"code":404,"msg":"declaration not found"})
  70. if str(update_declaration.declaration_person) != str(user_id):
  71. return JSONResponse(status_code=404, content={"code": 404, "msg": "declaration not permission"})
  72. update_declaration.declaration_amount = body['declaration_amount']
  73. update_declaration.update_by = user_id
  74. detail_list = []
  75. for info in body['detail']:
  76. if info['id']=='':
  77. new_detail = ResourceProvisionProcurementDeclarationDetail(
  78. id=new_guid(),
  79. serial_number=info['serial_number'],
  80. declaration_id=update_declaration.id,
  81. warehouse_id = info['warehouse_id'],
  82. material_type=info['material_type'],
  83. material_code=info['material_code'],
  84. material_quantity=info['material_quantity'],
  85. material_unit_price=info['material_unit_price'],
  86. material_purpose=info['material_purpose'],
  87. create_by=user_id
  88. )
  89. db.add(new_detail)
  90. detail_list.append(new_detail.id)
  91. else:
  92. detail = detail_id_get_declaration_detail_info(db,info['id'])
  93. if detail is None:
  94. new_detail = ResourceProvisionProcurementDeclarationDetail(
  95. id=new_guid(),
  96. serial_number=info['serial_number'],
  97. declaration_id=update_declaration.id,
  98. warehouse_id = info['warehouse_id'],
  99. material_type=info['material_type'],
  100. material_code=info['material_code'],
  101. material_quantity=info['material_quantity'],
  102. material_unit_price=info['material_unit_price'],
  103. material_purpose=info['material_purpose'],
  104. create_by=user_id
  105. )
  106. db.add(new_detail)
  107. detail_list.append(new_detail.id)
  108. else:
  109. detail.serial_number = info['serial_number']
  110. detail.warehouse_id = info['warehouse_id']
  111. detail.material_type = info['material_type']
  112. detail.material_code = info['material_code']
  113. detail.material_quantity = info['material_quantity']
  114. detail.material_unit_price = info['material_unit_price']
  115. detail.material_purpose = info['material_purpose']
  116. detail.update_by = user_id
  117. detail_list.append(info['id'])
  118. query = db.query(ResourceProvisionProcurementDeclarationDetail)
  119. query = query.filter_by(declaration_id=id, del_flag='0').filter(~ResourceProvisionProcurementDeclarationDetail.id.in_(detail_list))
  120. for i in query.all():
  121. i.del_flag='2'
  122. db.commit()
  123. return {"code": 200, "msg": "更新成功"}
  124. except Exception as e:
  125. traceback.print_exc()
  126. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  127. @router.get("/info/{id}")
  128. async def get_pattern_info(
  129. id: str,
  130. db: Session = Depends(get_db)
  131. ):
  132. try:
  133. info = declaration_id_get_declaration_info(db,id)
  134. if not info:
  135. return JSONResponse(status_code=404,content={"code":404,"msg":"type not found"})
  136. dept_info = dept_id_get_dept_info(db,info.declaration_unit)
  137. user_info = user_id_get_user_info(db,info.declaration_person)
  138. review_info = declaration_id_get_declaration_review_info(db,id)
  139. if review_info is None:
  140. declaration_details = info.declaration_details
  141. else:
  142. declaration_details = review_info.review_result
  143. data = {"id": info.id,
  144. "declaration_date": info.declaration_date,
  145. "declaration_amount": info.declaration_amount,
  146. "declaration_unit": info.declaration_unit,
  147. "declaration_unit_name": dept_info.dept_name,
  148. "declaration_person": info.declaration_person,
  149. "declaration_person_name": user_info.nick_name,
  150. "declaration_details": declaration_details,
  151. "create_time": info.create_time}
  152. detail=[]
  153. for detail_info in declaration_id_get_declaration_detail_list(db,id):
  154. material_type_info = type_id_get_material_type_info(db,detail_info.material_type)
  155. material_into = material_id_get_material_info(db,detail_info.material_code)
  156. warehouse_info = warehouse_id_get_warehouse_info(db,detail_info.warehouse_id)
  157. detail.append({"id":detail_info.id,
  158. "serial_number":detail_info.serial_number,
  159. "warehouse_id":detail_info.warehouse_id,
  160. "warehouse_name":warehouse_info.warehouse_name,
  161. "material_type":detail_info.material_type,
  162. "material_category_name":material_type_info.material_category_name,
  163. "material_code":detail_info.material_code,
  164. "material_name":material_into.material_name,
  165. "material_quantity":detail_info.material_quantity,
  166. "material_unit_price":detail_info.material_unit_price,
  167. "material_purpose":detail_info.material_purpose})
  168. data['detail']=detail
  169. return {"code": 200, "msg": "获取成功", "data": data}
  170. except Exception as e:
  171. traceback.print_exc()
  172. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  173. @router.get("/list")
  174. async def get_pattern_list(
  175. # declaration_details: str = Query(None, description='名称'),
  176. page: int = Query(1, gt=0, description='页码'),
  177. pageSize: int = Query(None, gt=0, description='每页条目数量'),
  178. db: Session = Depends(get_db)
  179. ):
  180. try:
  181. query = db.query(ResourceProvisionProcurementDeclaration)
  182. query = query.filter_by(del_flag='0')
  183. # if declaration_details:
  184. # query = query.filter(ResourceProvisionProcurementDeclaration.declaration_details==declaration_details)
  185. total_items = query.count()
  186. # 排序
  187. if pageSize is None:
  188. pageSize=total_items
  189. query = query.order_by(ResourceProvisionProcurementDeclaration.declaration_date.desc())
  190. # 执行分页查询
  191. lists = query.offset((page - 1) * pageSize).limit(pageSize).all()
  192. data = []
  193. for info in lists:
  194. dept_info = dept_id_get_dept_info(db, info.declaration_unit)
  195. user_info = user_id_get_user_info(db, info.declaration_person)
  196. review_info = declaration_id_get_declaration_review_info(db, info.id)
  197. if review_info is None:
  198. declaration_details = info.declaration_details
  199. else:
  200. declaration_details = review_info.review_result
  201. data .append( {"id": info.id,
  202. "declaration_date": info.declaration_date,
  203. "declaration_amount": info.declaration_amount,
  204. "declaration_unit": info.declaration_unit,
  205. "declaration_unit_name": dept_info.dept_name,
  206. "declaration_person": info.declaration_person,
  207. "declaration_person_name": user_info.nick_name,
  208. "declaration_details": declaration_details,
  209. "create_time": info.create_time})
  210. return {"code": 200, "msg": "查询成功", "data": data,
  211. "total": total_items,
  212. "page": page,
  213. "pageSize": pageSize,
  214. "totalPages": (total_items + pageSize - 1) // pageSize
  215. }
  216. except Exception as e:
  217. traceback.print_exc()
  218. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  219. # @router.delete("/delete/{id}")
  220. # async def delete_pattern(
  221. # id: str,
  222. # db: Session = Depends(get_db)
  223. # ):
  224. # try:
  225. # # 检查图案是否存在
  226. # info = declaration_id_get_declaration_info(db, id)
  227. # if not info:
  228. # return JSONResponse(status_code=404, content={"code": 404, "msg": "type not found"})
  229. # info.del_flag='2'
  230. # review_info = declaration_id_get_declaration_review_info(db, id)
  231. # review_info.del_flag ='2'
  232. # for detail_info in declaration_id_get_declaration_detail_list(db, id):
  233. # detail_info.del_flag='2'
  234. # db.commit()
  235. # return {"code": 200, "msg": "删除成功"}
  236. # except Exception as e:
  237. # traceback.print_exc()
  238. # raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  239. @router.post("/review")
  240. async def create_pattern(
  241. user_id=Depends(valid_access_token),
  242. body = Depends(remove_xss_json),
  243. db: Session = Depends(get_db)
  244. ):
  245. try:
  246. new_review = ResourceProvisionProcurementReview(
  247. id=new_guid(),
  248. reviewer=user_id,
  249. declaration_id=body['declaration_id'],
  250. review_result=body['review_result'],
  251. review_comments=body['review_comments'],
  252. create_by = user_id
  253. )
  254. db.add(new_review)
  255. db.commit()
  256. return {"code": 200, "msg": "审核成功", "data": None}
  257. except Exception as e:
  258. traceback.print_exc()
  259. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  260. @router.get("/review/list")
  261. async def get_pattern_list(
  262. page: int = Query(1, gt=0, description='页码'),
  263. pageSize: int = Query(None, gt=0, description='每页条目数量'),
  264. db: Session = Depends(get_db)
  265. ):
  266. try:
  267. review_list = [info.declaration_id for info in get_declaration_review_list(db)]
  268. query = db.query(ResourceProvisionProcurementDeclaration)
  269. query = query.filter_by(del_flag='0')
  270. query = query.filter(~ResourceProvisionProcurementDeclaration.id.in_(review_list))
  271. total_items = query.count()
  272. # 排序
  273. if pageSize is None:
  274. pageSize=total_items
  275. query = query.order_by(ResourceProvisionProcurementDeclaration.declaration_date.desc())
  276. # 执行分页查询
  277. lists = query.offset((page - 1) * pageSize).limit(pageSize).all()
  278. data = []
  279. for info in lists:
  280. dept_info = dept_id_get_dept_info(db, info.declaration_unit)
  281. user_info = user_id_get_user_info(db, info.declaration_person)
  282. # review_info = declaration_id_get_declaration_review_info(db, info.id)
  283. # if review_info is None:
  284. # declaration_details = info.declaration_details
  285. # else:
  286. # declaration_details = review_info.review_result
  287. data = {"id": info.id,
  288. "declaration_date": info.declaration_date,
  289. "declaration_amount": info.declaration_amount,
  290. "declaration_unit": info.declaration_unit,
  291. "declaration_unit_name": dept_info.dept_name,
  292. "declaration_person": info.declaration_person,
  293. "declaration_person_name": user_info.user_name,
  294. "declaration_details": info.declaration_details,
  295. "create_time": info.create_time}
  296. return {"code": 200, "msg": "查询成功", "data": data,
  297. "total": total_items,
  298. "page": page,
  299. "pageSize": pageSize,
  300. "totalPages": (total_items + pageSize - 1) // pageSize
  301. }
  302. except Exception as e:
  303. traceback.print_exc()
  304. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")