'use client' import { useParams, useRouter } from 'next/navigation' import { useVacancy } from '@/hooks/useVacancy' import { VacancyRead } from '@/types/api' import { ArrowLeft, MapPin, Clock, Banknote, Building, Users, Calendar, Phone, Mail, Globe } from 'lucide-react' import ResumeUploadForm from '@/components/ResumeUploadForm' export default function VacancyPage() { const params = useParams() const router = useRouter() const vacancyId = parseInt(params.id as string) const { data: vacancy, isLoading, error } = useVacancy(vacancyId) const formatSalary = (vacancy: VacancyRead) => { if (!vacancy.salary_from && !vacancy.salary_to) return 'Зарплата не указана' const currency = vacancy.salary_currency === 'RUR' ? '₽' : vacancy.salary_currency if (vacancy.salary_from && vacancy.salary_to) { return `${vacancy.salary_from.toLocaleString()} - ${vacancy.salary_to.toLocaleString()} ${currency}` } if (vacancy.salary_from) { return `от ${vacancy.salary_from.toLocaleString()} ${currency}` } if (vacancy.salary_to) { return `до ${vacancy.salary_to.toLocaleString()} ${currency}` } } const getExperienceText = (experience: string) => { const mapping = { noExperience: 'Без опыта', between1And3: '1-3 года', between3And6: '3-6 лет', moreThan6: 'Более 6 лет' } return mapping[experience as keyof typeof mapping] || experience } const getEmploymentText = (employment: string) => { const mapping = { full: 'Полная занятость', part: 'Частичная занятость', project: 'Проектная работа', volunteer: 'Волонтерство', probation: 'Стажировка' } return mapping[employment as keyof typeof mapping] || employment } const getScheduleText = (schedule: string) => { const mapping = { fullDay: 'Полный день', shift: 'Сменный график', flexible: 'Гибкий график', remote: 'Удаленная работа', flyInFlyOut: 'Вахтовый метод' } return mapping[schedule as keyof typeof mapping] || schedule } if (isLoading) { return (
Не удалось загрузить информацию о вакансии
{vacancy.description}
{vacancy.key_skills}
{vacancy.company_description}