Newer
Older
anicusi / js / functions.js
@Eugene Eugene on 11 Apr 5 KB init
const getSessionId = () => {
	const sessId = localStorage.getItem("sessionId");
	if(sessId) {
		return sessId;
	}

	return false;
};

const stdXHR = (method, url, onloadCallback) => {
	const xhr = new XMLHttpRequest();
	xhr.open(method, url);
	xhr.setRequestHeader("Cache-Control", "no-cache, no-store, max-age=0");

	xhr.onload = () => {
		if(xhr.status == 200) {
			onloadCallback(xhr);
		} else {
			if(xhr.status == 404) {
				app().router.goToPage("not-found");
			}
			const alert = createGlobalAlertComponent("danger", "Ошибка загрузки данных");
			setTimeout(() => alert.close(), 3000);
		}
	}

	xhr.onerror = () => {
		const alert = createGlobalAlertComponent("danger", "Сервер не доступен");
		setTimeout(() => alert.close(), 3000);
	}

	return xhr;
}

const showMobNav = () => {
	document.querySelector(".btn-nav-on-mob-show").classList.add("active");
	document.querySelectorAll(".navigation-main-wrapper, .userbar-wrapper").forEach(item => {
		item.classList.add("show");
	});
}

const hideMobNav = () => {
	document.querySelector(".btn-nav-on-mob-show").classList.remove("active");
	document.querySelectorAll(".navigation-main-wrapper, .userbar-wrapper").forEach(item => {
		item.classList.remove("show");
	});
}

const makeSelectedGenresActivated = () => {
	let selectedGenres = document.location.hash.split("sg:")[1];
	selectedGenres = selectedGenres 
		? selectedGenres.split(",").map(item => { return decodeURI(item); }) 
		: [];
	document.querySelectorAll("#genres .render-genres .genre-btn.active").forEach(
		i => i.classList.remove("active")
	);
	for(let i=0; i<selectedGenres.length; i++) {
		document.querySelector(`#genres .render-genres .genre-btn[data-genre-name="${selectedGenres[i]}"]`)?.classList.add("active");
	}
}

const getItemCardFields = (api2Flag) => {
	return (api2Flag === true) 
	? [ 
			"id", 
			"code", 
			"names", 
			"genres", 
			"posters", 
			"status", 
			"player", 
			"season", 
			"type" 
		]
	: [ 
			"id", 
			"code", 
			"names", 
			"genres", 
			"posters.medium.url", 
			"status", 
			"player.episodes", 
			"season", 
			"type" 
		]
}

const setPageTitle = pageTitle => {
	document.querySelector("head title").innerHTML = pageTitle;
}

const nodeFromHTML = html => {
	const container = document.createElement("DIV");
	container.innerHTML = html;
	return item = container.childNodes[0];
}

const addToFavourites = (postId, callback) => {
	const sessId = getSessionId();
	if(sessId) {
		anilibriaRequest(
			"user/favorites",
			{
				session: sessId,
				title_id: postId
			},
			resp => { 
				app().cacheProvider.unsetCache("favouritesList");
				callback(resp);
			},
			"PUT"
		);
	}
}

const removeFromFavourites = (postId, callback) => {
	const sessId = getSessionId();
	if(sessId) {
		anilibriaRequest(
			"user/favorites",
			{
				session: sessId,
				title_id: postId
			},
			resp => {
				app().cacheProvider.unsetCache("favouritesList");
				callback(resp);
			},
			"DELETE"
		);
	}
}

const insertListToRenderContainer = (renderContainer, list) => {
	for(let i = 0; i < list.length; i++) {
		renderContainer.appendChild(app().renderer.renderItemCard(list[i]).node);
	}
}

const anilibriaRequest = (name, params, callback, method) => {
	params = params || {};

	method = method || "GET";
	let ver = _CONF.api.ver;
	if(name.indexOf(":") != -1) {
		[ver, name] = name.split(":");
	}

	let url = `https://${_CONF.api.domen}/api/${ver}/${name}`;
	
	if(params["filter"]) {	
		params.filter = params.filter.join(",");
	}

	if(params["after"] === 0) {
		delete params["after"];
	}

	const query = (new URLSearchParams(params)).toString();
	if(query) {
		url += `?${query}`;
	}

	stdXHR(method, url,
		xhr => {
			const resp = JSON.parse(xhr.response);
			callback(resp);
		}
	).send();
}

const getSelectedGenres = () => {
	let genres = document.location.hash.split("sg:")[1];
	genres = decodeURI(genres);
	return genres.length ? genres.split(",") : [];
}

const getStorablePlayerData = () => {
	const data = {};
	const keys = Object.keys(localStorage);

	for(let key of keys) {
		if(key.indexOf("pljsplayfrom_main-player-") == -1) {
			continue;
		}

		const id = parseInt(key.split("pljsplayfrom_main-player-")[1].replaceAll(document.location.hostname, ""));
		let val = localStorage.getItem(key);
		[watched, len, watchedAt] = val.split("}")[1].split("--");
		data[id] = {
			currentEpisode: val.split("}")[0].split("s")[1],
			timing: {
				watched: parseInt(watched),
				len: parseInt(len),
				watchedAt: watchedAt
			}
		};
	}

	return data;
}

const transformScheduleList = schedule => {
	const resultList = {};
	const currentDayNum = (new Date()).getDay();
	const dayNames = ["понедельник", "вторник", "среда", "четверг", "пятница", "суббота", "воскресенье"];

	for(let i in schedule) {
		for(let j in schedule[i].list) {
			if(resultList[schedule[i].list[j].id]) {
				continue;
			}

			resultList[schedule[i].list[j].id] = {
				day: {
					num: schedule[i].day,
					string: dayNames[schedule[i].day],
					isToday: schedule[i].day == (currentDayNum - 1)
				},
				item: schedule[i].list[j]
			}
		}
	}

	return resultList;
}