Что нового

Модуль вложенных плейлистов для DLE

  • Автор темы Автор темы MrDeath
  • Дата начала Дата начала
Подскажите, в этой версии работает автоматическое заполнение серий по ссылке плейлиста с ютуба, как это было в первых версия. Стоит старая версия и там сейчас данная функция не работает. Есть ли смысл обновлять?
Думаю будет быстрее переименовать директорию playlists и залить другую верси для теста, нежели ждать ответа.

Изначально автор плейлисты парсили с ютуба. Потом на ютуб были изменения. Автор допилил модуль.

Последняя версия от втора парсит с ютуб до 100 серий. А вто какая версия тут, х.з. ((
 
Думаю будет быстрее переименовать директорию playlists и залить другую верси для теста, нежели ждать ответа.

Изначально автор плейлисты парсили с ютуба. Потом на ютуб были изменения. Автор допилил модуль.

Последняя версия от втора парсит с ютуб до 100 серий. А вто какая версия тут, х.з. ((
Тоже вариант. Проверю.
 
Привет. Добавила на сайт плеер, но почему-то в админке выводит несколко доп.полей которые не Плейлист, из-за чего это может быть???? Версия DLE 15.3
 

Вложения

  • Скриншот 05-03-2023 03_35_41.jpg
    Скриншот 05-03-2023 03_35_41.jpg
    82.7 КБ · Просмотры: 98
Привет. Добавила на сайт плеер, но почему-то в админке выводит несколко доп.полей которые не Плейлист, из-за чего это может быть???? Версия DLE 15.3
Проверьте нет ли в названии тех полей [PL]
 
Привет! У кого тоже такая проблема - список плей листа отображается всего на 200 пикселей в высоту - возможно вы его используете в связке с парсером кинопоиска. Там в стилях есть особенность max-height: 200px; в двух файлах
engine\dlepremium\kinopoisk_parser\inc\addnews.php
engine\dlepremium\kinopoisk_parser\inc\editnews.php

Это и приводит к такой проблеме.
playlist.png
 
как єво скачать?
 
как єво скачать?
 
Ребят, подскажите как этот плагин подключить в 15.1 версии DLE?
 
Ребята можете обновить модуль до DLE 16 версий, если есть возможность
 
Замутил в общем с помощью chatgpt простой js-скрипт для иного вывода плейлистов. Может кому-то пригодится подобное.

В fullstory.tpl на месте, где выводится плеер вставить:

HTML:
<div id="playlists">
<iframe src="" allowfullscreen></iframe>
<select id="dubbers"></select>
<select id="episodes"></select>
</div>

<script>
window.addEventListener('DOMContentLoaded', (event) => {
    let jsonArr = [xfvalue_playlist];

    let audioSelect = document.getElementById("dubbers");
    let episodeSelect = document.getElementById("episodes");
    let iframe = document.querySelector("iframe");

    // Добавляем пустую опцию к началу audioSelect
    let emptyOptionAudio = document.createElement("option");
    emptyOptionAudio.value = "";
    emptyOptionAudio.textContent = "Выбрать озвучку...";
    audioSelect.appendChild(emptyOptionAudio);

    // Добавляем пустую опцию к началу episodeSelect
    let emptyOptionEpisode = document.createElement("option");
    emptyOptionEpisode.value = "";
    emptyOptionEpisode.textContent = "Выбрать серию...";
    episodeSelect.appendChild(emptyOptionEpisode);

    jsonArr.forEach(item => {
        let option = document.createElement("option");
        option.value = item.title;
        option.textContent = item.title;
        audioSelect.appendChild(option);
    });

    let audioSelectChangeHandler = function() {
        let selectedTitle = audioSelect.value;
        let folder = jsonArr.find(item => item.title === selectedTitle).folder;
  
        episodeSelect.innerHTML = "";
        // Добавляем пустую опцию к началу episodeSelect при изменении audioSelect
        episodeSelect.appendChild(emptyOptionEpisode);

        folder.forEach(item => {
            let option = document.createElement("option");
            option.value = item.file;
            option.textContent = item.title;
            episodeSelect.appendChild(option);
        });

        episodeSelect.addEventListener("change", function() {
            let selectedFile = episodeSelect.value;
            iframe.src = selectedFile;
        });
    };

    audioSelect.addEventListener("change", audioSelectChangeHandler);
    audioSelectChangeHandler(); // load episodes for the initial selection
});
</script>
 

Вложения

  • 66.png
    66.png
    55 КБ · Просмотры: 103
Последнее редактирование:
У кого-то есть версия для DLE 16 и выше?
Если есть возможность обновите пожалуйста
 
Продолжаю эксперименты, на этот раз вместо селекторов кнопки.

Всё также в fullstory.tpl, в место, где должен быть плеер вставить код, который написан ниже. CSS стили из моего шаблона, потому требуют переделки под себя.

HTML:
<style>
#videoFrame {
    width: 100%;
    height: 320px;
    border-radius: 7px;
    margin-top: 15px;
    background-color: #6d6d6d33;
    background-image: linear-gradient(-20deg, #ffa58c 20%, #f85c6a 100%);
}

#audioButtons {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-bottom: 15px;
    margin-top: 10px;
}

#audioButtons button {
    display: inline-block;
    border: 0;
    padding: 7px 10px;
    background-color: #86868630;
    color: var(--sidebar-post-font-title);
    cursor: pointer;
    font-size: 15px;
    border-radius: 5px;
    font-family: 'Roboto', sans-serif;
}

#episodeButtons {
    max-height: 200px;
    overflow-y: auto;
    display: grid;
    grid-gap: 10px;
}

#episodeButtons div {
    display: flex;
    padding: 7px 35px 7px 10px;
    background-color: #86868630;
    color: var(--sidebar-post-font-title);
    cursor: pointer;
    font-size: 15px;
    border-radius: 5px;
    position: relative;
    line-height: 18px;
}

