personal-website/resources/sys/finder/finder.js

365 lines
12 KiB
JavaScript
Raw Normal View History

2023-03-20 11:20:37 +00:00
class Finder{
2023-05-10 12:39:49 +00:00
static appId = "Finder"
2023-05-09 03:17:34 +00:00
appId = "Finder"
2023-04-29 13:58:39 +00:00
fileView = undefined
path = "/"
homePath = "/home/user"
2023-05-04 00:38:24 +00:00
windowElement
2023-04-29 13:58:39 +00:00
// previousPath = "/"
pathHistory = [] //FIXME Fixed length
2023-04-12 17:04:25 +00:00
constructor(){
// this.appElem = appElem
2023-05-09 03:17:34 +00:00
// WebDesktopEnvironment.RegisterApp(this)
2023-03-17 01:16:51 +00:00
}
2023-03-22 21:53:06 +00:00
/**
2023-04-29 21:01:23 +00:00
* @param {string[]} args
2023-03-22 21:53:06 +00:00
*/
2023-05-09 03:17:34 +00:00
async NewWindow(args){
2023-05-10 12:39:49 +00:00
let newFinder = new FinderWindow()
await newFinder.Init(args)
return
2023-04-29 13:58:39 +00:00
this.path = args[0]
2023-04-29 21:01:23 +00:00
if (args[1] == "desktop"){
this.NewDesktop(args)
return
}
2023-05-10 12:39:49 +00:00
// const params = new URLSearchParams({isMobile: WebDesktopEnvironment.isMobile})
fetch(`/app/${Finder.appId}/render?` + params)
2023-03-17 01:16:51 +00:00
.then((response) => response.text())
.then((html) => {
2023-05-10 12:39:49 +00:00
let newWindow = WebDesktopEnvironment.CreateNewWindow(Finder.appId, 500, 350 )
2023-03-22 21:53:06 +00:00
newWindow.innerHTML = html
2023-04-13 01:09:07 +00:00
2023-05-04 00:38:24 +00:00
this.fileView = new FileView(newWindow.querySelector(".FileTileView"),
2023-05-04 22:11:11 +00:00
(event) =>{ this.Click(event) },
2023-05-04 19:49:22 +00:00
(event) =>{ this.RightClick(event) },
2023-05-10 12:39:49 +00:00
(event, draggedElem) =>{ this.DropEvent(event, draggedElem) },
2023-05-04 19:49:22 +00:00
)
2023-04-29 13:58:39 +00:00
this.OpenDir(this.path)
2023-05-05 22:50:57 +00:00
newWindow.querySelector("#RootButton").addEventListener('click', () =>{
this.OpenDir('/')
})
2023-04-29 13:58:39 +00:00
2023-05-07 19:56:40 +00:00
newWindow.querySelector("#HomeButton").addEventListener('click', () =>{
this.OpenDir('/home/user')
})
2023-04-29 13:58:39 +00:00
2023-05-04 00:38:24 +00:00
this.windowElement = newWindow
2023-04-13 01:09:07 +00:00
if (!WebDesktopEnvironment.isMobile){
2023-05-07 19:56:40 +00:00
let scrollBar = new WdeScrollBar(newWindow.querySelector(".ScrollbarPlace"), newWindow.querySelector(".FileTileView"))
2023-04-29 21:01:23 +00:00
// console.log(newWindow.querySelector("#closeWindowButton"))
2023-05-04 19:49:22 +00:00
2023-04-13 18:28:28 +00:00
newWindow.querySelector("#closeWindowButton").addEventListener('click', function (params) {
2023-04-29 15:34:25 +00:00
2023-04-13 01:09:07 +00:00
WebDesktopEnvironment.CloseWindow(newWindow)
2023-04-29 15:34:25 +00:00
2023-04-13 01:09:07 +00:00
})
}
2023-03-17 01:16:51 +00:00
})
.catch((error) => {
WebDesktopEnvironment.Alert(error);
2023-03-22 21:53:06 +00:00
})
2023-04-12 17:04:25 +00:00
}
2023-04-13 01:09:07 +00:00
2023-05-10 22:56:28 +00:00
2023-04-29 21:01:23 +00:00
/**
* @param {string[]} args
*/
NewDesktop(args){
2023-05-10 12:39:49 +00:00
fetch(`${window.location.origin}/application/${Finder.appId}/renderDesktop?` + new URLSearchParams({
2023-04-29 21:01:23 +00:00
isMobile: WebDesktopEnvironment.isMobile,
path: args[0]
}))
.then((response) => response.text())
.then((html) => {
// console.log(args)
args[2].innerHTML = html
this.fileView = new FileView(args[2].querySelector(".FileTileView"), (event) =>{
2023-05-04 22:11:11 +00:00
this.Click(event, true)
2023-04-29 21:01:23 +00:00
})
this.OpenDir(this.path)
})
.catch((error) => {
WebDesktopEnvironment.Alert(error);
})
}
2023-05-04 22:11:11 +00:00
// OpenPreviousDir(){
// if (this.pathHistory.length > 0){
// // console.log(this.pathHistory)
// let path = this.pathHistory[this.pathHistory.length - 1]
// // console.log(typeof( this.pathHistory))
// this.pathHistory.pop()
// this.OpenDir(this.path)
// }
// }
2023-04-29 13:58:39 +00:00
2023-04-12 17:04:25 +00:00
/**
* @param {string} path
*/
2023-04-29 13:58:39 +00:00
OpenDir(path){
2023-05-07 00:14:30 +00:00
this.path = path
2023-05-05 22:50:57 +00:00
this.fileView.OpenFolder(path)
2023-04-29 13:58:39 +00:00
}
2023-05-07 00:14:30 +00:00
// /**
// */
// OpenNewDir(){
// WebDesktopEnvironment.Open("finder", [this.path])
// }
2023-05-10 12:39:49 +00:00
/**
* @param {string} path
* @returns {boolean}
*/
static async RenderProperites(path){
const params = new URLSearchParams({
path: path
})
const response = await fetch(`/application/${Finder.appId}/renderProps?` + params)
if (response.status != 200){
WebDesktopEnvironment.Alert("Error in properties render") //TODO
return false
}
const html = response.text()
let newWindow = WebDesktopEnvironment.CreateNewWindow(Finder.appId, 350, 500 )
newWindow.innerHTML = html
newWindow.querySelector("#closeWindowButton").addEventListener('click', function (params) {
WebDesktopEnvironment.CloseWindow(newWindow)
})
}
}
class FinderWindow{
CurPath = ""
fileView = undefined
windowElem = undefined
async Init(args){
2023-05-10 23:56:40 +00:00
// console.log(args)
2023-05-10 23:45:38 +00:00
if (args[1] === "-desktop"){
const params = new URLSearchParams({
isMobile: WebDesktopEnvironment.isMobile,
path: args[0]
})
const response = await fetch(`/app/${Finder.appId}/renderDesktop?` + params)
if (response.status != 200){
WebDesktopEnvironment.Alert("Error in render desktop") //TODO
}
const html = await response.text()
args[2].innerHTML = html
this.fileView = new FileView(args[2].querySelector(".FileTileView"), (event) =>{
this.Click(event, true)
})
this.RenderDir(args[0])
return
}
2023-05-10 12:39:49 +00:00
const params = new URLSearchParams({isMobile: WebDesktopEnvironment.isMobile})
const response = await fetch(`/app/${Finder.appId}/render?` + params)
if (response.status != 200){
WebDesktopEnvironment.Alert("Finder ERROR TODO") //TODO
return
}
const html = await response.text()
let newWindow = WebDesktopEnvironment.CreateNewWindow(Finder.appId, 500, 350 )
newWindow.innerHTML = html
2023-05-10 22:56:28 +00:00
// console.log(this.ReRenderDir)
this.fileView = new FileView(
newWindow.querySelector(".FileTileView"),
(event) => { this.Click(event) },
(event) => { this.RightClick(event) },
(event, draggedElem) => { this.DropEvent(event, draggedElem)},
() => { this.ReRenderDir() }
)
2023-05-10 12:39:49 +00:00
newWindow.querySelector("#closeWindowButton").addEventListener('click', function (params) {
WebDesktopEnvironment.CloseWindow(newWindow)
})
newWindow.querySelector("#RootButton").addEventListener('click', () =>{
this.RenderDir('/')
})
newWindow.querySelector("#HomeButton").addEventListener('click', () =>{
this.RenderDir('/home/user')
})
let scrollBar = new WdeScrollBar(newWindow.querySelector(".ScrollbarPlace"), newWindow.querySelector(".FileTileView"))
this.windowElem = newWindow
this.RenderDir(args[0])
}
RenderDir(path){
this.CurPath = path
this.fileView.OpenFolder(path)
}
ReRenderDir(){
this.RenderDir(this.CurPath)
}
2023-05-10 22:56:28 +00:00
/**
* @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
*/
2023-05-04 22:11:11 +00:00
Click(event){
2023-04-13 01:09:07 +00:00
let fileType = event.target.getAttribute("fileType")
2023-04-29 13:58:39 +00:00
let fileName = event.target.getAttribute("name")
2023-05-09 03:17:34 +00:00
const fileExtension = fileName.split(".")[fileName.split(".").length - 1] //FIXME
2023-04-13 01:09:07 +00:00
switch (fileType) {
2023-04-29 13:58:39 +00:00
case "directory":
2023-05-09 03:17:34 +00:00
if (fileExtension == "app"){
2023-05-10 12:39:49 +00:00
WebDesktopEnvironment.Open(`${this.CurPath}/${fileName}`, [])
2023-05-09 03:17:34 +00:00
} else{
2023-05-10 12:39:49 +00:00
WebDesktopEnvironment.Open(`/Applications/Finder.app`, [`${this.CurPath}/${fileName}`])
2023-05-09 03:17:34 +00:00
}
2023-04-29 13:58:39 +00:00
break
case "blog":
2023-05-10 23:26:57 +00:00
WebDesktopEnvironment.Open("/Applications/BlogViewer.app", [`${this.CurPath}/${fileName}`])
2023-04-29 13:58:39 +00:00
break
2023-05-05 20:31:42 +00:00
case "jpeg":
case "png":
2023-05-10 12:39:49 +00:00
WebDesktopEnvironment.Open("img-viewer", [this.CurPath + "/" + fileName])
2023-04-29 16:47:12 +00:00
break;
2023-04-12 21:05:23 +00:00
default:
2023-05-02 11:32:56 +00:00
// console.log("Unsupported file type")
WebDesktopEnvironment.Alert("Unsupported file type")
2023-04-12 17:04:25 +00:00
break;
}
2023-03-17 01:16:51 +00:00
}
2023-05-04 00:38:24 +00:00
2023-05-10 12:39:49 +00:00
/**
* @param {MouseEvent} event
*/
RightClick(event){
this.CreateContextMenu(event.target, [event.clientY, event.clientX])
}
/**
* @param {HTMLElement} target
* @param {string[]} pos
*/
async CreateContextMenu(target, pos){
2023-05-04 19:49:22 +00:00
let context = ""
2023-05-09 03:17:34 +00:00
const fileName = target.getAttribute("name")
const fileType = target.getAttribute("fileType")
if (target.classList.contains("FileTileView"))
{
context = "FileTileView"
2023-05-09 03:17:34 +00:00
} else {
context = fileType
}
2023-05-10 12:39:49 +00:00
const params = new URLSearchParams({context: context, path: `${this.CurPath}/${fileName}`})
const response = await fetch(`/app/${Finder.appId}/contextMenu?` + params)
if (response.status != 200){
WebDesktopEnvironment.Alert("ERROR in Context menu TODO"); //TODO
return
}
const html = await response.text()
let overlay = document.createElement("div") //TODO Move to WDE.CreateOverlay()
overlay.setAttribute('id', 'finder-context-menu-overlay')
overlay.style.position = 'absolute'
overlay.style.width = "100%"
overlay.style.height = "100%"
let menu = document.createElement("div")
menu.setAttribute('class', 'ContextMenu WindowFrameShadow')
menu.style.position = 'absolute';
menu.style.top = pos[0] + "px";
menu.style.left = pos[1] + "px";
menu.innerHTML = html
menu.children[0].firstElementChild.remove()
menu.children[0].lastElementChild.remove() //FIXME Can't ommit rendering of horLine in end of menu on backend
overlay.appendChild(menu)
document.body.appendChild(overlay)
overlay.addEventListener('click', async (event) => {
if (event.target.classList.contains("Row")){ //TODO add uuid id to rows to more accurate checks??
let res = false
switch (event.target.children[0].getAttribute("action")) {
case "createDir":
2023-05-10 22:56:28 +00:00
res = await WebFS.CreateDirectory(`${this.CurPath}`)
2023-05-10 12:39:49 +00:00
console.log(res)
if (res){
this.ReRenderDir()
}
break
case "deleteFile":
2023-05-10 22:56:28 +00:00
res = await WebFS.DeleteFile(`${this.CurPath}/${fileName}`)
2023-05-10 12:39:49 +00:00
console.log(res)
if (res){
this.ReRenderDir()
}
break
case "getInfo":
res = await Finder.RenderProperites(`${this.CurPath}/${fileName}`)
break
case "openAsDir":
WebDesktopEnvironment.Open(`/Applications/${Finder.appId}.app`,[`${this.CurPath}/${fileName}`])
2023-05-05 18:32:41 +00:00
break
2023-05-10 12:39:49 +00:00
default:
break;
}
}
overlay.remove()
})
overlay.addEventListener('contextmenu', (event) => {
event.preventDefault();
overlay.remove()
2023-05-04 00:38:24 +00:00
})
}
2023-05-10 12:39:49 +00:00
}