chore (rewrite): drag and drop for moving things around

This commit is contained in:
MickaelK 2024-05-28 19:14:45 +10:00
parent a0cb495ce5
commit ca7cdb3683
5 changed files with 21 additions and 9 deletions

View file

@ -69,7 +69,7 @@
border-radius: 3px;
letter-spacing: -0.5px;
}
.component_breadcrumb .component_path-element .component_path-element-wrapper.highlight a {
.component_breadcrumb .component_path-element.highlight .component_path-element-wrapper a {
color: var(--bg-color);
background: var(--dark);
border-radius: 3px;

View file

@ -1,6 +1,9 @@
import { animate, slideYOut, slideYIn, opacityOut } from "../lib/animate.js";
import { loadCSS } from "../helpers/loader.js";
import { mv } from "../pages/filespage/model_files.js";
import { extractPath } from "../pages/filespage/helper.js";
class ComponentBreadcrumb extends window.HTMLDivElement {
constructor() {
super();
@ -100,7 +103,7 @@ class ComponentBreadcrumb extends window.HTMLDivElement {
})();
return `
<div class="component_path-element n${idx}">
<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="/files${link}" data-link>
${tmpl}
@ -154,16 +157,22 @@ class ComponentBreadcrumb extends window.HTMLDivElement {
setupDragDropTarget() {
this.querySelectorAll("a.label").forEach(($folder) => {
const $path = $folder.closest(".component_path-element");
$folder.ondragover = (e) => {
e.preventDefault();
$folder.parentElement.classList.add("highlight");
$path.classList.add("highlight");
};
$folder.ondragleave = () => {
$folder.parentElement.classList.remove("highlight");
$path.classList.remove("highlight");
};
$folder.ondrop = (e) => {
$folder.parentElement.classList.remove("highlight");
console.log("DROP", e.dataTransfer.getData("path"));
$folder.ondrop = async (e) => {
$path.classList.remove("highlight");
const from = e.dataTransfer.getData("path");
let to = $path.getAttribute("data-path");
const [fromBasepath, fromName] = extractPath(from);
to += fromName + "/";
await mv(from, to).toPromise();
};
});
}

View file

@ -11,6 +11,7 @@
"CAMERA": "appareil",
"CAN_RESHARE": "peut repartager",
"CANCEL": "annuler",
"CONNECTION_LOST": "Connection perdue",
"CANNOT_ESTABLISH_A_CONNECTION": "Impossible d'établir une connexion",
"CANT_LOAD_THIS_PICTURE": "impossible de charger cette image",
"CANT_USE_FILESYSTEM": "Impossible d'utiliser le système de fichiers",
@ -93,7 +94,7 @@
"SAVE_CURRENT_FILE": "enregistrer le fichier actuel",
"SEARCH": "recherche",
"SETTINGS": "réglage",
"SORT": "tri",
"SORT": "ordre",
"STARRED": "favoris",
"SHARE": "partager",
"SHARED_DRIVE": "disque partagé",

View file

@ -202,6 +202,7 @@ export function mv(ajax$, fromPath, toPath) {
fn: (file) => {
if (file.name === fromName) {
file.loading = true;
file.last = true;
type = file.type;
}
return file;

View file

@ -5,7 +5,7 @@ import assert from "../../lib/assert.js";
import { extractPath } from "./helper.js";
import { mv } from "./model_files.js";
import { files$ } from "./ctrl_filesystem.js";
import { addSelection, isSelected } from "./state_selection.js";
import { addSelection, isSelected, clearSelection } from "./state_selection.js";
const IMAGE = {
FILE: "",
@ -103,6 +103,7 @@ export function createThing({
});
};
$thing.ondragstart = (e) => {
clearSelection();
$thing.classList.add("hover");
e.dataTransfer.setData("path", path);
e.dataTransfer.setDragImage($thing, e.offsetX, -10);