(function ($, window, document) { function populateRatings(allParentalRatings, page) { var html = ""; html += ""; var ratings = []; var i, length, rating; for (i = 0, length = allParentalRatings.length; i < length; i++) { rating = allParentalRatings[i]; if (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).selectmenu("refresh"); } 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('OptionBlockLiveTvPrograms'), value: 'LiveTvProgram' }, { name: Globalize.translate('OptionBlockMovies'), value: 'Movie' }, { name: Globalize.translate('OptionBlockMusic'), value: 'Music' }, { name: Globalize.translate('OptionBlockTrailers'), value: 'Trailer' }, { name: Globalize.translate('OptionBlockTvShows'), value: 'Series' }, { name: Globalize.translate('OptionBlockOthers'), value: 'Other' } ]; var html = ''; html += '
'; html += '' + Globalize.translate('HeaderBlockItemsWithNoRating') + ''; for (var i = 0, length = items.length; i < length; i++) { var item = items[i]; var id = 'unratedItem' + i; var checkedAttribute = user.Configuration.BlockUnratedItems.indexOf(item.value) != -1 ? ' checked="checked"' : ''; html += ''; html += ''; } html += '
'; $('.blockUnratedItems', page).html(html).trigger('create'); } function loadUser(page, user, loggedInUser, allParentalRatings) { Dashboard.setPageTitle(user.Name); loadUnratedItems(page, user); populateRatings(allParentalRatings, page); var ratingValue = ""; if (user.Configuration.MaxParentalRating) { for (var i = 0, length = allParentalRatings.length; i < length; i++) { var rating = allParentalRatings[i]; if (user.Configuration.MaxParentalRating >= rating.Value) { ratingValue = rating.Value; } } } $('#selectMaxParentalRating', page).val(ratingValue).selectmenu("refresh"); if (user.Configuration.IsAdministrator) { $('.accessScheduleSection', page).hide(); } else { $('.accessScheduleSection', page).show(); } renderAccessSchedule(page, user.Configuration.AccessSchedules || []); Dashboard.hideLoadingMsg(); } function getDisplayTime(hour) { return new Date(2000, 1, 1, hour, 0, 0, 0).toLocaleTimeString(); } function deleteAccessSchedule(page, schedules, index) { schedules.splice(index, 1); renderAccessSchedule(page, schedules); } function renderAccessSchedule(page, schedules) { var html = ''; var elem = $('.accessScheduleList', page).html(html).trigger('create'); $('.btnDelete', elem).on('click', function () { deleteAccessSchedule(page, schedules, parseInt(this.getAttribute('data-index'))); }); } function onSaveComplete(page) { Dashboard.hideLoadingMsg(); Dashboard.alert(Globalize.translate('SettingsSaved')); } function saveUser(user, page) { user.Configuration.MaxParentalRating = $('#selectMaxParentalRating', page).val() || null; user.Configuration.BlockUnratedItems = $('.chkUnratedItem:checked', page).map(function () { return this.getAttribute('data-itemtype'); }).get(); user.Configuration.AccessSchedules = getSchedulesFromPage(page); ApiClient.updateUser(user).done(function () { onSaveComplete(page); }); } window.UserParentalControlPage = { onSubmit: function () { var page = $(this).parents('.page'); Dashboard.showLoadingMsg(); var userId = getParameterByName("userId"); ApiClient.getUser(userId).done(function (result) { saveUser(result, page); }); // Disable default form submission return false; }, onScheduleFormSubmit: function () { var page = $(this).parents('.page'); saveSchedule(page); // Disable default form submission return false; } }; function populateHours(page) { var html = ''; for (var i = 0; i < 24; i++) { html += ''; } $('#selectStart', page).html(html).selectmenu('refresh'); $('#selectEnd', page).html(html).selectmenu('refresh'); } function showSchedulePopup(page, schedule, index) { schedule = schedule || {}; $('#popupSchedule', page).popup('open'); $('#fldScheduleIndex', page).val(index); $('#selectDay', page).val(schedule.DayOfWeek || 'Sunday').selectmenu('refresh'); $('#selectStart', page).val(schedule.StartHour || 0).selectmenu('refresh'); $('#selectEnd', page).val(schedule.EndHour || 0).selectmenu('refresh'); } function saveSchedule(page) { var schedule = { DayOfWeek: $('#selectDay', page).val(), StartHour: $('#selectStart', page).val(), EndHour: $('#selectEnd', page).val() }; if (parseFloat(schedule.StartHour) >= parseFloat(schedule.EndHour)) { alert(Globalize.translate('ErrorMessageStartHourGreaterThanEnd')); return; } var schedules = getSchedulesFromPage(page); var index = parseInt($('#fldScheduleIndex', page).val()); if (index == -1) { index = schedules.length; } schedules[index] = schedule; renderAccessSchedule(page, schedules); $('#popupSchedule', page).popup('close'); } 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(); } $(document).on('pageinit', "#userParentalControlPage", function () { var page = this; $('.btnAddSchedule', page).on('click', function () { showSchedulePopup(page, {}, -1); }); populateHours(page); }).on('pageshow', "#userParentalControlPage", function () { var page = this; Dashboard.showLoadingMsg(); var userId = getParameterByName("userId"); var promise1; if (!userId) { var deferred = $.Deferred(); deferred.resolveWith(null, [{ Configuration: {} }]); promise1 = deferred.promise(); } else { promise1 = ApiClient.getUser(userId); } var promise2 = Dashboard.getCurrentUser(); var promise3 = ApiClient.getParentalRatings(); $.when(promise1, promise2, promise3).done(function (response1, response2, response3) { loadUser(page, response1[0] || response1, response2[0], response3[0]); }); }); })(jQuery, window, document);