import $ from 'jQuery'; import datetime from 'datetime'; import loading from 'loading'; import libraryMenu from 'libraryMenu'; import globalize from 'globalize'; import 'listViewStyle'; import 'paper-icon-button-light'; /* eslint-disable indent */ function populateRatings(allParentalRatings, page) { let html = ''; html += ""; let rating; const ratings = []; for (let i = 0, length = allParentalRatings.length; i < length; i++) { if (rating = allParentalRatings[i], ratings.length) { const lastRating = ratings[ratings.length - 1]; if (lastRating.Value === rating.Value) { lastRating.Name += '/' + rating.Name; continue; } } ratings.push({ Name: rating.Name, Value: rating.Value }); } for (let i = 0, length = ratings.length; i < length; i++) { rating = ratings[i]; html += "'; } $('#selectMaxParentalRating', page).html(html); } function loadUnratedItems(page, user) { const 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' }]; let html = ''; html += '

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

'; html += '
'; for (let i = 0, length = items.length; i < length; i++) { const item = items[i]; const checkedAttribute = user.Policy.BlockUnratedItems.indexOf(item.value) != -1 ? ' 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); let ratingValue = ''; if (user.Policy.MaxParentalRating) { for (let i = 0, length = allParentalRatings.length; i < length; i++) { const 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) { let html = tags.map(function (h) { let li = '
'; li += '
'; li += '

'; li += h; li += '

'; li += '
'; li += ''; return li += '
'; }).join(''); if (html) { html = '
' + html + '
'; } const elem = $('.blockedTags', page).html(html).trigger('create'); $('.btnDeleteTag', elem).on('click', function () { const tag = this.getAttribute('data-tag'); const 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) { let html = ''; let index = 0; html += schedules.map(function (a) { let 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(''); const 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(); import('toast').then(({default: 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) { let minutes = 0; const 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 || {}; import('components/accessSchedule/accessSchedule').then(({default: accessschedule}) => { accessschedule.show({ schedule: schedule }).then(function (updatedSchedule) { const schedules = getSchedulesFromPage(page); if (index == -1) { 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) { import('prompt').then(({default: prompt}) => { prompt({ label: globalize.translate('LabelTag') }).then(function (value) { const tags = getBlockedTagsFromPage(page); if (tags.indexOf(value) == -1) { tags.push(value); loadBlockedTags(page, tags); } }); }); } window.UserParentalControlPage = { onSubmit: function () { const page = $(this).parents('.page'); loading.show(); const userId = getParameterByName('userId'); ApiClient.getUser(userId).then(function (result) { saveUser(result, page); }); return false; } }; $(document).on('pageinit', '#userParentalControlPage', function () { const 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 () { const page = this; loading.show(); const userId = getParameterByName('userId'); const promise1 = ApiClient.getUser(userId); const promise2 = ApiClient.getParentalRatings(); Promise.all([promise1, promise2]).then(function (responses) { loadUser(page, responses[0], responses[1]); }); }); /* eslint-enable indent */