'require|checkData', 'contract_id' => 'require|checkContract', 'invoicing_date' => 'require|dateFormat:Y-m-d', 'invoice_no' => 'require', 'period' => 'require|checkPeriod', 'tax_rate' => 'require|checkTaxRate', 'invoice_type' => 'require|checkInvoiceType', 'invoicing_amount' => 'require|float|gt:0', 'annex' => 'checkAnnex', 'flow_id' => 'require|checkFlow', 'path' => 'require', ]; /** * 参数描述 * @var string[] */ protected $field = [ 'id' => 'id', 'contract_id' => '项目合同id', 'invoicing_date' => '开票日期', 'period' => '期次', 'invoice_no' => '发票编号', 'tax_rate' => '税率', 'invoice_type' => '发票类型', 'invoicing_amount' => '开票金额(含税)', ]; /** * @notes 添加场景 * @return FinanceInvoiceApplyValidate * @author likeadmin * @date 2023/12/13 15:01 */ public function sceneAdd() { return $this->remove('id', true)->remove('invoice_no',true)->remove('flow_id',true)->remove('path',true); } /** * @notes 编辑场景 * @return FinanceInvoiceApplyValidate * @author likeadmin * @date 2023/12/13 15:01 */ public function sceneEdit() { return $this->remove('flow_id',true)->remove('path',true); } /** * @notes 删除场景 * @return FinanceInvoiceApplyValidate * @author likeadmin * @date 2023/12/13 15:01 */ public function sceneDelete() { return $this->only(['id']); } /** * @notes 详情场景 * @return FinanceInvoiceApplyValidate * @author likeadmin * @date 2023/12/13 15:01 */ public function sceneDetail() { return $this->only(['id']); } public function sceneApprove() { return $this->only(['id','flow_id','path']); } public function checkData($value): bool|string { $data = FinanceInvoiceApply::where('id',$value)->findOrEmpty(); if($data->isEmpty()){ return '数据不存在'; } return true; } public function checkContract($value): bool|string { $data = Contract::where('id',$value)->findOrEmpty(); if($data->isEmpty()){ return '项目合同不存在'; } return true; } public function checkPeriod($value): bool|string { $dict = DictData::where('type_value','pay_period')->column('value'); if(!in_array($value,$dict)){ return '期次无效'; } return true; } public function checkTaxRate($value): bool|string { $dict = DictData::where('type_value','tax_rate')->column('value'); if(!in_array($value,$dict)){ return '税率无效'; } return true; } public function checkInvoiceType($value): bool|string { $dict = DictData::where('type_value','invoice_type')->column('value'); if(!in_array($value,$dict)){ return '发票类型无效'; } return true; } public function checkAnnex($value): bool|string { if(!empty($value) && $value != ''){ if(!is_array($value)){ return '附件格式错误'; } } return true; } }