define(["jQuery", "datetime", "loading", "libraryMenu", "listViewStyle", "paper-icon-button-light"], function($, datetime, loading, libraryMenu) { "use strict"; function populateRatings(allParentalRatings, page) { var html = ""; html += ""; var i, length, rating, 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("OptionBlockGames"), value: "Game" }, { 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" }], html = ""; html += '

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

", html += '
'; for (var i = 0, length = items.length; i < length; i++) { var item = items[i], 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]; user.Policy.MaxParentalRating >= rating.Value && (ratingValue = rating.Value) } $("#selectMaxParentalRating", page).val(ratingValue), user.Policy.IsAdministrator ? $(".accessScheduleSection", page).hide() : $(".accessScheduleSection", page).show(), renderAccessSchedule(page, user.Policy.AccessSchedules || []), loading.hide() } function loadBlockedTags(page, tags) { var html = tags.map(function(h) { var li = '
'; return li += '
', li += '

', li += h, li += "

", li += "
", li += '', li += "
" }).join(""); html && (html = '
' + html + "
"); var elem = $(".blockedTags", page).html(html).trigger("create"); $(".btnDeleteTag", elem).on("click", function() { var tag = this.getAttribute("data-tag"), 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 = "", index = 0; html += schedules.map(function(a) { var itemHtml = ""; return itemHtml += '
', itemHtml += '
', itemHtml += '

', itemHtml += Globalize.translate("Option" + a.DayOfWeek), itemHtml += "

", itemHtml += '
' + getDisplayTime(a.StartHour) + " - " + getDisplayTime(a.EndHour) + "
", itemHtml += "
", itemHtml += '', itemHtml += "
", index++, 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, pct = hours % 1; return pct && (minutes = parseInt(60 * pct)), datetime.getDisplayTime(new Date(2e3, 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); - 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); - 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"); return ApiClient.getUser(userId).then(function(result) { saveUser(result, page) }), !1 } }, $(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"), promise1 = ApiClient.getUser(userId), promise2 = ApiClient.getParentalRatings(); Promise.all([promise1, promise2]).then(function(responses) { loadUser(page, responses[0], responses[1]) }) }) });