findOrEmpty(); Db::startTrans(); try { MarketingBidInfo::create([ 'bid_evaluation_id' => $params['bid_evaluation_id'], 'margin_end_date' => !empty($params['margin_end_date']) ? strtotime($params['margin_end_date']) : 0, 'expected_return_date' => !empty($params['expected_return_date']) ? strtotime($params['expected_return_date']) : 0, 'service_charge' => $params['service_charge'] ?? 0, 'publish_website' => $params['publish_website'] ?? '', 'general_manager' => $params['general_manager'], 'bid_quotation' => $params['bid_quotation'] ?? 0, 'bid_rate' => $params['bid_rate'] ?? 0, 'bid_head' => $params['bid_head'] ?? 0, 'technology_head' => $params['technology_head'] ?? 0, 'business_head' => $params['business_head'] ?? 0, 'other_user' => $params['other_user'] ?? 0, 'remark' => $params['remark'] ?? '', 'annex' => $params['annex'] ? json_encode($params['annex']) : null, 'bid_status' => 0, ]); MarketingBusinessOpportunity::where('id', $bid_evaluation['business_opportunity_id'])->update(['status' => 2]); 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/12 09:23 */ public static function edit(array $params): bool { Db::startTrans(); try { MarketingBidInfo::where('id', $params['id'])->update([ 'bid_evaluation_id' => $params['bid_evaluation_id'], 'margin_end_date' => !empty($params['margin_end_date']) ? strtotime($params['margin_end_date']) : 0, 'expected_return_date' => !empty($params['expected_return_date']) ? strtotime($params['expected_return_date']) : 0, 'service_charge' => $params['service_charge'] ?? 0, 'publish_website' => $params['publish_website'] ?? '', 'general_manager' => $params['general_manager'], 'bid_quotation' => $params['bid_quotation'] ?? 0, 'bid_rate' => $params['bid_rate'] ?? 0, 'bid_head' => $params['bid_head'] ?? 0, 'technology_head' => $params['technology_head'] ?? 0, 'business_head' => $params['business_head'] ?? 0, 'other_user' => $params['other_user'] ?? 0, 'remark' => $params['remark'] ?? '', '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/04/12 09:23 */ public static function delete(array $params): bool { $bid_result = MarketingBidResult::where('bid_info_id', 'in', $params['id'])->findOrEmpty(); if (!$bid_result->isEmpty()) { self::setError('此数据关联了投标结果内容,需删除投标结果内容'); return false; } return MarketingBidInfo::destroy($params['id']); } /** * @notes 获取市场经营--投标管理--投标信息详情 * @param $params * @return array * @author likeadmin * @date 2024/04/12 09:23 */ public static function detail($params): array { $data = MarketingBidInfo::withoutField('create_time,update_time,delete_time')->findOrEmpty($params['id']); //投标审查信息 $bid_evaluation = MarketingBidEvaluation::withoutField('create_time,update_time,delete_time')->where('id', $data['bid_evaluation_id'])->findOrEmpty(); $data['bid_evaluation'] = $bid_evaluation; $data['bid_evaluation']['bid_type_text'] = $bid_evaluation->bid_type_text; $data['bid_evaluation']['bid_nature_text'] = $bid_evaluation->bid_nature_text; //业务机会信息 $business_opportunity = MarketingBusinessOpportunity::withoutField('bid_date,contacts,annex,approve_id,create_time,update_time,delete_time')->where('id', $bid_evaluation['business_opportunity_id'])->findOrEmpty(); $construct_company = MarketingCustom::field('name')->where('id', $business_opportunity['construct_company'])->findOrEmpty(); $business_opportunity_admin = Admin::where('id', 'in', [$business_opportunity['head'], $business_opportunity['leader']])->column('name', 'id'); $business_opportunity_dept = Dept::field('name')->where('id', $business_opportunity['dept'])->findOrEmpty(); $data['business_opportunity'] = $business_opportunity; $data['business_opportunity']['construct_company_name'] = $construct_company?->name; $data['business_opportunity']['business_nature_text'] = $business_opportunity->business_nature_text; $data['business_opportunity']['industry_nature_text'] = $business_opportunity->industry_nature_text; $data['business_opportunity']['info_sources_text'] = $business_opportunity->info_sources_text; $data['business_opportunity']['fund_sources_text'] = $business_opportunity->fund_sources_text; $data['business_opportunity']['const_area_text'] = $business_opportunity->const_area_text; $data['business_opportunity']['status_text'] = $business_opportunity->status_text; $data['business_opportunity']['dept_name'] = $business_opportunity_dept?->name; $data['business_opportunity']['head_name'] = $business_opportunity_admin[$business_opportunity['head']] ?? ''; $data['business_opportunity']['leader_name'] = $business_opportunity_admin[$business_opportunity['leader']] ?? ''; //投标信息 $admin = Admin::where('id', 'in', [$data['general_manager'], $data['bid_head'], $data['technology_head'], $data['business_head'], $data['other_user']])->column('name', 'id'); $data['general_manager_name'] = $admin[$data['general_manager']] ?? ''; $data['bid_head_name'] = $admin[$data['bid_head']] ?? ''; $data['technology_head_name'] = $admin[$data['technology_head']] ?? ''; $data['business_head_name'] = $admin[$data['business_head']] ?? ''; $data['other_user_name'] = $admin[$data['other_user']] ?? ''; $data['bid_status_text'] = $data->bid_status_text; return $data->toArray(); } }