This commit is contained in:
weiz 2024-03-25 14:18:47 +08:00
parent bc70ca1ed0
commit 23a6b23314
2 changed files with 287 additions and 287 deletions

View File

@ -11,118 +11,118 @@
// +----------------------------------------------------------------------
// | author: likeadminTeam
// +----------------------------------------------------------------------
namespace app\adminapi\controller\project;
use app\adminapi\controller\BaseAdminController;
use app\adminapi\lists\project\ProjectTotalBudgetLists;
use app\adminapi\logic\project\ProjectTotalBudgetLogic;
use app\adminapi\validate\project\ProjectTotalBudgetValidate;
use app\common\model\oa\Flow;
use app\common\model\oa\FlowType;
/**
* 项目总预算控制器
* Class ProjectTotalBudgetController
* @package app\adminapi\controller\project
*/
class ProjectTotalBudgetController extends BaseAdminController
{
/**
* @notes 获取项目总预算列表
* @return \think\response\Json
* @author likeadmin
* @date 2024/01/08 14:25
*/
public function lists()
{
return $this->dataLists(new ProjectTotalBudgetLists());
}
/**
* @notes 添加项目总预算
* @return \think\response\Json
* @author likeadmin
* @date 2024/01/08 14:25
*/
public function add()
{
$params = (new ProjectTotalBudgetValidate())->post()->goCheck('add');
$result = ProjectTotalBudgetLogic::add($params,$this->adminId);
if (true === $result) {
return $this->success('添加成功', [], 1, 1);
}
return $this->fail(ProjectTotalBudgetLogic::getError());
}
/**
* @notes 编辑项目总预算
* @return \think\response\Json
* @author likeadmin
* @date 2024/01/08 14:25
*/
public function edit()
{
$params = (new ProjectTotalBudgetValidate())->post()->goCheck('edit');
$result = ProjectTotalBudgetLogic::edit($params);
if (true === $result) {
return $this->success('编辑成功', [], 1, 1);
}
return $this->fail(ProjectTotalBudgetLogic::getError());
}
/**
* @notes 删除项目总预算
* @return \think\response\Json
* @author likeadmin
* @date 2024/01/08 14:25
*/
public function delete()
{
$params = (new ProjectTotalBudgetValidate())->post()->goCheck('delete');
ProjectTotalBudgetLogic::delete($params);
return $this->success('删除成功', [], 1, 1);
}
/**
* @notes 获取项目总预算详情
* @return \think\response\Json
* @author likeadmin
* @date 2024/01/08 14:25
*/
public function detail()
{
$params = (new ProjectTotalBudgetValidate())->goCheck('detail');
$result = ProjectTotalBudgetLogic::detail($params);
return $this->data($result);
}
public function flows(): \think\response\Json
{
$flow_type = FlowType::where('type',4)->where('name','xmzys')->findOrEmpty();
$data = Flow::field('id,name')->where('flow_cate',$flow_type['id'])->where('status',2)->select();
return $this->success('请求成功',$data->toArray());
}
//添加审批
public function approve(): \think\response\Json
namespace app\adminapi\controller\project;
use app\adminapi\controller\BaseAdminController;
use app\adminapi\lists\project\ProjectTotalBudgetLists;
use app\adminapi\logic\project\ProjectTotalBudgetLogic;
use app\adminapi\validate\project\ProjectTotalBudgetValidate;
use app\common\model\oa\Flow;
use app\common\model\oa\FlowType;
/**
* 项目总预算控制器
* Class ProjectTotalBudgetController
* @package app\adminapi\controller\project
*/
class ProjectTotalBudgetController extends BaseAdminController
{
$params = (new ProjectTotalBudgetValidate())->post()->goCheck('approve');
$result = ProjectTotalBudgetLogic::approve($params,$this->adminId);
if (true === $result) {
return $this->success('提交审核信息成功', [], 1, 1);
/**
* @notes 获取项目总预算列表
* @return \think\response\Json
* @author likeadmin
* @date 2024/01/08 14:25
*/
public function lists()
{
return $this->dataLists(new ProjectTotalBudgetLists());
}
return $this->fail(ProjectTotalBudgetLogic::getError());
}
}
/**
* @notes 添加项目总预算
* @return \think\response\Json
* @author likeadmin
* @date 2024/01/08 14:25
*/
public function add()
{
$params = (new ProjectTotalBudgetValidate())->post()->goCheck('add');
$result = ProjectTotalBudgetLogic::add($params);
if (true === $result) {
return $this->success('添加成功', [], 1, 1);
}
return $this->fail(ProjectTotalBudgetLogic::getError());
}
/**
* @notes 编辑项目总预算
* @return \think\response\Json
* @author likeadmin
* @date 2024/01/08 14:25
*/
public function edit()
{
$params = (new ProjectTotalBudgetValidate())->post()->goCheck('edit');
$result = ProjectTotalBudgetLogic::edit($params);
if (true === $result) {
return $this->success('编辑成功', [], 1, 1);
}
return $this->fail(ProjectTotalBudgetLogic::getError());
}
/**
* @notes 删除项目总预算
* @return \think\response\Json
* @author likeadmin
* @date 2024/01/08 14:25
*/
public function delete()
{
$params = (new ProjectTotalBudgetValidate())->post()->goCheck('delete');
ProjectTotalBudgetLogic::delete($params);
return $this->success('删除成功', [], 1, 1);
}
/**
* @notes 获取项目总预算详情
* @return \think\response\Json
* @author likeadmin
* @date 2024/01/08 14:25
*/
public function detail()
{
$params = (new ProjectTotalBudgetValidate())->goCheck('detail');
$result = ProjectTotalBudgetLogic::detail($params);
return $this->data($result);
}
public function flows(): \think\response\Json
{
$flow_type = FlowType::where('type', 4)->where('name', 'xmzys')->findOrEmpty();
$data = Flow::field('id,name')->where('flow_cate', $flow_type['id'])->where('status', 2)->select();
return $this->success('请求成功', $data->toArray());
}
//添加审批
public function approve(): \think\response\Json
{
$params = (new ProjectTotalBudgetValidate())->post()->goCheck('approve');
$result = ProjectTotalBudgetLogic::approve($params, $this->adminId);
if (true === $result) {
return $this->success('提交审核信息成功', [], 1, 1);
}
return $this->fail(ProjectTotalBudgetLogic::getError());
}
}

