Browse Source

后台编辑统一信息状态、接口提交统一信息状态

liugc 1 year ago
parent
commit
7d5c958f00

+ 12 - 0
app/adminapi/controller/master_worker/BankAccountController.php

@@ -20,6 +20,7 @@ use app\adminapi\controller\BaseAdminController;
 use app\adminapi\lists\master_worker\BankAccountLists;
 use app\adminapi\logic\master_worker\BankAccountLogic;
 use app\adminapi\validate\master_worker\BankAccountValidate;
+use app\common\logic\MasterWorkerExamineLogic;
 
 
 /**
@@ -54,6 +55,7 @@ class BankAccountController extends BaseAdminController
         $params = (new BankAccountValidate())->post()->goCheck('add');
         $result = BankAccountLogic::add($params);
         if (true === $result) {
+            MasterWorkerExamineLogic::updateEngineerInformation($params['worker_id']);
             return $this->success('添加成功', [], 1, 1);
         }
         return $this->fail(BankAccountLogic::getError());
@@ -71,6 +73,7 @@ class BankAccountController extends BaseAdminController
         $params = (new BankAccountValidate())->post()->goCheck('edit');
         $result = BankAccountLogic::edit($params);
         if (true === $result) {
+            MasterWorkerExamineLogic::updateEngineerInformation($params['worker_id']);
             return $this->success('编辑成功', [], 1, 1);
         }
         return $this->fail(BankAccountLogic::getError());
@@ -87,6 +90,15 @@ class BankAccountController extends BaseAdminController
     {
         $params = (new BankAccountValidate())->post()->goCheck('delete');
         BankAccountLogic::delete($params);
+        if (is_array($params['id'])) {
+            foreach ($params['id'] as $id) {
+                $info = BankAccountLogic::detail(['id'=>$id]);
+                MasterWorkerExamineLogic::updateEngineerInformation($info['worker_id']);
+            }
+        }else{
+            $info = BankAccountLogic::detail(['id'=>$params['id']]);
+            MasterWorkerExamineLogic::updateEngineerInformation($info['worker_id']);
+        }
         return $this->success('删除成功', [], 1, 1);
     }
 

+ 13 - 0
app/adminapi/controller/master_worker/MasterWorkerAgreeController.php

@@ -20,6 +20,7 @@ use app\adminapi\controller\BaseAdminController;
 use app\adminapi\lists\master_worker\MasterWorkerAgreeLists;
 use app\adminapi\logic\master_worker\MasterWorkerAgreeLogic;
 use app\adminapi\validate\master_worker\MasterWorkerAgreeValidate;
+use app\common\logic\MasterWorkerExamineLogic;
 
 
 /**
@@ -54,6 +55,7 @@ class MasterWorkerAgreeController extends BaseAdminController
         $params = (new MasterWorkerAgreeValidate())->post()->goCheck('add');
         $result = MasterWorkerAgreeLogic::add($params);
         if (true === $result) {
+            MasterWorkerExamineLogic::updateEngineerInformation($params['worker_id']);
             return $this->success('添加成功', [], 1, 1);
         }
         return $this->fail(MasterWorkerAgreeLogic::getError());
@@ -71,6 +73,8 @@ class MasterWorkerAgreeController extends BaseAdminController
         $params = (new MasterWorkerAgreeValidate())->post()->goCheck('edit');
         $result = MasterWorkerAgreeLogic::edit($params);
         if (true === $result) {
+            $info = MasterWorkerAgreeLogic::detail(['id'=>$params['id']]);
+            MasterWorkerExamineLogic::updateEngineerInformation($info['worker_id']);
             return $this->success('编辑成功', [], 1, 1);
         }
         return $this->fail(MasterWorkerAgreeLogic::getError());
@@ -87,6 +91,15 @@ class MasterWorkerAgreeController extends BaseAdminController
     {
         $params = (new MasterWorkerAgreeValidate())->post()->goCheck('delete');
         MasterWorkerAgreeLogic::delete($params);
+        if (is_array($params['id'])) {
+            foreach ($params['id'] as $id) {
+                $info = MasterWorkerAgreeLogic::detail(['id'=>$id]);
+                MasterWorkerExamineLogic::updateEngineerInformation($info['worker_id']);
+            }
+        }else{
+            $info = MasterWorkerAgreeLogic::detail(['id'=>$params['id']]);
+            MasterWorkerExamineLogic::updateEngineerInformation($info['worker_id']);
+        }
         return $this->success('删除成功', [], 1, 1);
     }
 

+ 9 - 3
app/adminapi/controller/master_worker/MasterWorkerController.php

@@ -30,8 +30,6 @@ use app\adminapi\validate\master_worker\MasterWorkerValidate;
  */
 class MasterWorkerController extends BaseAdminController
 {
-
-
     /**
      * @notes 获取列表
      * @return \think\response\Json
@@ -127,5 +125,13 @@ class MasterWorkerController extends BaseAdminController
         return $this->dataLists(new MoneyAnalysis());
     }
 
-
+    public function getAllWorkers()
+    {
+        $params = (new MasterWorkerValidate())->get();
+        $result = MasterWorkerLogic::getAllWorkers($params);
+        if (false === $result) {
+            return $this->fail(MasterWorkerLogic::getError());
+        }
+        return $this->data($result);
+    }
 }

+ 13 - 0
app/adminapi/controller/master_worker/MasterWorkerInfoController.php

@@ -20,6 +20,7 @@ use app\adminapi\controller\BaseAdminController;
 use app\adminapi\lists\master_worker\MasterWorkerInfoLists;
 use app\adminapi\logic\master_worker\MasterWorkerInfoLogic;
 use app\adminapi\validate\master_worker\MasterWorkerInfoValidate;
+use app\common\logic\MasterWorkerExamineLogic;
 
 
 /**
@@ -54,6 +55,7 @@ class MasterWorkerInfoController extends BaseAdminController
         $params = (new MasterWorkerInfoValidate())->post()->goCheck('add');
         $result = MasterWorkerInfoLogic::add($params);
         if (true === $result) {
+            MasterWorkerExamineLogic::updateEngineerInformation($params['worker_id']);
             return $this->success('添加成功', [], 1, 1);
         }
         return $this->fail(MasterWorkerInfoLogic::getError());
@@ -71,6 +73,8 @@ class MasterWorkerInfoController extends BaseAdminController
         $params = (new MasterWorkerInfoValidate())->post()->goCheck('edit');
         $result = MasterWorkerInfoLogic::edit($params);
         if (true === $result) {
+            $info = MasterWorkerInfoLogic::detail(['id'=>$params['id']]);
+            MasterWorkerExamineLogic::updateEngineerInformation($info['worker_id']);
             //审批通过 - 后续事件处理
             if($params['audit_state'] == 1){
                 // 工程师基本信息审核通知【给工程师的通知】
@@ -98,6 +102,15 @@ class MasterWorkerInfoController extends BaseAdminController
     {
         $params = (new MasterWorkerInfoValidate())->post()->goCheck('delete');
         MasterWorkerInfoLogic::delete($params);
+        if (is_array($params['id'])) {
+            foreach ($params['id'] as $id) {
+                $info = MasterWorkerInfoLogic::detail(['id'=>$id]);
+                MasterWorkerExamineLogic::updateEngineerInformation($info['worker_id']);
+            }
+        }else{
+            $info = MasterWorkerInfoLogic::detail(['id'=>$params['id']]);
+            MasterWorkerExamineLogic::updateEngineerInformation($info['worker_id']);
+        }
         return $this->success('删除成功', [], 1, 1);
     }
 

+ 15 - 0
app/adminapi/logic/master_worker/MasterWorkerLogic.php

@@ -193,4 +193,19 @@ class MasterWorkerLogic extends BaseLogic
         }
 
     }
+
+    /**
+     * 获取所有工程师选项列表
+     * @param $params
+     * @return false|string
+     */
+    public static function getAllWorkers($params){
+        try{
+            return MasterWorker::where(['is_disable'=>0])->column('id,id as value,worker_number as name,account,mobile');
+        } catch (\Exception $e){
+            self::setError($e->getMessage());
+            return false;
+        }
+
+    }
 }

