procurement.py 15 KB

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