define(["jQuery", "datetime", "loading", "libraryMenu", "listViewStyle", "paper-icon-button-light", "globalize"], function ($, datetime, loading, libraryMenu, globalize) { "use strict"; function populateRatings(allParentalRatings, page) { var html = ""; html += ""; var i; var length; var rating; var ratings = []; for (i = 0, length = allParentalRatings.length; i < length; i++) { if (rating = allParentalRatings[i], ratings.length) { var lastRating = ratings[ratings.length - 1]; if (lastRating.Value === rating.Value) { lastRating.Name += "/" + rating.Name; continue; } } ratings.push({ Name: rating.Name, Value: rating.Value }); } for (i = 0, length = ratings.length; i < length; i++) { rating = ratings[i]; html += ""; } $("#selectMaxParentalRating", page).html(html); } function loadUnratedItems(page, user) { var items = [{ name: globalize.translate("OptionBlockBooks"), value: "Book" }, { name: globalize.translate("OptionBlockChannelContent"), value: "ChannelContent" }, { name: globalize.translate("OptionBlockLiveTvChannels"), value: "LiveTvChannel" }, { name: globalize.translate("OptionBlockMovies"), value: "Movie" }, { name: globalize.translate("OptionBlockMusic"), value: "Music" }, { name: globalize.translate("OptionBlockTrailers"), value: "Trailer" }, { name: globalize.translate("OptionBlockTvShows"), value: "Series" }]; var html = ""; html += '

' + globalize.translate("HeaderBlockItemsWithNoRating") + "

"; html += '
'; for (var i = 0, length = items.length; i < length; i++) { var item = items[i]; var checkedAttribute = -1 != user.Policy.BlockUnratedItems.indexOf(item.value) ? ' checked="checked"' : ""; html += '"; } html += "
"; $(".blockUnratedItems", page).html(html).trigger("create"); } function loadUser(page, user, allParentalRatings) { page.querySelector(".username").innerHTML = user.Name; libraryMenu.setTitle(user.Name); loadUnratedItems(page, user); loadBlockedTags(page, user.Policy.BlockedTags); populateRatings(allParentalRatings, page); var ratingValue = ""; if (user.Policy.MaxParentalRating) { for (var i = 0, length = allParentalRatings.length; i < length; i++) { var rating = allParentalRatings[i]; if (user.Policy.MaxParentalRating >= rating.Value) { ratingValue = rating.Value; } } } $("#selectMaxParentalRating", page).val(ratingValue); if (user.Policy.IsAdministrator) { $(".accessScheduleSection", page).hide(); } else { $(".accessScheduleSection", page).show(); } renderAccessSchedule(page, user.Policy.AccessSchedules || []); loading.hide(); } function loadBlockedTags(page, tags) { var html = tags.map(function (h) { var li = '
'; li += '
'; li += '

'; li += h; li += "

"; li += "
"; li += ''; return li += "
"; }).join(""); if (html) { html = '
' + html + "
"; } var elem = $(".blockedTags", page).html(html).trigger("create"); $(".btnDeleteTag", elem).on("click", function () { var tag = this.getAttribute("data-tag"); var newTags = tags.filter(function (t) { return t != tag; }); loadBlockedTags(page, newTags); }); } function deleteAccessSchedule(page, schedules, index) { schedules.splice(index, 1); renderAccessSchedule(page, schedules); } function renderAccessSchedule(page, schedules) { var html = ""; var index = 0; html += schedules.map(function (a) { var itemHtml = ""; itemHtml += '
'; itemHtml += '
'; itemHtml += '

'; itemHtml += globalize.translate("Option" + a.DayOfWeek); itemHtml += "

"; itemHtml += '
' + getDisplayTime(a.StartHour) + " - " + getDisplayTime(a.EndHour) + "
"; itemHtml += "
"; itemHtml += ''; itemHtml += "
"; index++; return itemHtml; }).join(""); var accessScheduleList = page.querySelector(".accessScheduleList"); accessScheduleList.innerHTML = html; $(".btnDelete", accessScheduleList).on("click", function () { deleteAccessSchedule(page, schedules, parseInt(this.getAttribute("data-index"))); }); } function onSaveComplete(page) { loading.hide(); require(["toast"], function (toast) { toast(globalize.translate("SettingsSaved")); }); } function saveUser(user, page) { user.Policy.MaxParentalRating = $("#selectMaxParentalRating", page).val() || null; user.Policy.BlockUnratedItems = $(".chkUnratedItem", page).get().filter(function (i) { return i.checked; }).map(function (i) { return i.getAttribute("data-itemtype"); }); user.Policy.AccessSchedules = getSchedulesFromPage(page); user.Policy.BlockedTags = getBlockedTagsFromPage(page); ApiClient.updateUserPolicy(user.Id, user.Policy).then(function () { onSaveComplete(page); }); } function getDisplayTime(hours) { var minutes = 0; var pct = hours % 1; if (pct) { minutes = parseInt(60 * pct); } return datetime.getDisplayTime(new Date(2000, 1, 1, hours, minutes, 0, 0)); } function showSchedulePopup(page, schedule, index) { schedule = schedule || {}; require(["components/accessschedule/accessschedule"], function (accessschedule) { accessschedule.show({ schedule: schedule }).then(function (updatedSchedule) { var schedules = getSchedulesFromPage(page); if (-1 == index) { index = schedules.length; } schedules[index] = updatedSchedule; renderAccessSchedule(page, schedules); }); }); } function getSchedulesFromPage(page) { return $(".liSchedule", page).map(function () { return { DayOfWeek: this.getAttribute("data-day"), StartHour: this.getAttribute("data-start"), EndHour: this.getAttribute("data-end") }; }).get(); } function getBlockedTagsFromPage(page) { return $(".blockedTag", page).map(function () { return this.getAttribute("data-tag"); }).get(); } function showBlockedTagPopup(page) { require(["prompt"], function (prompt) { prompt({ label: globalize.translate("LabelTag") }).then(function (value) { var tags = getBlockedTagsFromPage(page); if (-1 == tags.indexOf(value)) { tags.push(value); loadBlockedTags(page, tags); } }); }); } window.UserParentalControlPage = { onSubmit: function () { var page = $(this).parents(".page"); loading.show(); var userId = getParameterByName("userId"); ApiClient.getUser(userId).then(function (result) { saveUser(result, page); }); return false; } }; $(document).on("pageinit", "#userParentalControlPage", function () { var page = this; $(".btnAddSchedule", page).on("click", function () { showSchedulePopup(page, {}, -1); }); $(".btnAddBlockedTag", page).on("click", function () { showBlockedTagPopup(page); }); $(".userParentalControlForm").off("submit", UserParentalControlPage.onSubmit).on("submit", UserParentalControlPage.onSubmit); }).on("pageshow", "#userParentalControlPage", function () { var page = this; loading.show(); var userId = getParameterByName("userId"); var promise1 = ApiClient.getUser(userId); var promise2 = ApiClient.getParentalRatings(); Promise.all([promise1, promise2]).then(function (responses) { loadUser(page, responses[0], responses[1]); }); }); });