import escapeHtml from 'escape-html'; import loading from '../loading/loading'; import dialogHelper from '../dialogHelper/dialogHelper'; import dom from '../../scripts/dom'; import globalize from '../../lib/globalize'; import '../listview/listview.scss'; import '../../elements/emby-input/emby-input'; import '../../elements/emby-button/paper-icon-button-light'; import './directorybrowser.scss'; import '../formdialog.scss'; import '../../elements/emby-button/emby-button'; import alert from '../alert'; function getSystemInfo() { return systemInfo ? Promise.resolve(systemInfo) : ApiClient.getPublicSystemInfo().then( info => { systemInfo = info; return info; } ); } function onDialogClosed() { loading.hide(); } function refreshDirectoryBrowser(page, path, fileOptions, updatePathOnError) { if (path && typeof path !== 'string') { throw new Error('invalid path'); } loading.show(); const promises = []; if (path) { promises.push(ApiClient.getDirectoryContents(path, fileOptions)); promises.push(ApiClient.getParentPath(path)); } else { promises.push(ApiClient.getDrives()); } Promise.all(promises).then( responses => { const folders = responses[0]; const parentPath = (responses[1] ? JSON.parse(responses[1]) : '') || ''; let html = ''; page.querySelector('.results').scrollTop = 0; page.querySelector('#txtDirectoryPickerPath').value = path || ''; if (path) { html += getItem('lnkPath lnkDirectory', '', parentPath, '...'); } for (let i = 0, length = folders.length; i < length; i++) { const folder = folders[i]; const cssClass = folder.Type === 'File' ? 'lnkPath lnkFile' : 'lnkPath lnkDirectory'; html += getItem(cssClass, folder.Type, folder.Path, folder.Name); } page.querySelector('.results').innerHTML = html; loading.hide(); }, () => { if (updatePathOnError) { page.querySelector('#txtDirectoryPickerPath').value = ''; page.querySelector('.results').innerHTML = ''; loading.hide(); } } ); } function getItem(cssClass, type, path, name) { let html = ''; html += `