View File

@ -11,183 +11,183 @@
// +----------------------------------------------------------------------
// | author: likeadminTeam
// +----------------------------------------------------------------------
namespace app\adminapi\logic\project;
use app\common\model\dept\Dept;
use app\common\model\dept\Orgs;
use app\common\model\oa\FlowApprove;
use app\common\model\project\Project;
use app\common\model\project\ProjectTotalBudget;
use app\common\logic\BaseLogic;
use think\facade\Db;
/**
* 项目总预算逻辑
* Class ProjectTotalBudgetLogic
* @package app\adminapi\logic\project
*/
class ProjectTotalBudgetLogic extends BaseLogic
{
/**
* @notes 添加项目总预算
* @param array $params
* @return bool
* @author likeadmin
* @date 2024/01/08 14:25
*/
public static function add(array $params,$admin_id): bool
{
Db::startTrans();
try {
$res = ProjectTotalBudget::create([
'org_id' => $params['org_id'],
'dept_id' => $params['dept_id'],
'project_id' => $params['project_id'],
'total_budget_code' => data_unique_code('项目总预算'),
'contract_amount' => $params['contract_amount'],
'cl_cost' => $params['cl_cost'] ?? 0,
'fb_cost' => $params['fb_cost'] ?? 0,
'rg_cost' => $params['rg_cost'] ?? 0,
'fy_cost' => $params['fy_cost'] ?? 0,
'jj_cost' => $params['jj_cost'] ?? 0,
'remark' => $params['remark'] ?? '',
'budget_list' => !empty($params['budget_list']) ? $params['budget_list'] : null,
'budget_date' => strtotime($params['budget_date']),
'project_manager' => $params['project_manager'],
]);
Project::where('id',$params['project_id'])->update([
'is_budget' => 1,
'update_time' => time(),
]);
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/01/08 14:25
*/
public static function edit(array $params): bool
{
Db::startTrans();
try {
ProjectTotalBudget::where('id', $params['id'])->update([
'contract_amount' => $params['contract_amount'],
'cl_cost' => $params['cl_cost'] ?? 0,
'fb_cost' => $params['fb_cost'] ?? 0,
'rg_cost' => $params['rg_cost'] ?? 0,
'fy_cost' => $params['fy_cost'] ?? 0,
'jj_cost' => $params['jj_cost'] ?? 0,
'remark' => $params['remark'] ?? '',
'budget_list' => !empty($params['budget_list']) ? $params['budget_list'] : null,
'budget_date' => strtotime($params['budget_date']),
'project_manager' => $params['project_manager'],
'update_time' => time(),
]);
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/01/08 14:25
*/
public static function delete(array $params): bool
{
return ProjectTotalBudget::destroy($params['id']);
}
/**
* @notes 获取项目总预算详情
* @param $params
* @return array
* @author likeadmin
* @date 2024/01/08 14:25
*/
public static function detail($params): array
{
$data = ProjectTotalBudget::field('id,org_id,dept_id,project_id,total_budget_code,contract_amount,cl_cost,fb_cost,rg_cost,fy_cost,jj_cost,remark,budget_list,budget_date,project_manager,approve_id')
->findOrEmpty($params['id']);
$org = Orgs::field('name')->where('id',$data['org_id'])->findOrEmpty();
$dept = Dept::field('name')->where('id',$data['dept_id'])->findOrEmpty();
$project = Project::field('name,project_code')->where('id',$data['project_id'])->findOrEmpty();
$data['org_name'] = $org['name'];
$data['dept_name'] = $dept['name'];
$data['project_name'] = $project['name'];
$data['project_code'] = $project['project_code'];
//总成本
$data['total_cost'] = $data['cl_cost'] + $data['fb_cost'] + $data['rg_cost'] + $data['fy_cost'] + $data['jj_cost'];
//项目利润
$data['profit'] = $data['contract_amount'] - $data['total_cost'];
//利润率
$data['profit_rate'] = $data['profit'] / $data['contract_amount'];
//材料成本占比
$data['cl_cost_ratio'] = number_format($data['cl_cost'] / $data['total_cost'],2);
//分包成本占比
$data['fb_cost_ratio'] = number_format($data['fb_cost'] / $data['total_cost'],2);
//人工成本占比
$data['rg_cost_ratio'] = number_format($data['rg_cost'] / $data['total_cost'],2);
//费用成本占比
$data['fy_cost_ratio'] = number_format($data['fy_cost'] / $data['total_cost'],2);
//机具成本占比
$data['jj_cost_ratio'] = number_format($data['jj_cost'] / $data['total_cost'],2);
$approve_data = FlowApprove::where('id',$data['approve_id'])->findOrEmpty();
$data['approve_check_status'] = $approve_data['check_status'];
return $data->toArray();
}
public static function approve($params,$admin_id): bool{
$data = ProjectTotalBudget::where('id',$params['id'])->findOrEmpty();
$approve_data = FlowApprove::where('id',$data['approve_id'])->findOrEmpty();
if(!empty($data['approve_id']) && $approve_data['check_status'] != 3){
self::setError('当前内容存在审核信息,请勿重复提交');
return false;
}
Db::startTrans();
try {
$res = addApprove(
'项目总预算',
$params['id'],
'app\common\model\project\ProjectTotalBudget',
$params['path'],
$params['flow_id'],
$admin_id
);
if($res){
ProjectTotalBudget::where('id',$params['id'])->update([
'approve_id' => $res,
namespace app\adminapi\logic\project;
use app\common\logic\BaseLogic;
use app\common\model\dept\Dept;
use app\common\model\dept\Orgs;
use app\common\model\oa\FlowApprove;
use app\common\model\project\Project;
use app\common\model\project\ProjectTotalBudget;
use think\facade\Db;
/**
* 项目总预算逻辑
* Class ProjectTotalBudgetLogic
* @package app\adminapi\logic\project
*/
class ProjectTotalBudgetLogic extends BaseLogic
{
/**
* @notes 添加项目总预算
* @param array $params
* @return bool
* @author likeadmin
* @date 2024/01/08 14:25
*/
public static function add(array $params): bool
{
Db::startTrans();
try {
$res = ProjectTotalBudget::create([
'org_id' => $params['org_id'],
'dept_id' => $params['dept_id'],
'project_id' => $params['project_id'],
'total_budget_code' => data_unique_code('项目总预算'),
'contract_amount' => $params['contract_amount'],
'cl_cost' => $params['cl_cost'] ?? 0,
'fb_cost' => $params['fb_cost'] ?? 0,
'rg_cost' => $params['rg_cost'] ?? 0,
'fy_cost' => $params['fy_cost'] ?? 0,
'jj_cost' => $params['jj_cost'] ?? 0,
'remark' => $params['remark'] ?? '',
'budget_list' => $params['budget_list'] ? json_encode($params['budget_list']) : null,
'budget_date' => strtotime($params['budget_date']),
'project_manager' => $params['project_manager'],
]);
Project::where('id', $params['project_id'])->update([
'is_budget' => 1,
'update_time' => time(),
]);
Db::commit();
return true;
} catch (\Exception $e) {
Db::rollback();
self::setError($e->getMessage());
return false;
}
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/01/08 14:25
*/
public static function edit(array $params): bool
{
Db::startTrans();
try {
ProjectTotalBudget::where('id', $params['id'])->update([
'contract_amount' => $params['contract_amount'],
'cl_cost' => $params['cl_cost'] ?? 0,
'fb_cost' => $params['fb_cost'] ?? 0,
'rg_cost' => $params['rg_cost'] ?? 0,
'fy_cost' => $params['fy_cost'] ?? 0,
'jj_cost' => $params['jj_cost'] ?? 0,
'remark' => $params['remark'] ?? '',
'budget_list' => $params['budget_list'] ? json_encode($params['budget_list']) : null,
'budget_date' => strtotime($params['budget_date']),
'project_manager' => $params['project_manager'],
'update_time' => time(),
]);
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/01/08 14:25
*/
public static function delete(array $params): bool
{
return ProjectTotalBudget::destroy($params['id']);
}
/**
* @notes 获取项目总预算详情
* @param $params
* @return array
* @author likeadmin
* @date 2024/01/08 14:25
*/
public static function detail($params): array
{
$data = ProjectTotalBudget::withoutField('create_time,update_time,delete_time')->findOrEmpty($params['id']);
$org = Orgs::field('name')->where('id', $data['org_id'])->findOrEmpty();
$dept = Dept::field('name')->where('id', $data['dept_id'])->findOrEmpty();
$project = Project::field('name,project_code')->where('id', $data['project_id'])->findOrEmpty();
$data['org_name'] = $org['name'];
$data['dept_name'] = $dept['name'];
$data['project_name'] = $project['name'];
$data['project_code'] = $project['project_code'];
//总成本
$data['total_cost'] = $data['cl_cost'] + $data['fb_cost'] + $data['rg_cost'] + $data['fy_cost'] + $data['jj_cost'];
//项目利润
$data['profit'] = $data['contract_amount'] - $data['total_cost'];
//利润率
$data['profit_rate'] = $data['profit'] / $data['contract_amount'];
//材料成本占比
$data['cl_cost_ratio'] = number_format($data['cl_cost'] / $data['total_cost'], 2);
//分包成本占比
$data['fb_cost_ratio'] = number_format($data['fb_cost'] / $data['total_cost'], 2);
//人工成本占比
$data['rg_cost_ratio'] = number_format($data['rg_cost'] / $data['total_cost'], 2);
//费用成本占比
$data['fy_cost_ratio'] = number_format($data['fy_cost'] / $data['total_cost'], 2);
//机具成本占比
$data['jj_cost_ratio'] = number_format($data['jj_cost'] / $data['total_cost'], 2);
$approve_data = FlowApprove::where('id', $data['approve_id'])->findOrEmpty();
$data['approve_check_status'] = $approve_data['check_status'];
return $data->toArray();
}
public static function approve($params, $admin_id): bool
{
$data = ProjectTotalBudget::where('id', $params['id'])->findOrEmpty();
$approve_data = FlowApprove::where('id', $data['approve_id'])->findOrEmpty();
if (!empty($data['approve_id']) && $approve_data['check_status'] != 3) {
self::setError('当前内容存在审核信息,请勿重复提交');
return false;
}
Db::startTrans();
try {
$res = addApprove(
'项目总预算',
$params['id'],
'app\common\model\project\ProjectTotalBudget',
$params['path'],
$params['flow_id'],
$admin_id
);
if ($res) {
ProjectTotalBudget::where('id', $params['id'])->update([
'approve_id' => $res,
]);
}
Db::commit();
return true;
} catch (\Exception $e) {
Db::rollback();
self::setError($e->getMessage());
return false;
}
}
}