+ 60 - 0
app/common/logic/MasterWorkerExamineLogic.php

@@ -0,0 +1,60 @@
+<?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\logic;
+
+use app\common\model\master_worker\MasterWorker;
+use think\facade\Db;
+
+/**
+ * MasterWorkerExamineLogic逻辑
+ * Class MasterWorkerExamineLogic
+ * @package app\common\logic
+ */
+class MasterWorkerExamineLogic extends BaseLogic
+{
+    /**
+     * @notes 查询更新工程师信息状态
+     * @param array $params
+     * @return bool
+     * @author likeadmin
+     * @date 2024/07/17 15:20
+     */
+    public static function updateEngineerInformation(int $worker_id): bool
+    {
+        Db::startTrans();
+        try {
+            $resData = MasterWorker::with(['workerInfo','workerAgree','bankAccount'])->where('id', $worker_id)->findOrEmpty()->toArray();
+            if(!isset($resData['workerInfo']['id']) || !isset($resData['workerAgree']['id']) || !isset($resData['bankAccount']['id'])) {
+                $audit_state = 3;
+            }elseif ((int)$resData['workerInfo']['audit_state'] === 0 || (int)$resData['workerAgree']['audit_state'] === 0 || (int)$resData['bankAccount']['audit_state'] === 0){
+                $audit_state = 0;
+            }elseif ((int)$resData['workerInfo']['audit_state'] === 2 || (int)$resData['workerAgree']['audit_state'] === 2 || (int)$resData['bankAccount']['audit_state'] === 2){
+                $audit_state = 2;
+            }else{
+                $audit_state = 1;
+            }
+            MasterWorker::where('id', $worker_id)->update([
+                'audit_state' => $audit_state,
+            ]);
+
+            Db::commit();
+            return true;
+        } catch (\Exception $e) {
+            Db::rollback();
+            self::setError($e->getMessage());
+            return false;
+        }
+    }
+}

