EngineerSettlementLogic.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  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\master_worker\EngineerSettlement;
  16. use app\common\logic\BaseLogic;
  17. use think\facade\Db;
  18. /**
  19. * EngineerSettlement逻辑
  20. * Class EngineerSettlementLogic
  21. * @package app\adminapi\logic
  22. */
  23. class EngineerSettlementLogic extends BaseLogic
  24. {
  25. /**
  26. * @notes 添加
  27. * @param array $params
  28. * @return bool
  29. * @author likeadmin
  30. * @date 2024/11/15 17:21
  31. */
  32. public static function add(array $params): bool
  33. {
  34. Db::startTrans();
  35. try {
  36. foreach ($params as $param) {
  37. EngineerSettlement::create([
  38. 'master_worker_id' => $param['master_worker_id'],
  39. 'worker_number' => $param['worker_number'],
  40. 'engineer_name' => $param['engineer_name'],
  41. 'original_balance' => $param['original_balance'],
  42. 'total_settlement_amount' => $param['total_settlement_amount'],
  43. 'deduction_amount' => $param['deduction_amount'],
  44. 'final_settlement_amount' => $param['final_settlement_amount'],
  45. 'settlement_time' => $param['settlement_time'],
  46. 'settlement_details_remarks' => $param['settlement_details_remarks'],
  47. ]);
  48. }
  49. Db::commit();
  50. return true;
  51. } catch (\Exception $e) {
  52. Db::rollback();
  53. self::setError($e->getMessage());
  54. return false;
  55. }
  56. }
  57. /**
  58. * @notes 编辑
  59. * @param array $params
  60. * @return bool
  61. * @author likeadmin
  62. * @date 2024/11/15 17:21
  63. */
  64. public static function edit(array $params): bool
  65. {
  66. Db::startTrans();
  67. try {
  68. EngineerSettlement::where('id', $params['id'])->update([
  69. 'master_worker_id' => $params['master_worker_id'],
  70. 'worker_number' => $params['worker_number'],
  71. 'engineer_name' => $params['engineer_name'],
  72. 'original_balance' => $params['original_balance'],
  73. 'total_settlement_amount' => $params['total_settlement_amount'],
  74. 'deduction_amount' => $params['deduction_amount'],
  75. 'final_settlement_amount' => $params['final_settlement_amount'],
  76. 'settlement_time' => $params['settlement_time'],
  77. 'settlement_details_remarks' => $params['settlement_details_remarks'],
  78. ]);
  79. Db::commit();
  80. return true;
  81. } catch (\Exception $e) {
  82. Db::rollback();
  83. self::setError($e->getMessage());
  84. return false;
  85. }
  86. }
  87. /**
  88. * @notes 删除
  89. * @param array $params
  90. * @return bool
  91. * @author likeadmin
  92. * @date 2024/11/15 17:21
  93. */
  94. public static function delete(array $params): bool
  95. {
  96. return EngineerSettlement::destroy($params['id']);
  97. }
  98. /**
  99. * @notes 获取详情
  100. * @param $params
  101. * @return array
  102. * @author likeadmin
  103. * @date 2024/11/15 17:21
  104. */
  105. public static function detail($params): array
  106. {
  107. return EngineerSettlement::findOrEmpty($params['id'])->toArray();
  108. }
  109. public static function downloadLists(): array
  110. {
  111. return EngineerSettlement::where('id','>',0)
  112. ->field(['id', 'master_worker_id', 'worker_number', 'engineer_name', 'original_balance', 'total_settlement_amount', 'deduction_amount', 'final_settlement_amount', 'settlement_time', 'settlement_details_remarks'])
  113. ->order(['id' => 'desc'])
  114. ->select()
  115. ->toArray();
  116. }
  117. }