EngineerSettlementLogic.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeadmin快速开发前后端分离管理后台(PHP版)
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
  8. // | github下载:https://github.com/likeshop-github/likeadmin
  9. // | 访问官网:https://www.likeadmin.cn
  10. // | likeadmin团队 版权所有 拥有最终解释权
  11. // +----------------------------------------------------------------------
  12. // | author: likeadminTeam
  13. // +----------------------------------------------------------------------
  14. namespace app\adminapi\logic\master_worker;
  15. use app\common\model\finance\MasterWorkerCaseOutLog;
  16. use app\common\model\financial\MasterSettlementDetails;
  17. use app\common\model\master_worker\EngineerSettlement;
  18. use app\common\logic\BaseLogic;
  19. use app\common\model\master_worker\MasterWorker;
  20. use think\facade\Db;
  21. /**
  22. * EngineerSettlement逻辑
  23. * Class EngineerSettlementLogic
  24. * @package app\adminapi\logic
  25. */
  26. class EngineerSettlementLogic extends BaseLogic
  27. {
  28. /**
  29. * @notes 添加
  30. * @param array $params
  31. * @return bool
  32. * @author likeadmin
  33. * @date 2024/11/15 17:21
  34. */
  35. public static function add(array $params, $adminId): bool
  36. {
  37. /*判断表格中打款状态是否已打款:
  38. 已打款 - 再判断数据表la_engineer_settlement中状态是否真已打 - la_master_settlement_details 更新为 已结算及不参与下批次计算
  39. 对已结算的:添加实发扣款记录
  40. 添加直接扣款记录
  41. 更新|添加xls到详细记录数据表:包括打款状态
  42. 检查 la_master_settlement_details 中该批号的所有记录,判断打款状态, 更新表格记录 : 已上传、全部已打款*/
  43. Db::startTrans();
  44. try {
  45. foreach ($params as $param) {
  46. //$param['payment_status'] == 1
  47. $engineerSettlement = EngineerSettlement::where('master_worker_id', $param['master_worker_id'])
  48. ->where('batch_number', $param['batch_number'])
  49. ->where('is_export', 1)
  50. ->where('is_deduction', 0)
  51. ->where('payment_status', 0)
  52. ->findOrEmpty();
  53. if(!$engineerSettlement->isEmpty()){
  54. MasterSettlementDetails::where('master_worker_id', $param['master_worker_id'])
  55. ->where('batch_number', $param['batch_number'])
  56. ->where('status', 2)
  57. ->update([
  58. 'payment_status' => 1,
  59. 'payment_time' => $param['settlement_time']??date('Y-m-d H:i:s'),
  60. 'status'=>3, 'remark'=>''
  61. ]);
  62. // 添加实发扣款记录
  63. $masterWorker = MasterWorker::where('id', $param['master_worker_id'])->where('worker_number', $param['worker_number'])->find();
  64. if($masterWorker && $masterWorker->user_money >= $param['total_settlement_amount']){
  65. $masterWorker->user_money = $masterWorker->user_money - $param['total_settlement_amount'];
  66. $masterWorker->save();
  67. MasterWorkerCaseOutLog::create([
  68. 'sn' => generate_sn(MasterWorkerCaseOutLog::class,'sn'),
  69. 'worker_id' => $masterWorker->id,
  70. 'title' => '财务打款',
  71. 'change_amount' => $param['total_settlement_amount'],
  72. 'review_status' => 3,
  73. 'admin_id' => $adminId,
  74. 'remark' => '财务打款',
  75. 'create_time' => time(),
  76. 'update_time' => time(),
  77. ]);
  78. }else{
  79. throw new \Exception('工程师不存在、余额不足');
  80. }
  81. 添加直接扣款记录
  82. }
  83. /*EngineerSettlement::create([
  84. 'master_worker_id' => $param['master_worker_id'],
  85. 'worker_number' => $param['worker_number'],
  86. 'engineer_name' => $param['engineer_name'],
  87. 'original_balance' => $param['original_balance'],
  88. 'total_settlement_amount' => $param['total_settlement_amount'],
  89. 'deduction_amount' => $param['deduction_amount'],
  90. 'final_settlement_amount' => $param['final_settlement_amount'],
  91. 'settlement_time' => $param['settlement_time'],
  92. 'settlement_details_remarks' => $param['settlement_details_remarks'],
  93. ]);*/
  94. $masterWorker = MasterWorker::where('id', $param['master_worker_id'])->where('worker_number', $param['worker_number'])->find();
  95. $user_money = $masterWorker->user_money;
  96. if($masterWorker && $user_money >= $param['total_settlement_amount']){
  97. $user_money = $user_money - $param['total_settlement_amount'];
  98. $masterWorker->user_money = $user_money;
  99. MasterWorkerCaseOutLog::create([
  100. 'sn' => generate_sn(MasterWorkerCaseOutLog::class,'sn'),
  101. 'worker_id' => $masterWorker->id,
  102. 'title' => '财务打款',
  103. 'change_amount' => $param['total_settlement_amount'],
  104. 'review_status' => 3,
  105. 'admin_id' => $adminId,
  106. 'remark' => '财务打款',
  107. 'create_time' => time(),
  108. 'update_time' => time(),
  109. ]);
  110. }else{
  111. throw new \Exception('工程师不存在、余额不足');
  112. }
  113. $masterWorker->save();
  114. }
  115. Db::commit();
  116. return true;
  117. } catch (\Exception $e) {
  118. Db::rollback();
  119. self::setError($e->getMessage());
  120. return false;
  121. }
  122. }
  123. /**
  124. * @notes 编辑
  125. * @param array $params
  126. * @return bool
  127. * @author likeadmin
  128. * @date 2024/11/15 17:21
  129. */
  130. public static function edit(array $params): bool
  131. {
  132. Db::startTrans();
  133. try {
  134. EngineerSettlement::where('id', $params['id'])->update([
  135. 'master_worker_id' => $params['master_worker_id'],
  136. 'worker_number' => $params['worker_number'],
  137. 'engineer_name' => $params['engineer_name'],
  138. 'original_balance' => $params['original_balance'],
  139. 'total_settlement_amount' => $params['total_settlement_amount'],
  140. 'deduction_amount' => $params['deduction_amount'],
  141. 'final_settlement_amount' => $params['final_settlement_amount'],
  142. 'settlement_time' => $params['settlement_time'],
  143. 'settlement_details_remarks' => $params['settlement_details_remarks'],
  144. ]);
  145. Db::commit();
  146. return true;
  147. } catch (\Exception $e) {
  148. Db::rollback();
  149. self::setError($e->getMessage());
  150. return false;
  151. }
  152. }
  153. /**
  154. * @notes 删除
  155. * @param array $params
  156. * @return bool
  157. * @author likeadmin
  158. * @date 2024/11/15 17:21
  159. */
  160. public static function delete(array $params): bool
  161. {
  162. return EngineerSettlement::destroy($params['id']);
  163. }
  164. /**
  165. * @notes 获取详情
  166. * @param $params
  167. * @return array
  168. * @author likeadmin
  169. * @date 2024/11/15 17:21
  170. */
  171. public static function detail($params): array
  172. {
  173. return EngineerSettlement::findOrEmpty($params['id'])->toArray();
  174. }
  175. public static function downloadLists(): array
  176. {
  177. return [EngineerSettlement::where('id','>',0)
  178. ->field(['id', 'master_worker_id', 'worker_number', 'engineer_name', 'original_balance', 'total_settlement_amount', 'deduction_amount', 'final_settlement_amount', 'settlement_time', 'settlement_details_remarks'])
  179. ->order(['id' => 'desc'])
  180. ->select()
  181. ->toArray()[0]];
  182. }
  183. public static function engineerSettlementValidate($params)
  184. {
  185. try {
  186. if(empty($params)) throw new \Exception('表格数据为空');
  187. foreach ($params as &$param) {
  188. //判断日期时间格式是否正确 2024/1/1 00:00:00 或 2024-1-1 00:00:00
  189. if(!preg_match('/^[0-9]{4}\/[0-9]{1,2}\/[0-9]{1,2} [0-9]{1,2}:[0-9]{1,2}:[0-9]{1,2}$/', $param['settlement_time'])
  190. && !preg_match('/^[0-9]{4}-[0-9]{1,2}-[0-9]{1,2} [0-9]{1,2}:[0-9]{1,2}:[0-9]{1,2}$/', $param['settlement_time'])){
  191. throw new \Exception('日期时间格式错误');
  192. }else{
  193. $param['settlement_time'] = date('Y-m-d H:i:s', strtotime($param['settlement_time']));
  194. }
  195. if(!is_numeric($param['original_balance']) || !is_numeric($param['total_settlement_amount']) || !is_numeric($param['deduction_amount']) || !is_numeric($param['final_settlement_amount'])){
  196. throw new \Exception('金额格式错误');
  197. }
  198. if(!preg_match('/^[0-9]*$/', $param['worker_number'])){
  199. throw new \Exception('工程师编号格式错误:'.$param['worker_number']);
  200. }
  201. if(!preg_match('/^[0-9]*$/', $param['master_worker_id'])){
  202. throw new \Exception('工程师ID格式错误:'.$param['master_worker_id']);
  203. }
  204. $masterWorker = MasterWorker::where('id', $param['master_worker_id'])->where('worker_number', $param['worker_number'])->findOrEmpty();
  205. if($masterWorker->isEmpty()) throw new \Exception('工程师不存在:'.$param['master_worker_id']);
  206. if($masterWorker->user_money < $param['total_settlement_amount']) throw new \Exception('余额不足');
  207. }
  208. return $params;
  209. } catch (\Exception $e) {
  210. throw new \Exception($e->getMessage());
  211. }
  212. }
  213. }