+ 2 - 0
app/workerapi/controller/MasterWorkerAgreeController.php

@@ -3,6 +3,7 @@
 namespace app\workerapi\controller;
 
 use app\common\command\AddAgreementPdf;
+use app\common\logic\MasterWorkerExamineLogic;
 use app\common\model\master_worker\MasterWorkerAgree;
 use app\workerapi\logic\MasterWorkerAgreeLogic;
 use app\workerapi\validate\MasterWorkerAgreeValidate;
@@ -71,6 +72,7 @@ class MasterWorkerAgreeController extends BaseApiController
         if (false === $result) {
             return $this->fail(MasterWorkerAgreeLogic::getError());
         }
+        MasterWorkerExamineLogic::updateEngineerInformation($params['user_id']);
         return $this->success('签名成功', [], 1, 1);
     }
 }

+ 3 - 0
app/workerapi/controller/MasterWorkerController.php

@@ -2,6 +2,7 @@
 
 namespace app\workerapi\controller;
 
+use app\common\logic\MasterWorkerExamineLogic;
 use app\common\model\dict\DictData;
 use app\workerapi\logic\LoginLogic;
 use app\workerapi\logic\MasterWorkerInfoLogic;
@@ -57,6 +58,7 @@ class MasterWorkerController extends BaseApiController
         $params =  (new MasterWokerInfoValidate())->post()->goCheck('changeIdCard');
         $result = MasterWorkerInfoLogic::changeIdCard($params, $this->userId);
         if (true === $result) {
+            \app\common\logic\MasterWorkerExamineLogic::updateEngineerInformation($this->userId);
             return $this->success('操作成功', [], 1, 1);
         }
         return $this->fail(MasterWorkerInfoLogic::getError());
@@ -105,6 +107,7 @@ class MasterWorkerController extends BaseApiController
         $params =  (new BankAccountValidate())->post()->goCheck('bindBankAccount');
         $result = MasterWorkerInfoLogic::bindBankAccount($params, $this->userId);
         if (true === $result) {
+            \app\common\logic\MasterWorkerExamineLogic::updateEngineerInformation($this->userId);
             return $this->success('操作成功', [], 1, 1);
         }
         return $this->fail(MasterWorkerInfoLogic::getError());