'require|checkData', 'fee_application_id' => 'require|checkFeeApplication', 'subject_category' => 'require|checkSubjectCategory', 'bill_num' => 'require|integer|egt:0', 'amount' => 'require|float|egt:0', ]; /** * 参数描述 * @var string[] */ protected $field = [ 'id' => 'id', 'fee_application_id' => '费用申请id', 'subject_category' => '科目类别', 'bill_num' => '票据张数', 'amount' => '申请金额', ]; /** * @notes 添加场景 * @return FinancialFeeApplicationDetailValidate * @author likeadmin * @date 2024/03/27 14:53 */ public function sceneAdd() { return $this->only(['fee_application_id', 'subject_category', 'bill_num', 'amount']); } /** * @notes 编辑场景 * @return FinancialFeeApplicationDetailValidate * @author likeadmin * @date 2024/03/27 14:53 */ public function sceneEdit() { return $this->only(['id', 'fee_application_id', 'subject_category', 'bill_num', 'amount']); } /** * @notes 删除场景 * @return FinancialFeeApplicationDetailValidate * @author likeadmin * @date 2024/03/27 14:53 */ public function sceneDelete() { return $this->only(['id'])->remove('id', 'checkData'); } /** * @notes 详情场景 * @return FinancialFeeApplicationDetailValidate * @author likeadmin * @date 2024/03/27 14:53 */ public function sceneDetail() { return $this->only(['id']); } public function checkData($value): bool|string { $data = FinancialFeeApplicationDetail::where('id', $value)->findOrEmpty(); return $data->isEmpty() ? '数据不存在' : true; } public function checkFeeApplication($value): bool|string { $data = FinancialFeeApplication::where('id', $value)->findOrEmpty(); return $data->isEmpty() ? '费用申请信息不存在' : true; } public function checkSubjectCategory($value): bool|string { $dict = DictData::where('type_value', 'subject_category')->column('value'); return !in_array($value, $dict) ? '科目类别数据值无效' : true; } }