liugc 1 rok pred
rodič
commit
43701bfe6c

+ 131 - 0
app/adminapi/controller/master_worker/EngineerSettlementController.php

@@ -0,0 +1,131 @@
+<?php
+// +----------------------------------------------------------------------
+// | likeadmin快速开发前后端分离管理后台(PHP版)
+// +----------------------------------------------------------------------
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
+// | 开源版本可自由商用,可去除界面版权logo
+// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
+// | github下载:https://github.com/likeshop-github/likeadmin
+// | 访问官网:https://www.likeadmin.cn
+// | likeadmin团队 版权所有 拥有最终解释权
+// +----------------------------------------------------------------------
+// | author: likeadminTeam
+// +----------------------------------------------------------------------
+
+
+namespace app\adminapi\controller\master_worker;
+
+
+use app\adminapi\controller\BaseAdminController;
+use app\adminapi\lists\master_worker\EngineerSettlementLists;
+use app\adminapi\logic\master_worker\EngineerSettlementLogic;
+use app\adminapi\validate\master_worker\EngineerSettlementValidate;
+
+
+/**
+ * EngineerSettlement控制器
+ * Class EngineerSettlementController
+ * @package app\adminapi\controller
+ */
+class EngineerSettlementController extends BaseAdminController
+{
+    public array $notNeedLogin = ['download'];
+
+    /**
+     * @notes 获取列表
+     * @return \think\response\Json
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function lists()
+    {
+        return $this->dataLists(new EngineerSettlementLists());
+    }
+
+
+    /**
+     * @notes 添加
+     * @return \think\response\Json
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function add()
+    {
+        //$params = (new EngineerSettlementValidate())->post();//->goCheck('add');
+        $params = $this->request->post();
+        $result = EngineerSettlementLogic::add($params);
+        if (true === $result) {
+            return $this->success('添加成功', [], 1, 1);
+        }
+        return $this->fail(EngineerSettlementLogic::getError());
+    }
+
+
+    /**
+     * @notes 编辑
+     * @return \think\response\Json
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function edit()
+    {
+        $params = (new EngineerSettlementValidate())->post()->goCheck('edit');
+        $result = EngineerSettlementLogic::edit($params);
+        if (true === $result) {
+            return $this->success('编辑成功', [], 1, 1);
+        }
+        return $this->fail(EngineerSettlementLogic::getError());
+    }
+
+
+    /**
+     * @notes 删除
+     * @return \think\response\Json
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function delete()
+    {
+        $params = (new EngineerSettlementValidate())->post()->goCheck('delete');
+        EngineerSettlementLogic::delete($params);
+        return $this->success('删除成功', [], 1, 1);
+    }
+
+
+    /**
+     * @notes 获取详情
+     * @return \think\response\Json
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function detail()
+    {
+        $params = (new EngineerSettlementValidate())->goCheck('detail');
+        $result = EngineerSettlementLogic::detail($params);
+        return $this->data($result);
+    }
+
+    public function download()
+    {
+        $lists = EngineerSettlementLogic::downloadLists();
+        header('Content-Type: text/csv; charset=utf-8');
+        header('Content-Disposition: attachment; filename=engineer_settlement.csv');
+        $output = fopen('php://output', 'w');
+        fputcsv($output, array('工程师ID', '工程师编号', '工程师姓名', '工程师原始余额', '工程师总结算金额', '工程师扣款金额', '工程师最终结算金额', '结算时间', '结算明细备注'));
+        foreach ($lists as $row) {
+            fputcsv($output, array(
+                $row['master_worker_id'],
+                $row['worker_number'],
+                $row['engineer_name'],
+                $row['original_balance'],
+                $row['total_settlement_amount'],
+                $row['deduction_amount'],
+                $row['final_settlement_amount'],
+                $row['settlement_time'],
+                $row['settlement_details_remarks']
+            ));
+        }
+        fclose($output);
+    }
+
+}

+ 78 - 0
app/adminapi/lists/master_worker/EngineerSettlementLists.php

@@ -0,0 +1,78 @@
+<?php
+// +----------------------------------------------------------------------
+// | likeadmin快速开发前后端分离管理后台(PHP版)
+// +----------------------------------------------------------------------
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
+// | 开源版本可自由商用,可去除界面版权logo
+// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
+// | github下载:https://github.com/likeshop-github/likeadmin
+// | 访问官网:https://www.likeadmin.cn
+// | likeadmin团队 版权所有 拥有最终解释权
+// +----------------------------------------------------------------------
+// | author: likeadminTeam
+// +----------------------------------------------------------------------
+
+namespace app\adminapi\lists\master_worker;
+
+
+use app\adminapi\lists\BaseAdminDataLists;
+use app\common\model\master_worker\EngineerSettlement;
+use app\common\lists\ListsSearchInterface;
+
+
+/**
+ * EngineerSettlement列表
+ * Class EngineerSettlementLists
+ * @package app\adminapi\lists
+ */
+class EngineerSettlementLists extends BaseAdminDataLists implements ListsSearchInterface
+{
+
+
+    /**
+     * @notes 设置搜索条件
+     * @return \string[][]
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function setSearch(): array
+    {
+        return [
+            '=' => ['master_worker_id', 'worker_number', 'engineer_name', 'original_balance', 'total_settlement_amount', 'deduction_amount', 'final_settlement_amount', 'settlement_time', 'settlement_details_remarks'],
+
+        ];
+    }
+
+
+    /**
+     * @notes 获取列表
+     * @return array
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function lists(): array
+    {
+        return EngineerSettlement::where($this->searchWhere)
+            ->field(['id', 'master_worker_id', 'worker_number', 'engineer_name', 'original_balance', 'total_settlement_amount', 'deduction_amount', 'final_settlement_amount', 'settlement_time', 'settlement_details_remarks'])
+            ->limit($this->limitOffset, $this->limitLength)
+            ->order(['id' => 'desc'])
+            ->select()
+            ->toArray();
+    }
+
+
+    /**
+     * @notes 获取数量
+     * @return int
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function count(): int
+    {
+        return EngineerSettlement::where($this->searchWhere)->count();
+    }
+
+}

+ 135 - 0
app/adminapi/logic/master_worker/EngineerSettlementLogic.php

@@ -0,0 +1,135 @@
+<?php
+// +----------------------------------------------------------------------
+// | likeadmin快速开发前后端分离管理后台(PHP版)
+// +----------------------------------------------------------------------
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
+// | 开源版本可自由商用,可去除界面版权logo
+// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
+// | github下载:https://github.com/likeshop-github/likeadmin
+// | 访问官网:https://www.likeadmin.cn
+// | likeadmin团队 版权所有 拥有最终解释权
+// +----------------------------------------------------------------------
+// | author: likeadminTeam
+// +----------------------------------------------------------------------
+
+namespace app\adminapi\logic\master_worker;
+
+
+use app\common\model\master_worker\EngineerSettlement;
+use app\common\logic\BaseLogic;
+use think\facade\Db;
+
+
+/**
+ * EngineerSettlement逻辑
+ * Class EngineerSettlementLogic
+ * @package app\adminapi\logic
+ */
+class EngineerSettlementLogic extends BaseLogic
+{
+
+
+    /**
+     * @notes 添加
+     * @param array $params
+     * @return bool
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public static function add(array $params): bool
+    {
+        Db::startTrans();
+        try {
+            foreach ($params as $param) {
+                EngineerSettlement::create([
+                    'master_worker_id' => $param['master_worker_id'],
+                    'worker_number' => $param['worker_number'],
+                    'engineer_name' => $param['engineer_name'],
+                    'original_balance' => $param['original_balance'],
+                    'total_settlement_amount' => $param['total_settlement_amount'],
+                    'deduction_amount' => $param['deduction_amount'],
+                    'final_settlement_amount' => $param['final_settlement_amount'],
+                    'settlement_time' => $param['settlement_time'],
+                    'settlement_details_remarks' => $param['settlement_details_remarks'],
+                ]);
+            }
+            Db::commit();
+            return true;
+        } catch (\Exception $e) {
+            Db::rollback();
+            self::setError($e->getMessage());
+            return false;
+        }
+    }
+
+
+    /**
+     * @notes 编辑
+     * @param array $params
+     * @return bool
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public static function edit(array $params): bool
+    {
+        Db::startTrans();
+        try {
+            EngineerSettlement::where('id', $params['id'])->update([
+                'master_worker_id' => $params['master_worker_id'],
+                'worker_number' => $params['worker_number'],
+                'engineer_name' => $params['engineer_name'],
+                'original_balance' => $params['original_balance'],
+                'total_settlement_amount' => $params['total_settlement_amount'],
+                'deduction_amount' => $params['deduction_amount'],
+                'final_settlement_amount' => $params['final_settlement_amount'],
+                'settlement_time' => $params['settlement_time'],
+                'settlement_details_remarks' => $params['settlement_details_remarks'],
+            ]);
+
+            Db::commit();
+            return true;
+        } catch (\Exception $e) {
+            Db::rollback();
+            self::setError($e->getMessage());
+            return false;
+        }
+    }
+
+
+    /**
+     * @notes 删除
+     * @param array $params
+     * @return bool
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public static function delete(array $params): bool
+    {
+        return EngineerSettlement::destroy($params['id']);
+    }
+
+
+    /**
+     * @notes 获取详情
+     * @param $params
+     * @return array
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public static function detail($params): array
+    {
+        return EngineerSettlement::findOrEmpty($params['id'])->toArray();
+    }
+    public static function downloadLists(): array
+    {
+        return EngineerSettlement::where('id','>',0)
+            ->field(['id', 'master_worker_id', 'worker_number', 'engineer_name', 'original_balance', 'total_settlement_amount', 'deduction_amount', 'final_settlement_amount', 'settlement_time', 'settlement_details_remarks'])
+            ->order(['id' => 'desc'])
+            ->select()
+            ->toArray();
+    }
+
+
+
+
+}

+ 112 - 0
app/adminapi/validate/master_worker/EngineerSettlementValidate.php

@@ -0,0 +1,112 @@
+<?php
+// +----------------------------------------------------------------------
+// | likeadmin快速开发前后端分离管理后台(PHP版)
+// +----------------------------------------------------------------------
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
+// | 开源版本可自由商用,可去除界面版权logo
+// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
+// | github下载:https://github.com/likeshop-github/likeadmin
+// | 访问官网:https://www.likeadmin.cn
+// | likeadmin团队 版权所有 拥有最终解释权
+// +----------------------------------------------------------------------
+// | author: likeadminTeam
+// +----------------------------------------------------------------------
+
+namespace app\adminapi\validate\master_worker;
+
+
+use app\common\validate\BaseValidate;
+
+
+/**
+ * EngineerSettlement验证器
+ * Class EngineerSettlementValidate
+ * @package app\adminapi\validate
+ */
+class EngineerSettlementValidate extends BaseValidate
+{
+
+     /**
+      * 设置校验规则
+      * @var string[]
+      */
+    protected $rule = [
+        'id' => 'require',
+        'master_worker_id' => 'require',
+        'worker_number' => 'require',
+        'engineer_name' => 'require',
+        'original_balance' => 'require',
+        'total_settlement_amount' => 'require',
+        'deduction_amount' => 'require',
+        'final_settlement_amount' => 'require',
+        'settlement_time' => 'require',
+
+    ];
+
+
+    /**
+     * 参数描述
+     * @var string[]
+     */
+    protected $field = [
+        'id' => 'id',
+        'master_worker_id' => '工程师ID',
+        'worker_number' => '工程师编号',
+        'engineer_name' => '工程师姓名',
+        'original_balance' => '工程师原始余额',
+        'total_settlement_amount' => '工程师总结算金额',
+        'deduction_amount' => '工程师扣款金额',
+        'final_settlement_amount' => '工程师最终结算金额',
+        'settlement_time' => '结算时间',
+
+    ];
+
+
+    /**
+     * @notes 添加场景
+     * @return EngineerSettlementValidate
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function sceneAdd()
+    {
+        return $this->only(['master_worker_id','worker_number','engineer_name','original_balance','total_settlement_amount','deduction_amount','final_settlement_amount','settlement_time']);
+    }
+
+
+    /**
+     * @notes 编辑场景
+     * @return EngineerSettlementValidate
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function sceneEdit()
+    {
+        return $this->only(['id','master_worker_id','worker_number','engineer_name','original_balance','total_settlement_amount','deduction_amount','final_settlement_amount','settlement_time']);
+    }
+
+
+    /**
+     * @notes 删除场景
+     * @return EngineerSettlementValidate
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function sceneDelete()
+    {
+        return $this->only(['id']);
+    }
+
+
+    /**
+     * @notes 详情场景
+     * @return EngineerSettlementValidate
+     * @author likeadmin
+     * @date 2024/11/15 17:21
+     */
+    public function sceneDetail()
+    {
+        return $this->only(['id']);
+    }
+
+}

+ 34 - 0
app/common/model/master_worker/EngineerSettlement.php

@@ -0,0 +1,34 @@
+<?php
+// +----------------------------------------------------------------------
+// | likeadmin快速开发前后端分离管理后台(PHP版)
+// +----------------------------------------------------------------------
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
+// | 开源版本可自由商用,可去除界面版权logo
+// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
+// | github下载:https://github.com/likeshop-github/likeadmin
+// | 访问官网:https://www.likeadmin.cn
+// | likeadmin团队 版权所有 拥有最终解释权
+// +----------------------------------------------------------------------
+// | author: likeadminTeam
+// +----------------------------------------------------------------------
+
+namespace app\common\model\master_worker;
+
+
+use app\common\model\BaseModel;
+
+
+
+/**
+ * EngineerSettlement模型
+ * Class EngineerSettlement
+ * @package app\common\model
+ */
+class EngineerSettlement extends BaseModel
+{
+    
+    protected $name = 'engineer_settlement';
+    
+
+    
+}