This commit is contained in:
weiz 2024-04-05 14:47:21 +08:00
parent bae8f96514
commit 2691a5669d
11 changed files with 991 additions and 441 deletions

View File

@ -19,12 +19,13 @@
use app\adminapi\controller\BaseAdminController;
use app\adminapi\lists\cost_project\CostApprovedProjectLists;
use app\adminapi\logic\cost_project\CostApprovedProjectLogic;
use app\adminapi\logic\cost_project\CostProjectLogic;
use app\adminapi\validate\cost_project\CostApprovedProjectValidate;
use app\common\model\cost_project\CostApprovedProject;
use app\common\model\dept\Dept;
use app\common\model\financial\FinancialInvoice;
use app\common\model\financial\FinancialRefund;
use app\common\model\financial\FinancialSettlement;
use app\common\model\marketing\MarketingContract;
use app\common\model\marketing\MarketingCustom;
/**
@ -54,26 +55,30 @@
$page_no = !empty($params['page_no']) ? $params['page_no'] : 1;
$page_size = !empty($params['page_size']) ? $params['page_size'] : 15;
if (!empty($params['contract_name'])) {
$contract_ids1 = CostApprovedProject::where('contract_name', 'like', '%' . $params['contract_name'] . '%')->column('id');
$contract_ids1 = MarketingContract::where('contract_name', 'like', '%' . $params['contract_name'] . '%')->column('id');
$where[] = ['contract_id', 'in', $contract_ids1];
}
if (!empty($params['contract_num'])) {
$contract_ids2 = CostApprovedProject::where('contract_num', 'like', '%' . $params['contract_num'] . '%')->column('id');
$contract_ids2 = MarketingContract::where('contract_num', 'like', '%' . $params['contract_num'] . '%')->column('id');
$where[] = ['contract_id', 'in', $contract_ids2];
}
if (!empty($params['part_b'])) {
$contract_ids3 = CostApprovedProject::where('part_b', 'like', '%' . $params['part_b'] . '%')->column('id');
$contract_ids3 = MarketingContract::where('part_b', 'like', '%' . $params['part_b'] . '%')->column('id');
$where[] = ['contract_id', 'in', $contract_ids3];
}
if (!empty($params['contract_type'])) {
$where[] = ['contract_type', '=', $params['contract_type']];
}
$lists = CostApprovedProject::field('id,contract_num,contract_name,contract_type,business_nature,part_a,money,dept,create_date')
->where($where)->where('status', 2)
$lists = MarketingContract::field('id,contract_code,contract_name,contract_type,business_nature,part_a,signed_amount,signed_dept,create_time')
->where($where)->where('status', 1)
->page($page_no, $page_size)
->order('id desc')
->select()
->each(function ($data) {
$custom = MarketingCustom::field('name')->where('id', 'part_a')->findOrEmpty();
$dept = Dept::field('name')->where('id', $data['signed_dept'])->findOrEmpty();
$data['part_a_name'] = $custom['name'];
$data['signed_dept_name'] = $dept['name'];
$invoice_ids = FinancialInvoice::where('contract_id', $data['id'])->column('id');
//开票金额
$data['total_invoice_amount'] = FinancialInvoice::where('contract_id', $data['id'])->sum('apply_amount');
@ -104,7 +109,7 @@
}
})
->toArray();
$count = CostApprovedProject::where($where)->count();
$count = MarketingCustom::where($where)->count();
return $this->success('成功', compact('count', 'lists', 'page_no', 'page_size'));
}
@ -114,16 +119,17 @@
* @return \think\response\Json
* @author likeadmin
* @date 2024/02/20 14:16
*
* public function add()
* {
* $params = (new CostApprovedProjectValidate())->post()->goCheck('add');
* $result = CostApprovedProjectLogic::add($params);
* if (true === $result) {
* return $this->success('添加成功', [], 1, 1);
* }
* return $this->fail(CostApprovedProjectLogic::getError());
* }
*/
public function add()
{
$params = (new CostApprovedProjectValidate())->post()->goCheck('add');
$result = CostApprovedProjectLogic::add($params);
if (true === $result) {
return $this->success('添加成功', [], 1, 1);
}
return $this->fail(CostApprovedProjectLogic::getError());
}
/**
@ -131,16 +137,17 @@
* @return \think\response\Json
* @author likeadmin
* @date 2024/02/20 14:16
*
* public function edit()
* {
* $params = (new CostApprovedProjectValidate())->post()->goCheck('edit');
* $result = CostApprovedProjectLogic::edit($params);
* if (true === $result) {
* return $this->success('编辑成功', [], 1, 1);
* }
* return $this->fail(CostApprovedProjectLogic::getError());
* }
*/
public function edit()
{
$params = (new CostApprovedProjectValidate())->post()->goCheck('edit');
$result = CostApprovedProjectLogic::edit($params);
if (true === $result) {
return $this->success('编辑成功', [], 1, 1);
}
return $this->fail(CostApprovedProjectLogic::getError());
}
/**
@ -148,23 +155,17 @@
* @return \think\response\Json
* @author likeadmin
* @date 2024/02/20 14:16
*
* public function delete()
* {
* $params = (new CostApprovedProjectValidate())->post()->goCheck('delete');
* $result = CostApprovedProjectLogic::delete($params);
* if (true === $result) {
* return $this->success('删除成功', [], 1, 1);
* }
* return $this->fail(CostApprovedProjectLogic::getError());
* }
*/
public function delete()
{
$params = (new CostApprovedProjectValidate())->post()->goCheck('delete');
$result = CostApprovedProjectLogic::delete($params);
if (true === $result) {
return $this->success('删除成功', [], 1, 1);
}
return $this->fail(CostApprovedProjectLogic::getError());
}
public function createProject()
{
$params = $this->request->param();
$data = CostApprovedProjectLogic::detail($params);
$re = CostProjectLogic::createProject($data);
}
/**
* @notes 获取待立项造价项目详情

View File

@ -0,0 +1,126 @@
<?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\marketing;
use app\adminapi\controller\BaseAdminController;
use app\adminapi\lists\marketing\MarketingHandoverContractLists;
use app\adminapi\logic\marketing\MarketingHandoverContractLogic;
use app\adminapi\validate\marketing\MarketingHandoverContractValidate;
/**
* 市场经营--待移交合同控制器
* Class MarketingHandoverContractController
* @package app\adminapi\controller\marketing
*/
class MarketingHandoverContractController extends BaseAdminController
{
/**
* @notes 获取市场经营--合同信息列表
* @return \think\response\Json
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function lists()
{
return $this->dataLists(new MarketingHandoverContractLists());
}
/**
* @notes 添加市场经营--合同信息
* @return \think\response\Json
* @author likeadmin
* @date 2024/04/03 09:19
*
* public function add()
* {
* $params = (new MarketingHandoverContractValidate())->post()->goCheck('add');
* $result = MarketingHandoverContractLogic::add($params);
* if (true === $result) {
* return $this->success('添加成功', [], 1, 1);
* }
* return $this->fail(MarketingHandoverContractLogic::getError());
* }
*/
/**
* @notes 编辑市场经营--合同信息
* @return \think\response\Json
* @author likeadmin
* @date 2024/04/03 09:19
*
* public function edit()
* {
* $params = (new MarketingHandoverContractValidate())->post()->goCheck('edit');
* $result = MarketingHandoverContractLogic::edit($params);
* if (true === $result) {
* return $this->success('编辑成功', [], 1, 1);
* }
* return $this->fail(MarketingHandoverContractLogic::getError());
* }
*/
/**
* @notes 删除市场经营--合同信息
* @return \think\response\Json
* @author likeadmin
* @date 2024/04/03 09:19
*
* public function delete()
* {
* $params = (new MarketingHandoverContractValidate())->post()->goCheck('delete');
* MarketingHandoverContractLogic::delete($params);
* return $this->success('删除成功', [], 1, 1);
* }
*/
/**
* @notes 移交市场经营--合同信息
* @return \think\response\Json
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function handover()
{
$params = (new MarketingHandoverContractValidate())->post()->goCheck('handover');
$result = MarketingHandoverContractLogic::handover($params);
if (true === $result) {
return $this->success('移交成功', [], 1, 1);
}
return $this->fail(MarketingHandoverContractLogic::getError());
}
/**
* @notes 获取市场经营--合同信息详情
* @return \think\response\Json
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function detail()
{
$params = (new MarketingHandoverContractValidate())->goCheck('detail');
$result = MarketingHandoverContractLogic::detail($params);
return $this->data($result);
}
}

View File

@ -18,9 +18,10 @@
use app\adminapi\lists\BaseAdminDataLists;
use app\common\lists\ListsExcelInterface;
use app\common\lists\ListsSearchInterface;
use app\common\model\cost_project\CostApprovedProject;
use app\common\model\financial\FinancialInvoice;
use app\common\model\financial\FinancialRefund;
use app\common\model\auth\Admin;
use app\common\model\dept\Dept;
use app\common\model\marketing\MarketingContract;
use app\common\model\marketing\MarketingCustom;
/**
@ -58,21 +59,26 @@
*/
public function lists(): array
{
$status = $this->request->get('status', 1);
return CostApprovedProject::where($this->searchWhere)
$status = $this->request->get('status', 0);
return MarketingContract::where($this->searchWhere)->where('review_status', 1)
->where('status', $status)
->limit($this->limitOffset, $this->limitLength)
->order(['id' => 'desc'])
->select()->each(function ($data) {
$custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty();
$dept = Dept::where('id', 'in', [$data['signed_dept'], $data['supervise_dept']])->column('name', 'id');
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['project_manager'], $data['seal_user']])->column('name', 'id');
$data['part_a_name'] = $custom['name'];
$data['signed_dept_name'] = $dept[$data['signed_dept']];
$data['supervise_dept_name'] = $dept[$data['supervise_dept']];
$data['signed_head_name'] = $admin[$data['signed_head']];
$data['project_manager_name'] = $admin[$data['project_manager']];
$data['seal_user_name'] = $admin[$data['seal_user']];
$data['contract_type_text'] = $data->contract_type_text;
$data['business_nature_text'] = $data->business_nature_text;
$data['industry_nature_text'] = $data->industry_nature_text;
$data['fund_sources_text'] = $data->fund_sources_text;
$data['const_area_text'] = $data->const_area_text;
//开票金额
$data['total_invoice_amount'] = FinancialInvoice::where('contract_id', $data['id'])->sum('apply_amount');
//到账金额
$data['total_refund_amount'] = FinancialRefund::where('contract_id', $data['id'])->sum('amount');
})
->toArray();
}
@ -86,8 +92,8 @@
*/
public function count(): int
{
$status = $this->request->get('status', 1);
return CostApprovedProject::where($this->searchWhere)->where('status', $status)->count();
$status = $this->request->get('status', 0);
return MarketingContract::where($this->searchWhere)->where('status', $status)->where('review_status', 1)->count();
}
public function setFileName(): string
@ -105,43 +111,47 @@
{
return [
'id' => 'id',
'related_contract_id' => '关联主合同id',
'contract_type' => '合同类型 0-主合同 1-框架协议 2-补充协议',
'contract_name' => '合同名称',
'contract_num' => '合同编号',
'contract_code' => '合同编号',
'part_a' => '甲方签约单位',
'part_a_contract' => '甲方联系人',
'part_a_contact' => '联系人',
'part_a_address' => '业主地址',
'part_b' => '乙方签约',
'part_b' => '乙方签约单位',
'part_b_signatory' => '乙方签约人',
'business_nature' => '业务性质',
'industry_nature' => '行业性质',
'fund_sources' => '资金来源',
'const_area' => '建设区域',
'agreement_nature' => '协议性质',
'project_money' => '工程总投资',
'project_scale' => '工程规模及概况',
'money' => '签订金额(元)',
'rate' => '合同签订费率(%)',
'contract_service' => '合同服务工期',
'start_date' => '合同计划开始日期',
'end_date' => '合同计划结束日期',
'performance' => '合同履约金(元)',
'due_time' => '履约金到期时间',
'payment' => '合同付款方式',
'signed_amount' => '签订金额',
'signed_rate' => '合同签订费率',
'service_duration' => '合同服务工期',
'start_date' => '计划开始日期',
'end_date' => '计划结束日期',
'performance_money' => '履约金',
'performance_money_expiration_time' => '履约金到期时间',
'payment_method' => '合同付款方式',
'content' => '合同主要内容',
'founder' => '创建人',
'create_date' => '创建日期',
'dept' => '签订部门',
'signing_person' => '签订负责人',
'regulators' => '监管部门',
'project_director' => '项目总监/经理',
'way' => '实施方式',
'signed_dept' => '签订部门',
'signed_head' => '签订负责人',
'supervise_dept' => '监管部门',
'project_manager' => '项目总监/经理',
'implement_method' => '实施方式',
'seal_name' => '盖章名称',
'limit' => '是否限制',
'is_limit' => '是否限制',
'limit_num' => '限制次数',
'file_type' => '文件类',
'file_type' => '文件类',
'seal_num' => '盖章份数',
'sealer' => '盖章人',
'seal_user' => '盖章人',
'plance_seal' => '骑缝盖章',
'send_date' => '发出日期',
'number' => '邮寄编号',
'mailing_number' => '邮寄编号',
'create_user' => '录入人',
'create_time' => '录入时间',
];
}
}

