Игровые новости / Project Motor Racing
Легендарный Ford Falcon V8 2013 из чемпионата V8 Supercars бесплатно появится в Project Motor Racing в обновлении 1.7.0.0. Узнайте подробности о…
Игровые новости / iRacing
iRacing представила Season 2 2026: новая трасса St. Petersburg (Сент-Питерсберг), переиздание Barber Motorsports Park, Audi RS3 LMS Gen2 TCR и…
Теория и практика
Разбираемся, что такое Ньютон-метры в рулях с прямым приводом (Direct Drive). Постоянный и пиковый момент, клиппинг, влияние размера руля.…
Игровые новости
Свежее обновление для Le Mans Ultimate вносит масштабные изменения в BoP LMGT3: Aston Martin получил облегчение, а Lamborghini — вес. Увеличены…
Игровые новости / Assetto Corsa Evo
Руководитель Kunos объясняет отказ от XP и валюты в Assetto Corsa EVO, обещает карьеру в будущем и просит сообщество о доверии. Подробности о смене…
Анонсы соревнований / Le Mans Ultimate
Предстоящая командная 24-часовая гонка в Le Mans Ultimate, которая должна была стать ключевым событием для эндуранс-сообщества, отменена. Как стало…
Игровые новости / RENNSPORT
Porsche 911 GT1 ’98 прибыл в RENNSPORT! Подробности о легендарном болиде, победителе Ле-Мана 1998. Характеристики, история и дата выхода в симуляторе.…
Игровые новости / Le Mans Ultimate
Разработчики Le Mans Ultimate (LMU) неожиданно раньше запланированного срока выпустили обновление, которое кардинально меняет поведение автомобилей…
Игровые новости / Assetto Corsa Evo
Разработчики Assetto Corsa EVO продолжают активно работать над симулятором, находящимся в раннем доступе. После недавнего пересмотра структуры…
Игровые новости / RENNSPORT
Анонсировано добавление в гоночный симулятор Rennsport водородного гиперкара Hyundai N Vision 74. Узнайте дату выхода DLC, мощность в 670 л.с. и…
Игровые новости / Automobilista 2
Студия Reiza Studios, известная своим кропотливым подходом к деталям, представила дорожную карту развития своего флагманского симулятора…
Игровые новости / Assetto Corsa Evo
В своём последнем заявлении студия Kunos Simulazioni и издатель 505 Games объявили о радикальном изменении планов для Assetto Corsa EVO. Игра на…
${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