RetentionMoneyLogic.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. <?php
  2. /**
  3. * @author 林海涛
  4. * @date 2024/7/28 下午2:36
  5. */
  6. namespace app\adminapi\logic\master_worker;
  7. use app\common\enum\worker\WorkerAccountLogEnum;
  8. use app\common\logic\BaseLogic;
  9. use app\common\model\master_worker\MasterWorker;
  10. use app\common\model\master_worker\MasterWorkerRetentionMoneyLog;
  11. use app\common\model\works\ServiceWork;
  12. use think\facade\Db;
  13. class RetentionMoneyLogic extends BaseLogic
  14. {
  15. public static function totalAmount($params)
  16. {
  17. try{
  18. $model = MasterWorker::findOrEmpty($params['worker_id']);
  19. if($model->isEmpty()){
  20. throw new \Exception('用户不存在');
  21. }
  22. $where = [];
  23. $where[] = ['worker_id','=',$params['worker_id']] ;
  24. $incWhere =$where;
  25. $incWhere[] = ['action', '=',WorkerAccountLogEnum::INC];
  26. $data = [];
  27. //$data['amount_inc_total'] = MasterWorkerRetentionMoneyLog::where($incWhere)->sum('amount');
  28. $data['amount_inc_total'] = $model->earnest_money;
  29. $outWhere = $where;
  30. $outWhere[] =['action', '=',WorkerAccountLogEnum::DEC];
  31. //$data['amount_dec_total'] = MasterWorkerRetentionMoneyLog::where($outWhere)->sum('amount');
  32. $data['amount_dec_total'] = $model->earnest_money_freeze;
  33. //$data['amount_available_total'] = $data['amount_inc_total'] - $data['amount_dec_total'];
  34. $data['amount_available_total'] = $model->earnest_money_usable;
  35. $data['retention_money_status'] = $model->retention_money_status;
  36. $data['retention_money_status_text'] = $model->retention_money_status_text;
  37. $data['retention_pay_status'] = $model->retention_pay_status;
  38. $data['retention_pay_status_text'] = $model->retention_pay_status_text;
  39. $data['worker_number'] = $model->worker_number;
  40. $data['real_name'] = $model->real_name;
  41. $data['worker_id'] = $model->id;
  42. $data['installment_ratio'] = $model->installment_ratio;
  43. return $data;
  44. } catch(\Exception $e){
  45. self::setError($e->getMessage());
  46. return false;
  47. }
  48. }
  49. public static function add($params)
  50. {
  51. Db::startTrans();
  52. try {
  53. if(isset($params['work_id']) && !empty($params['work_id'])){
  54. $workModel = ServiceWork::findOrEmpty($params['work_id']);
  55. if($workModel->isEmpty()){
  56. throw new \Exception('工单不存在');
  57. }
  58. }
  59. MasterWorkerRetentionMoneyLog::create([
  60. 'sn' => generate_sn(MasterWorkerRetentionMoneyLog::class,'sn'),
  61. 'worker_id' => $params['worker_id'],
  62. 'action' => $params['action'],
  63. 'amount' => $params['amount'],
  64. 'work_id' => $params['work_id'],
  65. 'remark' => $params['remark'],
  66. ]);
  67. // $params['worker_id']
  68. $masterWorkerInfo = MasterWorker::where('id', $params['worker_id'])->findOrEmpty();
  69. if($params['action'] == WorkerAccountLogEnum::INC){
  70. $earnest_money_usable = $masterWorkerInfo->earnest_money_usable + $params['amount'];
  71. if($earnest_money_usable > $masterWorkerInfo->earnest_money){
  72. throw new \Exception('可用质保金超过配置质保金');
  73. }
  74. $masterWorkerInfo->earnest_money_usable = $earnest_money_usable;
  75. }
  76. if($params['action'] == WorkerAccountLogEnum::DEC){
  77. $earnest_money_usable = $masterWorkerInfo->earnest_money_usable - $params['amount'];
  78. if($earnest_money_usable < 0){
  79. throw new \Exception('可用质保金不足');
  80. }
  81. $masterWorkerInfo->earnest_money_usable = $earnest_money_usable;
  82. $masterWorkerInfo->earnest_money_freeze += $params['amount'];
  83. }
  84. $masterWorkerInfo->save();
  85. Db::commit();
  86. return true;
  87. } catch (\Exception $e) {
  88. Db::rollback();
  89. self::setError($e->getMessage());
  90. return false;
  91. }
  92. }
  93. public static function refundRetention($params,$to_freeze = true)
  94. {
  95. Db::startTrans();
  96. try {
  97. if(isset($params['work_id']) && !empty($params['work_id'])){
  98. $workModel = ServiceWork::findOrEmpty($params['work_id']);
  99. if($workModel->isEmpty()){
  100. throw new \Exception('工单不存在');
  101. }
  102. }
  103. MasterWorkerRetentionMoneyLog::create([
  104. 'sn' => generate_sn(MasterWorkerRetentionMoneyLog::class,'sn'),
  105. 'worker_id' => $params['worker_id'],
  106. 'action' => WorkerAccountLogEnum::DEC,
  107. 'amount' => $params['amount'],
  108. 'work_id' => $params['work_id'],
  109. 'remark' => $params['remark'],
  110. 'return_work_id' => isset($params['return_work_id'])?$params['return_work_id']:0,
  111. ]);
  112. // $params['worker_id']
  113. $masterWorkerInfo = MasterWorker::where('id', $params['worker_id'])->findOrEmpty();
  114. $earnest_money_usable = $masterWorkerInfo->earnest_money_usable - $params['amount'];
  115. if($earnest_money_usable < 0){
  116. throw new \Exception('退可用质保金不足');
  117. }
  118. $masterWorkerInfo->earnest_money_usable = $earnest_money_usable;
  119. // 是否要扣到 冻结 里面?
  120. $to_freeze && $masterWorkerInfo->earnest_money_freeze += $params['amount'];
  121. $masterWorkerInfo->save();
  122. // 记录冻结金额日志
  123. if($to_freeze){
  124. }
  125. Db::commit();
  126. return true;
  127. } catch (\Exception $e) {
  128. Db::rollback();
  129. self::setError($e->getMessage());
  130. return false;
  131. }
  132. }
  133. }