class Renderer { constructor() {} renderThumbnail(post) { let status = post.status.string ? post.status.string : "Завершен"; if(post.inSchedule) { if(post.inSchedule.isToday) { status = `<span class="mdi mdi-flag-checkered"></span> Сегодня`; } else { status = `<span class="mdi mdi-flag-checkered"></span> ${(post.inSchedule.string.charAt(0).toUpperCase() + post.inSchedule.string.slice(1))}`; } } const watched = (post.localPlayerData && post.localPlayerData.currentEpisode == post.player.episodes.last) ? `<div class="thumb-label watched">Просмотрено</div>` : "" return ` <div class="component thumbnail"> <img src="http://anilibria.tv${post.posters.medium.url}" class="thumbnail-img"> <img src="" class="poster-placeholder" > <div class="hover-effect"> <span class="mdi mdi-arrow-right"></span> </div> ${watched} <div class="thumb-label status">${status}</div> <div class="thumb-label series">Серий ${post.player.episodes.last}</div> </div> `; } renderItemCard(post) { let genres = post.genres.join(", "); const thumb = this.renderThumbnail(post); let html = `<a href="#page:single;id${post.id}" class="no-decoration item-link"> <div class="component card item-card" data-id="${post.id}"> ${thumb} <div class="info"> <div class="title">${post.names.ru} (<span class="year">${post.season.year}</span>)</div> <div class="meta"> <div class="genres">${genres}</div> <div class="type">${post.type.full_string}</div> </div> </div> </div> </a>`; return { string: html, node: app().postRender.itemCard(html) }; } renderTorrents(post) { let html = `<div class="component torrents">`; for(let i=0; i<post.torrents.list.length; i++) { const torrent = post.torrents.list[i]; let size = torrent.total_size / 1024 / 1024; size = (size > 1024) ? (size / 1024).toString().split(".")[0] + "." + (size / 1024).toString().split(".")[1].substr(0,2) + " ГБ" : size.toString().split(".")[0] + "." + size.toString().split(".")[1].substr(0,2) + " МБ"; html += ` <div class="torrent" data-torrent-id="${torrent.torrent_id}"> <div class="series">Серии ${torrent.episodes.string}</div> <div class="quality">${torrent.quality.string}</div> <div class="seed-leech"> <span class="seed"> <span class="mdi mdi-arrow-up"></span> ${torrent.seeders} </span> <span class="leech"> <span class="mdi mdi-arrow-down"></span> ${torrent.leechers} </span> </div> <div class="download"> <a href="http://anilibria.tv${torrent.url}" class="std-btn btn-success" target="_blank"> <span class="mdi mdi-download"></span> <span class="btn-label">Скачать</span> <span class="btn-tsize">${size}</span> </a> </div> </div> `; } html += "</div>"; return html; } renderFavoriteBtn(post) { const html = `<button class="std-btn btn-warning fav-btn dnone" data-id="${post.id}"> <span class="state unset-from"> <span class="mdi mdi-star"></span> В избранном </span> <span class="state set-to"> <span class="mdi mdi-star-outline"></span> Добавить в избранное </span> </button>`; return { html: html, node: app().postRender.favoriteBtn(html, post.id) }; } renderTabs(props) { let nav = `<div class="tabs-nav">`; let content = `<div class="tabs-content">`; for(let tabName in props.tabs) { const active = (props.active == tabName) ? "active" : ""; nav += `<div class="tab ${active}" data-tab="${tabName}">${props.tabs[tabName].btn}</div>`; content += `<div class="tab-content ${tabName} ${active}" data-tab="${tabName}">${props.tabs[tabName].content}</div>`; } nav += `</div>`; content += `</div>`; let html = `<div class="component tabs ${props.name}" id="${props.name}"> ${nav} ${content} </div>`; return html; } renderSingle(post) { let genres = this.renderGenresList(post.genres).html; const thumb = this.renderThumbnail(post); const voices = post.team.voice.join(", "); const schedule = post.inSchedule ? `<div class=""><span class="mdi mdi-flag-checkered"></span> Новая серия: ${(post.inSchedule.isToday ? "сегодня" : post.inSchedule.string)}</div>` : ""; let html = `<div class="component single-item"> <div class="std-row"> ${thumb} <div class="item-info"> <h2 class="title"><strong>${post.names.ru}</strong> / ${post.names.en}</h2> <div class="time-period">${post.season.string || ""} ${post.season.year}</div> <div class="genres">${genres}</div> <div class="type">${post.type.full_string}</div> ${schedule} <div class="team"> <div class="voice"> <strong>Голоса:</strong> ${voices} </div> </div> <div class="description">${post.description}</div> <div class="control-panel"> <div class="fav-btn-wrap"></div> </div> </div> </div> <div class="video-container"></div> </div>`; return { string: html, node: app().postRender.single(html, post) }; } renderPreloadSpinner() { return `<div class="loadingio-spinner-dual-ball-9pyhqeozhs"><div class="ldio-jyt13pqa73"> <div></div><div></div><div></div> </div></div>`; } renderGenreBtn(genre) { let html = `<a href="#page:genres;sg:${genre}" class="std-btn genre-btn" data-genre-name="${genre}" > ${genre} </a>`; return { html: html, node: app().postRender.genreBtn(html) }; } renderGenresList(genres) { let container = document.createElement("DIV"); container.classList.add("genres-wrap"); let html = `<div class="genres-wrap">`; for(let i=0; i<genres.length; i++) { const btn = this.renderGenreBtn(genres[i]); container.appendChild(btn.node); html += btn.html; } html += "</div>"; return { html: html, node: container }; } }