var MediaLibraryPage = { onPageShow: function () { var page = this; MediaLibraryPage.lastVirtualFolderName = ""; MediaLibraryPage.reloadUsers(page); $('#selectUser', page).on('change.reloadLibrary', function() { MediaLibraryPage.reloadLibrary(page); }); }, onPageHide: function() { var page = this; $('#selectUser', page).off('click.reloadLibrary'); }, reloadUsers: function (page) { ApiClient.getUsers().done(function (users) { var html = users.map(function (u) { return ''; }); html = '' + html; $('#selectUser', page).html(html).val('').selectmenu('refresh'); MediaLibraryPage.reloadLibrary(page); }); }, getCurrentUserId: function(page) { return $('#selectUser', page).val(); }, reloadLibrary: function (page) { Dashboard.showLoadingMsg(); var userId = MediaLibraryPage.getCurrentUserId(page); if (userId) { ApiClient.getUser(userId).done(function (user) { $('#fldUseDefaultLibrary', page).show(); $('#chkUseDefaultLibrary', page).checked(!user.Configuration.UseCustomLibrary).checkboxradio("refresh"); if (user.Configuration.UseCustomLibrary) { ApiClient.getVirtualFolders(userId).done(function (result) { MediaLibraryPage.reloadVirtualFolders(page, result); }); $(".editing_default", page).hide(); $('#divMediaLibrary', page).show(); } else { $('#divMediaLibrary', page).hide(); Dashboard.hideLoadingMsg(); } }); } else { ApiClient.getVirtualFolders().done(function (result) { MediaLibraryPage.reloadVirtualFolders(page, result); }); $('#fldUseDefaultLibrary', page).hide(); $('#divMediaLibrary', page).show(); Dashboard.setPageTitle("Media Library"); } }, shouldRefreshLibraryAfterChanges: function () { return $($.mobile.activePage).is('#mediaLibraryPage'); }, reloadVirtualFolders: function (page, virtualFolders) { if (virtualFolders) { MediaLibraryPage.virtualFolders = virtualFolders; } else { virtualFolders = MediaLibraryPage.virtualFolders; } var html = ''; for (var i = 0, length = virtualFolders.length; i < length; i++) { var virtualFolder = virtualFolders[i]; var isCollapsed = MediaLibraryPage.lastVirtualFolderName != virtualFolder.Name; html += MediaLibraryPage.getVirtualFolderHtml(virtualFolder, isCollapsed, i); } $('#divVirtualFolders', page).html(html).trigger('create'); Dashboard.hideLoadingMsg(); }, changeCollectionType: function () { Dashboard.alert({ message: "To change the folder type, please remove and rebuild the collection with the new type.", title: "Change Folder Type" }); }, getVirtualFolderHtml: function (virtualFolder, isCollapsed, index) { isCollapsed = isCollapsed ? "true" : "false"; var html = '
'; html += '

' + virtualFolder.Name + '

'; var typeName = MediaLibraryPage.getCollectionTypeOptions().filter(function (t) { return t.value == virtualFolder.CollectionType; })[0]; typeName = typeName ? typeName.name : "General or mixed content"; html += '

Folder type: ' + typeName + '

'; html += ''; html += '

'; html += ''; html += ''; html += ''; html += '

'; html += '
'; return html; }, setUseDefaultMediaLibrary: function (useDefaultLibrary) { Dashboard.showLoadingMsg(); var page = $.mobile.activePage; var userId = MediaLibraryPage.getCurrentUserId(page); ApiClient.getUser(userId).done(function (user) { user.Configuration.UseCustomLibrary = !useDefaultLibrary; ApiClient.updateUser(user).done(function () { MediaLibraryPage.reloadLibrary(page); }); $(".editing_default", page).hide(); }); }, addVirtualFolder: function () { $('.collectionTypeFieldDescription').show(); MediaLibraryPage.getTextValue("Add Media Folder", "Name (Movies, Music, TV, etc):", "", true, function (name, type) { var userId = MediaLibraryPage.getCurrentUserId($.mobile.activePage); MediaLibraryPage.lastVirtualFolderName = name; var refreshAfterChange = MediaLibraryPage.shouldRefreshLibraryAfterChanges(); ApiClient.addVirtualFolder(name, type, userId, refreshAfterChange).done(MediaLibraryPage.processOperationResult); }); }, addMediaLocation: function (virtualFolderIndex) { MediaLibraryPage.selectDirectory(function (path) { if (path) { var virtualFolder = MediaLibraryPage.virtualFolders[virtualFolderIndex]; MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; var userId = MediaLibraryPage.getCurrentUserId($.mobile.activePage); var refreshAfterChange = MediaLibraryPage.shouldRefreshLibraryAfterChanges(); ApiClient.addMediaPath(virtualFolder.Name, path, userId, refreshAfterChange).done(MediaLibraryPage.processOperationResult); } }); }, selectDirectory: function (callback) { var picker = new DirectoryBrowser($.mobile.activePage); picker.show({ callback: callback }); MediaLibraryPage.directoryPicker = picker; }, getTextValue: function (header, label, initialValue, showCollectionType, callback) { var page = $.mobile.activePage; var popup = $('#popupEnterText', page); $('h3', popup).html(header); $('#lblValue', popup).html(label); $('#txtValue', popup).val(initialValue); if (showCollectionType) { $('#fldCollectionType', popup).show(); $('#selectCollectionType', popup).attr('required', 'required').selectmenu('refresh'); } else { $('#fldCollectionType', popup).hide(); $('#selectCollectionType', popup).removeAttr('required').selectmenu('refresh'); } $('#selectCollectionType', popup).html(MediaLibraryPage.getCollectionTypeOptionsHtml()).val('').selectmenu('refresh'); popup.on("popupafteropen", function () { $('#textEntryForm input:first', this).focus(); }).on("popupafterclose", function () { $(this).off("popupafterclose").off("click"); $('#textEntryForm', this).off("submit"); }).popup("open"); $('#textEntryForm', popup).on('submit', function () { if (callback) { if (showCollectionType) { var collectionType = $('#selectCollectionType', popup).val(); // The server expects an empty value for mixed if (collectionType == 'mixed') { collectionType = ''; } callback($('#txtValue', popup).val(), collectionType); } else { callback($('#txtValue', popup).val()); } } return false; }); }, getCollectionTypeOptionsHtml: function () { return MediaLibraryPage.getCollectionTypeOptions().filter(function (i) { return i.isSelectable !== false; }).map(function (i) { return ''; }).join(""); }, getCollectionTypeOptions: function () { return [ { name: "", value: "" }, { name: "Movies", value: "movies" }, { name: "Music", value: "music" }, { name: "TV shows", value: "tvshows" }, { name: "Books*", value: "books" }, { name: "Collections", value: "boxsets" }, { name: "Games*", value: "games" }, { name: "Home videos", value: "homevideos" }, { name: "Music videos", value: "musicvideos" }, { name: "Photos*", value: "photos" }, { name: "Trailers", value: "trailers" }, { name: "Adult videos", value: "adultvideos" }, { name: "Mixed content", value: "mixed" } ]; }, renameVirtualFolder: function (button) { var folderIndex = button.getAttribute('data-folderindex'); var virtualFolder = MediaLibraryPage.virtualFolders[folderIndex]; MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; $('.collectionTypeFieldDescription').hide(); MediaLibraryPage.getTextValue(virtualFolder.Name, "Rename " + virtualFolder.Name, virtualFolder.Name, false, function (newName) { if (virtualFolder.Name != newName) { var userId = MediaLibraryPage.getCurrentUserId($.mobile.activePage); var refreshAfterChange = MediaLibraryPage.shouldRefreshLibraryAfterChanges(); ApiClient.renameVirtualFolder(virtualFolder.Name, newName, userId, refreshAfterChange).done(MediaLibraryPage.processOperationResult); } }); }, deleteVirtualFolder: function (button) { var folderIndex = button.getAttribute('data-folderindex'); var virtualFolder = MediaLibraryPage.virtualFolders[folderIndex]; var parent = $(button).parents('.collapsibleVirtualFolder'); var locations = $('.lnkMediaLocation', parent).map(function () { return this.innerHTML; }).get(); var msg = "Are you sure you wish to remove " + virtualFolder.Name + "?"; if (locations.length) { msg += "

The following media locations will be removed from your library:

"; msg += locations.join("
"); } MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; Dashboard.confirm(msg, "Remove Media Folder", function (confirmResult) { if (confirmResult) { var userId = MediaLibraryPage.getCurrentUserId($.mobile.activePage); var refreshAfterChange = MediaLibraryPage.shouldRefreshLibraryAfterChanges(); ApiClient.removeVirtualFolder(virtualFolder.Name, userId, refreshAfterChange).done(MediaLibraryPage.processOperationResult); } }); }, deleteMediaLocation: function (button) { var folderIndex = button.getAttribute('data-folderindex'); var index = parseInt(button.getAttribute('data-index')); var virtualFolder = MediaLibraryPage.virtualFolders[folderIndex]; MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; var location = virtualFolder.Locations[index]; Dashboard.confirm("Are you sure you wish to remove " + location + "?", "Remove Media Location", function (confirmResult) { if (confirmResult) { var userId = MediaLibraryPage.getCurrentUserId($.mobile.activePage); var refreshAfterChange = MediaLibraryPage.shouldRefreshLibraryAfterChanges(); ApiClient.removeMediaPath(virtualFolder.Name, location, userId, refreshAfterChange).done(MediaLibraryPage.processOperationResult); } }); }, processOperationResult: function (result) { Dashboard.hideLoadingMsg(); var page = $.mobile.activePage; $('#popupEnterText', page).popup("close"); if (MediaLibraryPage.directoryPicker) { MediaLibraryPage.directoryPicker.close(); MediaLibraryPage.directoryPicker = null; } MediaLibraryPage.reloadLibrary(page); } }; $(document).on('pageshow', ".mediaLibraryPage", MediaLibraryPage.onPageShow).on('pagehide', ".mediaLibraryPage", MediaLibraryPage.onPageHide);