1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00
jellyfin-web/src/components/directorybrowser/directorybrowser.js

298 lines
12 KiB
JavaScript
Raw Normal View History

2019-01-11 09:11:57 -05:00
define(['loading', 'dialogHelper', 'dom', 'listViewStyle', 'emby-input', 'emby-button', 'paper-icon-button-light', 'css!./directorybrowser', 'formDialogStyle', 'emby-linkbutton'], function(loading, dialogHelper, dom) {
'use strict';
2018-10-23 01:05:09 +03:00
function getSystemInfo() {
2019-01-11 09:11:57 -05:00
return systemInfo ? Promise.resolve(systemInfo) : ApiClient.getPublicSystemInfo().then(
function(info) {
systemInfo = info;
return info;
}
)
2018-10-23 01:05:09 +03:00
}
function onDialogClosed() {
loading.hide()
}
function refreshDirectoryBrowser(page, path, fileOptions, updatePathOnError) {
2019-01-11 09:11:57 -05:00
if (path && typeof path !== 'string') {
throw new Error("invalid path");
}
2018-10-23 01:05:09 +03:00
loading.show();
2018-10-23 01:05:09 +03:00
var promises = [];
2019-01-11 09:11:57 -05:00
if ("Network" === path) {
promises.push(ApiClient.getNetworkDevices())
} else {
if (path) {
2019-01-11 09:11:57 -05:00
promises.push(ApiClient.getDirectoryContents(path, fileOptions));
promises.push(ApiClient.getParentPath(path));
} else {
2019-01-11 09:11:57 -05:00
promises.push(ApiClient.getDrives());
2018-10-23 01:05:09 +03:00
}
2019-01-11 09:11:57 -05:00
}
Promise.all(promises).then(
function(responses) {
var folders = responses[0];
var parentPath = responses[1] || "";
var html = "";
page.querySelector(".results").scrollTop = 0;
page.querySelector("#txtDirectoryPickerPath").value = path || "";
2019-01-11 09:11:57 -05:00
if (path) {
html += getItem("lnkPath lnkDirectory", "", parentPath, "...");
}
for (var i = 0, length = folders.length; i < length; i++) {
var folder = folders[i];
var cssClass = "File" === folder.Type ? "lnkPath lnkFile" : "lnkPath lnkDirectory";
html += getItem(cssClass, folder.Type, folder.Path, folder.Name);
}
2019-01-11 09:11:57 -05:00
if (!path) {
html += getItem("lnkPath lnkDirectory", "", "Network", Globalize.translate("ButtonNetwork"));
}
page.querySelector(".results").innerHTML = html;
loading.hide();
}, function() {
if (updatePathOnError) {
page.querySelector("#txtDirectoryPickerPath").value = "";
page.querySelector(".results").innerHTML = "";
loading.hide();
}
}
);
2018-10-23 01:05:09 +03:00
}
function getItem(cssClass, type, path, name) {
var html = "";
2019-01-11 09:11:57 -05:00
html += '<div class="listItem listItem-border ' + cssClass + '" data-type="' + type + '" data-path="' + path + '">';
html += '<div class="listItemBody" style="padding-left:0;padding-top:.5em;padding-bottom:.5em;">';
html += '<div class="listItemBodyText">';
html += name;
html += "</div>";
html += "</div>";
html += '<i class="md-icon" style="font-size:inherit;">arrow_forward</i>';
html += "</div>";
return html;
2018-10-23 01:05:09 +03:00
}
function getEditorHtml(options, systemInfo) {
var html = "";
2019-01-11 09:11:57 -05:00
html += '<div class="formDialogContent scrollY">';
html += '<div class="dialogContentInner dialog-content-centered" style="padding-top:2em;">';
if (!options.pathReadOnly) {
2018-10-23 01:05:09 +03:00
var instruction = options.instruction ? options.instruction + "<br/><br/>" : "";
2019-01-11 09:11:57 -05:00
html += '<div class="infoBanner" style="margin-bottom:1.5em;">';
html += instruction;
html += Globalize.translate("MessageDirectoryPickerInstruction").replace("{0}", "<b>\\\\server</b>").replace("{1}", "<b>\\\\192.168.1.101</b>");
if ("synology" === (systemInfo.PackageName || "").toLowerCase()) {
html += "<br/>";
html += "<br/>";
html += '<a is="emby-linkbutton" class="button-link" href="https://web.archive.org/web/20181216120305/https://github.com/MediaBrowser/Wiki/wiki/Synology-:-Setting-Up-Your-Media-Library-Share" target="_blank">';
html += Globalize.translate("LearnHowToCreateSynologyShares");
html += "</a>";
} else if ("bsd" === systemInfo.OperatingSystem.toLowerCase()) {
html += "<br/>";
html += "<br/>";
html += Globalize.translate("MessageDirectoryPickerBSDInstruction");
html += "<br/>";
html += '<a is="emby-linkbutton" class="button-link" href="http://doc.freenas.org/9.3/freenas_jails.html#add-storage" target="_blank">';
html += Globalize.translate("ButtonMoreInformation");
html += "</a>";
} else if ("linux" === systemInfo.OperatingSystem.toLowerCase()) {
html += "<br/>";
html += "<br/>";
html += Globalize.translate("MessageDirectoryPickerLinuxInstruction");
html += "<br/>";
}
html += "</div>"
}
html += '<form style="margin:auto;">';
html += '<div class="inputContainer" style="display: flex; align-items: center;">';
html += '<div style="flex-grow:1;">';
var labelKey;
if (options.includeFiles !== true) {
labelKey = "LabelFolder";
} else {
labelKey = "LabelPath";
}
var readOnlyAttribute = options.pathReadOnly ? " readonly" : "";
html += '<input is="emby-input" id="txtDirectoryPickerPath" type="text" required="required" ' + readOnlyAttribute + ' label="' + Globalize.translate(labelKey) + '"/>';
html += "</div>";
if (!readOnlyAttribute) {
html += '<button type="button" is="paper-icon-button-light" class="btnRefreshDirectories emby-input-iconbutton" title="' + Globalize.translate("ButtonRefresh") + '"><i class="md-icon">search</i></button>';
}
html += "</div>";
if (!readOnlyAttribute) {
2019-01-11 09:11:57 -05:00
html += '<div class="results paperList" style="max-height: 200px; overflow-y: auto;"></div>';
}
html += '<div class="formDialogFooter">';
html += '<button is="emby-button" type="submit" class="raised button-submit block formDialogFooterItem">' + Globalize.translate("ButtonOk") + "</button>";
html += "</div>";
html += "</form>";
html += "</div>";
html += "</div>";
html += "</div>";
return html;
2018-10-23 01:05:09 +03:00
}
function alertText(text) {
alertTextWithOptions({
text: text
})
}
function alertTextWithOptions(options) {
require(["alert"], function(alert) {
alert(options)
})
}
function validatePath(path, validateWriteable, apiClient) {
return apiClient.ajax({
type: "POST",
url: apiClient.getUrl("Environment/ValidatePath"),
data: {
ValidateWriteable: validateWriteable,
Path: path
}
}).catch(function(response) {
if (response) {
2019-01-11 09:11:57 -05:00
// TODO All alerts (across the project), should use Globalize.translate()
if (response.status === 404) {
alertText("The path could not be found. Please ensure the path is valid and try again.");
return Promise.reject();
}
if (response.status === 500) {
if (validateWriteable) {
alertText("Jellyfin Server requires write access to this folder. Please ensure write access and try again.");
} else {
alertText("The path could not be found. Please ensure the path is valid and try again.")
}
return Promise.reject()
}
2018-10-23 01:05:09 +03:00
}
return Promise.resolve()
2019-01-11 09:11:57 -05:00
});
2018-10-23 01:05:09 +03:00
}
function initEditor(content, options, fileOptions) {
content.addEventListener("click", function(e) {
var lnkPath = dom.parentWithClass(e.target, "lnkPath");
if (lnkPath) {
var path = lnkPath.getAttribute("data-path");
2019-01-11 09:11:57 -05:00
if (lnkPath.classList.contains("lnkFile")) {
content.querySelector("#txtDirectoryPickerPath").value = path;
} else {
refreshDirectoryBrowser(content, path, fileOptions, true)
};
2018-10-23 01:05:09 +03:00
}
2019-01-11 09:11:57 -05:00
});
content.addEventListener("click", function(e) {
2018-10-23 01:05:09 +03:00
if (dom.parentWithClass(e.target, "btnRefreshDirectories")) {
var path = content.querySelector("#txtDirectoryPickerPath").value;
2019-01-11 09:11:57 -05:00
refreshDirectoryBrowser(content, path, fileOptions);
2018-10-23 01:05:09 +03:00
}
2019-01-11 09:11:57 -05:00
});
content.addEventListener("change", function(e) {
2018-10-23 01:05:09 +03:00
var txtDirectoryPickerPath = dom.parentWithTag(e.target, "INPUT");
2019-01-11 09:11:57 -05:00
if (txtDirectoryPickerPath && "txtDirectoryPickerPath" === txtDirectoryPickerPath.id) {
refreshDirectoryBrowser(content, txtDirectoryPickerPath.value, fileOptions);
}
});
content.querySelector("form").addEventListener("submit", function(e) {
2018-10-23 01:05:09 +03:00
if (options.callback) {
var path = this.querySelector("#txtDirectoryPickerPath").value;
validatePath(path, options.validateWriteable, ApiClient).then(options.callback(path));
2018-10-23 01:05:09 +03:00
}
2019-01-11 09:11:57 -05:00
e.preventDefault();
e.stopPropagation();
return false;
});
2018-10-23 01:05:09 +03:00
}
function getDefaultPath(options) {
2019-01-11 09:11:57 -05:00
if (options.path) {
Promise.resolve(options.path);
} else {
ApiClient.getJSON(ApiClient.getUrl("Environment/DefaultDirectoryBrowser")).then(
function(result) {
return result.Path || "";
}, function() {
return "";
}
);
}
2018-10-23 01:05:09 +03:00
}
function directoryBrowser() {
2019-01-11 09:11:57 -05:00
var currentDialog;
var self = this;
2018-10-23 01:05:09 +03:00
self.show = function(options) {
options = options || {};
var fileOptions = {
2019-01-11 09:11:57 -05:00
includeDirectories: true
2018-10-23 01:05:09 +03:00
};
2019-01-11 09:11:57 -05:00
if (options.includeDirectories != null) {
fileOptions.includeDirectories = options.includeDirectories;
}
if (options.includeFiles != null) {
fileOptions.includeFiles = options.includeFiles;
}
Promise.all([getSystemInfo(), getDefaultPath(options)]).then(
function(responses) {
var systemInfo = responses[0];
var initialPath = responses[1];
var dlg = dialogHelper.createDialog({
size: "medium-tall",
removeOnClose: true,
scrollY: false
});
dlg.classList.add("ui-body-a");
dlg.classList.add("background-theme-a");
dlg.classList.add("directoryPicker");
dlg.classList.add("formDialog");
var html = "";
html += '<div class="formDialogHeader">';
html += '<button is="paper-icon-button-light" class="btnCloseDialog autoSize" tabindex="-1"><i class="md-icon">&#xE5C4;</i></button>';
html += '<h3 class="formDialogHeaderTitle">';
html += options.header || Globalize.translate("HeaderSelectPath");
html += "</h3>";
html += "</div>";
html += getEditorHtml(options, systemInfo);
dlg.innerHTML = html;
initEditor(dlg, options, fileOptions);
dlg.addEventListener("close", onDialogClosed);
dialogHelper.open(dlg);
dlg.querySelector(".btnCloseDialog").addEventListener("click", function() {
dialogHelper.close(dlg)
2018-10-23 01:05:09 +03:00
});
2019-01-11 09:11:57 -05:00
currentDialog = dlg;
dlg.querySelector("#txtDirectoryPickerPath").value = initialPath;
if (!options.pathReadOnly) {
refreshDirectoryBrowser(dlg, initialPath, fileOptions, true);
}
}
);
};
self.close = function() {
if (currentDialog) {
dialogHelper.close(currentDialog);
}
2018-10-23 01:05:09 +03:00
}
}
2019-01-11 09:11:57 -05:00
2018-10-23 01:05:09 +03:00
var systemInfo;
return directoryBrowser
});