Newer
Older
anicusi / js / Renderer.js
@Eugene Eugene on 11 Apr 9 KB init
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
		};
	}
}