$params['contract_id'], 'pay_type' => $params['pay_type'], 'payment_date' => !empty($params['payment_date']) ? strtotime($params['payment_date']) : 0, 'apply_amount' => $params['apply_amount'], 'collection_company' => $params['collection_company'], 'collection_account' => $params['collection_account'], 'collection_bank' => $params['collection_bank'], 'collection_open_bank' => $params['collection_open_bank'], 'province' => $params['province'] ?? '', 'city' => $params['city'] ?? '', 'pay_user' => $params['pay_user'] ?? 0, 'pay_account' => $params['pay_account'] ?? '', 'pay_amount' => $params['pay_amount'] ?? 0, 'pay_date' => !empty($params['pay_date']) ? strtotime($params['pay_date']) : 0, 'remark' => $params['remark'] ?? '', 'annex' => $params['annex'] ? json_encode($params['annex']) : null, 'create_user' => $params['create_user'], 'create_time' => !empty($params['create_time']) ? strtotime($params['create_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 2024/04/13 17:24 */ public static function edit(array $params): bool { Db::startTrans(); try { FinancialPerformanceMoneyApply::where('id', $params['id'])->update([ 'contract_id' => $params['contract_id'], 'pay_type' => $params['pay_type'], 'payment_date' => !empty($params['payment_date']) ? strtotime($params['payment_date']) : 0, 'apply_amount' => $params['apply_amount'], 'collection_company' => $params['collection_company'], 'collection_account' => $params['collection_account'], 'collection_bank' => $params['collection_bank'], 'collection_open_bank' => $params['collection_open_bank'], 'province' => $params['province'] ?? '', 'city' => $params['city'] ?? '', 'pay_user' => $params['pay_user'] ?? 0, 'pay_account' => $params['pay_account'] ?? '', 'pay_amount' => $params['pay_amount'] ?? 0, 'pay_date' => !empty($params['pay_date']) ? strtotime($params['pay_date']) : 0, 'remark' => $params['remark'] ?? '', 'annex' => $params['annex'] ? json_encode($params['annex']) : null, 'create_user' => $params['create_user'], 'create_time' => !empty($params['create_time']) ? strtotime($params['create_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 2024/04/13 17:24 */ public static function delete(array $params): bool { return FinancialPerformanceMoneyApply::destroy($params['id']); } /** * @notes 获取财务管理--履约金申请详情 * @param $params * @return array * @author likeadmin * @date 2024/04/13 17:24 */ public static function detail($params): array { $data = FinancialPerformanceMoneyApply::withoutField('update_time,delete_time')->findOrEmpty($params['id']); $contract = MarketingContract::field('contract_name,part_a,signed_amount,performance_money,performance_money_expiration_time,signed_dept,project_manager')->where('id', $data['contract_id'])->findOrEmpty(); $part_a = MarketingCustom::field('name')->where('id', $contract['part_a'])->findOrEmpty(); $signed_dept = Dept::field('name')->where('id', $contract['signed_dept'])->findOrEmpty(); $project_manager = Admin::field('name')->where('id', $contract['project_manager'])->findOrEmpty(); $province = GeoProvince::field('province_name')->where('province_code', $data['province'])->findOrEmpty(); $city = GeoCity::field('city_name')->where('city_code', $data['city'])->findOrEmpty(); $pay_user = Admin::field('name')->where('id', $data['pay_user'])->findOrEmpty(); $data['contract_name'] = $contract?->contract_name; $data['part_a'] = $part_a?->name; $data['signed_amount'] = $contract?->signed_amount; $data['performance_money'] = $contract?->performance_money; $data['performance_money_expiration_time'] = $contract?->performance_money_expiration_time; $data['signed_dept'] = $signed_dept?->name; $data['project_manager'] = $project_manager?->name; $data['province_name'] = $province?->province_name; $data['city_name'] = $city?->city_name; $data['pay_type_text'] = $data->pay_type_text; $data['pay_user_name'] = $pay_user?->name; return $data->toArray(); } }