Finder refactoring

This commit is contained in:
cyber-dream 2023-05-11 01:56:28 +03:00
parent 9c0cc8d709
commit 4426d30342
6 changed files with 122 additions and 107 deletions

View File

@ -8,6 +8,7 @@ import (
"github.com/gin-gonic/gin" "github.com/gin-gonic/gin"
) )
//TODO Use this to get json from back
type Cat struct { type Cat struct {
fs *webfilesystem.WebFileSystem fs *webfilesystem.WebFileSystem
} }

View File

@ -63,42 +63,7 @@ class Finder{
}) })
} }
/**
* @param {DragEvent} event
* @param {HTMLElement} draggedElem
*/
async DropEvent(event){
// console.log(event.dataTransfer.getData("dropType"))
if (event.dataTransfer.getData("dropType") == "move"){
let params = new URLSearchParams({
sourcePath: event.dataTransfer.getData("filePath"),
targetPath: this.path + "/" + event.dataTransfer.getData("fileName"),
})
let response = await fetch('/fs/move/?' + params)
console.log(response.status)
} else {
let formData = new FormData()
console.log(this.path)
for (let i = 0; i < event.length; i++) {
const element = event[i];
formData.append("file", element.getAsFile())
// console.log(formData)
}
// console.log(formData)
// formData.append("photo", photo);
fetch('/fs/upload/?' + new URLSearchParams({
parentPath: this.path,
}),
{
method: "POST",
body: formData
})
.catch((error) => {
WebDesktopEnvironment.Alert(error);
})
}
}
/** /**
* @param {string[]} args * @param {string[]} args
*/ */
@ -166,46 +131,6 @@ class Finder{
WebDesktopEnvironment.CloseWindow(newWindow) WebDesktopEnvironment.CloseWindow(newWindow)
}) })
} }
/**
* @param {string} path
* @returns {boolean}
*/
static async DeleteFile(path){
const params = new URLSearchParams({
path: path
})
const response = await fetch(`/fs/delete?` + params)
if (response.status != 200){
WebDesktopEnvironment.Alert("DELETE ERROR") //TODO
return false
}
return true
}
/**
* @param {string} path
* @returns {boolean}
*/
static async CreateDirectory(path){
if (path == undefined){
WebDesktopEnvironment.Alert("Path is undefined")
return false
}
const params = new URLSearchParams({
path: `${path}/New Directory`
})
const response = await fetch(`/fs/createDir?` + params)
if (response.status != 200){
WebDesktopEnvironment.Alert("DIRCTORY CREATION ERROR") //TODO
return false
}
return true
}
} }
@ -226,11 +151,14 @@ class FinderWindow{
let newWindow = WebDesktopEnvironment.CreateNewWindow(Finder.appId, 500, 350 ) let newWindow = WebDesktopEnvironment.CreateNewWindow(Finder.appId, 500, 350 )
newWindow.innerHTML = html newWindow.innerHTML = html
this.fileView = new FileView(newWindow.querySelector(".FileTileView"), // console.log(this.ReRenderDir)
(event) =>{ this.Click(event) }, this.fileView = new FileView(
(event) =>{ this.RightClick(event) }, newWindow.querySelector(".FileTileView"),
(event, draggedElem) =>{ this.DropEvent(event, draggedElem) (event) => { this.Click(event) },
}) (event) => { this.RightClick(event) },
(event, draggedElem) => { this.DropEvent(event, draggedElem)},
() => { this.ReRenderDir() }
)
newWindow.querySelector("#closeWindowButton").addEventListener('click', function (params) { newWindow.querySelector("#closeWindowButton").addEventListener('click', function (params) {
@ -262,6 +190,48 @@ class FinderWindow{
this.RenderDir(this.CurPath) this.RenderDir(this.CurPath)
} }
/**
* @param {DragEvent} event
* @param {HTMLElement} draggedElem
*/
async DropEvent(event){
// console.log(event.dataTransfer.getData("dropType"))
if (event.dataTransfer.getData("dropType") == "move"){
const sourcePath= event.dataTransfer.getData("filePath")
const targetPath = this.CurPath + "/" + event.dataTransfer.getData("fileName")
const res = await WebFS.MoveFile(sourcePath, targetPath)
if (res){
this.ReRenderDir()
} else {
WebDesktopEnvironment.Alert("UWAGA TODO MOVE FILE ERROR") //TODO
}
} else {
WebDesktopEnvironment.Alert("Not fixed yet")
return
let formData = new FormData()
let files = event.dataTransfer.files
for (let i = 0; i < files.length; i++) {
const element = files[i];
console.log(element)
formData.append("file", element) //FIXME Conn reset
}
const params = new URLSearchParams({
parentPath: this.CurPath,
})
const response = await fetch('/fs/upload/?' + params,
{
method: "POST", //TODO Change to PUT?
body: formData
})
if (response.status != 200){
WebDesktopEnvironment.Alert("ERROR IN UPLOADING FILE")//TODO
} else {
this.ReRenderDir()
}
}
}
/** /**
* @param {MouseEvent} event * @param {MouseEvent} event
@ -351,14 +321,14 @@ class FinderWindow{
let res = false let res = false
switch (event.target.children[0].getAttribute("action")) { switch (event.target.children[0].getAttribute("action")) {
case "createDir": case "createDir":
res = await Finder.CreateDirectory(`${this.CurPath}`) res = await WebFS.CreateDirectory(`${this.CurPath}`)
console.log(res) console.log(res)
if (res){ if (res){
this.ReRenderDir() this.ReRenderDir()
} }
break break
case "deleteFile": case "deleteFile":
res = await Finder.DeleteFile(`${this.CurPath}/${fileName}`) res = await WebFS.DeleteFile(`${this.CurPath}/${fileName}`)
console.log(res) console.log(res)
if (res){ if (res){
this.ReRenderDir() this.ReRenderDir()
@ -366,26 +336,6 @@ class FinderWindow{
break break
case "getInfo": case "getInfo":
res = await Finder.RenderProperites(`${this.CurPath}/${fileName}`) res = await Finder.RenderProperites(`${this.CurPath}/${fileName}`)
// fetch(`/application/${Finder.appId}/renderProps?` + new URLSearchParams({
// path: `${this.CurPath}/${fileName}`
// }))
// .then((response) => {
// console.log(response)
// if (response.status == 200){
// console.log("Success")
// return response.text();
// }
// })
// .then((html) =>{
// let newWindow = WebDesktopEnvironment.CreateNewWindow(Finder.appId, 350, 500 )
// newWindow.innerHTML = html
// newWindow.querySelector("#closeWindowButton").addEventListener('click', function (params) {
// WebDesktopEnvironment.CloseWindow(newWindow)
// })
// })
// .catch((error) => {
// WebDesktopEnvironment.Alert(error);
// })
break break
case "openAsDir": case "openAsDir":
WebDesktopEnvironment.Open(`/Applications/${Finder.appId}.app`,[`${this.CurPath}/${fileName}`]) WebDesktopEnvironment.Open(`/Applications/${Finder.appId}.app`,[`${this.CurPath}/${fileName}`])

0
resources/sys/libs/fs.js Normal file
View File

View File

@ -6,8 +6,9 @@ class FileView{
* @param {HTMLElement} fileViewElem * @param {HTMLElement} fileViewElem
* @param {Function} doubleClickCallback * @param {Function} doubleClickCallback
* @param {Function} rightClickCallback * @param {Function} rightClickCallback
* @param {Function} updateFileViewCallback
*/ */
constructor(fileViewElem, doubleClickCallback, rightClickCallback, fileUploadCallback){ constructor(fileViewElem, doubleClickCallback, rightClickCallback, fileUploadCallback, updateFileViewCallback){
//TODO check all params //TODO check all params
this.parentElem = fileViewElem this.parentElem = fileViewElem
@ -46,6 +47,8 @@ class FileView{
event.dataTransfer.setData("fileName", event.target.getAttribute("name")) event.dataTransfer.setData("fileName", event.target.getAttribute("name"))
event.dataTransfer.setData("filePath", this.path + "/" + event.target.getAttribute("name")) event.dataTransfer.setData("filePath", this.path + "/" + event.target.getAttribute("name"))
event.dataTransfer.setData("dropType", "move") event.dataTransfer.setData("dropType", "move")
// console.log(updateFileViewCallback)
// event.dataTransfer.setData("updateCallback", updateFileViewCallback)
// event.dataTransfer.setData("fileName", ) // event.dataTransfer.setData("fileName", )
// console.log(draggedElem) // console.log(draggedElem)
}) })
@ -54,8 +57,6 @@ class FileView{
event.preventDefault(); event.preventDefault();
counter++ counter++
fileViewElem.classList.add("DragDropBorder") fileViewElem.classList.add("DragDropBorder")
// draggedElem = event.relatedTarget
}) })
fileViewElem.addEventListener('dragend', function(event) { fileViewElem.addEventListener('dragend', function(event) {
@ -65,6 +66,7 @@ class FileView{
if (counter === 0){ if (counter === 0){
fileViewElem.classList.remove("DragDropBorder") fileViewElem.classList.remove("DragDropBorder")
} }
// updateFileViewCallback()
// draggedElem = undefined // draggedElem = undefined
}) })
@ -84,9 +86,10 @@ class FileView{
fileViewElem.addEventListener("drop", (event) => { fileViewElem.addEventListener("drop", (event) => {
event.preventDefault(); event.preventDefault();
// console.log(event.dataTransfer.getData("dropType"))
fileUploadCallback(event) fileUploadCallback(event)
fileViewElem.classList.remove("DragDropBorder") fileViewElem.classList.remove("DragDropBorder")
// updateFileViewCallback()
// this.OpenFolder(this.path)
// draggedElem = undefined // draggedElem = undefined
}) })
} }

