where('id',$params['subcontracting_contract_id'])->findOrEmpty(); Db::startTrans(); try { $res = SubcontractingContractNegotiation::create([ 'project_id' => $subcontracting_contract['project_id'], 'subcontracting_contract_id' => $params['subcontracting_contract_id'], 'sign_date' => strtotime($params['sign_date']), 'negotiation_name' => $params['negotiation_name'], 'negotiation_no' => data_unique_code('QS-FBHT'), 'negotiation_amount' => $params['negotiation_amount'], 'negotiation_type' => $params['negotiation_type'], 'warranty_amount' => $params['warranty_amount'] ?? 0, 'warranty_expire_date' => !empty($params['Warranty_expire_date']) ? strtotime($params['Warranty_expire_date']) : 0, 'negotiation_content' => $params['negotiation_content'] ?? '', 'negotiation_detail' => $params['negotiation_detail'] ?? '', 'negotiation_quotation' => $params['negotiation_quotation'] ? json_encode($params['negotiation_quotation']) : null, 'negotiation_basis' => $params['negotiation_basis'] ? json_encode($params['negotiation_basis']) : 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 2023/12/12 17:21 */ public static function edit(array $params): bool { $subcontracting_contract = SubcontractingContract::field('project_id')->where('id',$params['subcontracting_contract_id'])->findOrEmpty(); Db::startTrans(); try { SubcontractingContractNegotiation::where('id', $params['id'])->update([ 'project_id' => $subcontracting_contract['project_id'], 'subcontracting_contract_id' => $params['subcontracting_contract_id'], 'sign_date' => strtotime($params['sign_date']), 'negotiation_name' => $params['negotiation_name'], 'negotiation_amount' => $params['negotiation_amount'], 'negotiation_type' => $params['negotiation_type'], 'warranty_amount' => $params['warranty_amount'] ?? 0, 'warranty_expire_date' => !empty($params['Warranty_expire_date']) ? strtotime($params['Warranty_expire_date']) : 0, 'negotiation_content' => $params['negotiation_content'] ?? '', 'negotiation_detail' => $params['negotiation_detail'] ?? '', 'negotiation_quotation' => $params['negotiation_quotation'] ? json_encode($params['negotiation_quotation']) : null, 'negotiation_basis' => $params['negotiation_basis'] ? json_encode($params['negotiation_basis']) : 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 2023/12/12 17:21 */ public static function delete(array $params): bool { return SubcontractingContractNegotiation::destroy($params['id']); } /** * @notes 获取详情 * @param $params * @return array * @author likeadmin * @date 2023/12/12 17:21 */ public static function detail($params): array { $data = SubcontractingContractNegotiation::field('id,project_id,subcontracting_contract_id,negotiation_name,negotiation_no,negotiation_amount,negotiation_type,sign_date,warranty_amount,warranty_expire_date,negotiation_content,negotiation_detail,negotiation_quotation,negotiation_basis,approve_id') ->findOrEmpty($params['id']); $subcontracting_contract = SubcontractingContract::field('supplier_id,contract_no,contract_name')->where('id',$data['subcontracting_contract_id'])->findOrEmpty(); $project = Project::field('name,project_code')->where('id',$data['project_id'])->findOrEmpty(); $supplier = Supplier::field('supplier_name,supplier_code')->where('id',$subcontracting_contract['supplier_id'])->findOrEmpty(); $data['contract_name'] = $subcontracting_contract['contract_name']; $data['contract_no'] = $subcontracting_contract['contract_no']; $data['supplier_name'] = $supplier['supplier_name']; $data['supplier_code'] = $supplier['supplier_code']; $data['project_code'] = $project['project_code']; $data['project_name'] = $project['name']; $data['negotiation_type_text'] = $data->negotiation_type_text; $approve_data = FlowApprove::where('id',$data['approve_id'])->findOrEmpty(); $data['approve_check_status'] = $approve_data['check_status']; return $data->toArray(); } public static function approve($params,$admin_id): bool{ $data = SubcontractingContractNegotiation::where('id',$params['id'])->findOrEmpty(); $approve_data = FlowApprove::where('id',$data['approve_id'])->findOrEmpty(); if(!empty($data['approve_id']) && $approve_data['check_status'] != 3){ self::setError('当前内容存在审核信息,请勿重复提交'); return false; } Db::startTrans(); try { $res = addApprove( '分包合同洽商', $params['id'], 'app\common\model\contract\SubcontractingContractNegotiation', $params['path'], $params['flow_id'], $admin_id ); if($res){ SubcontractingContractNegotiation::where('id',$params['id'])->update([ 'approve_id' => $res, ]); } Db::commit(); return true; } catch (\Exception $e) { Db::rollback(); self::setError($e->getMessage()); return false; } } }