#episodeButtons div label {
    display: block;
    width: 100%;
    cursor: pointer;
}

#episodeButtons div input[type="checkbox"] {
    position: absolute;
    right: 10px;
    top: 9px;
}

#episodeButtons div.active, #audioButtons button.active {
    background-color: #ff6060;
    color: #fff;
    cursor: not-allowed;
}
</style>

<iframe id="videoFrame" src="" allowfullscreen frameborder="0"></iframe>
<div id="audioButtons" class="button-container"></div>
<div id="episodeButtons" class="button-container"></div>
<script>
    document.addEventListener('DOMContentLoaded', (event) => {
        let jsonArr = [xfvalue_playlist];
    
        let audioButtonContainer = document.getElementById("audioButtons");
        let episodeButtonContainer = document.getElementById("episodeButtons");
        let videoFrame = document.getElementById("videoFrame");
    
        function displayAudioButtons() {
            audioButtonContainer.innerHTML = "";
            jsonArr.forEach(item => {
                let button = document.createElement("button");
                button.textContent = item.title;
                button.addEventListener("click", function() {
                    displayEpisodeButtons(item.folder);
                    // Убираем класс "active" у всех кнопок
                    document.querySelectorAll('#audioButtons button').forEach(btn => btn.classList.remove('active'));
                    // Добавляем класс "active" к выбранной кнопке
                    button.classList.add('active');
                });
                audioButtonContainer.appendChild(button);
            });
        }
    
        function saveCheckboxState(checkbox, watched) {
            let episodeFile = checkbox.getAttribute("data-episode-file");
            if (watched) {
                localStorage.setItem(episodeFile, "watched");
            } else {
                localStorage.removeItem(episodeFile);
            }
        }
    
        function displayEpisodeButtons(folder) {
            episodeButtonContainer.innerHTML = "";
            folder.forEach(item => {
                let buttonContainer = document.createElement("div");
                let checkbox = document.createElement("input");
                checkbox.type = "checkbox";
                checkbox.setAttribute("data-episode-file", item.file);
    
                let label = document.createElement("label");
                label.textContent = item.title;
    
                buttonContainer.appendChild(checkbox);
                buttonContainer.appendChild(label);
    
                if (localStorage.getItem(item.file) === "watched") {
                    checkbox.checked = true;
                }
    
                label.addEventListener("click", function() {
                    videoFrame.src = item.file;
                    // Убираем класс "active" у всех кнопок эпизодов
                    document.querySelectorAll('#episodeButtons div').forEach(btnContainer => btnContainer.classList.remove('active'));
                    // Добавляем класс "active" к выбранной кнопке
                    buttonContainer.classList.add('active');
                    console.log("Selected episode:", item.title);
                });
    
                checkbox.addEventListener("change", function() {
                    if (this.checked) {
                        console.log("Marked as watched:", item.title);
                        saveCheckboxState(this, true); // Сохраняем состояние при выборе
                    } else {
                        console.log("Marked as unwatched:", item.title);
                        saveCheckboxState(this, false); // Сохраняем состояние при снятии отметки
                    }
                });
    
                episodeButtonContainer.appendChild(buttonContainer);
            });
    
            restoreCheckboxesState(); // Добавляем восстановление состояния чекбоксов после создания
        }
    
        function restoreCheckboxesState() {
            let allCheckboxes = document.querySelectorAll('#episodeButtons input[type="checkbox"]');
            allCheckboxes.forEach(checkbox => {
                let episodeFile = checkbox.getAttribute("data-episode-file");
                if (localStorage.getItem(episodeFile) === "watched") {
                    checkbox.checked = true;
                }
            });
        }
    
        displayAudioButtons();
    });
</script>
 

Вложения

  • 13.png
    13.png
    68.3 КБ · Просмотры: 80
Устанавливается, но ссылки на видео должны быть вида

Код:
https://www.youtube.com/embed/Gumq8x51Zhs

На сайте использую плеер playerjs, как можно заставить работать этот плагин с плеером, а не со стандартным ютубовским?
Версия DLE 14.3.
 
Последнее редактирование:
Верх