InvoiceOrder.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php
  2. namespace app\cxinv\model;
  3. use think\facade\Log;
  4. use think\model\concern\SoftDelete;
  5. class InvoiceOrder extends Base{
  6. use SoftDelete;
  7. protected $createTime='createTime';
  8. protected $updateTime='updateTime';
  9. protected $autoWriteTimestamp=true;
  10. protected $deleteTime='delete_time';
  11. protected $append=["merge_code","short_name","cat_code","cat_name","tax","inv_good_name"];
  12. public function ItemInfo(){
  13. return $this->hasOne('InvoiceItem','itemId','id');
  14. }
  15. public static function getInvoiceOrderTotalFee($code){
  16. $banance = (new InvoiceOrder)->where(['code'=>$code,'status'=>[1,2]])->field('sum(ifnull(total_amount-balance_amount,0)) as total_amount')->find();
  17. return $banance['total_amount']??"0";
  18. }
  19. public function getMergeCodeAttr($value,$data){
  20. return OrderCategory::where(['code'=>$data['code'],'spuCode'=>$data['spuCode']])->value("merge_code","");
  21. }
  22. public function getShortNameAttr($value,$data){
  23. return OrderCategory::where(['code'=>$data['code'],'spuCode'=>$data['spuCode']])->value("short_name","");
  24. }
  25. public function getCatCodeAttr($value,$data){
  26. return OrderCategory::where(['code'=>$data['code'],'spuCode'=>$data['spuCode']])->value("cat_code","");
  27. }
  28. public function getCatNameAttr($value,$data){
  29. return OrderCategory::where(['code'=>$data['code'],'spuCode'=>$data['spuCode']])->value("cat_name","");
  30. }
  31. public function getTaxAttr($value,$data){
  32. return OrderCategory::where(['code'=>$data['code'],'spuCode'=>$data['spuCode']])->value("tax","");
  33. }
  34. public function getInvGoodNameAttr($value,$data){
  35. return OrderCategory::where(['code'=>$data['code'],'spuCode'=>$data['spuCode']])->value("inv_good_name","");
  36. }
  37. public static function getNumAttr($val){
  38. return strval(floatval($val));
  39. }
  40. public static function setDiffInfoAttr($val){
  41. return json_encode($val,JSON_UNESCAPED_UNICODE);
  42. }
  43. public static function getDiffInfoAttr($val){
  44. return json_decode($val,true);
  45. }
  46. public static function getOrderInfo($code,$orderCode,$type){
  47. if($type==1){
  48. $info=InvoiceGood::alias('a')
  49. ->join('qrd_info b','a.orderCode=b.sequenceNo','left')
  50. ->join('order_category c','b.sequenceNo=c.code and b.goodNo=c.spuCode and c.order_type=1','left')
  51. ->where(["invNo"=>$code,"a.orderCode"=>$orderCode])
  52. ->where([['a.goodNum','>',0],['a.is_del','=',0]])
  53. ->field('b.sequenceNo,b.goodNo,b.goodName,a.goodNum,a.goodPrice,a.totalPrice,c.merge_code,c.cat_code,c.cat_name,c.short_name,c.tax,c.inv_good_name')
  54. ->findOrEmpty();
  55. } else{
  56. $payNo = PayInvoice::where(['hpNo'=>$code])->value("payNo","");
  57. $info = PayInfo::alias('a')
  58. ->join('cgd_info b','a.cgdNo=b.sequenceNo','left')
  59. ->join('order_category c','b.sequenceNo=c.code and b.goodNo=c.spuCode and c.order_type=2','left')
  60. ->where([['a.status','=',1],['a.is_del','=',0],['a.payNo',"=",$payNo ],['a.cgdNo',"=",$orderCode]])
  61. ->field('b.sequenceNo,b.goodNo,b.goodName,(b.goodNum-thNum) as goodNum,b.goodPrice,b.totalPrice,
  62. c.merge_code,c.cat_code,c.cat_name,c.short_name,c.tax,c.inv_good_name')
  63. ->findOrEmpty();
  64. }
  65. if(!$info->isEmpty())$info['balance_amount']= bcsub($info['totalPrice'],InvoiceOrder::getInvoiceOrderTotalFee($info['sequenceNo']),2);
  66. return $info;
  67. }
  68. //回票流程结束未认证 状态3 退票认证结束 状态4
  69. public static function onAfterWrite($model){
  70. $id= $model->id;
  71. $info = InvoiceOrder::where(['id'=>$id])->findOrEmpty();
  72. if(!$info->isEmpty())return ;
  73. if(in_array($info->status,[1,2])){
  74. $cgdinfo = CgdInfo::where(['sequenceNo'=>$info->code])->findOrEmpty();
  75. if(!$cgdinfo->isEmpty()){
  76. $cgdinfo->winv_fee = bcsub($cgdinfo->winv_fee,bcsub($info->total_amount,$info->balance_amount,2),2);
  77. $cgdinfo->save();
  78. }
  79. $payinfo = PayInfo::where(["cgdNo"=>$info->code,"status"=>1,"is_del"=>0])->findOrEmpty();
  80. if(!$payinfo->isEmpty()){
  81. $pay= Pay::where(['payNo'=>$payinfo->payNo,"status"=>2])->findOrEmpty();
  82. if(!$pay->isEmpty()){
  83. $pay->winv_fee=bcsub($pay->winv_fee,bcsub($info->total_amount,$info->balance_amount,2),2);
  84. $pay->inv_fee = bcadd($pay->inv_fee,bcsub($info->total_amount,$info->balance_amount,2),2);
  85. $pay->save();
  86. }
  87. }
  88. }
  89. if($info->status==3){
  90. $cgdinfo = CgdInfo::where(['sequenceNo'=>$info->code])->findOrEmpty();
  91. if(!$cgdinfo->isEmpty()){
  92. $cgdinfo->winv_fee = bcadd($cgdinfo->winv_fee,bcsub($info->total_amount,$info->balance_amount,2),2);
  93. $cgdinfo->save();
  94. }
  95. $payinfo = PayInfo::where(['cgdNo'=>$info->code,'status'=>1,'is_del'=>0])->findOrEmpty();
  96. if(!$payinfo->isEmpty()){
  97. $pay= Pay::where(['payNo'=>$payinfo->payNo,'status'=>2])->findOrEmpty();
  98. if(!$pay->isEmpty()){
  99. $pay->winv_fee=bcadd($pay->winv_fee,bcsub($info->total_amount,$info->balance_amount,2),2);
  100. $pay->inv_fee = bcsub($pay->inv_fee,bcsub($info->total_amount,$info->balance_amount,2),2);
  101. $pay->save();
  102. }
  103. }
  104. }
  105. if($info->status==4){
  106. $cgdinfo = CgdInfo::where(['sequenceNo'=>$info->code])->findOrEmpty();
  107. if(!$cgdinfo->isEmpty()){
  108. $cgdinfo->winv_fee = bcadd($cgdinfo->winv_fee,bcsub($info->total_amount,$info->balance_amount,2),2);
  109. $cgdinfo->ainv_fee = bcsub($cgdinfo->ainv_fee,bcsub($info->total_amount,$info->balance_amount,2),2);
  110. $cgdinfo->inv_status = $cgdinfo->winv_fee >0 && $cgdinfo->ainv_fee==0?1:2;
  111. $cgdinfo->save();
  112. }
  113. $payinfo = PayInfo::where(['cgdNo'=>$info->code,'status'=>1,'is_del'=>0])->findOrEmpty();
  114. if(!$payinfo->isEmpty()){
  115. $pay= Pay::where(['payNo'=>$payinfo->payNo,'status'=>2])->findOrEmpty();
  116. if(!$pay->isEmpty()){
  117. $pay->winv_fee=bcadd($pay->winv_fee,bcsub($info->total_amount,$info->balance_amount,2),2);
  118. $pay->ainv_fee = bcsub($pay->ainv_fee,bcsub($info->total_amount,$info->balance_amount,2),2);
  119. $pay->inv_status = $pay->winv_fee >0 && $pay->ainv_fee==0?1:2;
  120. $pay->save();
  121. }
  122. }
  123. }
  124. }
  125. }