var MediaLibraryPage = { onPageInit: function () { var page = this; $('#selectCollectionType', page).on('change', function () { var index = this.selectedIndex; if (index != -1) { var name = this.options[index].innerHTML .replace('*', '') .replace('&', '&'); var value = this.value; $('#txtValue', page).val(name); var folderOption = MediaLibraryPage.getCollectionTypeOptions().filter(function (i) { return i.value == value; })[0]; $('.collectionTypeFieldDescription', page).html(folderOption.message || ''); } }); }, onPageShow: function () { var page = this; MediaLibraryPage.lastVirtualFolderName = ""; MediaLibraryPage.reloadLibrary(page); }, reloadLibrary: function (page) { Dashboard.showLoadingMsg(); ApiClient.getVirtualFolders().done(function (result) { MediaLibraryPage.reloadVirtualFolders(page, result); }); $('#divMediaLibrary', page).show(); }, shouldRefreshLibraryAfterChanges: function () { return $($.mobile.activePage).is('#mediaLibraryPage'); }, reloadVirtualFolders: function (page, virtualFolders) { if (virtualFolders) { MediaLibraryPage.virtualFolders = virtualFolders; } else { virtualFolders = MediaLibraryPage.virtualFolders; } var html = ''; var addPathMappingInfo = $(page).is('#mediaLibraryPage'); 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, addPathMappingInfo); } $('#divVirtualFolders', page).html(html).trigger('create'); Dashboard.hideLoadingMsg(); }, changeCollectionType: function () { Dashboard.alert({ message: Globalize.translate('HeaderChangeFolderTypeHelp'), title: Globalize.translate('HeaderChangeFolderType') }); }, getVirtualFolderHtml: function (virtualFolder, isCollapsed, index, addPathMappingInfo) { 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 : Globalize.translate('FolderTypeUnset'); html += '

'; html += Globalize.translate('LabelContentTypeValue').replace('{0}', '' + typeName + ''); html += '

'; if (addPathMappingInfo) { html += '
' + Globalize.translate('LabelPathSubstitutionHelp') + '
'; } html += '

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

'; html += '
'; return html; }, addVirtualFolder: function () { $('.collectionTypeFieldDescription').show(); MediaLibraryPage.getTextValue(Globalize.translate('HeaderAddMediaFolder'), Globalize.translate('LabelName'), "", true, function (name, type) { MediaLibraryPage.lastVirtualFolderName = name; var refreshAfterChange = MediaLibraryPage.shouldRefreshLibraryAfterChanges(); ApiClient.addVirtualFolder(name, type, refreshAfterChange).done(MediaLibraryPage.processOperationResult); }); }, addMediaLocation: function (virtualFolderIndex) { MediaLibraryPage.selectDirectory(function (path) { if (path) { var virtualFolder = MediaLibraryPage.virtualFolders[virtualFolderIndex]; MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; var refreshAfterChange = MediaLibraryPage.shouldRefreshLibraryAfterChanges(); ApiClient.addMediaPath(virtualFolder.Name, path, 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("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: Globalize.translate('FolderTypeMovies'), value: "movies" }, { name: Globalize.translate('FolderTypeMusic'), value: "music" }, { name: Globalize.translate('FolderTypeTvShows'), value: "tvshows" }, { name: Globalize.translate('FolderTypeBooks'), value: "books", message: Globalize.translate('MessageBookPluginRequired') }, { name: Globalize.translate('FolderTypeGames'), value: "games", message: Globalize.translate('MessageGamePluginRequired') }, { name: Globalize.translate('FolderTypeHomeVideos'), value: "homevideos" }, { name: Globalize.translate('FolderTypeMusicVideos'), value: "musicvideos" }, { name: Globalize.translate('FolderTypePhotos'), value: "photos" }, { name: Globalize.translate('FolderTypeUnset'), value: "mixed", message: Globalize.translate('MessageUnsetContentHelp') } ]; }, renameVirtualFolder: function (button) { var folderIndex = button.getAttribute('data-folderindex'); var virtualFolder = MediaLibraryPage.virtualFolders[folderIndex]; MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; $('.collectionTypeFieldDescription').hide(); MediaLibraryPage.getTextValue(Globalize.translate('HeaderRenameMediaFolder'), Globalize.translate('LabelNewName'), virtualFolder.Name, false, function (newName) { if (virtualFolder.Name != newName) { var refreshAfterChange = MediaLibraryPage.shouldRefreshLibraryAfterChanges(); ApiClient.renameVirtualFolder(virtualFolder.Name, newName, 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 = Globalize.translate('MessageAreYouSureYouWishToRemoveMediaFolder'); if (locations.length) { msg += "

" + Globalize.translate("MessageTheFollowingLocationWillBeRemovedFromLibrary") + "

"; msg += locations.join("
"); } MediaLibraryPage.lastVirtualFolderName = virtualFolder.Name; Dashboard.confirm(msg, Globalize.translate('HeaderRemoveMediaFolder'), function (confirmResult) { if (confirmResult) { var refreshAfterChange = MediaLibraryPage.shouldRefreshLibraryAfterChanges(); ApiClient.removeVirtualFolder(virtualFolder.Name, 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(Globalize.translate('MessageConfirmRemoveMediaLocation'), Globalize.translate('HeaderRemoveMediaLocation'), function (confirmResult) { if (confirmResult) { var refreshAfterChange = MediaLibraryPage.shouldRefreshLibraryAfterChanges(); ApiClient.removeMediaPath(virtualFolder.Name, location, 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('pageinitdepends', ".mediaLibraryPage", MediaLibraryPage.onPageInit).on('pageshowready', ".mediaLibraryPage", MediaLibraryPage.onPageShow); var WizardLibraryPage = { next: function () { Dashboard.showLoadingMsg(); var apiClient = ApiClient; apiClient.ajax({ type: "POST", url: apiClient.getUrl('System/Configuration/MetadataPlugins/Autoset') }).done(function () { Dashboard.hideLoadingMsg(); Dashboard.navigate('wizardsettings.html'); }); } }; (function ($, document, window) { $(document).on('pageshowready', "#mediaLibraryPage", function () { var page = this; // on here $('.btnRefresh', page).taskButton({ mode: 'on', progressElem: $('.refreshProgress', page), lastResultElem: $('.lastRefreshResult', page), taskKey: 'RefreshLibrary' }); }).on('pagebeforehide', "#mediaLibraryPage", function () { var page = this; // off here $('.btnRefresh', page).taskButton({ mode: 'off' }); }); })(jQuery, document, window);