/* eslint-disable indent */ /** * Module for media library creator. * @module components/mediaLibraryCreator/mediaLibraryCreator */ import escapeHtml from 'escape-html'; import loading from '../loading/loading'; import dialogHelper from '../dialogHelper/dialogHelper'; import dom from '../../scripts/dom'; import 'jquery'; import libraryoptionseditor from '../libraryoptionseditor/libraryoptionseditor'; import globalize from '../../scripts/globalize'; import '../../elements/emby-button/emby-button'; import '../../elements/emby-button/paper-icon-button-light'; import '../../elements/emby-input/emby-input'; import '../../elements/emby-select/emby-select'; import '../../elements/emby-toggle/emby-toggle'; import '../listview/listview.scss'; import '../formdialog.scss'; import '../../styles/flexstyles.scss'; import './style.scss'; import toast from '../toast/toast'; import alert from '../alert'; import template from './mediaLibraryCreator.template.html'; function onAddLibrary(e) { if (isCreating) { return false; } if (pathInfos.length == 0) { alert({ text: globalize.translate('PleaseAddAtLeastOneFolder'), type: 'error' }); return false; } isCreating = true; loading.show(); const dlg = dom.parentWithClass(this, 'dlg-librarycreator'); const name = $('#txtValue', dlg).val(); let type = $('#selectCollectionType', dlg).val(); if (type == 'mixed') { type = null; } const libraryOptions = libraryoptionseditor.getLibraryOptions(dlg.querySelector('.libraryOptions')); libraryOptions.PathInfos = pathInfos; ApiClient.addVirtualFolder(name, type, currentOptions.refresh, libraryOptions).then(() => { hasChanges = true; isCreating = false; loading.hide(); dialogHelper.close(dlg); }, () => { toast(globalize.translate('ErrorAddingMediaPathToVirtualFolder')); isCreating = false; loading.hide(); }); e.preventDefault(); } function getCollectionTypeOptionsHtml(collectionTypeOptions) { return collectionTypeOptions.map(i => { return ``; }).join(''); } function initEditor(page, collectionTypeOptions) { $('#selectCollectionType', page).html(getCollectionTypeOptionsHtml(collectionTypeOptions)).val('').on('change', function () { const value = this.value; const dlg = $(this).parents('.dialog')[0]; libraryoptionseditor.setContentType(dlg.querySelector('.libraryOptions'), value); if (value) { dlg.querySelector('.libraryOptions').classList.remove('hide'); } else { dlg.querySelector('.libraryOptions').classList.add('hide'); } if (value != 'mixed') { const index = this.selectedIndex; if (index != -1) { const name = this.options[index].innerHTML.replace('*', '').replace('&', '&'); $('#txtValue', dlg).val(name); } } const folderOption = collectionTypeOptions.find(i => i.value === value); $('.collectionTypeFieldDescription', dlg).html(folderOption?.message || ''); }); page.querySelector('.btnAddFolder').addEventListener('click', onAddButtonClick); page.querySelector('.addLibraryForm').addEventListener('submit', onAddLibrary); page.querySelector('.folderList').addEventListener('click', onRemoveClick); } function onAddButtonClick() { const page = dom.parentWithClass(this, 'dlg-librarycreator'); import('../directorybrowser/directorybrowser').then(({ default: DirectoryBrowser }) => { const picker = new DirectoryBrowser(); picker.show({ enableNetworkSharePath: true, callback: function (path, networkSharePath) { if (path) { addMediaLocation(page, path, networkSharePath); } picker.close(); } }); }); } function getFolderHtml(pathInfo, index) { let html = ''; html += '