engineering/app/adminapi/validate/zjzx_finance/ZjzxInvoiceValidate.php
2024-03-21 14:16:47 +08:00

126 lines
3.0 KiB
PHP

<?php
namespace app\adminapi\validate\zjzx_finance;
use app\common\model\cost_project\CostProject;
use app\common\model\dict\DictData;
use app\common\model\zjzx_finance\ZjzxInvoice;
use app\common\validate\BaseValidate;
/**
* 造价咨询--开票台账验证器
* Class ZjzxInvoiceValidate
* @package app\adminapi\validate\zjzx_finance
*/
class ZjzxInvoiceValidate extends BaseValidate
{
/**
* 设置校验规则
* @var string[]
*/
protected $rule = [
'id' => 'require|checkData',
'project_id' => 'require|checkProject',
'invoice_type' => 'require|checkInvoiceType',
'apply_amount' => 'require|float|gt:0',
'apply_company' => 'require',
'apply_company_number' => 'require',
'apply_email' => 'email',
'create_user' => 'require',
'create_time' => 'require|dateFormat:Y-m-d H:i:s'
];
/**
* 参数描述
* @var string[]
*/
protected $field = [
'id' => 'id',
'project_id' => '项目id',
'invoice_code' => '开票编号',
'invoice_type' => '发票类型',
'apply_amount' => '开票申请金额',
'apply_company' => '开票单位名称',
'apply_company_number' => '纳税人识别号',
'apply_company_address' => '开票单位注册地址',
'apply_company_telephone' => '开票单位电话',
'apply_company_bank' => '开户银行',
'apply_company_account' => '开户账号',
'apply_contact' => '开票联系人',
'pay_type' => '对应付款方式',
'invoice_content' => '开票内容',
'apply_email' => '发票接收邮箱',
'create_user' => '开票申请人',
'create_time' => '开票申请时间'
];
/**
* @notes 添加场景
* @return ZjzxInvoiceValidate
* @author likeadmin
* @date 2024/03/15 17:05
*/
public function sceneAdd()
{
return $this->remove('id', true);
}
/**
* @notes 编辑场景
* @return ZjzxInvoiceValidate
* @author likeadmin
* @date 2024/03/15 17:05
*/
public function sceneEdit()
{
return $this->remove('id', 'checkData');
}
/**
* @notes 删除场景
* @return ZjzxInvoiceValidate
* @author likeadmin
* @date 2024/03/15 17:05
*/
public function sceneDelete()
{
return $this->only(['id'])->remove('id', 'checkData');
}
/**
* @notes 详情场景
* @return ZjzxInvoiceValidate
* @author likeadmin
* @date 2024/03/15 17:05
*/
public function sceneDetail()
{
return $this->only(['id']);
}
public function checkData($value): bool|string
{
$data = ZjzxInvoice::where('id', $value)->findOrEmpty();
return $data->isEmpty() ? '数据不存在' : true;
}
public function checkProject($value): bool|string
{
$data = CostProject::where('id', $value)->findOrEmpty();
return $data->isEmpty() ? '项目信息不存在' : true;
}
public function checkInvoiceType($value): bool|string
{
$dict = DictData::where('type_value', 'zjzx_invoice_type')->column('value');
return !in_array($value, $dict) ? '发票类型数据值无效' : true;
}
}