'use client' import { useState } from 'react' import { VacancyRead } from '@/types/api' import { useVacancies } from '@/hooks/useVacancy' import Link from 'next/link' import { Search, MapPin, Clock, Banknote } from 'lucide-react' export default function HomePage() { const [searchTerm, setSearchTerm] = useState('') const [searchParams, setSearchParams] = useState({ active_only: true, title: undefined as string | undefined, }) const { data: vacancies = [], isLoading, error, refetch } = useVacancies(searchParams) const handleSearch = (e: React.FormEvent) => { e.preventDefault() setSearchParams({ active_only: true, title: searchTerm || undefined, }) } 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 } if (isLoading) { return (
Платформа с искусственным интеллектом для поиска идеальной вакансии
Не удалось загрузить вакансии
{vacancy.company_name}
{vacancy.description}
Попробуйте изменить параметры поиска или вернитесь позже