(function ($, document, window) { var showOverlayTimeout; function onHoverOut() { if (showOverlayTimeout) { clearTimeout(showOverlayTimeout); showOverlayTimeout = null; } $('.cardOverlayTarget:visible', this).each(function () { var elem = this; $(this).animate({ "height": "0" }, "fast", function () { $(elem).hide(); }); }); $('.cardOverlayTarget:visible', this).stop().animate({ "height": "0" }, function () { $(this).hide(); }); } function getOverlayHtml(item, currentUser, card, commands) { var html = ''; html += '
'; var className = card.className.toLowerCase(); var isMiniItem = className.indexOf('mini') != -1; var isSmallItem = isMiniItem || className.indexOf('small') != -1; var isPortrait = className.indexOf('portrait') != -1; var isSquare = className.indexOf('square') != -1; var parentName = isSmallItem || isMiniItem || isPortrait ? null : item.SeriesName; var name = LibraryBrowser.getPosterViewDisplayName(item, true); html += '
'; var logoHeight = isSmallItem || isMiniItem ? 20 : 26; var maxLogoWidth = isPortrait ? 100 : 200; var imgUrl; if (parentName && item.ParentLogoItemId) { imgUrl = ApiClient.getScaledImageUrl(item.ParentLogoItemId, { height: logoHeight, type: 'logo', tag: item.ParentLogoImageTag }); html += ''; } else if (item.ImageTags.Logo) { imgUrl = ApiClient.getScaledImageUrl(item.Id, { height: logoHeight, type: 'logo', tag: item.ImageTags.Logo }); html += ''; } else { html += parentName || name; } html += '
'; if (parentName) { html += '

'; html += name; html += '

'; } else if (!isSmallItem && !isMiniItem) { html += '

'; html += LibraryBrowser.getMiscInfoHtml(item); html += '

'; } if (!isMiniItem) { html += '
'; if (isPortrait) { html += '
'; html += LibraryBrowser.getRatingHtml(item, false); html += '
'; html += '
'; html += LibraryBrowser.getUserDataIconsHtml(item); html += '
'; } else { html += ''; html += LibraryBrowser.getRatingHtml(item, false); html += ''; html += ''; html += LibraryBrowser.getUserDataIconsHtml(item); html += ''; } html += '
'; } html += '
'; var buttonMargin = isPortrait || isSquare ? "margin:0 4px 0 0;" : "margin:0 10px 0 0;"; var buttonCount = 0; if (MediaController.canPlay(item)) { var resumePosition = (item.UserData || {}).PlaybackPositionTicks || 0; html += ''; buttonCount++; } if (commands.indexOf('trailer') != -1) { html += ''; buttonCount++; } html += ''; buttonCount++; html += '
'; html += '
'; return html; } function closeContextMenu() { // Used by the tab menu, not the slide up $('.tapHoldMenu').popup('close'); } function onTrailerButtonClick() { var id = this.getAttribute('data-itemid'); ApiClient.getLocalTrailers(Dashboard.getCurrentUserId(), id).done(function (trailers) { MediaController.play({ items: trailers }); }); closeContextMenu(); return false; } function onPlayItemButtonClick() { var id = this.getAttribute('data-itemid'); var type = this.getAttribute('data-itemtype'); var isFolder = this.getAttribute('data-isfolder') == 'true'; var mediaType = this.getAttribute('data-mediatype'); var resumePosition = parseInt(this.getAttribute('data-resumeposition')); closeContextMenu(); LibraryBrowser.showPlayMenu(this, id, type, isFolder, mediaType, resumePosition); return false; } function onMoreButtonClick() { var card = $(this).parents('.card')[0]; closeContextMenu(); showContextMenu(card, { showPlayOptions: false }); return false; } function onAddToCollectionButtonClick() { var id = this.getAttribute('data-itemid'); closeContextMenu(); BoxSetEditor.showPanel([id]); return false; } function onAddToPlaylistButtonClick() { var id = this.getAttribute('data-itemid'); closeContextMenu(); PlaylistManager.showPanel([id]); return false; } function onShuffleButtonClick() { var id = this.getAttribute('data-itemid'); MediaController.shuffle(id); closeContextMenu(); return false; } function onInstantMixButtonClick() { var id = this.getAttribute('data-itemid'); MediaController.instantMix(id); closeContextMenu(); return false; } function onQueueButtonClick() { var id = this.getAttribute('data-itemid'); MediaController.queue(id); closeContextMenu(); return false; } function onPlayButtonClick() { var id = this.getAttribute('data-itemid'); MediaController.play(id); closeContextMenu(); return false; } function onDeleteButtonClick() { var id = this.getAttribute('data-itemid'); closeContextMenu(); LibraryBrowser.deleteItem(id); return false; } function onSyncButtonClick() { var id = this.getAttribute('data-itemid'); closeContextMenu(); SyncManager.showMenu({ items: [ { Id: id }] }); return false; } function onExternalPlayerButtonClick() { closeContextMenu(); var id = this.getAttribute('data-itemid'); ExternalPlayer.showMenu(id); return false; } function onPlayAllFromHereButtonClick() { var index = this.getAttribute('data-index'); var page = $(this).parents('.page'); var itemsContainer = $('.hasContextMenu', page).parents('.itemsContainer'); closeContextMenu(); itemsContainer.trigger('playallfromhere', [index]); return false; } function onQueueAllFromHereButtonClick() { var index = this.getAttribute('data-index'); var page = $(this).parents('.page'); var itemsContainer = $('.hasContextMenu', page).parents('.itemsContainer'); closeContextMenu(); itemsContainer.trigger('queueallfromhere', [index]); return false; } function onRemoveFromPlaylistButtonClick() { var playlistItemId = this.getAttribute('data-playlistitemid'); var page = $(this).parents('.page'); var itemsContainer = $('.hasContextMenu', page).parents('.itemsContainer'); itemsContainer.trigger('removefromplaylist', [playlistItemId]); closeContextMenu(); return false; } function onResumeButtonClick() { var id = this.getAttribute('data-itemid'); MediaController.play({ ids: [id], startPositionTicks: parseInt(this.getAttribute('data-ticks')) }); closeContextMenu(); return false; } function onCardTapHold(e) { showContextMenu(this, {}); e.preventDefault(); return false; } function showContextMenu(card, options) { closeContextMenu(); var displayContextItem = card; if ($(card).hasClass('listviewMenuButton')) { card = $(card).parents('.listItem,.card')[0]; } var itemId = card.getAttribute('data-itemid'); var playlistItemId = card.getAttribute('data-playlistitemid'); var commands = card.getAttribute('data-commands').split(','); var itemType = card.getAttribute('data-itemtype'); var mediaType = card.getAttribute('data-mediatype'); var playbackPositionTicks = parseInt(card.getAttribute('data-positionticks') || '0'); var playAccess = card.getAttribute('data-playaccess'); var locationType = card.getAttribute('data-locationtype'); var index = card.getAttribute('data-index'); $(card).addClass('hasContextMenu'); Dashboard.getCurrentUser().done(function (user) { var html = '
'; html += ''; html += '
'; $($.mobile.activePage).append(html); var elem = $('.tapHoldMenu').popup({ positionTo: displayContextItem }).trigger('create').popup("open").on("popupafterclose", function () { $(this).off("popupafterclose").remove(); $(card).removeClass('hasContextMenu'); }); $('.btnPlay', elem).on('click', onPlayButtonClick); $('.btnResume', elem).on('click', onResumeButtonClick); $('.btnQueue', elem).on('click', onQueueButtonClick); $('.btnInstantMix', elem).on('click', onInstantMixButtonClick); $('.btnShuffle', elem).on('click', onShuffleButtonClick); $('.btnPlayTrailer', elem).on('click', onTrailerButtonClick); $('.btnAddToPlaylist', elem).on('click', onAddToPlaylistButtonClick); $('.btnRemoveFromPlaylist', elem).on('click', onRemoveFromPlaylistButtonClick); $('.btnPlayAllFromHere', elem).on('click', onPlayAllFromHereButtonClick); $('.btnQueueAllFromHere', elem).on('click', onQueueAllFromHereButtonClick); $('.btnExternalPlayer', elem).on('click', onExternalPlayerButtonClick); $('.btnDelete', elem).on('click', onDeleteButtonClick); $('.btnSync', elem).on('click', onSyncButtonClick); $('.btnAddToCollection', elem).on('click', onAddToCollectionButtonClick); }); } function onListViewMenuButtonClick(e) { showContextMenu(this, {}); e.preventDefault(); return false; } function onGroupedCardClick(e) { var target = $(e.target); var card = this; var itemId = card.getAttribute('data-itemid'); var context = card.getAttribute('data-context'); $(card).addClass('hasContextMenu'); var userId = Dashboard.getCurrentUserId(); var promise1 = ApiClient.getItem(userId, itemId); var options = { Limit: parseInt($('.playedIndicator', card).html() || '10'), Fields: "PrimaryImageAspectRatio,DateCreated", ParentId: itemId, GroupItems: false }; var promise2 = ApiClient.getJSON(ApiClient.getUrl('Users/' + userId + '/Items/Latest', options)); $.when(promise1, promise2).done(function (response1, response2) { var item = response1[0]; var latestItems = response2[0]; if (latestItems.length == 1) { if (!target.is('a,button')) { var first = latestItems[0]; Dashboard.navigate(LibraryBrowser.getHref(first, context)); return; } } var html = '
'; html += 'Close'; html += '
'; html += ''; html += ''; html += '
'; html += '
'; $($.mobile.activePage).append(html); $('.groupingMenu').popup().trigger('create').popup("open").on("popupafterclose", function () { $(this).off("popupafterclose").remove(); $(card).removeClass('hasContextMenu'); }); }); e.preventDefault(); return false; } $.fn.createCardMenus = function () { var preventHover = false; function onShowTimerExpired(elem) { elem = $('a', elem)[0]; if ($(elem).hasClass('hasContextMenu')) { return; } if ($('.itemSelectionPanel:visible', elem).length) { return; } var innerElem = $('.cardOverlayTarget', elem); var dataElement = elem; while (!dataElement.getAttribute('data-itemid')) { dataElement = dataElement.parentNode; } var id = dataElement.getAttribute('data-itemid'); var commands = dataElement.getAttribute('data-commands').split(','); var promise1 = ApiClient.getItem(Dashboard.getCurrentUserId(), id); var promise2 = Dashboard.getCurrentUser(); $.when(promise1, promise2).done(function (response1, response2) { var item = response1[0]; var user = response2[0]; var card = $(elem); if (!card.hasClass('card')) { card = card.parents('.card'); } innerElem.html(getOverlayHtml(item, user, card[0], commands)).trigger('create'); $('.btnPlayItem', innerElem).on('click', onPlayItemButtonClick); $('.btnPlayTrailer', innerElem).on('click', onTrailerButtonClick); $('.btnMoreCommands', innerElem).on('click', onMoreButtonClick); }); innerElem.show().each(function () { this.style.height = 0; }).animate({ "height": "100%" }, "fast"); } function onHoverIn() { if (preventHover === true) { preventHover = false; return; } if (showOverlayTimeout) { clearTimeout(showOverlayTimeout); showOverlayTimeout = null; } var elem = this; showOverlayTimeout = setTimeout(function () { onShowTimerExpired(elem); }, 1000); } function preventTouchHover() { preventHover = true; } return this .off('.cardMenu') .on('contextmenu.cardMenu', '.card', onCardTapHold) .off('.latestgroupings') .on('click.latestgroupings', '.groupedCard', onGroupedCardClick) .off('.dotmenu') .on('click.dotmenu', '.listviewMenuButton', onListViewMenuButtonClick) .off('.cardHoverMenu') .on('mouseenter.cardHoverMenu', '.card:not(.bannerCard)', onHoverIn) .on('mouseleave.cardHoverMenu', '.card:not(.bannerCard)', onHoverOut) .on("touchstart.cardHoverMenu", '.card:not(.bannerCard)', preventTouchHover); }; function toggleSelections(page) { Dashboard.showLoadingMsg(); var selectionCommands = $('.selectionCommands', page); if (selectionCommands.is(':visible')) { selectionCommands.hide(); $('.itemSelectionPanel', page).hide(); } else { selectionCommands.show(); var panels = $('.itemSelectionPanel', page).show(); if (!panels.length) { var index = 0; $('.cardContent', page).each(function () { var chkItemSelectId = 'chkItemSelect' + index; $(this).append('
'); index++; }); $('.itemsContainer', page).trigger('create'); } $('.chkItemSelect:checked', page).checked(false).checkboxradio('refresh'); } Dashboard.hideLoadingMsg(); } function hideSelections(page) { $('.selectionCommands', page).hide(); $('.itemSelectionPanel', page).hide(); } function getSelectedItems(page) { var selection = $('.chkItemSelect:checked', page); return selection.parents('.card') .map(function () { return this.getAttribute('data-itemid'); }).get(); } function sync(page) { var selection = getSelectedItems(page); if (selection.length < 1) { Dashboard.alert({ message: Globalize.translate('MessagePleaseSelectOneItem'), title: Globalize.translate('HeaderError') }); return; } SyncManager.showMenu({ items: selection }); $(SyncManager).off('jobsubmit.librarylist').on('jobsubmit.librarylist', function () { hideSelections(page); }); } function combineVersions(page) { var selection = getSelectedItems(page); if (selection.length < 2) { Dashboard.alert({ message: Globalize.translate('MessagePleaseSelectTwoItems'), title: Globalize.translate('HeaderError') }); return; } var names = $('.chkItemSelect:checked', page).parents('.card').get().reverse().map(function (e) { return $('.cardText', e).html(); }).join('
'); var msg = Globalize.translate('MessageTheFollowingItemsWillBeGrouped') + "

" + names; msg += "

" + Globalize.translate('MessageConfirmItemGrouping'); Dashboard.confirm(msg, "Group Versions", function (confirmResult) { if (confirmResult) { Dashboard.showLoadingMsg(); ApiClient.ajax({ type: "POST", url: ApiClient.getUrl("Videos/MergeVersions", { Ids: selection.join(',') }) }).done(function () { Dashboard.hideLoadingMsg(); hideSelections(page); $('.itemsContainer', page).trigger('needsrefresh'); }); } }); } function addToCollection(page) { var selection = getSelectedItems(page); if (selection.length < 1) { Dashboard.alert({ message: Globalize.translate('MessagePleaseSelectOneItem'), title: Globalize.translate('HeaderError') }); return; } BoxSetEditor.showPanel(selection); } function addToPlaylist(page) { var selection = getSelectedItems(page); if (selection.length < 1) { Dashboard.alert({ message: Globalize.translate('MessagePleaseSelectOneItem'), title: Globalize.translate('HeaderError') }); return; } PlaylistManager.showPanel(selection); } function onItemWithActionClick(e) { var elem = this; var action = elem.getAttribute('data-action'); var elemWithAttributes = elem; if (action) { while (!elemWithAttributes.getAttribute('data-itemid')) { elemWithAttributes = elemWithAttributes.parentNode; } } var index; var itemsContainer; var itemId = elemWithAttributes.getAttribute('data-itemid'); if (action == 'play') { MediaController.play(itemId); } else if (action == 'playallfromhere') { index = elemWithAttributes.getAttribute('data-index'); itemsContainer = $(elem).parents('.itemsContainer'); closeContextMenu(); itemsContainer.trigger('playallfromhere', [index]); } else if (action == 'setplaylistindex') { index = elemWithAttributes.getAttribute('data-index'); closeContextMenu(); MediaController.currentPlaylistIndex(index); } else if (action == 'photoslideshow') { if (!$(elem).hasClass('card')) { elem = $(elem).parents('.card')[0]; } itemsContainer = $(elem).parents('.itemsContainer'); index = $('.card', itemsContainer).get().indexOf(elem); closeContextMenu(); itemsContainer.trigger('photoslideshow', [index]); } return false; } function resetCardImage() { this.style.backgroundImage = "url('css/images/empty.png')"; } function resetImages(page) { //$('cardImage', page).remove(); $('.cardImage', page).each(resetCardImage); } $(document).on('pageinit', ".libraryPage", function () { var page = this; $('.btnAddToPlaylist', page).on('click', function () { addToPlaylist(page); }); $('.btnMergeVersions', page).on('click', function () { combineVersions(page); }); $('.btnSyncItems', page).on('click', function () { sync(page); }); $('.btnAddToCollection', page).on('click', function () { addToCollection(page); }); $('.viewTabButton', page).on('click', function () { $('.viewTabButton', page).removeClass('ui-btn-active'); $(this).addClass('ui-btn-active'); $('.viewTab', page).hide(); $('.' + this.getAttribute('data-tab'), page).show(); }); var viewPanel = $('.viewPanel', page); $('#selectPageSize', viewPanel).html(LibraryBrowser.getDefaultPageSizeSelections().map(function (i) { return ''; }).join('')).selectmenu('refresh'); $(page).on('click', '.btnToggleSelections', function () { toggleSelections(page); }).on('click', '.itemWithAction', onItemWithActionClick); $('.itemsContainer', page).createCardMenus(); }).on('pagebeforeshow', ".libraryPage", function () { var page = this; hideSelections(page); $('.viewTabButton:first', page).trigger('click'); }).on('pagebeforehide', ".libraryPage", function () { var page = this; resetImages(page); }); function renderUserDataChanges(card, userData) { if (userData.Played) { if (!$('.playedIndicator', card).length) { $('
').insertAfter($('.cardOverlayTarget', card)); } $('.playedIndicator', card).html('
'); $('.cardProgress', card).remove(); } else if (userData.UnplayedItemCount) { if (!$('.playedIndicator', card).length) { $('
').insertAfter($('.cardOverlayTarget', card)); } $('.playedIndicator', card).html(userData.UnplayedItemCount); } else { $('.playedIndicator', card).remove(); var progressHtml = LibraryBrowser.getItemProgressBarHtml(userData); $('.cardProgress', card).html(progressHtml); } } function onUserDataChanged(userData) { var cssClass = LibraryBrowser.getUserDataCssClass(userData.Key); if (!cssClass) { return; } $('.' + cssClass).each(function () { var mediaType = this.getAttribute('data-mediatype'); if (mediaType == 'Video') { this.setAttribute('data-positionticks', (userData.PlaybackPositionTicks || 0)); if ($(this).hasClass('card')) { renderUserDataChanges(this, userData); } } }); } function onWebSocketMessage(e, data) { var msg = data; if (msg.MessageType === "UserDataChanged") { if (msg.Data.UserId == Dashboard.getCurrentUserId()) { for (var i = 0, length = msg.Data.UserDataList.length; i < length; i++) { onUserDataChanged(msg.Data.UserDataList[i]); } } } } function initializeApiClient(apiClient) { $(apiClient).off('websocketmessage.librarylist', onWebSocketMessage).on('websocketmessage.librarylist', onWebSocketMessage); } $(ConnectionManager).on('apiclientcreated', function (e, apiClient) { initializeApiClient(apiClient); }); })(jQuery, document, window);