View File

@ -17,10 +17,11 @@
use app\adminapi\lists\BaseAdminDataLists;
use app\common\lists\ListsSearchInterface;
use app\common\model\cost_project\CostApprovedProject;
use app\common\model\financial\FinancialInvoice;
use app\common\model\financial\FinancialRefund;
use app\common\model\financial\FinancialSettlement;
use app\common\model\marketing\MarketingContract;
use app\common\model\marketing\MarketingCustom;
/**
@ -62,13 +63,14 @@
->limit($this->limitOffset, $this->limitLength)
->order(['id' => 'desc'])
->select()->each(function ($data) {
$contract = CostApprovedProject::field('contract_name,contract_type,part_a,part_b,money,create_time')->where('id', $data['contract_id'])->findOrEmpty();
$contract = MarketingContract::field('contract_name,contract_type,part_a,part_b,signed_amount,create_time')->where('id', $data['contract_id'])->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', $contract['part_a'])->findOrEmpty();
$data['invoice_type_text'] = $data->invoice_type_text;
$data['contract_name'] = $contract['contract_name'];
$data['contract_type'] = $contract->contract_type_text;
$data['part_a'] = $contract['part_a'];
$data['part_a'] = $custom['name'];
$data['part_b'] = $contract['part_b'];
$data['sign_money'] = $contract['money'];
$data['sign_money'] = $contract['signed_amount'];
$data['sign_time'] = $contract['create_time'];
$data['total_invoice_amount'] = FinancialInvoice::where('contract_id', $data['contract_id'])->sum('apply_amount');
$data['total_refund_amount'] = FinancialRefund::where('contract_id', $data['contract_id'])->sum('amount');

View File

@ -64,7 +64,7 @@
->order(['id' => 'desc'])
->select()->each(function ($data) {
$contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', 'part_a')->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty();
$dept = Dept::where('id', 'in', [$data['signed_dept'], $data['supervise_dept']])->column('name', 'id');
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['project_manager'], $data['seal_user']])->column('name', 'id');
$data['framework_agreement_name'] = $contract['contract_name'];

View File

@ -0,0 +1,104 @@
<?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\marketing;
use app\adminapi\lists\BaseAdminDataLists;
use app\common\lists\ListsSearchInterface;
use app\common\model\auth\Admin;
use app\common\model\dept\Dept;
use app\common\model\marketing\MarketingContract;
use app\common\model\marketing\MarketingCustom;
/**
* 市场经营--合同信息列表
* Class MarketingHandoverContractLists
* @package app\adminapi\listsmarketing
*/
class MarketingHandoverContractLists extends BaseAdminDataLists implements ListsSearchInterface
{
/**
* @notes 设置搜索条件
* @return \string[][]
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function setSearch(): array
{
return [
'=' => ['contract_type', 'part_a', 'business_nature', 'industry_nature', 'fund_sources', 'const_area', 'signed_dept'],
'%like%' => ['contract_name', 'contract_code'],
];
}
/**
* @notes 获取市场经营--合同信息列表
* @return array
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\DbException
* @throws \think\db\exception\ModelNotFoundException
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function lists(): array
{
return MarketingContract::withoutField('update_time,delete_time')->where($this->searchWhere)->where('review_status', 0)
->limit($this->limitOffset, $this->limitLength)
->order(['id' => 'desc'])
->select()->each(function ($data) {
$contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', 'part_a')->findOrEmpty();
$dept = Dept::where('id', 'in', [$data['signed_dept'], $data['supervise_dept']])->column('name', 'id');
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['project_manager'], $data['seal_user']])->column('name', 'id');
$data['framework_agreement_name'] = $contract['contract_name'];
$data['part_a_name'] = $custom['name'];
$data['part_b_signatory_name'] = $admin[$data['part_b_signatory']];
$data['signed_dept_name'] = $dept[$data['signed_dept']];
$data['supervise_dept_name'] = $dept[$data['supervise_dept']];
$data['signed_head_name'] = $admin[$data['signed_head']];
$data['project_manager_name'] = $admin[$data['project_manager']];
$data['seal_user_name'] = $admin[$data['seal_user']];
$data['business_nature_text'] = $data->business_nature_text;
$data['industry_nature_text'] = $data->industry_nature_text;
$data['fund_sources_text'] = $data->fund_sources_text;
$data['const_area_text'] = $data->const_area_text;
$data['implement_method_text'] = $data->implement_method_text;
$data['seal_name_text'] = $data->seal_name_text;
$data['is_limit_text'] = $data->is_limit_text;
$data['file_type_text'] = $data->file_type_text;
$data['plance_seal_text'] = $data->plance_seal_text;
$data['contract_type_text'] = $data->contract_type_text;
$data['review_status_text'] = $data->review_status_text;
})
->toArray();
}
/**
* @notes 获取市场经营--合同信息数量
* @return int
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function count(): int
{
return MarketingContract::where($this->searchWhere)->where('review_status', 0)->count();
}
}

View File

@ -3,9 +3,10 @@
namespace app\adminapi\logic\cost_project;
use app\common\logic\BaseLogic;
use app\common\model\cost_project\CostApprovedProject;
use app\common\model\cost_project\CostProject;
use think\facade\Db;
use app\common\model\auth\Admin;
use app\common\model\dept\Dept;
use app\common\model\marketing\MarketingContract;
use app\common\model\marketing\MarketingCustom;
/**
@ -15,151 +16,6 @@
*/
class CostApprovedProjectLogic extends BaseLogic
{
/**
* @notes 添加待立项造价项目
* @param array $params
* @return bool
* @author likeadmin
* @date 2024/02/20 14:16
*/
public static function add(array $params): bool
{
Db::startTrans();
try {
CostApprovedProject::create([
'contract_name' => $params['contract_name'],
'contract_num' => date('Ymd', time()) . '-' . mt_rand(100000, 999999),
'contract_type' => $params['contract_type'],
'part_a' => $params['part_a'],
'part_a_contract' => $params['part_a_contract'] ?? '',
'part_a_address' => $params['part_a_address'] ?? '',
'part_b' => $params['part_b'],
'part_b_signatory' => $params['part_b_signatory'] ?? '',
'business_nature' => $params['business_nature'] ?? 0,
'industry_nature' => $params['industry_nature'] ?? 0,
'fund_sources' => $params['fund_sources'] ?? 0,
'const_area' => $params['const_area'] ?? 0,
'project_money' => $params['project_money'] ?? 0,
'project_scale' => $params['project_scale'] ?? '',
'money' => $params['money'],
'rate' => $params['rate'] ?? 0,
'contract_service' => $params['contract_service'] ?? '',
'start_date' => !empty($params['start_date']) ? strtotime($params['start_date']) : 0,
'end_date' => !empty($params['end_date']) ? strtotime($params['end_date']) : 0,
'performance' => $params['performance'] ?? 0,
'due_time' => !empty($params['due_time']) ? strtotime($params['due_time']) : 0,
'payment' => $params['payment'] ?? '',
'content' => $params['content'] ?? '',
'founder' => $params['founder'] ?? '',
'create_date' => !empty($params['create_date']) ? strtotime($params['create_date']) : 0,
'dept' => $params['dept'],
'signing_person' => $params['signing_person'] ?? '',
'regulators' => $params['regulators'],
'project_director' => $params['project_director'] ?? '',
'way' => $params['way'] ?? 0,
'seal_name' => $params['seal_name'] ?? 0,
'limit' => $params['limit'] ?? 0,
'limit_num' => $params['limit_num'] ?? 0,
'file_type' => $params['file_type'] ?? 0,
'seal_num' => $params['seal_num'] ?? 0,
'sealer' => $params['sealer'] ?? '',
'plance_seal' => $params['plance_seal'] ?? 0,
'send_date' => !empty($params['send_date']) ? strtotime($params['send_date']) : 0,
'number' => $params['number'] ?? '',
'annex' => $params['annex'] ? json_encode($params['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/02/20 14:16
*/
public static function edit(array $params): bool
{
Db::startTrans();
try {
CostApprovedProject::where('id', $params['id'])->update([
'contract_type' => $params['contract_type'],
'contract_name' => $params['contract_name'],
'part_a' => $params['part_a'],
'part_a_contract' => $params['part_a_contract'] ?? '',
'part_a_address' => $params['part_a_address'] ?? '',
'part_b' => $params['part_b'],
'part_b_signatory' => $params['part_b_signatory'] ?? '',
'business_nature' => $params['business_nature'] ?? 0,
'industry_nature' => $params['industry_nature'] ?? 0,
'fund_sources' => $params['fund_sources'] ?? 0,
'const_area' => $params['const_area'] ?? 0,
'project_money' => $params['project_money'] ?? 0,
'project_scale' => $params['project_scale'] ?? '',
'money' => $params['money'],
'rate' => $params['rate'] ?? 0,
'contract_service' => $params['contract_service'] ?? '',
'start_date' => !empty($params['start_date']) ? strtotime($params['start_date']) : 0,
'end_date' => !empty($params['end_date']) ? strtotime($params['end_date']) : 0,
'performance' => $params['performance'] ?? 0,
'due_time' => !empty($params['due_time']) ? strtotime($params['due_time']) : 0,
'payment' => $params['payment'] ?? '',
'content' => $params['content'] ?? '',
'founder' => $params['founder'] ?? '',
'create_date' => !empty($params['create_date']) ? strtotime($params['create_date']) : 0,
'dept' => $params['dept'],
'signing_person' => $params['signing_person'] ?? '',
'regulators' => $params['regulators'],
'project_director' => $params['project_director'] ?? '',
'way' => $params['way'] ?? 0,
'seal_name' => $params['seal_name'] ?? 0,
'limit' => $params['limit'] ?? 0,
'limit_num' => $params['limit_num'] ?? 0,
'file_type' => $params['file_type'] ?? 0,
'seal_num' => $params['seal_num'] ?? 0,
'sealer' => $params['sealer'] ?? '',
'plance_seal' => $params['plance_seal'] ?? 0,
'send_date' => !empty($params['send_date']) ? strtotime($params['send_date']) : 0,
'number' => $params['number'] ?? '',
'annex' => $params['annex'] ? json_encode($params['annex']) : null,
'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/02/20 14:16
*/
public static function delete(array $params): bool
{
$project = CostProject::where('contract_id', 'in', $params['id'])->findOrEmpty();
if (!$project->isEmpty()) {
self::setError('此数据关联了造价项目信息,需删除造价项目信息');
return false;
}
return CostApprovedProject::destroy($params['id']);
}
/**
* @notes 获取待立项造价项目详情
* @param $params
@ -169,23 +25,36 @@
*/
public static function detail($params): array
{
$data = CostApprovedProject::withoutField('create_time,update_time,delete_time')->findOrEmpty($params['id']);
$data['contract_type_text'] = $data->contract_type_text;
$data = MarketingContract::withoutField('update_time,delete_time')->findOrEmpty($params['id']);
$contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', 'part_a')->findOrEmpty();
$dept = Dept::where('id', 'in', [$data['signed_dept'], $data['supervise_dept']])->column('name', 'id');
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['project_manager'], $data['seal_user']])->column('name', 'id');
$data['framework_agreement_name'] = $contract['contract_name'];
$data['part_a_name'] = $custom['name'];
$data['part_b_signatory_name'] = $admin[$data['part_b_signatory']];
$data['signed_dept_name'] = $dept[$data['signed_dept']];
$data['supervise_dept_name'] = $dept[$data['supervise_dept']];
$data['signed_head_name'] = $admin[$data['signed_head']];
$data['project_manager_name'] = $admin[$data['project_manager']];
$data['seal_user_name'] = $admin[$data['seal_user']];
$data['business_nature_text'] = $data->business_nature_text;
$data['industry_nature_text'] = $data->industry_nature_text;
$data['fund_sources_text'] = $data->fund_sources_text;
$data['const_area_text'] = $data->const_area_text;
$data['way_text'] = $data->way_text;
$data['implement_method_text'] = $data->implement_method_text;
$data['seal_name_text'] = $data->seal_name_text;
$data['is_limit_text'] = $data->is_limit_text;
$data['file_type_text'] = $data->file_type_text;
$data['plance_seal_text'] = $data->plance_seal_text;
$data['limit_text'] = $data->limit_text;
$data['contract_type_text'] = $data->contract_type_text;
$data['review_status_text'] = $data->review_status_text;
return $data->toArray();
}
public static function datas()
{
return CostApprovedProject::field(['id', 'contract_name'])->order(['id' => 'desc'])->select()->each(function ($data) {
return MarketingContract::field(['id', 'contract_name'])->where('review_status', 1)->order(['id' => 'desc'])->select()->each(function ($data) {
$data['projectinfo'] = 'ID' . $data['id'] . ' / 名称:' . $data['contract_name'];
})->toArray();
}

View File

@ -189,7 +189,7 @@
{
$data = MarketingContract::withoutField('update_time,delete_time')->findOrEmpty($params['id']);
$contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', 'part_a')->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', $data['part_a'])->findOrEmpty();
$dept = Dept::where('id', 'in', [$data['signed_dept'], $data['supervise_dept']])->column('name', 'id');
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['project_manager'], $data['seal_user']])->column('name', 'id');
$data['framework_agreement_name'] = $contract['contract_name'];

View File

@ -0,0 +1,239 @@
<?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\marketing;
use app\common\logic\BaseLogic;
use app\common\model\auth\Admin;
use app\common\model\dept\Dept;
use app\common\model\marketing\MarketingContract;
use app\common\model\marketing\MarketingCustom;
use think\facade\Db;
/**
* 市场经营--合同信息逻辑
* Class MarketingContractLogic
* @package app\adminapi\logic\marketing
*/
class MarketingHandoverContractLogic extends BaseLogic
{
/**
* @notes 添加市场经营--合同信息
* @param array $params
* @return bool
* @author likeadmin
* @date 2024/04/03 09:19
*/
public static function add(array $params): bool
{
Db::startTrans();
try {
MarketingContract::create([
'related_contract_id' => $params['related_contract_id'] ?? 0,
'contract_type' => 0,
'contract_name' => $params['contract_name'],
'contract_code' => data_unique_code('ZHT'),
'part_a' => $params['part_a'],
'part_a_contact' => $params['part_a_contact'] ?? '',
'part_a_address' => $params['part_a_address'] ?? '',
'part_b' => $params['part_b'],
'part_b_signatory' => $params['part_b_signatory'] ?? 0,
'business_nature' => $params['business_nature'],
'industry_nature' => $params['industry_nature'],
'fund_sources' => $params['fund_sources'],
'const_area' => $params['const_area'],
'project_money' => $params['project_money'] ?? 0,
'project_scale' => $params['project_scale'] ?? '',
'signed_amount' => $params['signed_amount'],
'signed_rate' => $params['signed_rate'] ?? 0,
'service_duration' => $params['service_duration'] ?? '',
'start_date' => !empty($params['start_date']) ? strtotime($params['start_date']) : 0,
'end_date' => !empty($params['end_date']) ? strtotime($params['end_date']) : 0,
'performance_money' => $params['performance_money'] ?? 0,
'performance_money_expiration_time' => !empty($params['performance_money_expiration_time']) ? strtotime($params['performance_money_expiration_time']) : 0,
'payment_method' => $params['payment_method'] ?? '',
'content' => $params['content'] ?? '',
'annex' => $params['annex'] ? json_encode($params['annex']) : null,
'signed_dept' => $params['signed_dept'],
'signed_head' => $params['signed_head'] ?? 0,
'supervise_dept' => $params['supervise_dept'],
'project_manager' => $params['project_manager'] ?? 0,
'implement_method' => $params['implement_method'] ?? 0,
'seal_name' => $params['seal_name'] ?? 0,
'is_limit' => $params['is_limit'] ?? 0,
'limit_num' => $params['limit_num'] ?? 0,
'file_type' => $params['file_type'] ?? 0,
'seal_num' => $params['seal_num'] ?? 0,
'seal_user' => $params['seal_user'] ?? 0,
'plance_seal' => $params['plance_seal'] ?? 0,
'send_date' => !empty($params['send_date']) ? strtotime($params['send_date']) : 0,
'mailing_number' => $params['mailing_number'] ?? '',
'review_status' => 0,
'status' => 0,
'create_user' => $params['create_user'],
'create_time' => !empty($params['create_time']) ? strtotime($params['create_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/04/03 09:19
*/
public static function edit(array $params): bool
{
Db::startTrans();
try {
MarketingContract::where('id', $params['id'])->update([
'related_contract_id' => $params['related_contract_id'] ?? 0,
'contract_type' => 0,
'contract_name' => $params['contract_name'],
'part_a' => $params['part_a'],
'part_a_contact' => $params['part_a_contact'] ?? '',
'part_a_address' => $params['part_a_address'] ?? '',
'part_b' => $params['part_b'],
'part_b_signatory' => $params['part_b_signatory'] ?? 0,
'business_nature' => $params['business_nature'],
'industry_nature' => $params['industry_nature'],
'fund_sources' => $params['fund_sources'],
'const_area' => $params['const_area'],
'project_money' => $params['project_money'] ?? 0,
'project_scale' => $params['project_scale'] ?? '',
'signed_amount' => $params['signed_amount'],
'signed_rate' => $params['signed_rate'] ?? 0,
'service_duration' => $params['service_duration'] ?? '',
'start_date' => !empty($params['start_date']) ? strtotime($params['start_date']) : 0,
'end_date' => !empty($params['end_date']) ? strtotime($params['end_date']) : 0,
'performance_money' => $params['performance_money'] ?? 0,
'performance_money_expiration_time' => !empty($params['performance_money_expiration_time']) ? strtotime($params['performance_money_expiration_time']) : 0,
'payment_method' => $params['payment_method'] ?? '',
'content' => $params['content'] ?? '',
'annex' => $params['annex'] ? json_encode($params['annex']) : null,
'signed_dept' => $params['signed_dept'],
'signed_head' => $params['signed_head'] ?? 0,
'supervise_dept' => $params['supervise_dept'],
'project_manager' => $params['project_manager'] ?? 0,
'implement_method' => $params['implement_method'] ?? 0,
'seal_name' => $params['seal_name'] ?? 0,
'is_limit' => $params['is_limit'] ?? 0,
'limit_num' => $params['limit_num'] ?? 0,
'file_type' => $params['file_type'] ?? 0,
'seal_num' => $params['seal_num'] ?? 0,
'seal_user' => $params['seal_user'] ?? 0,
'plance_seal' => $params['plance_seal'] ?? 0,
'send_date' => !empty($params['send_date']) ? strtotime($params['send_date']) : 0,
'mailing_number' => $params['mailing_number'] ?? '',
'review_status' => 0,
'status' => 0,
'create_user' => $params['create_user'],
'create_time' => !empty($params['create_time']) ? strtotime($params['create_time']) : time(),
'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/04/03 09:19
*/
public static function handover(array $params): bool
{
Db::startTrans();
try {
MarketingContract::where('id', $params['id'])->update([
'review_status' => 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/04/03 09:19
*/
public static function delete(array $params): bool
{
return MarketingContract::destroy($params['id']);
}
/**
* @notes 获取市场经营--合同信息详情
* @param $params
* @return array
* @author likeadmin
* @date 2024/04/03 09:19
*/
public static function detail($params): array
{
$data = MarketingContract::withoutField('update_time,delete_time')->findOrEmpty($params['id']);
$contract = MarketingContract::field('contract_name')->where('id', $data['related_contract_id'])->findOrEmpty();
$custom = MarketingCustom::field('name')->where('id', 'part_a')->findOrEmpty();
$dept = Dept::where('id', 'in', [$data['signed_dept'], $data['supervise_dept']])->column('name', 'id');
$admin = Admin::where('in', 'in', [$data['part_b_signatory'], $data['signed_head'], $data['project_manager'], $data['seal_user']])->column('name', 'id');
$data['framework_agreement_name'] = $contract['contract_name'];
$data['part_a_name'] = $custom['name'];
$data['part_b_signatory_name'] = $admin[$data['part_b_signatory']];
$data['signed_dept_name'] = $dept[$data['signed_dept']];
$data['supervise_dept_name'] = $dept[$data['supervise_dept']];
$data['signed_head_name'] = $admin[$data['signed_head']];
$data['project_manager_name'] = $admin[$data['project_manager']];
$data['seal_user_name'] = $admin[$data['seal_user']];
$data['business_nature_text'] = $data->business_nature_text;
$data['industry_nature_text'] = $data->industry_nature_text;
$data['fund_sources_text'] = $data->fund_sources_text;
$data['const_area_text'] = $data->const_area_text;
$data['implement_method_text'] = $data->implement_method_text;
$data['seal_name_text'] = $data->seal_name_text;
$data['is_limit_text'] = $data->is_limit_text;
$data['file_type_text'] = $data->file_type_text;
$data['plance_seal_text'] = $data->plance_seal_text;
$data['contract_type_text'] = $data->contract_type_text;
$data['review_status_text'] = $data->review_status_text;
return $data->toArray();
}
}

View File

@ -11,217 +11,94 @@
// +----------------------------------------------------------------------
// | author: likeadminTeam
// +----------------------------------------------------------------------
namespace app\adminapi\validate\cost_project;
use app\common\model\cost_project\CostApprovedProject;
use app\common\model\dict\DictData;
use app\common\validate\BaseValidate;
/**
* 待立项造价项目验证器
* Class CostApprovedProjectValidate
* @package app\adminapi\validate\cost_project
*/
class CostApprovedProjectValidate extends BaseValidate
{
/**
* 设置校验规则
* @var string[]
*/
protected $rule = [
'id' => 'require|checkData',
'contract_name' => 'require',
'contract_type' => 'require|checkContractType',
'part_a' => 'require',
'part_b' => 'require',
'business_nature' => 'checkBusinessNature',
'industry_nature' => 'checkIndustryNature',
'fund_sources' => 'checkFundSources',
'const_area' => 'checkConstArea',
'project_money' => 'float|egt:0',
'money' => 'require|float|gt:0',
'rate' => 'float|egt:0',
'start_date' => 'dateFormat:Y-m-d',
'end_date' => 'dateFormat:Y-m-d',
'performance' => 'float|egt:0',
'due_time' => 'dateFormat:Y-m-d',
'create_date' => 'dateFormat:Y-m-d',
'dept' => 'require',
'regulators' => 'require',
'way' => 'checkWay',
'seal_name' => 'checkSealName',
'limit' => 'integer|in:0,1',
'limit_num' => 'integer',
'file_type' => 'checkFileType',
'seal_num' => 'integer',
'plance_seal' => 'integer|in:0,1',
'send_date' => 'dateFormat:Y-m-d',
'annex' => 'checkAnnex',
];
/**
* 参数描述
* @var string[]
*/
protected $field = [
'id' => 'id',
'contract_name' => '合同名称',
'contract_type' => '合同类型',
'part_a' => '甲方签约单位',
'part_b' => '乙方签约单位',
'business_nature' => '业务性质',
'industry_nature' => '行业性质',
'fund_sources' => '资金来源',
'const_area' => '建设区域',
'project_money' => '工程总投资(元)',
'money' => '签订金额(元)',
'rate' => '合同签订费率(%)',
'start_date' => '合同计划开始日期',
'end_date' => '合同计划结束日期',
'performance' => '履约金(元)',
'due_time' => '履约金到期时间',
'create_date' => '录入日期',
'dept' => '签订部门',
'regulators' => '监管部门',
'way' => '实施方式',
'seal_name' => '盖章名称',
'limit' => '是否限制',
'limit_num' => '限制次数',
'file_type' => '文件类型',
'seal_num' => '盖章份数',
'plance_seal' => '骑缝盖章',
'send_date' => '发出日期',
];
/**
* @notes 添加场景
* @return CostApprovedProjectValidate
* @author likeadmin
* @date 2024/02/20 14:16
*/
public function sceneAdd()
{
return $this->remove('id',true);
}
/**
* @notes 编辑场景
* @return CostApprovedProjectValidate
* @author likeadmin
* @date 2024/02/20 14:16
*/
public function sceneEdit()
{}
/**
* @notes 删除场景
* @return CostApprovedProjectValidate
* @author likeadmin
* @date 2024/02/20 14:16
*/
public function sceneDelete()
{
return $this->only(['id'])->remove('id','checkData');
}
/**
* @notes 详情场景
* @return CostApprovedProjectValidate
* @author likeadmin
* @date 2024/02/20 14:16
*/
public function sceneDetail()
{
return $this->only(['id']);
}
public function checkData($value): bool|string
namespace app\adminapi\validate\cost_project;
use app\common\model\marketing\MarketingContract;
use app\common\validate\BaseValidate;
/**
* 待立项造价项目验证器
* Class CostApprovedProjectValidate
* @package app\adminapi\validate\cost_project
*/
class CostApprovedProjectValidate extends BaseValidate
{
$data = CostApprovedProject::field('id')->where('id',$value)->findOrEmpty();
if($data->isEmpty()){
return '数据不存在';
/**
* 设置校验规则
* @var string[]
*/
protected $rule = [
'id' => 'require|checkData',
];
/**
* 参数描述
* @var string[]
*/
protected $field = [
'id' => 'id',
];
/**
* @notes 添加场景
* @return CostApprovedProjectValidate
* @author likeadmin
* @date 2024/02/20 14:16
*/
public function sceneAdd()
{
return $this->remove('id', true);
}
return true;
}
public function checkContractType($value){
$dict = DictData::where('type_value','cost_contract_type')->column('value');
if(!in_array($value,$dict)){
return '合同类型数据值无效';
/**
* @notes 编辑场景
* @return CostApprovedProjectValidate
* @author likeadmin
* @date 2024/02/20 14:16
*/
public function sceneEdit()
{
return $this->only(['id']);
}
return true;
}
public function checkBusinessNature($value): bool|string
{
$dict = DictData::where('type_value','cost_consultation_business_nature')->column('value');
if(!in_array($value,$dict)){
return '业务性质数据值无效';
/**
* @notes 删除场景
* @return CostApprovedProjectValidate
* @author likeadmin
* @date 2024/02/20 14:16
*/
public function sceneDelete()
{
return $this->only(['id'])->remove('id', 'checkData');
}
return true;
}
public function checkIndustryNature($value): bool|string
{
$dict = DictData::where('type_value','cost_consultation_industry_nature')->column('value');
if(!in_array($value,$dict)){
return '行业性质数据值无效';
/**
* @notes 详情场景
* @return CostApprovedProjectValidate
* @author likeadmin
* @date 2024/02/20 14:16
*/
public function sceneDetail()
{
return $this->only(['id']);
}
return true;
}
public function checkFundSources($value): bool|string
{
$dict = DictData::where('type_value','cost_consultation_fund_sources')->column('value');
if(!in_array($value,$dict)){
return '资金来源数据值无效';
public function checkData($value): bool|string
{
$data = MarketingContract::field('id')->where('id', $value)->findOrEmpty();
if ($data->isEmpty()) {
return '数据不存在';
}
return true;
}
return true;
}
public function checkConstArea($value): bool|string
{
$dict = DictData::where('type_value','cost_consultation_const_area')->column('value');
if(!in_array($value,$dict)){
return '建设区域数据值无效';
}
return true;
}
public function checkWay($value): bool|string
{
$dict = DictData::where('type_value','cost_consultation_way')->column('value');
if(!in_array($value,$dict)){
return '实施方式数据值无效';
}
return true;
}
public function checkSealName($value): bool|string
{
$dict = DictData::where('type_value','cost_consultation_seal_name')->column('value');
if(!in_array($value,$dict)){
return '盖章名称数据值无效';
}
return true;
}
public function checkFileType($value): bool|string
{
$dict = DictData::where('type_value','cost_consultation_file_type')->column('value');
if(!in_array($value,$dict)){
return '文件类型数据值无效';
}
return true;
}
}
}

View File

@ -0,0 +1,322 @@
<?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\marketing;
use app\common\model\auth\Admin;
use app\common\model\dept\Dept;
use app\common\model\dict\DictData;
use app\common\model\marketing\MarketingContract;
use app\common\model\marketing\MarketingCustom;
use app\common\validate\BaseValidate;
/**
* 市场经营--合同信息验证器
* Class MarketingHandoverContractValidate
* @package app\adminapi\validate\marketing
*/
class MarketingHandoverContractValidate extends BaseValidate
{
/**
* 设置校验规则
* @var string[]
*/
protected $rule = [
'id' => 'require|checkData',
'related_contract_id' => 'checkRelatedContract',
'contract_name' => 'require',
'part_a' => 'require|checkPartA',
'part_b' => 'require',
'part_b_signatory' => 'checkPartBSignatory',
'business_nature' => 'require|checkBusinessNature',
'industry_nature' => 'require|IndustryNature',
'fund_sources' => 'require|checkFundSources',
'const_area' => 'require|checkConstArea',
'project_money' => 'float|egt:0',
'signed_amount' => 'require|float|gt:0',
'signed_rate' => 'float|egt:0',
'start_date' => 'dateFormat:Y-m-d',
'end_date' => 'dateFormat:Y-m-d',
'performance_money' => 'float|egt:0',
'performance_money_expiration_time' => 'dateFormat:Y-m-d',
'signed_dept' => 'require|checkSignedDept',
'signed_head' => 'require|checkSignedHead',
'supervise_dept' => 'require|checkSuperviseDept',
'project_manager' => 'checkProjectManager',
'implement_method' => 'checkImplementMethod',
'seal_name' => 'checkSealName',
'is_limit' => 'integer|in:0,1',
'limit_num' => 'integer|egt:0',
'file_type' => 'checkFileType',
'seal_num' => 'integer|egt:0',
'seal_user' => 'checkSealUser',
'plance_seal' => 'integer|in:0,1',
'send_date' => 'dateFormat:Y-m-d',
'create_user' => 'require',
'create_time' => 'require|dateFormat:Y-m-d H:i:s',
'annex' => 'checkAnnex',
'flow_id' => 'require|checkFlow',
'path' => 'require',
];
/**
* 参数描述
* @var string[]
*/
protected $field = [
'id' => 'id',
'related_contract_id' => '关联主合同id',
'contract_type' => '合同类型 0-主合同 1-框架协议 2-补充协议',
'contract_name' => '合同名称',
'contract_code' => '合同编号',
'part_a' => '甲方签约单位',
'part_a_contact' => '联系人',
'part_a_address' => '业主地址',
'part_b' => '乙方签约单位',
'part_b_signatory' => '乙方签约人',
'business_nature' => '业务性质',
'industry_nature' => '行业性质',
'fund_sources' => '资金来源',
'const_area' => '建设区域',
'agreement_nature' => '协议性质',
'project_money' => '工程总投资',
'project_scale' => '工程规模及概况',
'signed_amount' => '签订金额',
'signed_rate' => '合同签订费率',
'service_duration' => '合同服务工期',
'start_date' => '计划开始日期',
'end_date' => '计划结束日期',
'performance_money' => '履约金',
'performance_money_expiration_time' => '履约金到期时间',
'payment_method' => '合同付款方式',
'content' => '合同主要内容',
'signed_dept' => '签订部门',
'signed_head' => '签订负责人',
'supervise_dept' => '监管部门',
'project_manager' => '项目总监/经理',
'implement_method' => '实施方式',
'seal_name' => '盖章名称',
'is_limit' => '是否限制',
'limit_num' => '限制次数',
'file_type' => '文件类型',
'seal_num' => '盖章份数',
'seal_user' => '盖章人',
'plance_seal' => '骑缝盖章',
'send_date' => '发出日期',
'mailing_number' => '邮寄编号',
'create_user' => '录入人',
'create_time' => '录入时间',
];
/**
* @notes 添加场景
* @return MarketingHandoverContractValidate
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function sceneAdd()
{
return $this->remove('id', true);
}
/**
* @notes 编辑场景
* @return MarketingHandoverContractValidate
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function sceneEdit()
{
}
/**
* @notes 删除场景
* @return MarketingHandoverContractValidate
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function sceneDelete()
{
return $this->only(['id'])->remove('id', 'checkData');
}
/**
* @notes 移交场景
* @return MarketingHandoverContractValidate
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function sceneHandover()
{
return $this->only(['id']);
}
/**
* @notes 详情场景
* @return MarketingHandoverContractValidate
* @author likeadmin
* @date 2024/04/03 09:19
*/
public function sceneDetail()
{
return $this->only(['id']);
}
public function sceneApprove()
{
return $this->only(['id', 'flow_id', 'path']);
}
public function checkData($value): bool|string
{
$data = MarketingContract::where('id', $value)->findOrEmpty();
return $data->isEmpty() ? '数据不存在' : true;
}
public function checkRelatedContract($value)
{
if (empty($value)) return true;
$data = MarketingContract::where('id', $value)->where('contract_type', 1)->findOrEmpty();
return $data->isEmpty() ? '关联协议框架数据不存在' : true;
}
public function checkAgreementNature($value): bool|string
{
$dict = DictData::where('type_value', 'agreement_nature')->column('value');
if (!in_array($value, $dict)) {
return '协议性质数据值无效';
}
return true;
}
public function checkPartA($value): bool|string
{
$data = MarketingCustom::where('id', $value)->findOrEmpty();
return $data->isEmpty() ? '甲方签订单位数据不存在' : true;
}
public function checkPartBSignatory($value): bool|string
{
if (empty($value)) return true;
$data = Admin::where('id', $value)->findOrEmpty();
return $data->isEmpty() ? '乙方签约人数据不存在' : true;
}
public function checkBusinessNature($value): bool|string
{
$dict = DictData::where('type_value', 'cost_consultation_business_nature')->column('value');
if (!in_array($value, $dict)) {
return '业务性质数据值无效';
}
return true;
}
public function checkIndustryNature($value): bool|string
{
$dict = DictData::where('type_value', 'cost_consultation_industry_nature')->column('value');
if (!in_array($value, $dict)) {
return '行业性质数据值无效';
}
return true;
}
public function checkFundSources($value): bool|string
{
$dict = DictData::where('type_value', 'cost_consultation_fund_sources')->column('value');
if (!in_array($value, $dict)) {
return '资金来源数据值无效';
}
return true;
}
public function checkConstArea($value): bool|string
{
$dict = DictData::where('type_value', 'cost_consultation_const_area')->column('value');
if (!in_array($value, $dict)) {
return '建设区域数据值无效';
}
return true;
}
public function checkSignedDept($value): bool|string
{
$data = Dept::where('id', $value)->findOrEmpty();
return $data->isEmpty() ? '签订部门数据不存在' : true;
}
public function checkSignedHead($value): bool|string
{
$data = Admin::where('id', $value)->findOrEmpty();
return $data->isEmpty() ? '签订负责人数据不存在' : true;
}
public function checkSuperviseDept($value): bool|string
{
$data = Dept::where('id', $value)->findOrEmpty();
return $data->isEmpty() ? '监管部门数据不存在' : true;
}
public function checkProjectManager($value): bool|string
{
if (empty($value)) return true;
$data = Admin::where('id', $value)->findOrEmpty();
return $data->isEmpty() ? '项目经理数据不存在' : true;
}
public function checkImplementMethod($value): bool|string
{
if (empty($value)) return true;
$dict = DictData::where('type_value', 'cost_consultation_way')->column('value');
if (!in_array($value, $dict)) {
return '实施方式数据值无效';
}
return true;
}
public function checkSealName($value): bool|string
{
if (empty($value)) return true;
$dict = DictData::where('type_value', 'cost_consultation_seal_name')->column('value');
if (!in_array($value, $dict)) {
return '盖章名称数据值无效';
}
return true;
}
public function checkFileType($value): bool|string
{
if (empty($value)) return true;
$dict = DictData::where('type_value', 'cost_consultation_file_type')->column('value');
if (!in_array($value, $dict)) {
return '文件类型数据值无效';
}
return true;
}
public function checkSealUser($value): bool|string
{
if (empty($value)) return true;
$data = Admin::where('id', $value)->findOrEmpty();
return $data->isEmpty() ? '盖章人数据不存在' : true;
}
}