1
0

EngineerSettlementLogic.php 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  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\master_worker\EngineerSettlement;
  17. use app\common\logic\BaseLogic;
  18. use app\common\model\master_worker\MasterWorker;
  19. use think\facade\Db;
  20. /**
  21. * EngineerSettlement逻辑
  22. * Class EngineerSettlementLogic
  23. * @package app\adminapi\logic
  24. */
  25. class EngineerSettlementLogic extends BaseLogic
  26. {
  27. /**
  28. * @notes 添加
  29. * @param array $params
  30. * @return bool
  31. * @author likeadmin
  32. * @date 2024/11/15 17:21
  33. */
  34. public static function add(array $params, $adminId): bool
  35. {
  36. Db::startTrans();
  37. try {
  38. foreach ($params as $param) {
  39. EngineerSettlement::create([
  40. 'master_worker_id' => $param['master_worker_id'],
  41. 'worker_number' => $param['worker_number'],
  42. 'engineer_name' => $param['engineer_name'],
  43. 'original_balance' => $param['original_balance'],
  44. 'total_settlement_amount' => $param['total_settlement_amount'],
  45. 'deduction_amount' => $param['deduction_amount'],
  46. 'final_settlement_amount' => $param['final_settlement_amount'],
  47. 'settlement_time' => $param['settlement_time'],
  48. 'settlement_details_remarks' => $param['settlement_details_remarks'],
  49. ]);
  50. $masterWorker = MasterWorker::where('id', $param['master_worker_id'])->where('worker_number', $param['worker_number'])->find();
  51. if($masterWorker && $masterWorker->user_money >= $param['total_settlement_amount']){
  52. $masterWorker->user_money = $masterWorker->user_money - $param['total_settlement_amount'];
  53. $masterWorker->save();
  54. MasterWorkerCaseOutLog::create([
  55. 'sn' => generate_sn(MasterWorkerCaseOutLog::class,'sn'),
  56. 'worker_id' => $masterWorker->id,
  57. 'title' => '财务打款',
  58. 'change_amount' => $param['total_settlement_amount'],
  59. 'review_status' => 3,
  60. 'admin_id' => $adminId,
  61. 'remark' => '财务打款',
  62. 'create_time' => time(),
  63. 'update_time' => time(),
  64. ]);
  65. }else{
  66. throw new \Exception('工程师不存在、余额不足');
  67. }
  68. }
  69. Db::commit();
  70. return true;
  71. } catch (\Exception $e) {
  72. Db::rollback();
  73. self::setError($e->getMessage());
  74. return false;
  75. }
  76. }
  77. /**
  78. * @notes 编辑
  79. * @param array $params
  80. * @return bool
  81. * @author likeadmin
  82. * @date 2024/11/15 17:21
  83. */
  84. public static function edit(array $params): bool
  85. {
  86. Db::startTrans();
  87. try {
  88. EngineerSettlement::where('id', $params['id'])->update([
  89. 'master_worker_id' => $params['master_worker_id'],
  90. 'worker_number' => $params['worker_number'],
  91. 'engineer_name' => $params['engineer_name'],
  92. 'original_balance' => $params['original_balance'],
  93. 'total_settlement_amount' => $params['total_settlement_amount'],
  94. 'deduction_amount' => $params['deduction_amount'],
  95. 'final_settlement_amount' => $params['final_settlement_amount'],
  96. 'settlement_time' => $params['settlement_time'],
  97. 'settlement_details_remarks' => $params['settlement_details_remarks'],
  98. ]);
  99. Db::commit();
  100. return true;
  101. } catch (\Exception $e) {
  102. Db::rollback();
  103. self::setError($e->getMessage());
  104. return false;
  105. }
  106. }
  107. /**
  108. * @notes 删除
  109. * @param array $params
  110. * @return bool
  111. * @author likeadmin
  112. * @date 2024/11/15 17:21
  113. */
  114. public static function delete(array $params): bool
  115. {
  116. return EngineerSettlement::destroy($params['id']);
  117. }
  118. /**
  119. * @notes 获取详情
  120. * @param $params
  121. * @return array
  122. * @author likeadmin
  123. * @date 2024/11/15 17:21
  124. */
  125. public static function detail($params): array
  126. {
  127. return EngineerSettlement::findOrEmpty($params['id'])->toArray();
  128. }
  129. public static function downloadLists(): array
  130. {
  131. return EngineerSettlement::where('id','>',0)
  132. ->field(['id', 'master_worker_id', 'worker_number', 'engineer_name', 'original_balance', 'total_settlement_amount', 'deduction_amount', 'final_settlement_amount', 'settlement_time', 'settlement_details_remarks'])
  133. ->order(['id' => 'desc'])
  134. ->select()
  135. ->toArray();
  136. }
  137. public static function engineerSettlementValidate($params)
  138. {
  139. try {
  140. if(empty($params)) throw new \Exception('表格数据为空');
  141. foreach ($params as &$param) {
  142. //判断日期时间格式是否正确 2024/1/1 00:00:00 或 2024-1-1 00:00:00
  143. 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'])
  144. && !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'])){
  145. throw new \Exception('日期时间格式错误');
  146. }else{
  147. $param['settlement_time'] = date('Y-m-d H:i:s', strtotime($param['settlement_time']));
  148. }
  149. if(!is_numeric($param['original_balance']) || !is_numeric($param['total_settlement_amount']) || !is_numeric($param['deduction_amount']) || !is_numeric($param['final_settlement_amount'])){
  150. throw new \Exception('金额格式错误');
  151. }
  152. if(!preg_match('/^[0-9]*$/', $param['worker_number'])){
  153. throw new \Exception('工程师ID格式错误:'.$param['master_worker_id']);
  154. }
  155. if(!preg_match('/^[0-9]*$/', $param['master_worker_id'])){
  156. throw new \Exception('工程师ID格式错误:'.$param['master_worker_id']);
  157. }
  158. $masterWorker = MasterWorker::where('id', $param['master_worker_id'])->where('worker_number', $param['worker_number'])->findOrEmpty();
  159. if($masterWorker->isEmpty()) throw new \Exception('工程师不存在:'.$param['master_worker_id']);
  160. if($masterWorker->user_money < $param['total_settlement_amount']) throw new \Exception('余额不足');
  161. }
  162. return $params;
  163. } catch (\Exception $e) {
  164. throw new \Exception($e->getMessage());
  165. }
  166. }
  167. }