188 lines
6.7 KiB
PHP
188 lines
6.7 KiB
PHP
<?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\supervision_work;
|
||
|
||
|
||
use app\common\model\auth\Admin;
|
||
use app\common\model\supervision_project\SupervisionParticipatingUnits;
|
||
use app\common\model\supervision_project\SupervisionProject;
|
||
use app\common\model\supervision_work\SupervisionNotice;
|
||
use app\common\logic\BaseLogic;
|
||
use app\common\model\supervision_work\SupervisionNoticeProblem;
|
||
use think\facade\Db;
|
||
|
||
|
||
/**
|
||
* 工程监理--监理通知单逻辑
|
||
* Class SupervisionNoticeLogic
|
||
* @package app\adminapi\logic\supervision_work
|
||
*/
|
||
class SupervisionNoticeLogic extends BaseLogic
|
||
{
|
||
|
||
|
||
/**
|
||
* @notes 添加工程监理--监理通知单
|
||
* @param array $params
|
||
* @return bool
|
||
* @author likeadmin
|
||
* @date 2024/03/01 09:20
|
||
*/
|
||
public static function add(array $params,$admin_id): bool
|
||
{
|
||
Db::startTrans();
|
||
try {
|
||
$res = SupervisionNotice::create([
|
||
'project_id' => $params['project_id'],
|
||
'code' => data_unique_code('JLTZD'),
|
||
'reply_date' => !empty($params['reply_date']) ? strtotime($params['reply_date']) : 0,
|
||
'company_id' => $params['company_id'],
|
||
'notify_user' => $params['notify_user'],
|
||
'issue_date' => !empty($params['issue_date']) ? strtotime($params['issue_date']) : 0,
|
||
'annex' => $params['annex'] ? json_encode($params['annex']) : null,
|
||
'create_user' => $admin_id,
|
||
]);
|
||
if(!empty($params['problem'])){
|
||
foreach($params['problem'] as $v){
|
||
SupervisionNoticeProblem::create([
|
||
'notice_id' => $res->id,
|
||
'problem_description' => $v['problem_description'],
|
||
'content_description' => $v['content_description'],
|
||
'demand_description' => $v['demand_description'],
|
||
]);
|
||
}
|
||
}
|
||
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/03/01 09:20
|
||
*/
|
||
public static function edit(array $params): bool
|
||
{
|
||
Db::startTrans();
|
||
try {
|
||
SupervisionNotice::where('id', $params['id'])->update([
|
||
'project_id' => $params['project_id'],
|
||
'reply_date' => !empty($params['reply_date']) ? strtotime($params['reply_date']) : 0,
|
||
'company_id' => $params['company_id'],
|
||
'notify_user' => $params['notify_user'],
|
||
'issue_date' => !empty($params['issue_date']) ? strtotime($params['issue_date']) : 0,
|
||
'annex' => $params['annex'] ? json_encode($params['annex']) : null,
|
||
'update_time' => time(),
|
||
]);
|
||
if(!empty($params['problem'])){
|
||
foreach($params['problem'] as $v){
|
||
if(!empty($v['id'])){
|
||
SupervisionNoticeProblem::where('id',$v['id'])->update([
|
||
'notice_id' => $params['id'],
|
||
'problem_description' => $v['problem_description'],
|
||
'content_description' => $v['content_description'],
|
||
'demand_description' => $v['demand_description'],
|
||
]);
|
||
}else{
|
||
SupervisionNoticeProblem::create([
|
||
'notice_id' => $params['id'],
|
||
'problem_description' => $v['problem_description'],
|
||
'content_description' => $v['content_description'],
|
||
'demand_description' => $v['demand_description'],
|
||
]);
|
||
}
|
||
}
|
||
}
|
||
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/03/01 09:20
|
||
*/
|
||
public static function reply(array $params): bool
|
||
{
|
||
Db::startTrans();
|
||
try {
|
||
SupervisionNotice::where('id', $params['id'])->update([
|
||
'rectification_reply_time' => !empty($params['rectification_reply_time']) ? strtotime($params['rectification_reply_time']) : 0,
|
||
'rectification_reply_user' => $params['rectification_reply_user'],
|
||
'rectification_reply_opinions' => $params['rectification_reply_opinions'],
|
||
'rectification_reply_annex' => $params['rectification_reply_annex'] ? json_encode($params['rectification_reply_annex']) : null,
|
||
]);
|
||
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/03/01 09:20
|
||
*/
|
||
public static function delete(array $params): bool
|
||
{
|
||
$problem = SupervisionNoticeProblem::where('notice_id',$params['id'])->findOrEmpty();
|
||
if(!$problem->isEmpty()){
|
||
self::setError('该数据下存在通知问题数据,请先删除通知问题数据');
|
||
return false;
|
||
}
|
||
return SupervisionNotice::destroy($params['id']);
|
||
}
|
||
|
||
|
||
/**
|
||
* @notes 获取工程监理--监理通知单详情
|
||
* @param $params
|
||
* @return array
|
||
* @author likeadmin
|
||
* @date 2024/03/01 09:20
|
||
*/
|
||
public static function detail($params): array
|
||
{
|
||
$data = SupervisionNotice::withoutField('update_time,delete_time')->findOrEmpty($params['id']);
|
||
$project = SupervisionProject::field('project_name')->where('id',$data['project_id'])->findOrEmpty();
|
||
$company = SupervisionParticipatingUnits::field('unit_name')->where('id',$data['company_id'])->findOrEmpty();
|
||
$create_user = Admin::field('name')->where('id',$data['create_user'])->findOrEmpty();
|
||
$data['project_name'] = $project['project_name'];
|
||
$data['company_name'] = $company['unit_name'];
|
||
$data['create_user_name'] = $create_user['name'];
|
||
return $data->toArray();
|
||
}
|
||
} |