Игровые новости / RENNSPORT
RENNSPORT расширяет календарь трасс за счет альтернативных конфигураций. В рамках бесплатного обновления в симулятор добавят короткую версию Road…
Игровые новости / Assetto Corsa Rally
В самый разгар Ралли Монте-Карло 2026 — одного из самых сложных, непредсказуемых и атмосферных этапов мирового раллийного чемпионата — студии Kunos…
Игровые новости / NASCAR 25
Обновление NASCAR 25 от 21 января 2026 года: добавлена трасса Portland International Raceway, полностью обновлена Sonoma Raceway, улучшен bump…
Игровые новости / Le Mans Ultimate
Разработчики гоночного симулятора Le Mans Ultimate выпустили очередное обновление, которое не только исправляет накопившиеся баги, но и задаёт вектор…
Игровые новости / MONOsim
MONOsim — новый автосимулятор от независимых разработчиков. Его суть на глубокой технической проработке каждой детали. Проект делает ставку на…
Игровые новости / Assetto Corsa Evo
В обновлении 0.5 Assetto Corsa EVO добавят легендарный Toyota Corolla AE86 Sprinter Trueno в бело-чёрной расцветке Такуми Фудзивары. Узнайте…
Игровые новости / Endurance Motorsport Series
Новый трейлер Endurance Motorsport Series. Гонки в дождь на Spa, динамическая погода, стратегия пит-стопов. Выход на PC, PS5, Xbox в 2026.…
Игровые новости / Automobilista 2
Automobilista 2 обновление 1.6.9.2: улучшено поведение ИИ на овалах (Daytona, Pocono), исправлены мультиклассовые гонки, TAA и физика. Подробный…
Новости Hardware
MOZA анонсировала три руля — KS PRO, CS PRO и Porsche Mission R. Читайте про экраны, подсветку, совместимость и стратегию бренда в ответ конкурентам.…
Игровые новости / Automobilista 2
Компания Reiza Studios объявила о крупном зимнем обновлении v1.6.9 для своего симулятора Automobilista 2. Обновление включает в себя новые…
Игровые новости / Le Mans Ultimate
Здесь представлен полный перечень всех трасс, доступных в гоночном автосимуляторе Le Mans Ultimate от Studio 397 и Motorsport Games, включая контент…
Игровые новости / Assetto Corsa Rally
В симулятор Assetto Corsa Rally вышло первое крупное обновление 0.2 от студии Kunos Simulazioni. Главные нововведения — ледовая трасса «Ghiacciodromo…
${platformName}
${video.title}
${categoryName}
`;
// Динамически загружаем превью
getVideoThumbnail(video, (thumbnailUrl) => {
const thumbnailContainer = videoCard.querySelector('.video-thumbnail');
thumbnailContainer.innerHTML = `
${platformName}
`;
});
videoCard.addEventListener('click', (e) => {
if (!e.target.closest('.clickable-category')) {
openVideoInModal(video);
}
});
return videoCard;
}
// Рендеринг порции видео
function renderVideosChunk(videos) {
currentVideos = videos;
currentIndex = Math.min(videos.length, currentIndex + videosPerPage);
const chunk = videos.slice(0, currentIndex);
videoGallery.innerHTML = "";
if (videos.length === 0) {
videoGallery.innerHTML = "
Нет видео для отображения.
";
return;
}
chunk.forEach(video => {
const videoCard = createVideoCard(video);
videoGallery.appendChild(videoCard);
});
}
// Рендеринг кнопки "Показать ещё"
function renderLoadMoreButton(filteredVideos) {
const loadMoreContainer = document.getElementById("load-more-container");
if (loadMoreContainer) loadMoreContainer.remove();
if (currentIndex >= filteredVideos.length) return;
const container = document.createElement("div");
container.id = "load-more-container";
container.style.textAlign = "center";
container.style.marginTop = "20px";
const button = document.createElement("button");
button.textContent = "Показать ещё";
button.style.padding = "10px 20px";
button.style.fontSize = "16px";
button.addEventListener("click", () => {
renderVideosChunk(filteredVideos);
renderLoadMoreButton(filteredVideos);
});
container.appendChild(button);
videoGallery.parentElement.appendChild(container);
}
// Рендеринг кнопок фильтрации
function renderFilterButtons(categoriesList) {
filterButtonsContainer.innerHTML = "";
const allButton = document.createElement("button");
allButton.textContent = "Все";
allButton.dataset.categoryId = "all";
allButton.classList.add("active");
allButton.addEventListener("click", () => {
document.querySelectorAll(".filter-buttons button").forEach(btn => btn.classList.remove("active"));
allButton.classList.add("active");
const filteredVideos = filterVideos('all');
currentIndex = 0;
renderVideosChunk(filteredVideos);
renderLoadMoreButton(filteredVideos);
});
filterButtonsContainer.appendChild(allButton);
categoriesList.forEach(category => {
if (category.id === 'all') return;
const button = document.createElement("button");
button.textContent = category.name;
button.dataset.categoryId = category.id;
button.addEventListener("click", () => {
document.querySelectorAll(".filter-buttons button").forEach(btn => btn.classList.remove("active"));
button.classList.add("active");
const filteredVideos = filterVideos(category.id);
currentIndex = 0;
renderVideosChunk(filteredVideos);
renderLoadMoreButton(filteredVideos);
});
filterButtonsContainer.appendChild(button);
});
}
// Обработчик клика по категории
document.addEventListener('click', (e) => {
if (e.target.classList.contains('clickable-category')) {
e.preventDefault();
e.stopPropagation();
const categoryId = e.target.dataset.categoryId;
const button = document.querySelector(`.filter-buttons button[data-category-id="${categoryId}"]`);
if (button) button.click();
}
});
// Инициализация
renderFilterButtons(categories);
const initialVideos = filterVideos('all');
renderVideosChunk(initialVideos);
renderLoadMoreButton(initialVideos);
Back to top button