material.py 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730
  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,StreamingResponse
  6. from common.db import db_czrz
  7. from sqlalchemy.orm import Session
  8. from sqlalchemy.sql import func
  9. from common.auth_user import *
  10. from sqlalchemy import text
  11. from pydantic import BaseModel
  12. from common.BigDataCenterAPI import *
  13. from database import get_db
  14. from typing import List
  15. from models import *
  16. from utils import *
  17. from utils.spatial import *
  18. from utils.ry_system_util import *
  19. from utils.resource_provision_util import *
  20. from common.barcode import create_bar,create_qr
  21. import json
  22. import traceback
  23. import xlrd
  24. # 目录在文档上传接口写死
  25. UPLOAD_mergefile_PATH = '/data/upload/mergefile'
  26. router = APIRouter()
  27. @router.post("/create")
  28. async def create_pattern(
  29. user_id=Depends(valid_access_token),
  30. body = Depends(remove_xss_json),
  31. db: Session = Depends(get_db)
  32. ):
  33. try:
  34. new_material = ResourceProvisionMaterialInfo(
  35. # id = new_guid(),
  36. material_name=body['material_name'],
  37. warehouse_id=body['warehouse_id'],
  38. inventory=body['inventory'],
  39. specification=body['specification'],
  40. model=body['model'],
  41. category_name=body['category_name'],
  42. material_type=body['material_type_id'],
  43. unit_name=body['unit_name'],
  44. brand_name=body['brand_name'],
  45. length=body['length'],
  46. width=body['width'],
  47. height=body['height'],
  48. volume=body['volume'],
  49. gross_weight=body['gross_weight'],
  50. net_weight=body['net_weight'],
  51. manufacturer=body['manufacturer'],
  52. origin=body['origin'],
  53. status=body['status'],
  54. room_id=body['room_id'],
  55. package_quantity=body['package_quantity'],
  56. package_volume=body['package_volume'],
  57. package_weight=body['package_weight'],
  58. price=body['price'],
  59. selling_price=body['selling_price'],
  60. value=body['value'],
  61. cost_price=body['cost_price'],
  62. disaster_types=body['disaster_types'],
  63. maintenance=body['maintenance'],
  64. supplier_name=body['supplier_name'],
  65. special_transportation_requirements=body['special_transportation_requirements'],
  66. material=body['material'],
  67. shelf_life=body['shelf_life'],
  68. inventory_warning_pusher=body['inventory_warning_pusher'],
  69. inventory_warning_quantity=body['inventory_warning_quantity'],
  70. shelf_life_warning_days=body['shelf_life_warning_days'],
  71. shelf_life_warning_pusher=body['shelf_life_warning_pusher'],
  72. from_sys=body['from_sys'],
  73. create_by = user_id
  74. )
  75. db.add(new_material)
  76. new_file_list = body['fileList']
  77. db.commit()
  78. db.refresh(new_material)
  79. for file in new_file_list:
  80. file_name = file['url']
  81. file_name_desc = file['name']
  82. status = file['status']
  83. uid = file['uid']
  84. new_file = ResourceProvisionFile(
  85. file_id=uid,
  86. foreign_key=new_material.material_id,
  87. from_scenario='ResourceProvisionMaterialInfo',
  88. file_name=file_name,
  89. file_name_desc=file_name_desc,
  90. status=status
  91. )
  92. db.add(new_file)
  93. bar_fileanme = new_guid()+'.png'
  94. qr_fileanme = new_guid()+'.png'
  95. if create_bar(str(new_material.material_id),bar_fileanme) and create_qr(str(new_material.material_id),qr_fileanme):
  96. barcode = ResourceProvisionMaterialBarcode(
  97. id=new_guid(),
  98. material_code = new_material.material_id,
  99. barcode = bar_fileanme,
  100. qr_code = qr_fileanme
  101. )
  102. db.add(barcode)
  103. db.commit()
  104. return {"code": 200, "msg": "创建成功", "data": None}
  105. except Exception as e:
  106. traceback.print_exc()
  107. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  108. @router.put("/update/{id}")
  109. async def update_pattern(
  110. id :str ,
  111. user_id=Depends(valid_access_token),
  112. body=Depends(remove_xss_json),
  113. db: Session = Depends(get_db)
  114. ):
  115. try:
  116. info = material_id_get_material_info(db,id)
  117. if not info:
  118. return JSONResponse(status_code=404,content={"code":404,"msg":"warehouse room not found"})
  119. # info.room_name = body['room_name']
  120. info.material_name = body['material_name']
  121. info.warehouse_id = body['warehouse_id']
  122. info.inventory = body['inventory']
  123. info.specification = body['specification']
  124. info.model = body['model']
  125. info.category_name = body['category_name']
  126. info.material_type = body['material_type_id']
  127. info.unit_name = body['unit_name']
  128. info.brand_name = body['brand_name']
  129. info.length = body['length']
  130. info.width = body['width']
  131. info.height = body['height']
  132. info.volume = body['volume']
  133. info.gross_weight = body['gross_weight']
  134. info.net_weight = body['net_weight']
  135. info.manufacturer = body['manufacturer']
  136. info.origin = body['origin']
  137. info.status = body['status']
  138. info.room_id = body['room_id']
  139. info.package_quantity = body['package_quantity']
  140. info.package_volume = body['package_volume']
  141. info.package_weight = body['package_weight']
  142. info.price = body['price']
  143. info.selling_price = body['selling_price']
  144. info.value = body['value']
  145. info.cost_price = body['cost_price']
  146. info.disaster_types = body['disaster_types']
  147. info.maintenance = body['maintenance']
  148. info.supplier_name = body['supplier_name']
  149. info.special_transportation_requirements = body['special_transportation_requirements']
  150. info.material = body['material']
  151. info.shelf_life = body['shelf_life']
  152. info.inventory_warning_pusher = body['inventory_warning_pusher']
  153. info.inventory_warning_quantity = body['inventory_warning_quantity']
  154. info.shelf_life_warning_days = body['shelf_life_warning_days']
  155. info.shelf_life_warning_pusher = body['shelf_life_warning_pusher']
  156. info.from_sys = body['from_sys']
  157. info.update_by = user_id
  158. delete_resource_provision_file(db,'ResourceProvisionMaterialInfo',id)
  159. new_file_list = body['fileList']
  160. for file in new_file_list:
  161. file_name = file['url']
  162. file_name_desc = file['name']
  163. status = file['status']
  164. uid = file['uid']
  165. new_file = ResourceProvisionFile(
  166. file_id=uid,
  167. foreign_key=id,
  168. from_scenario='ResourceProvisionMaterialInfo',
  169. file_name=file_name,
  170. file_name_desc=file_name_desc,
  171. status=status
  172. )
  173. db.add(new_file)
  174. db.commit()
  175. return {"code": 200, "msg": "更新成功"}
  176. except Exception as e:
  177. traceback.print_exc()
  178. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  179. @router.get("/info/{id}")
  180. async def get_pattern_info(
  181. id: str,
  182. user_id=Depends(valid_access_token),
  183. db: Session = Depends(get_db)
  184. ):
  185. try:
  186. info = material_id_get_material_info(db,id)
  187. if not info:
  188. return JSONResponse(status_code=404,content={"code":404,"msg":"warehouse room not found"})
  189. warehouse_info = warehouse_id_get_warehouse_info(db,info.warehouse_id)
  190. if warehouse_info:
  191. warehouse_name = warehouse_info.warehouse_name
  192. else:
  193. warehouse_name=None
  194. material_type_info = type_id_get_material_type_info(db,info.material_type)
  195. if material_type_info:
  196. material_category_name = material_type_info.material_category_name
  197. else:
  198. material_category_name=None
  199. warehouse_room_info = warehouse_room_id_get_warehouse_room_info(db, info.room_id)
  200. if warehouse_room_info:
  201. room_name = warehouse_room_info.room_name
  202. else:
  203. room_name = None
  204. data = {
  205. "material_id": info.material_id,
  206. "material_name": info.material_name,
  207. "warehouse_id": info.warehouse_id,
  208. "warehouse_name": warehouse_name,
  209. "inventory": info.inventory,
  210. "specification": info.specification,
  211. "model": info.model,
  212. "category_name": info.category_name,
  213. "material_type_id": info.material_type,
  214. "material_type_name": material_category_name,
  215. "unit_name": info.unit_name,
  216. "brand_name": info.brand_name,
  217. "length": info.length,
  218. "width": info.width,
  219. "height": info.height,
  220. "volume": info.volume,
  221. "gross_weight": info.gross_weight,
  222. "net_weight": info.net_weight,
  223. "manufacturer": info.manufacturer,
  224. "origin": info.origin,
  225. "status": info.status,
  226. "room_id": info.room_id,
  227. "room_name":room_name,
  228. "package_quantity": info.package_quantity,
  229. "package_volume": info.package_volume,
  230. "package_weight": info.package_weight,
  231. "price": info.price,
  232. "selling_price": info.selling_price,
  233. "value": info.value,
  234. "cost_price": info.cost_price,
  235. "disaster_types": info.disaster_types,
  236. "maintenance": info.maintenance,
  237. "supplier_name": info.supplier_name,
  238. "special_transportation_requirements": info.special_transportation_requirements,
  239. "material": info.material,
  240. "shelf_life": info.shelf_life,
  241. "inventory_warning_pusher": info.inventory_warning_pusher,
  242. "inventory_warning_quantity": info.inventory_warning_quantity,
  243. "shelf_life_warning_days": info.shelf_life_warning_days,
  244. "shelf_life_warning_pusher": info.shelf_life_warning_pusher,
  245. "from_sys": info.from_sys,
  246. "create_time":info.create_time,
  247. "fileList": get_resource_provision_file_query_fun(db=db,from_scenario='ResourceProvisionMaterialInfo', foreign_key=info.material_id)}
  248. return {"code": 200, "msg": "获取成功", "data": data}
  249. except Exception as e:
  250. traceback.print_exc()
  251. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  252. @router.get("/list")
  253. async def get_pattern_list(
  254. user_id=Depends(valid_access_token),
  255. material_id: str = Query(None, description='名称'),
  256. material_name: str = Query(None, description='名称'),
  257. warehouse_id: str = Query(None, description='名称'),
  258. from_sys: str = Query(None, description='名称'),
  259. page: int = Query(1, gt=0, description='页码'),
  260. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  261. db: Session = Depends(get_db)
  262. ):
  263. try:
  264. query = db.query(ResourceProvisionMaterialInfo)
  265. query = query.filter_by(del_flag='0')
  266. if material_id:
  267. query = query.filter(ResourceProvisionMaterialInfo.material_id.like(f'%{material_id}%'))
  268. if material_name:
  269. query = query.filter(ResourceProvisionMaterialInfo.material_name.like(f'%{material_name}%'))
  270. if warehouse_id:
  271. query = query.filter(ResourceProvisionMaterialInfo.warehouse_id==warehouse_id)
  272. if from_sys:
  273. query = query.filter(ResourceProvisionMaterialInfo.from_sys==from_sys)
  274. total_items = query.count()
  275. # 排序
  276. query = query.order_by(ResourceProvisionMaterialInfo.create_time.desc())
  277. # 执行分页查询
  278. lists = query.offset((page - 1) * pageSize).limit(pageSize).all()
  279. data = []
  280. for info in lists:
  281. warehouse_info = warehouse_id_get_warehouse_info(db, info.warehouse_id)
  282. if warehouse_info:
  283. warehouse_name = warehouse_info.warehouse_name
  284. else:
  285. warehouse_name = None
  286. material_type_info = type_id_get_material_type_info(db, info.material_type)
  287. if material_type_info:
  288. material_category_name = material_type_info.material_category_name
  289. else:
  290. material_category_name = None
  291. warehouse_room_info = warehouse_room_id_get_warehouse_room_info(db, info.room_id)
  292. if warehouse_room_info:
  293. room_name = warehouse_room_info.room_name
  294. else:
  295. room_name = None
  296. data.append({
  297. "material_id": info.material_id,
  298. "material_name": info.material_name,
  299. "warehouse_id": info.warehouse_id,
  300. "warehouse_name": warehouse_name,
  301. "inventory": info.inventory,
  302. "specification": info.specification,
  303. "model": info.model,
  304. "category_name": info.category_name,
  305. "material_type_id": info.material_type,
  306. "material_type_name": material_category_name,
  307. "unit_name": info.unit_name,
  308. "brand_name": info.brand_name,
  309. "length": info.length,
  310. "width": info.width,
  311. "height": info.height,
  312. "volume": info.volume,
  313. "gross_weight": info.gross_weight,
  314. "net_weight": info.net_weight,
  315. "manufacturer": info.manufacturer,
  316. "origin": info.origin,
  317. "status": info.status,
  318. "room_id": info.room_id,
  319. "room_name":room_name,
  320. "package_quantity": info.package_quantity,
  321. "package_volume": info.package_volume,
  322. "package_weight": info.package_weight,
  323. "price": info.price,
  324. "selling_price": info.selling_price,
  325. "value": info.value,
  326. "cost_price": info.cost_price,
  327. "disaster_types": info.disaster_types,
  328. "maintenance": info.maintenance,
  329. "supplier_name": info.supplier_name,
  330. "special_transportation_requirements": info.special_transportation_requirements,
  331. "material": info.material,
  332. "shelf_life": info.shelf_life,
  333. "inventory_warning_pusher": info.inventory_warning_pusher,
  334. "inventory_warning_quantity": info.inventory_warning_quantity,
  335. "shelf_life_warning_days": info.shelf_life_warning_days,
  336. "shelf_life_warning_pusher": info.shelf_life_warning_pusher,
  337. "from_sys": info.from_sys,
  338. "create_time":info.create_time,
  339. "fileList": get_resource_provision_file_query_fun(db=db,from_scenario='ResourceProvisionMaterialInfo', foreign_key=info.material_id)})
  340. return {"code": 200, "msg": "查询成功", "data": data,
  341. "total": total_items,
  342. "page": page,
  343. "pageSize": pageSize,
  344. "totalPages": (total_items + pageSize - 1) // pageSize
  345. }
  346. except Exception as e:
  347. traceback.print_exc()
  348. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  349. @router.get("/list")
  350. async def get_pattern_list(
  351. request: Request,
  352. user_id=Depends(valid_access_token),
  353. material_id: str = Query(None, description='名称'),
  354. material_name: str = Query(None, description='名称'),
  355. warehouse_id: str = Query(None, description='名称'),
  356. from_sys: str = Query(None, description='名称'),
  357. auth_user: AuthUser = Depends(find_auth_user),
  358. db: Session = Depends(get_db)
  359. ):
  360. try:
  361. query = db.query(ResourceProvisionMaterialInfo)
  362. query = query.filter_by(del_flag='0')
  363. if material_id:
  364. query = query.filter(ResourceProvisionMaterialInfo.material_id.like(f'%{material_id}%'))
  365. if material_name:
  366. query = query.filter(ResourceProvisionMaterialInfo.material_name.like(f'%{material_name}%'))
  367. if warehouse_id:
  368. query = query.filter(ResourceProvisionMaterialInfo.warehouse_id==warehouse_id)
  369. if from_sys:
  370. query = query.filter(ResourceProvisionMaterialInfo.from_sys==from_sys)
  371. # 排序
  372. query = query.order_by(ResourceProvisionMaterialInfo.create_time.desc())
  373. # 执行分页查询
  374. lists = query.all()
  375. data = []
  376. for info in lists:
  377. warehouse_info = warehouse_id_get_warehouse_info(db, info.warehouse_id)
  378. if warehouse_info:
  379. warehouse_name = warehouse_info.warehouse_name
  380. else:
  381. warehouse_name = None
  382. material_type_info = type_id_get_material_type_info(db, info.material_type)
  383. if material_type_info:
  384. material_category_name = material_type_info.material_category_name
  385. else:
  386. material_category_name = None
  387. warehouse_room_info = warehouse_room_id_get_warehouse_room_info(db, info.room_id)
  388. if warehouse_room_info:
  389. room_name = warehouse_room_info.room_name
  390. else:
  391. room_name = None
  392. data.append({
  393. "物资编码": info.material_id,
  394. "物资名称": info.material_name,
  395. "仓库id": info.warehouse_id,
  396. "仓库": warehouse_name,
  397. "库存": info.inventory,
  398. "规格": info.specification,
  399. "型号": info.model,
  400. "分类名称": info.category_name,
  401. "物资类型id": info.material_type,
  402. "物资类型": material_category_name,
  403. "计量单位名称": info.unit_name,
  404. "品牌名称": info.brand_name,
  405. "长(厘米)": info.length,
  406. "宽(厘米)": info.width,
  407. "高(厘米)": info.height,
  408. "体积(立方厘米)": info.volume,
  409. "毛重(kg)": info.gross_weight,
  410. "净重(kg)": info.net_weight,
  411. "生产厂商": info.manufacturer,
  412. "产地": info.origin,
  413. "状态": info.status,
  414. "库房id": info.room_id,
  415. "库房":room_name,
  416. "包装数量": info.package_quantity,
  417. "包装体积(立方厘米)": info.package_volume,
  418. "包装重量(kg)": info.package_weight,
  419. "价格": info.price,
  420. "售卖价格": info.selling_price,
  421. "价值": info.value,
  422. "成本价格": info.cost_price,
  423. "适用灾种": info.disaster_types,
  424. "使用保养": info.maintenance,
  425. "供应商名称": info.supplier_name,
  426. "特殊运输要求": info.special_transportation_requirements,
  427. "材质": info.material,
  428. "保质期": info.shelf_life,
  429. "库存预警推送人": info.inventory_warning_pusher,
  430. "库存预警数量": info.inventory_warning_quantity,
  431. "保质期到期预警天数": info.shelf_life_warning_days,
  432. "保质期预警推送人": info.shelf_life_warning_pusher,
  433. "来源系统": info.from_sys,
  434. "数据创建时间":info.create_time})
  435. # "fileList": get_resource_provision_file_query_fun(db=db,from_scenario='ResourceProvisionMaterialInfo', foreign_key=info.material_id)})
  436. # 返回结果
  437. import pandas as pd
  438. from io import BytesIO
  439. # 将查询结果转换为 DataFrame
  440. df = pd.DataFrame(data)
  441. # 将 DataFrame 导出为 Excel 文件
  442. output = BytesIO()
  443. with pd.ExcelWriter(output, engine='openpyxl') as writer:
  444. df.to_excel(writer, index=False)
  445. # 设置响应头
  446. output.seek(0)
  447. from urllib.parse import quote
  448. encoded_filename = f'物资明细{datetime.now().strftime("%Y%m%d%H%mi%s")}.xlsx'
  449. encoded_filename = quote(encoded_filename, encoding='utf-8')
  450. headers = {
  451. 'Content-Disposition': f'attachment; filename*=UTF-8\'\'{encoded_filename}',
  452. 'Content-Type': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
  453. }
  454. db_czrz.log(db, auth_user, "物资储备管理", f"物资储备管理物资明细导出数据成功", request.client.host)
  455. # 返回文件流
  456. return StreamingResponse(output, headers=headers)
  457. except Exception as e:
  458. traceback.print_exc()
  459. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  460. @router.delete("/delete/{id}")
  461. async def delete_pattern(
  462. id: str,
  463. user_id=Depends(valid_access_token),
  464. db: Session = Depends(get_db)
  465. ):
  466. try:
  467. # 检查图案是否存在
  468. info = material_id_get_material_info(db, id)
  469. if not info:
  470. return JSONResponse(status_code=404, content={"code": 404, "msg": "warehouse room not found"})
  471. bar_info = material_id_get_material_barcode_info(db,id)
  472. info.del_flag='2'
  473. if bar_info is not None:
  474. bar_info.del_flag = '2'
  475. delete_resource_provision_file(db, 'ResourceProvisionMaterialInfo', id)
  476. db.commit()
  477. return {"code": 200, "msg": "删除成功"}
  478. except Exception as e:
  479. traceback.print_exc()
  480. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  481. @router.get("/barcode/list")
  482. async def get_pattern_list(
  483. user_id=Depends(valid_access_token),
  484. name: str = Query(None, description='名称'),
  485. page: int = Query(1, gt=0, description='页码'),
  486. pageSize: int = Query(None, gt=0, description='每页条目数量'),
  487. db: Session = Depends(get_db)
  488. ):
  489. try:
  490. material_code_list=None
  491. if name:
  492. query_1 = db.query(ResourceProvisionMaterialInfo.material_id)
  493. query_1 = query_1.filter(ResourceProvisionMaterialInfo.del_flag=='0')
  494. query_1 = query_1.filter(ResourceProvisionMaterialInfo.material_name.like(f'%{name}%'))
  495. material_code_list =[i.material_id for i in query_1.all()]
  496. query = db.query(ResourceProvisionMaterialBarcode)
  497. query = query.filter_by(del_flag='0')
  498. if material_code_list is not None:
  499. query = query.filter(ResourceProvisionMaterialBarcode.material_code.in_(material_code_list))
  500. total_items = query.count()
  501. # 排序
  502. if pageSize is None:
  503. pageSize=total_items
  504. query = query.order_by(ResourceProvisionMaterialBarcode.create_time.desc())
  505. # 执行分页查询
  506. lists = query.offset((page - 1) * pageSize).limit(pageSize).all()
  507. data = []
  508. for info in lists:
  509. material_info = material_id_get_material_info(db, info.material_code)
  510. data.append({"id": info.id,
  511. "material_name": material_info.material_name,
  512. "material_code": info.material_code,
  513. "barcode": info.barcode,
  514. "qr_code": info.qr_code,
  515. "status": info.status,
  516. "create_time": info.create_time} )
  517. return {"code": 200, "msg": "查询成功", "data": data,
  518. "total": total_items,
  519. "page": page,
  520. "pageSize": pageSize,
  521. "totalPages": (total_items + pageSize - 1) // pageSize
  522. }
  523. except Exception as e:
  524. traceback.print_exc()
  525. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  526. @router.get("/barcode/export")
  527. async def get_pattern_list(
  528. request: Request,
  529. user_id=Depends(valid_access_token),
  530. name: str = Query(None, description='名称'),
  531. auth_user: AuthUser = Depends(find_auth_user),
  532. db: Session = Depends(get_db)
  533. ):
  534. try:
  535. material_code_list=None
  536. if name:
  537. query_1 = db.query(ResourceProvisionMaterialInfo.material_id)
  538. query_1 = query_1.filter(ResourceProvisionMaterialInfo.del_flag=='0')
  539. query_1 = query_1.filter(ResourceProvisionMaterialInfo.material_name.like(f'%{name}%'))
  540. material_code_list =[i.material_id for i in query_1.all()]
  541. query = db.query(ResourceProvisionMaterialBarcode)
  542. query = query.filter_by(del_flag='0')
  543. if material_code_list is not None:
  544. query = query.filter(ResourceProvisionMaterialBarcode.material_code.in_(material_code_list))
  545. total_items = query.count()
  546. # 排序
  547. query = query.order_by(ResourceProvisionMaterialBarcode.create_time.desc())
  548. # 执行分页查询
  549. lists = query.all()
  550. data = []
  551. for info in lists:
  552. material_info = material_id_get_material_info(db, info.material_code)
  553. status = ""
  554. if info.status == "1":
  555. status = '启用'
  556. else:
  557. status='禁用'
  558. data.append({"id": info.id,
  559. "物资名称": material_info.material_name,
  560. "物资编号": info.material_code,
  561. "条形码": 'http://120.241.74.139:8086/api/file/get_img/get_img_by_id/'+info.barcode,
  562. "二维码": 'http://120.241.74.139:8086/api/file/get_img/get_img_by_id/'+info.qr_code,
  563. "条码状态": status,
  564. "创建时间": info.create_time} )
  565. # 返回结果
  566. import pandas as pd
  567. from io import BytesIO
  568. # 将查询结果转换为 DataFrame
  569. df = pd.DataFrame(data)
  570. # 将 DataFrame 导出为 Excel 文件
  571. output = BytesIO()
  572. with pd.ExcelWriter(output, engine='openpyxl') as writer:
  573. df.to_excel(writer, index=False)
  574. # 设置响应头
  575. output.seek(0)
  576. from urllib.parse import quote
  577. encoded_filename = f'条码管理{datetime.now().strftime("%Y%m%d%H%mi%s")}.xlsx'
  578. encoded_filename = quote(encoded_filename, encoding='utf-8')
  579. headers = {
  580. 'Content-Disposition': f'attachment; filename*=UTF-8\'\'{encoded_filename}',
  581. 'Content-Type': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
  582. }
  583. db_czrz.log(db, auth_user, "物资储备管理", f"物资储备管理条码管理导出数据成功", request.client.host)
  584. # 返回文件流
  585. return StreamingResponse(output, headers=headers)
  586. except Exception as e:
  587. traceback.print_exc()
  588. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  589. @router.put('/barcode/changeStatus')
  590. async def change_barcode_status(
  591. db: Session = Depends(get_db),
  592. body=Depends(remove_xss_json),
  593. user_id=Depends(valid_access_token)
  594. ):
  595. try:
  596. barcode_id = body['id']
  597. status = body['status']
  598. info = material_barcode_id_get_material_barcode_info(db, barcode_id)
  599. if not info:
  600. return JSONResponse(status_code=404, content={"code": 404, "msg": "barcode not found"})
  601. info.status= status
  602. info.update_by=user_id
  603. db.commit()
  604. return {
  605. "code": 200,
  606. "msg": "操作成功"
  607. }
  608. except Exception as e:
  609. # 处理异常
  610. traceback.print_exc()
  611. raise HTTPException(status_code=500, detail=str(e))
  612. @router.get('/treeselect')
  613. async def gettreeselect(request: Request,material_name: str = Query(None, description='名称'),material_type_name: str = Query(None, description='名称'),db: Session = Depends(get_db), user_id: int = Depends(valid_access_token)):
  614. query = db.query(ResourceProvisionWarehouseInfo)
  615. query = query.filter_by(del_flag='0')
  616. query = query.filter_by(status='1')
  617. query = query.order_by(ResourceProvisionWarehouseInfo.create_time.desc())
  618. lists = query.all()
  619. data = []
  620. for info in lists:
  621. data_info = {"id": info.warehouse_id,
  622. "label": info.warehouse_name,
  623. "isWarehouse": True}
  624. # material_list = warehouse_id_get_material_list(db,info.warehouse_id)
  625. query1 = db.query(ResourceProvisionMaterialInfo)
  626. query1 = query1.filter_by(warehouse_id=info.warehouse_id, del_flag='0')
  627. if material_name:
  628. query1 = query1.filter_by(material_name=material_name)
  629. if material_type_name:
  630. query2 = db.query(ResourceProvisionMaterialType)
  631. query2 = query2.filter(ResourceProvisionMaterialType.material_category_name.like(f'%{material_type_name}%'), ResourceProvisionMaterialType.del_flag=='0')
  632. material_type_list = [str(material_type.id) for material_type in query2.all()]
  633. query1 = query1.filter(ResourceProvisionMaterialInfo.material_type.in_(material_type_list))
  634. material_list= query1.all()
  635. if material_list:
  636. data_info['children'] = []
  637. for material in material_list:
  638. type_info = type_id_get_material_type_info(db,material.material_type)
  639. material_category_name = None
  640. if type_info:
  641. material_category_name = type_info.material_category_name
  642. data_info['children'].append({"id": material.material_id,
  643. "label": material.material_name,
  644. "type_id": material.material_type,
  645. "type":material_category_name,
  646. "warehouse_id": info.warehouse_id,
  647. "warehouse_name":info.warehouse_name,
  648. "isWarehouse": False})
  649. data.append(data_info)
  650. return {
  651. "code": 200,
  652. "msg": "操作成功",
  653. "data": data
  654. }
  655. # 导入
  656. @router.post('/import')
  657. async def import_doc(
  658. request: Request,
  659. db: Session = Depends(get_db),
  660. body = Depends(remove_xss_json),
  661. user_id = Depends(valid_access_token)
  662. ):
  663. try:
  664. filename = body['filename']
  665. if len(filename) == 0:
  666. raise Exception()
  667. file = filename[0]
  668. url = file['url']
  669. file_path = f"{UPLOAD_mergefile_PATH}/uploads/{url}"
  670. file_path = os.path.abspath(file_path)
  671. print(file_path)
  672. book = xlrd.open_workbook(file_path)
  673. sheet = book.sheet_by_index(0)
  674. data = []
  675. return {
  676. 'code': 200,
  677. 'msg': '导入成功'
  678. }
  679. except Exception:
  680. traceback.print_exc()
  681. return {
  682. 'code': 500,
  683. 'msg': '导入发生异常'
  684. }