View File

@ -24,6 +24,7 @@ class WebDesktopEnvironment{
document.body.style.setProperty('--zoom', 1) document.body.style.setProperty('--zoom', 1)
this.wc = new WindowsCompositor() this.wc = new WindowsCompositor()
this.loadWDE() this.loadWDE()
let kek = new WebFS()
return return
// let applications = document.createElement("div") // let applications = document.createElement("div")
@ -343,3 +344,62 @@ class WindowsCompositor{
} }
class WebFS{
constructor(){
console.log("fs loaded")
}
/**
* @param {string} path
* @returns {boolean}
*/
static async CreateDirectory(path){
if (path == undefined){
WebDesktopEnvironment.Alert("Path is undefined")
return false
}
const params = new URLSearchParams({
path: `${path}/New Directory`
})
const response = await fetch(`/fs/createDir?` + params)
if (response.status != 200){
WebDesktopEnvironment.Alert("DIRCTORY CREATION ERROR") //TODO
return false
}
return true
}
/**
* @param {string} path
* @returns {boolean}
*/
static async DeleteFile(path){
const params = new URLSearchParams({
path: path
})
const response = await fetch(`/fs/delete?` + params)
if (response.status != 200){
WebDesktopEnvironment.Alert("DELETE ERROR") //TODO
return false
}
return true
}
/**
* @param {string} path
* @returns {boolean}
*/
static async MoveFile(sourcePath, targetPath){
const params = new URLSearchParams({
sourcePath: sourcePath,
targetPath: targetPath
})
const response = await fetch(`/fs/move?` + params)
if (response.status != 200){
// WebDesktopEnvironment.Alert("Move ERROR") //TODO
return false
}
return true
}
}

View File

@ -8,6 +8,7 @@
<link rel="stylesheet" type="text/css" href="res/sys/wde/wde-scrollbar.css"> <link rel="stylesheet" type="text/css" href="res/sys/wde/wde-scrollbar.css">
<link rel="stylesheet" type="text/css" href="res/sys/wde/basic-widgets.css"> <link rel="stylesheet" type="text/css" href="res/sys/wde/basic-widgets.css">
<link rel="stylesheet" type="text/css" href="res/sys/wde/file-view.css"> <link rel="stylesheet" type="text/css" href="res/sys/wde/file-view.css">
<link rel="stylesheet" type="text/css" href="res/sys/libs/fs.js">
<link rel="stylesheet" type="text/css" href="res/mobile-wdeUI.css"> <link rel="stylesheet" type="text/css" href="res/mobile-wdeUI.css">
<link rel="stylesheet" href="/res/sys/wde/simple-scrollbar.css"> <link rel="stylesheet" href="/res/sys/wde/simple-scrollbar.css">
<link rel="stylesheet" type="text/css" href="res/sys/finder/finder.css"> <link rel="stylesheet" type="text/css" href="res/sys/finder/finder.css">