This commit is contained in:
Vanessa 2022-11-04 21:50:03 +08:00
parent bc3ab68a9d
commit be3ac44ce7
12 changed files with 80 additions and 85 deletions

View file

@ -282,34 +282,34 @@ export class Files extends Model {
window.getSelection().removeAllRanges();
const liElement = hasClosestByTag(event.target, "LI");
if (liElement) {
let selectElements: Element[] = Array.from(this.element.querySelectorAll(".b3-list-item--focus"))
let selectElements: Element[] = Array.from(this.element.querySelectorAll(".b3-list-item--focus"));
if (!liElement.classList.contains("b3-list-item--focus")) {
selectElements.forEach((item) => {
item.classList.remove("b3-list-item--focus");
})
});
liElement.classList.add("b3-list-item--focus");
selectElements = [liElement];
}
let ids = ""
let ids = "";
selectElements.forEach((item: HTMLElement) => {
item.style.opacity = "0.1";
ids += (item.getAttribute("data-node-id") || "") + ","
})
ids += (item.getAttribute("data-node-id") || "") + ",";
});
const img = new Image();
// TODO: drag preview
img.src = ``;
img.src = "";
event.dataTransfer.setDragImage(img, 10, 10);
event.dataTransfer.setData(Constants.SIYUAN_DROP_FILE, ids);
event.dataTransfer.dropEffect = "move";
const tempEelement = document.createElement("div")
const tempEelement = document.createElement("div");
tempEelement.innerText = ids;
window.siyuan.dragElement = tempEelement;
}
});
this.element.addEventListener("dragend", (event: DragEvent & { target: HTMLElement }) => {
this.element.addEventListener("dragend", () => {
this.element.querySelectorAll(".b3-list-item--focus").forEach((item: HTMLElement) => {
item.style.opacity = ""
})
item.style.opacity = "";
});
window.siyuan.dragElement = undefined;
});
this.element.addEventListener("dragover", (event: DragEvent & { target: HTMLElement }) => {
@ -330,13 +330,13 @@ export class Files extends Model {
event.preventDefault();
return;
}
let sourceOnlyRoot = true
let sourceOnlyRoot = true;
Array.from(this.element.querySelectorAll(".b3-list-item--focus")).find((item: HTMLElement) => {
if (item.getAttribute("data-type") === "navigation-file") {
sourceOnlyRoot = false
sourceOnlyRoot = false;
return true;
}
})
});
const targetType = liElement.getAttribute("data-type");
if (sourceOnlyRoot && targetType !== "navigation-root") {
event.preventDefault();
@ -379,7 +379,7 @@ export class Files extends Model {
}
const toURL = newUlElement.getAttribute("data-url");
const toPath = newElement.getAttribute("data-path");
const gutterType = window.siyuan.dragElement?.getAttribute("data-type")
const gutterType = window.siyuan.dragElement?.getAttribute("data-type");
if (newElement.classList.contains("dragover") && ["NodeListItem", "NodeHeading"].includes(gutterType)) {
// 块标拖拽
if (gutterType === "NodeHeading") {
@ -406,22 +406,22 @@ export class Files extends Model {
newElement.classList.remove("dragover", "dragover__bottom", "dragover__top");
return;
}
const selectRootElements: HTMLElement[] = []
const selectFileElements: HTMLElement[] = []
const fromPaths: string[] = []
const selectRootElements: HTMLElement[] = [];
const selectFileElements: HTMLElement[] = [];
const fromPaths: string[] = [];
this.element.querySelectorAll(".b3-list-item--focus").forEach((item: HTMLElement) => {
if (item.getAttribute("data-type") === "navigation-root") {
selectRootElements.push(item)
selectRootElements.push(item);
} else {
const dataPath = item.getAttribute("data-path")
const dataPath = item.getAttribute("data-path");
const isChild = fromPaths.find(item => {
if (dataPath.startsWith(item.replace(".sy", ""))) {
return true;
}
})
});
if (!isChild) {
selectFileElements.push(item)
fromPaths.push(dataPath)
selectFileElements.push(item);
fromPaths.push(dataPath);
}
}
});
@ -437,11 +437,11 @@ export class Files extends Model {
if (newElement.classList.contains("dragover__top")) {
selectRootElements.forEach(item => {
newElement.parentElement.before(item.parentElement);
})
});
} else {
selectRootElements.reverse().forEach(item => {
newElement.parentElement.after(item.parentElement);
})
});
}
const notebooks: string[] = [];
Array.from(this.element.children).forEach(item => {
@ -461,7 +461,7 @@ export class Files extends Model {
});
selectFileElements.forEach(item => {
item.setAttribute("data-path", pathPosix().join(toDir, item.getAttribute("data-node-id") + ".sy"));
})
});
hasMove = true;
}
if (newElement.classList.contains("dragover__top")) {
@ -474,7 +474,7 @@ export class Files extends Model {
if (nextULElement) {
item.after(nextULElement);
}
})
});
} else if (newElement.classList.contains("dragover__bottom")) {
selectFileElements.reverse().forEach(item => {
let nextULElement;
@ -489,7 +489,7 @@ export class Files extends Model {
if (nextULElement) {
item.after(nextULElement);
}
})
});
}
const paths: string[] = [];
Array.from(newElement.parentElement.children).forEach(item => {
@ -668,7 +668,7 @@ export class Files extends Model {
targetElement.remove();
}
}
})
});
}
private onMount(data: { data: { box: INotebook, existed?: boolean }, callback?: string }) {