EngineerSettlementController.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  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\controller\master_worker;
  15. use app\adminapi\controller\BaseAdminController;
  16. use app\adminapi\lists\master_worker\EngineerSettlementLists;
  17. use app\adminapi\logic\master_worker\EngineerSettlementLogic;
  18. use app\adminapi\validate\master_worker\EngineerSettlementValidate;
  19. /**
  20. * EngineerSettlement控制器
  21. * Class EngineerSettlementController
  22. * @package app\adminapi\controller
  23. */
  24. class EngineerSettlementController extends BaseAdminController
  25. {
  26. public array $notNeedLogin = ['download'];
  27. /**
  28. * @notes 获取列表
  29. * @return \think\response\Json
  30. * @author likeadmin
  31. * @date 2024/11/15 17:21
  32. */
  33. public function lists()
  34. {
  35. return $this->dataLists(new EngineerSettlementLists());
  36. }
  37. /**
  38. * @notes 添加
  39. * @return \think\response\Json
  40. * @author likeadmin
  41. * @date 2024/11/15 17:21
  42. */
  43. public function add()
  44. {
  45. //$params = (new EngineerSettlementValidate())->post();//->goCheck('add');
  46. try {
  47. $params = $this->request->post();
  48. $params = EngineerSettlementLogic::engineerSettlementValidate($params);
  49. $result = EngineerSettlementLogic::add($params,$this->adminId);
  50. if (true === $result) {
  51. return $this->success('添加成功', [], 1, 1);
  52. }
  53. return $this->fail(EngineerSettlementLogic::getError());
  54. } catch (\Exception $e) {
  55. return $this->fail($e->getMessage()?:EngineerSettlementLogic::getError());
  56. }
  57. }
  58. /**
  59. * @notes 编辑
  60. * @return \think\response\Json
  61. * @author likeadmin
  62. * @date 2024/11/15 17:21
  63. */
  64. public function edit()
  65. {
  66. $params = (new EngineerSettlementValidate())->post()->goCheck('edit');
  67. $result = EngineerSettlementLogic::edit($params);
  68. if (true === $result) {
  69. return $this->success('编辑成功', [], 1, 1);
  70. }
  71. return $this->fail(EngineerSettlementLogic::getError());
  72. }
  73. /**
  74. * @notes 删除
  75. * @return \think\response\Json
  76. * @author likeadmin
  77. * @date 2024/11/15 17:21
  78. */
  79. public function delete()
  80. {
  81. $params = (new EngineerSettlementValidate())->post()->goCheck('delete');
  82. EngineerSettlementLogic::delete($params);
  83. return $this->success('删除成功', [], 1, 1);
  84. }
  85. /**
  86. * @notes 获取详情
  87. * @return \think\response\Json
  88. * @author likeadmin
  89. * @date 2024/11/15 17:21
  90. */
  91. public function detail()
  92. {
  93. $params = (new EngineerSettlementValidate())->goCheck('detail');
  94. $result = EngineerSettlementLogic::detail($params);
  95. return $this->data($result);
  96. }
  97. public function download()
  98. {
  99. $lists = EngineerSettlementLogic::downloadLists();
  100. header('Content-Type: text/csv; charset=utf-8');
  101. header('Content-Disposition: attachment; filename=engineer_settlement.csv');
  102. $output = fopen('php://output', 'w');
  103. fputcsv($output, array('工程师ID', '工程师编号', '工程师姓名', '工程师原始余额', '工程师总结算金额', '工程师扣款金额', '工程师最终结算金额', '结算时间', '结算明细备注'));
  104. foreach ($lists as $row) {
  105. fputcsv($output, array(
  106. $row['master_worker_id'],
  107. $row['worker_number'],
  108. $row['engineer_name'],
  109. $row['original_balance'],
  110. $row['total_settlement_amount'],
  111. $row['deduction_amount'],
  112. $row['final_settlement_amount'],
  113. $row['settlement_time'],
  114. $row['settlement_details_remarks']
  115. ));
  116. }
  117. fclose($output);
  118. }
  119. }