Adjust.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <?php
  2. namespace app\cxinv\controller;
  3. use app\cxinv\model\FinancialTz;
  4. use app\cxinv\model\ProductFz;
  5. use app\cxinv\model\TzProduct;
  6. use think\App;
  7. class Adjust extends Base
  8. {
  9. public function __construct(App $app)
  10. {
  11. parent::__construct($app);
  12. $this->model = new FinancialTz();
  13. }
  14. public function list()
  15. {
  16. $params = $this->request->param(["goodNo"=>"","goodType"=>"","status"=>"","start"=>"","end"=>"",'seller_code'=>"",
  17. "page"=>1,"size"=>15],"post","trim");
  18. $where=[];
  19. if($params['goodNo']!='') $where[]=['manager.goodNo','like','%'.$params['goodNo'].'%'];
  20. if($params['goodType']!='') $where[]=['manager.goodType','=',$params['goodType']];
  21. if($params['status']!='') $where[]=['financial_tz.status','=',$params['status']];
  22. if($params['start']!='') $where[]=['financial_tz.create_time','>=',startTime($params['start'])];
  23. if($params['end']!='') $where[]=['financial_tz.create_time','<=',startTime($params['end'])];
  24. if($params['seller_code']!='') $where[]=['manager.seller_code','=',$params['seller_code']];
  25. $list = $this->model
  26. ->with(["ProductTz"=>["Product"]])
  27. ->withJoin("Manager", "LEFT")
  28. ->where($where)
  29. ->order("financial_tz.id", "desc")
  30. ->paginate(['page'=>$params['page'],'list_rows'=>$params['size']]);
  31. return success("获取成功",["list"=>$list->items(),"count"=>$list->total()]);
  32. }
  33. public function info()
  34. {
  35. $ids = $this->request->param("id","0","int");
  36. if($ids==0) return error("参数错误");
  37. $info = $this->model
  38. ->with(["ProductTz"=>["Product"],"Manager"=>['ProductRela'=>['Product']],"FinancialCheck"])
  39. ->findOrEmpty($ids);
  40. if($info->isEmpty()) return error("信息不存在");
  41. return success("获取成功",$info);
  42. }
  43. public function status()
  44. {
  45. $params = $this->request->param(["id","status","idArr"=>[],'fz_date'=>"","checkFee"=>"","isAddCheck"=>0],"post","trim");
  46. $validate = $this->validate($params,[
  47. 'id|计提单ID'=>'require|number',
  48. 'status|状态'=>'require|number|in:1,2,3,4',
  49. 'fz_date|调整日期'=>'requireIf:status,2|max:255',
  50. 'idArr|关联商品id'=>'requireIf:status,2|array',
  51. 'checkFee|调整金额'=>'requireIf:status,2|float',
  52. 'isAddCheck|是否添加至调整单'=>'number|in:0,1',
  53. ]);
  54. if($validate!==true) return error($validate);
  55. $info = $this->model->with(['Manager'])->findOrEmpty($params['id']);
  56. if($info->isEmpty()) return error("计提单信息不存在");
  57. if($info->status==2) return error("已审核,无法修改");
  58. $manager = $info->Manager;
  59. $companyCode= in_array($manager['type'],['2','4'])?$manager['seller_code']:$manager['buyer_code'];
  60. $fz_date = ProductFz::where(['company_code'=>$companyCode,'fz_date'=>$params['fz_date']])->findOrEmpty();
  61. if($fz_date->isEmpty()) return error("请先生成{$params['fz_date']}封账数据");
  62. if($fz_date->status!=0) return error("{$params['fz_date']}封账状态不可用");
  63. if($params['status']==2 && !empty($params['idArr'])){
  64. foreach ($params['idArr'] as $k=>$v){
  65. $vali=$this->validate($v,[
  66. 'id|商品id'=>'require|number',
  67. 'num|数量'=>'require|float',
  68. 'subunit_price|不含税单价'=>'require|float',
  69. 'unit_price|含税单价'=>'require|float',
  70. ]);
  71. if($vali!==true) return error($vali);
  72. $params['idArr'][$k]['ktCode']=$info->ktCode;
  73. $params['idArr'][$k]['type']=2;
  74. $params['idArr'][$k]['checkUid']=$this->uid;
  75. $params['idArr'][$k]['checkUname']=$this->uname;
  76. $params['idArr'][$k]['product_id']=$v['id'];
  77. unset($params['idArr'][$k]['id']);
  78. }
  79. }
  80. $info->status=$params['status'];
  81. $info->check_fee=$params['checkFee'];
  82. $info->is_checkOrder=$params['isAddCheck'];
  83. $info->fz_date=$params['fz_date'];
  84. $info->checkUid=$this->uid;
  85. $info->checkUname=$this->uname;
  86. $this->model->startTrans();
  87. try{
  88. $save=$info->save();
  89. if($save===false) throw new \Exception("保存失败");
  90. if($params['status']==2 && !empty($params['idArr'])){
  91. $key=(new TzProduct)->saveAll($params['idArr']);
  92. if($key->isEmpty()) throw new \Exception("保存商品信息失败");
  93. }
  94. $this->model->commit();
  95. }catch (\Exception $e){
  96. $this->model->rollback();
  97. return error($e->getMessage());
  98. }
  99. return success("操作成功");
  100. }
  101. }