fix (filename): weird filenames

I've tried a lot of things to make the URL look nice but somehow there's
always a bug to handle all possible scenarios. Eg:

/test/test#test%20with a: space.txt

maybe one day, we can make the urls looks nicer but this would need a
significant revamp, until that happen, that will do.

tip: don't understimate the work it takes to do it nicely, I've tried to
do this 2 times quickly and everytime there's a edge case that make
things not working and breaking other odd stuff
This commit is contained in:
MickaelK
2024-12-10 21:23:23 +11:00
parent 5df9fad3b4
commit 003c4a9737
5 changed files with 8 additions and 6 deletions

View File

@ -119,7 +119,7 @@ class ComponentBreadcrumb extends HTMLElement {
return `
<div class="component_path-element n${idx}" data-path="${pathChunks.slice(0, idx+1).join("/") + "/"}">
<div class="li component_path-element-wrapper">
<a class="label" href="${forwardURLParams(toHref("/files") + link, ["share", "canary"])}" data-link>
<a class="label" href="${forwardURLParams(toHref("/files" + encodeURIComponent(link).replaceAll("%2F", "/")), ["share", "canary"])}" data-link>
${tmpl}
</a>
<div class="component_separator">

View File

@ -168,7 +168,7 @@ async function _createListOfFiles(path, currentName, fullpath) {
const currpath = path + whats[i] + "/";
const $li = createElement(`
<li data-path="${currpath}" title="${currpath}" class="no-select">
<a data-link href="${forwardURLParams(toHref("/files" + currpath), ["share", "canary"])}" draggable="false">
<a data-link href="${forwardURLParams(toHref("/files" + encodeURIComponent(currpath).replaceAll("%2F", "/")), ["share", "canary"])}" draggable="false">
<img class="component_icon" src="" alt="directory">
<div class="ellipsis">${whats[i]}</div>
</a>

View File

@ -7,7 +7,8 @@ export function extname(str) {
}
export function join(baseURL, segment) {
return new URL(segment, baseURL).pathname;
const url = new URL(segment, baseURL);
return decodeURIComponent(url.pathname + url.hash);
}
export function forwardURLParams(url, allowed = []) {

View File

@ -329,7 +329,7 @@ function createLink(file, currentPath) {
let path = file.path;
if (!path) path = currentPath + file.name + (file.type === "directory" ? "/" : "");
let link = file.type === "directory" ? "files" + path : "view" + path;
link = link.replaceAll("#", "%23");
link = encodeURIComponent(link).replaceAll("%2F", "/");
return {
path,
link,

View File

@ -183,9 +183,10 @@ async function ctrlListShares(render, { load, remove, all, formLinks }) {
}
async function ctrlCreateShare(render, { save, formState }) {
const enc = (p) => encodeURIComponent(p).replaceAll("%2F", "/");
if (formState.path) formState.path = join(
location.origin + currentPath(),
formState.path,
location.origin + enc(currentPath()),
enc(formState.path),
);
let id = formState.id || randomString(7);
const $page = createElement(`