This commit is contained in:
weiz 2024-03-25 13:43:08 +08:00
parent 3abe30b2fc
commit bc70ca1ed0
2 changed files with 251 additions and 233 deletions

View File

@ -13,24 +13,24 @@
// +---------------------------------------------------------------------- // +----------------------------------------------------------------------
namespace app\adminapi\controller\project; namespace app\adminapi\controller\project;
use app\adminapi\controller\BaseAdminController; use app\adminapi\controller\BaseAdminController;
use app\adminapi\lists\project\ProjectSettlementLists; use app\adminapi\lists\project\ProjectSettlementLists;
use app\adminapi\logic\project\ProjectSettlementLogic; use app\adminapi\logic\project\ProjectSettlementLogic;
use app\adminapi\validate\project\ProjectSettlementValidate; use app\adminapi\validate\project\ProjectSettlementValidate;
use app\common\model\oa\Flow; use app\common\model\oa\Flow;
use app\common\model\oa\FlowType; use app\common\model\oa\FlowType;
/** /**
* 甲方结算控制器 * 甲方结算控制器
* Class ProjectSettlementController * Class ProjectSettlementController
* @package app\adminapi\controller\project * @package app\adminapi\controller\project
*/ */
class ProjectSettlementController extends BaseAdminController class ProjectSettlementController extends BaseAdminController
{ {
/** /**
@ -54,13 +54,30 @@ class ProjectSettlementController extends BaseAdminController
public function add() public function add()
{ {
$params = (new ProjectSettlementValidate())->post()->goCheck('add'); $params = (new ProjectSettlementValidate())->post()->goCheck('add');
$result = ProjectSettlementLogic::add($params,$this->adminId); $result = ProjectSettlementLogic::add($params, $this->adminId);
if (true === $result) { if (true === $result) {
return $this->success('添加成功', [], 1, 1); return $this->success('添加成功', [], 1, 1);
} }
return $this->fail(ProjectSettlementLogic::getError()); return $this->fail(ProjectSettlementLogic::getError());
} }
public function edit()
{
$params = (new ProjectSettlementValidate())->post()->goCheck('edit');
$result = ProjectSettlementLogic::edit($params);
if (true === $result) {
return $this->success('编辑成功', [], 1, 1);
}
return $this->fail(ProjectSettlementLogic::getError());
}
public function delete()
{
$params = (new ProjectSettlementValidate())->post()->goCheck('delete');
ProjectSettlementLogic::delete($params);
return $this->success('编辑成功', [], 1, 1);
}
/** /**
* @notes 获取甲方结算详情 * @notes 获取甲方结算详情
@ -77,16 +94,16 @@ class ProjectSettlementController extends BaseAdminController
public function flows(): \think\response\Json public function flows(): \think\response\Json
{ {
$flow_type = FlowType::where('type',4)->where('name','jfjs')->findOrEmpty(); $flow_type = FlowType::where('type', 4)->where('name', 'jfjs')->findOrEmpty();
$data = Flow::field('id,name')->where('flow_cate',$flow_type['id'])->where('status',2)->select(); $data = Flow::field('id,name')->where('flow_cate', $flow_type['id'])->where('status', 2)->select();
return $this->success('请求成功',$data->toArray()); return $this->success('请求成功', $data->toArray());
} }
//添加审批 //添加审批
public function approve(): \think\response\Json public function approve(): \think\response\Json
{ {
$params = (new ProjectSettlementValidate())->post()->goCheck('approve'); $params = (new ProjectSettlementValidate())->post()->goCheck('approve');
$result = ProjectSettlementLogic::approve($params,$this->adminId); $result = ProjectSettlementLogic::approve($params, $this->adminId);
if (true === $result) { if (true === $result) {
return $this->success('提交审核信息成功', [], 1, 1); return $this->success('提交审核信息成功', [], 1, 1);
} }
@ -94,4 +111,4 @@ class ProjectSettlementController extends BaseAdminController
} }
} }

View File

@ -12,26 +12,26 @@
// | author: likeadminTeam // | author: likeadminTeam
// +---------------------------------------------------------------------- // +----------------------------------------------------------------------
namespace app\adminapi\logic\project; namespace app\adminapi\logic\project;
use app\common\model\contract\Contract; use app\common\logic\BaseLogic;
use app\common\model\contract\ContractNegotiation; use app\common\model\contract\Contract;
use app\common\model\custom\Custom; use app\common\model\contract\ContractNegotiation;
use app\common\model\oa\FlowApprove; use app\common\model\custom\Custom;
use app\common\model\project\Project; use app\common\model\oa\FlowApprove;
use app\common\model\project\ProjectSettlement; use app\common\model\project\Project;
use app\common\logic\BaseLogic; use app\common\model\project\ProjectSettlement;
use think\facade\Db; use think\facade\Db;
/** /**
* 甲方结算逻辑 * 甲方结算逻辑
* Class ProjectSettlementLogic * Class ProjectSettlementLogic
* @package app\adminapi\logic\project * @package app\adminapi\logic\project
*/ */
class ProjectSettlementLogic extends BaseLogic class ProjectSettlementLogic extends BaseLogic
{ {
/** /**
@ -41,18 +41,18 @@ class ProjectSettlementLogic extends BaseLogic
* @author likeadmin * @author likeadmin
* @date 2023/12/29 10:22 * @date 2023/12/29 10:22
*/ */
public static function add(array $params,$admin_id): bool public static function add(array $params, $admin_id): bool
{ {
Db::startTrans(); Db::startTrans();
try { try {
$res = ProjectSettlement::create([ ProjectSettlement::create([
'settlement_code' => data_unique_code('甲方结算'), 'settlement_code' => data_unique_code('甲方结算'),
'project_id' => $params['project_id'], 'project_id' => $params['project_id'],
'contract_id' => $params['contract_id'], 'contract_id' => $params['contract_id'],
'settlement_amount' => $params['settlement_amount'], 'settlement_amount' => $params['settlement_amount'],
'settlement_date' => strtotime($params['settlement_date']), 'settlement_date' => strtotime($params['settlement_date']),
'remark' => $params['remark'], 'remark' => $params['remark'],
'annex' => $params['annex']? json_encode($params['annex']) : null, 'annex' => $params['annex'] ? json_encode($params['annex']) : null,
'add_user' => $admin_id 'add_user' => $admin_id
]); ]);
Db::commit(); Db::commit();
@ -82,7 +82,7 @@ class ProjectSettlementLogic extends BaseLogic
'settlement_amount' => $params['settlement_amount'], 'settlement_amount' => $params['settlement_amount'],
'settlement_date' => strtotime($params['settlement_date']), 'settlement_date' => strtotime($params['settlement_date']),
'remark' => $params['remark'], 'remark' => $params['remark'],
'annex' => $params['annex']? json_encode($params['annex']) : null, 'annex' => $params['annex'] ? json_encode($params['annex']) : null,
'update_time' => time() 'update_time' => time()
]); ]);
Db::commit(); Db::commit();
@ -118,9 +118,9 @@ class ProjectSettlementLogic extends BaseLogic
public static function detail($params): array public static function detail($params): array
{ {
$data = ProjectSettlement::field('id,settlement_code,project_id,contract_id,settlement_amount,settlement_date,remark,annex,approve_id')->findOrEmpty($params['id'])->toArray(); $data = ProjectSettlement::field('id,settlement_code,project_id,contract_id,settlement_amount,settlement_date,remark,annex,approve_id')->findOrEmpty($params['id'])->toArray();
$project = Project::field('custom_id,name,project_code')->where('id',$data['project_id'])->findOrEmpty(); $project = Project::field('custom_id,name,project_code')->where('id', $data['project_id'])->findOrEmpty();
$contract = Contract::field('contract_name,contract_code,amount')->where('id',$data['contract_id'])->findOrEmpty(); $contract = Contract::field('contract_name,contract_code,amount')->where('id', $data['contract_id'])->findOrEmpty();
$custom = Custom::field('name')->where('id',$project['custom_id'])->findOrEmpty(); $custom = Custom::field('name')->where('id', $project['custom_id'])->findOrEmpty();
$data['project_name'] = $project['name']; $data['project_name'] = $project['name'];
$data['project_code'] = $project['project_code']; $data['project_code'] = $project['project_code'];
$data['contract_name'] = $contract['contract_name']; $data['contract_name'] = $contract['contract_name'];
@ -129,18 +129,19 @@ class ProjectSettlementLogic extends BaseLogic
//合同金额 //合同金额
$data['contract_amount'] = $contract['amount']; $data['contract_amount'] = $contract['amount'];
//洽商金额 //洽商金额
$data['negotiation_amount'] = ContractNegotiation::where('contract_id',$data['contract_id'])->sum('negotiation_amount'); $data['negotiation_amount'] = ContractNegotiation::where('contract_id', $data['contract_id'])->sum('negotiation_amount');
//结算差异 //结算差异
$data['settlement_difference'] = bcsub(($data['contract_amount']+$data['negotiation_amount']),$data['settlement_amount']); $data['settlement_difference'] = bcsub(($data['contract_amount'] + $data['negotiation_amount']), $data['settlement_amount']);
$approve_data = FlowApprove::where('id',$data['approve_id'])->findOrEmpty(); $approve_data = FlowApprove::where('id', $data['approve_id'])->findOrEmpty();
$data['approve_check_status'] = $approve_data['check_status']; $data['approve_check_status'] = $approve_data['check_status'];
return $data; return $data;
} }
public static function approve($params,$admin_id): bool{ public static function approve($params, $admin_id): bool
$data = ProjectSettlement::where('id',$params['id'])->findOrEmpty(); {
$approve_data = FlowApprove::where('id',$data['approve_id'])->findOrEmpty(); $data = ProjectSettlement::where('id', $params['id'])->findOrEmpty();
if(!empty($data['approve_id']) && $approve_data['check_status'] != 3){ $approve_data = FlowApprove::where('id', $data['approve_id'])->findOrEmpty();
if (!empty($data['approve_id']) && $approve_data['check_status'] != 3) {
self::setError('当前内容存在审核信息,请勿重复提交'); self::setError('当前内容存在审核信息,请勿重复提交');
return false; return false;
} }
@ -154,8 +155,8 @@ class ProjectSettlementLogic extends BaseLogic
$params['flow_id'], $params['flow_id'],
$admin_id $admin_id
); );
if($res){ if ($res) {
ProjectSettlement::where('id',$params['id'])->update([ ProjectSettlement::where('id', $params['id'])->update([
'approve_id' => $res, 'approve_id' => $res,
]); ]);
} }
@ -167,4 +168,4 @@ class ProjectSettlementLogic extends BaseLogic
return false; return false;
} }
} }
} }