icons and title-bar as widget
This commit is contained in:
parent
766b7ac4bf
commit
b79b65868c
@ -8,6 +8,7 @@ import (
|
|||||||
"personalwebsite/apps/appCtx"
|
"personalwebsite/apps/appCtx"
|
||||||
"personalwebsite/errormessage"
|
"personalwebsite/errormessage"
|
||||||
"personalwebsite/libs"
|
"personalwebsite/libs"
|
||||||
|
"personalwebsite/wde"
|
||||||
"personalwebsite/webfilesystem"
|
"personalwebsite/webfilesystem"
|
||||||
|
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
@ -18,12 +19,17 @@ type AboutMeApp struct {
|
|||||||
fs *webfilesystem.WebFileSystem
|
fs *webfilesystem.WebFileSystem
|
||||||
appID string
|
appID string
|
||||||
mLib libs.MarkdownLib
|
mLib libs.MarkdownLib
|
||||||
|
titleBarConfig wde.TitleBarConfig //TODO to app manifest?
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewAboutMeApp(webFs *webfilesystem.WebFileSystem) *AboutMeApp {
|
func NewAboutMeApp(webFs *webfilesystem.WebFileSystem) *AboutMeApp {
|
||||||
newApp := AboutMeApp{
|
newApp := AboutMeApp{
|
||||||
fs: webFs,
|
fs: webFs,
|
||||||
appID: "AboutMe",
|
appID: "AboutMe",
|
||||||
|
titleBarConfig: wde.TitleBarConfig{
|
||||||
|
Lable: "About Me",
|
||||||
|
CloseButton: true,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
return &newApp
|
return &newApp
|
||||||
}
|
}
|
||||||
@ -253,6 +259,7 @@ func (p *AboutMeApp) Render(appCtx appCtx.AppContext, filePath string) (gin.H, e
|
|||||||
}
|
}
|
||||||
|
|
||||||
return gin.H{
|
return gin.H{
|
||||||
|
"TitleBarConfig": p.titleBarConfig,
|
||||||
"HeaderProps": propsData.Header,
|
"HeaderProps": propsData.Header,
|
||||||
"Links": absoluteLinks,
|
"Links": absoluteLinks,
|
||||||
"Islands": renderedIslands,
|
"Islands": renderedIslands,
|
||||||
|
@ -11,6 +11,7 @@ import (
|
|||||||
type FinderApplication struct {
|
type FinderApplication struct {
|
||||||
fs *webfilesystem.WebFileSystem
|
fs *webfilesystem.WebFileSystem
|
||||||
appID string
|
appID string
|
||||||
|
titleBarConfig wde.TitleBarConfig
|
||||||
// manifest apps.ApplicationManifest
|
// manifest apps.ApplicationManifest
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -18,6 +19,10 @@ func NewFinderApplication(webFs *webfilesystem.WebFileSystem) *FinderApplication
|
|||||||
return &FinderApplication{
|
return &FinderApplication{
|
||||||
fs: webFs,
|
fs: webFs,
|
||||||
appID: "Finder",
|
appID: "Finder",
|
||||||
|
titleBarConfig: wde.TitleBarConfig{
|
||||||
|
Lable: "Finder",
|
||||||
|
CloseButton: true,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -26,7 +31,9 @@ func (f *FinderApplication) GetAppID() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (f *FinderApplication) Render(appCtx appCtx.AppContext) gin.H {
|
func (f *FinderApplication) Render(appCtx appCtx.AppContext) gin.H {
|
||||||
return gin.H{}
|
return gin.H{
|
||||||
|
"TitleBarConfig": f.titleBarConfig,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (f *FinderApplication) RenderPublicContextMenu(context string, filePath string, data string) gin.H {
|
func (f *FinderApplication) RenderPublicContextMenu(context string, filePath string, data string) gin.H {
|
||||||
|
@ -87,8 +87,9 @@ export default class FinderWindow{
|
|||||||
|
|
||||||
let newWindow = this.#wde.Decorat.CreateNewWindow(this.#appId, 500, 350 )
|
let newWindow = this.#wde.Decorat.CreateNewWindow(this.#appId, 500, 350 )
|
||||||
newWindow.innerHTML = html
|
newWindow.innerHTML = html
|
||||||
|
newWindow.querySelector(".title-bar").querySelector(".icon").setAttribute("src","/system/libs/img/icon/get?path=/Icons/GenericFolder.icn&size=16")
|
||||||
|
|
||||||
console.log(newWindow.querySelector(".FileTileView"))
|
// console.log(newWindow.querySelector(".FileTileView"))
|
||||||
|
|
||||||
this.fileView = new this.#wde.FileView(
|
this.fileView = new this.#wde.FileView(
|
||||||
newWindow.querySelector(".FileTileView"),
|
newWindow.querySelector(".FileTileView"),
|
||||||
@ -190,7 +191,7 @@ export default class FinderWindow{
|
|||||||
if (event.dataTransfer.getData("dropType") == "move"){
|
if (event.dataTransfer.getData("dropType") == "move"){
|
||||||
const sourcePath= event.dataTransfer.getData("filePath")
|
const sourcePath= event.dataTransfer.getData("filePath")
|
||||||
const targetPath = this.curPath + "/" + event.dataTransfer.getData("fileName")
|
const targetPath = this.curPath + "/" + event.dataTransfer.getData("fileName")
|
||||||
const res = await WebFS.MoveFile(sourcePath, targetPath)
|
const res = await this.#finder.WDE().WebFS().MoveFile(sourcePath, targetPath)
|
||||||
if (res){
|
if (res){
|
||||||
this.ReRenderDir()
|
this.ReRenderDir()
|
||||||
} else {
|
} else {
|
||||||
@ -203,7 +204,7 @@ export default class FinderWindow{
|
|||||||
const file = files[i];
|
const file = files[i];
|
||||||
console.log("file:" + file.name)
|
console.log("file:" + file.name)
|
||||||
|
|
||||||
const res = await WebFS.UploadFile(file, this.curPath)
|
const res = await this.#finder.WDE().WebFS().UploadFile(file, this.curPath)
|
||||||
if (res){
|
if (res){
|
||||||
this.ReRenderDir()
|
this.ReRenderDir()
|
||||||
}
|
}
|
||||||
@ -233,6 +234,14 @@ export default class FinderWindow{
|
|||||||
this.OpenFile(this.curPath, event.target.getAttribute("name"), event.target.getAttribute("filetype"))
|
this.OpenFile(this.curPath, event.target.getAttribute("name"), event.target.getAttribute("filetype"))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param {string} fileName
|
||||||
|
*/
|
||||||
|
getFileExtension(fileName){
|
||||||
|
return fileName.split(".")[fileName.split(".").length - 1] //FIXME
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {string} filePath
|
* @param {string} filePath
|
||||||
*/
|
*/
|
||||||
@ -240,11 +249,12 @@ export default class FinderWindow{
|
|||||||
// console.log(parentPath, fileName, fileType)
|
// console.log(parentPath, fileName, fileType)
|
||||||
// const splittedPath = filePath.split("/")
|
// const splittedPath = filePath.split("/")
|
||||||
// const fileName = splittedPath[splittedPath.length - 1]
|
// const fileName = splittedPath[splittedPath.length - 1]
|
||||||
const fileExtension = fileName.split(".")[fileName.split(".").length - 1] //FIXME
|
|
||||||
|
|
||||||
|
const fileExtension = this.getFileExtension(fileName)
|
||||||
|
console.log(fileExtension)
|
||||||
switch (true) {
|
switch (true) {
|
||||||
case fileType == "objectlink":
|
case fileType == "objectlink":
|
||||||
this.#wde.Alert("Links not supported yet")
|
this.#finder.WDE().Alert("Links not supported yet")
|
||||||
break
|
break
|
||||||
case fileType == "pathlink":
|
case fileType == "pathlink":
|
||||||
let res = await WebFS.ReadPathLink(`${parentPath}/${fileName}`)
|
let res = await WebFS.ReadPathLink(`${parentPath}/${fileName}`)
|
||||||
@ -252,22 +262,22 @@ export default class FinderWindow{
|
|||||||
this.OpenFile(res.parentPath, res.name, res.filetype)
|
this.OpenFile(res.parentPath, res.name, res.filetype)
|
||||||
break
|
break
|
||||||
case fileExtension == "app":
|
case fileExtension == "app":
|
||||||
this.#wde.Open(`${parentPath}/${fileName}`, [])
|
this.#finder.WDE().Open(`${parentPath}/${fileName}`, [])
|
||||||
break
|
break
|
||||||
case fileExtension == "blog":
|
case fileExtension == "blog":
|
||||||
this.#wde.Open(`/Applications/BlogViewer.app`, [`${parentPath}/${fileName}`])
|
this.#finder.WDE().Open(`/Applications/BlogViewer.app`, [`${parentPath}/${fileName}`])
|
||||||
break
|
break
|
||||||
case fileType == "directory":
|
case fileType == "directory":
|
||||||
this.#wde.Open(`/Applications/Finder.app`, [`${parentPath}/${fileName}`])
|
this.#finder.WDE().Open(`/Applications/Finder.app`, [`${parentPath}/${fileName}`])
|
||||||
break
|
break
|
||||||
case fileExtension == "blog":
|
case fileExtension == "blog":
|
||||||
this.#wde.Open("/Applications/BlogViewer.app", [`${parentPath}/${fileName}`])
|
this.#finder.WDE().Open("/Applications/BlogViewer.app", [`${parentPath}/${fileName}`])
|
||||||
break
|
break
|
||||||
case fileExtension == "jpeg" | fileExtension == "png":
|
case fileExtension == "jpeg" | fileExtension == "png":
|
||||||
this.#wde.Open("img-viewer", [`${parentPath}/${fileName}`])
|
this.#finder.WDE().Open("img-viewer", [`${parentPath}/${fileName}`])
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
this.#wde.Alert("Unsupported file type")
|
this.#finder.WDE().Alert("Unsupported file type")
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,14 @@
|
|||||||
@import "./wde/sunboard/sunboard-mobile.less";
|
@import "./wde/sunboard/sunboard-mobile.less";
|
||||||
|
|
||||||
body{
|
body{
|
||||||
zoom: 2;
|
// zoom: 2;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
margin: 0px;
|
margin: 0px;
|
||||||
|
|
||||||
|
font-size: 16px;
|
||||||
|
|
||||||
/* font: normal 14px Summer Pixel 22, "res/SummerPixel22Regular.ttf"; */
|
/* font: normal 14px Summer Pixel 22, "res/SummerPixel22Regular.ttf"; */
|
||||||
-webkit-touch-callout: none; /* iOS Safari */
|
-webkit-touch-callout: none; /* iOS Safari */
|
||||||
-webkit-user-select: none; /* Safari */
|
-webkit-user-select: none; /* Safari */
|
||||||
|
@ -36,8 +36,8 @@ export default class WebDesktopEnvironment extends AbstractWebDesktopEnvironment
|
|||||||
|
|
||||||
async loadWDE(){
|
async loadWDE(){
|
||||||
await this.Open("/Applications/Finder.app", ["/","--desktop", "desktop-layer"])
|
await this.Open("/Applications/Finder.app", ["/","--desktop", "desktop-layer"])
|
||||||
// await this.Open("/Applications/Finder.app", ["/", "desktop-layer"])
|
await this.Open("/Applications/Finder.app", ["/", "desktop-layer"])
|
||||||
await this.Open("/Applications/AboutMe.app", ["/", "desktop-layer"])
|
// await this.Open("/Applications/AboutMe.app", ["/", "desktop-layer"])
|
||||||
return
|
return
|
||||||
|
|
||||||
let autoStart = document.body.querySelector("wde-autostart")
|
let autoStart = document.body.querySelector("wde-autostart")
|
||||||
|
@ -32,6 +32,10 @@
|
|||||||
letter-spacing: 0.35px;
|
letter-spacing: 0.35px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.window-frame.Focused .title-bar .lable{
|
||||||
|
color: @col-black;
|
||||||
|
}
|
||||||
|
|
||||||
.window-frame.Focused .title-bar .visual-drag-area{
|
.window-frame.Focused .title-bar .visual-drag-area{
|
||||||
&:extend(.rows-fill-shadowed);
|
&:extend(.rows-fill-shadowed);
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
@ -39,9 +43,14 @@
|
|||||||
height: 11px;
|
height: 11px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.title-bar > .icon{
|
||||||
|
// background-color: aqua;
|
||||||
|
width: 16px;
|
||||||
|
height: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
.title-bar .button{
|
.title-bar > .button{
|
||||||
width: 11px;
|
width: 11px;
|
||||||
height: 11px;
|
height: 11px;
|
||||||
padding: 0%;
|
padding: 0%;
|
||||||
@ -49,6 +58,13 @@
|
|||||||
top: 1px;
|
top: 1px;
|
||||||
visibility: hidden;
|
visibility: hidden;
|
||||||
|
|
||||||
|
&:active{
|
||||||
|
background-color: rgba(0, 0, 0, 0.4);
|
||||||
|
/* Green */
|
||||||
|
box-shadow: 0.5px 0.5px 0px 0.5px #FFFFFF,
|
||||||
|
-0.5px -0.5px 0px 0.5px rgba(0, 0, 0, 0.25);
|
||||||
|
}
|
||||||
|
|
||||||
background: linear-gradient(135deg, #999999 18.18%, #FFFFFF 81.82%);
|
background: linear-gradient(135deg, #999999 18.18%, #FFFFFF 81.82%);
|
||||||
border: 1px solid @col-raisin-black;
|
border: 1px solid @col-raisin-black;
|
||||||
box-shadow: 0.5px 0.5px 0px 0.5px #FFFFFF,
|
box-shadow: 0.5px 0.5px 0px 0.5px #FFFFFF,
|
||||||
@ -61,6 +77,10 @@
|
|||||||
flex-grow: 0;
|
flex-grow: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.Focused .title-bar .button{
|
.window-frame.Focused .title-bar > .button{
|
||||||
visibility:visible;
|
visibility:visible;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// .window-frame.Focused .title-bar > .button:active{
|
||||||
|
// background-color: aqua;
|
||||||
|
// }
|
||||||
|
BIN
icons/genericApp/color/16.png
(Stored with Git LFS)
Normal file
BIN
icons/genericApp/color/16.png
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
icons/genericApp/color/32.png
(Stored with Git LFS)
Normal file
BIN
icons/genericApp/color/32.png
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
icons/genericDocument/color/16.png
(Stored with Git LFS)
Normal file
BIN
icons/genericDocument/color/16.png
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
icons/genericDocument/color/32.png
(Stored with Git LFS)
Normal file
BIN
icons/genericDocument/color/32.png
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
icons/genericFolder/color/16.png
(Stored with Git LFS)
Normal file
BIN
icons/genericFolder/color/16.png
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
icons/genericFolder/color/32.png
(Stored with Git LFS)
Normal file
BIN
icons/genericFolder/color/32.png
(Stored with Git LFS)
Normal file
Binary file not shown.
@ -1,13 +1,5 @@
|
|||||||
{{ define "finder/admin-app.tmpl" }}
|
{{ define "finder/admin-app.tmpl" }}
|
||||||
<div class="title-bar DragArea">
|
{{template "wde-widgets/window-title-bar.tmpl" .TitleBarConfig}}
|
||||||
<button id="closeWindowButton" class="button" title="Close Window"></button>
|
|
||||||
<div id="Drag" class="visual-drag-area"></div>
|
|
||||||
<div class="lable">
|
|
||||||
Admin Finder
|
|
||||||
</div>
|
|
||||||
<div id="Drag" class="visual-drag-area"></div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
<div id="ContentBorder" class="content-border AdjectiveElement">
|
<div id="ContentBorder" class="content-border AdjectiveElement">
|
||||||
<div class="finder-content">
|
<div class="finder-content">
|
||||||
|
|
||||||
|
@ -1,10 +1,5 @@
|
|||||||
{{ define "personal-properties/app.tmpl" }}
|
{{ define "personal-properties/app.tmpl" }}
|
||||||
<div class="title-bar DragArea">
|
{{template "wde-widgets/window-title-bar.tmpl" .TitleBarConfig}}
|
||||||
<button id="closeWindowButton" class="Button" title="Close Window"></button>
|
|
||||||
<div id="Drag" class="visual-drag-area"></div>
|
|
||||||
<div class="Lable">About me</div>
|
|
||||||
<div id="Drag" class="visual-drag-area"></div>
|
|
||||||
</div>
|
|
||||||
<div class="content-border">
|
<div class="content-border">
|
||||||
<div class="PersPropsContent">
|
<div class="PersPropsContent">
|
||||||
<div class="PropsView">
|
<div class="PropsView">
|
||||||
|
14
templates/wde-widgets/window-title-bar.html
Normal file
14
templates/wde-widgets/window-title-bar.html
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{{ define "wde-widgets/window-title-bar.tmpl" }}
|
||||||
|
<div class="title-bar DragArea">
|
||||||
|
{{if .CloseButton}}
|
||||||
|
<button id="closeWindowButton" class="button" title="Close Window"></button>
|
||||||
|
{{end}}
|
||||||
|
<div id="Drag" class="visual-drag-area"></div>
|
||||||
|
<!-- TODO:Disable dragging of icon -->
|
||||||
|
<img class="icon">
|
||||||
|
<div class="lable">
|
||||||
|
{{.Lable}}
|
||||||
|
</div>
|
||||||
|
<div id="Drag" class="visual-drag-area"></div>
|
||||||
|
</div>
|
||||||
|
{{ end }}
|
6
wde/titlebar.go
Normal file
6
wde/titlebar.go
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
package wde
|
||||||
|
|
||||||
|
type TitleBarConfig struct {
|
||||||
|
Lable string
|
||||||
|
CloseButton bool
|
||||||
|
}
|
22
wde/wde.go
22
wde/wde.go
@ -37,19 +37,23 @@ func (w *WDE) RenderFileTileView(directory string, host string) (gin.H, error) {
|
|||||||
|
|
||||||
func (w *WDE) GetIconPathForFile(fileHeader *webfilesystem.FileHeader, parentDir string, size string) string {
|
func (w *WDE) GetIconPathForFile(fileHeader *webfilesystem.FileHeader, parentDir string, size string) string {
|
||||||
if fileHeader.Icon != "" {
|
if fileHeader.Icon != "" {
|
||||||
return "/system/libs/img/icon/get?path=" + fileHeader.Icon
|
return "/system/libs/img/icon/get?path=" + fileHeader.Icon + "&size=" + size
|
||||||
}
|
}
|
||||||
|
|
||||||
switch fileHeader.GetType() {
|
extension := fileHeader.GetExtension()
|
||||||
case "directory":
|
|
||||||
return "/system/libs/img/icon/get?path=/Icons2/GenericFolder.icn&size=" + size
|
switch true {
|
||||||
case "jpeg":
|
case extension == "app":
|
||||||
|
return "/system/libs/img/icon/get?path=/Icons/GenericApp.icn&size=" + size
|
||||||
|
case extension == "jpeg":
|
||||||
fallthrough
|
fallthrough
|
||||||
case "png":
|
case extension == "png":
|
||||||
fallthrough
|
fallthrough
|
||||||
case "jpg":
|
case extension == "jpg":
|
||||||
return "/system/libs/img/icon/get?path=" + path.Join(parentDir, fileHeader.Name) + "&size=" + size
|
return "/system/libs/img/get?path=" + path.Join(parentDir, fileHeader.Name) //+ "&size=" + size
|
||||||
|
case fileHeader.GetType() == "directory":
|
||||||
|
return "/system/libs/img/icon/get?path=/Icons/GenericFolder.icn&size=" + size
|
||||||
default:
|
default:
|
||||||
return "/system/libs/img/icon/get?path=/Icons2/GenericFolder.icn&size=" + size
|
return "/system/libs/img/icon/get?path=/Icons/GenericDocument.icn&size=" + size
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -41,6 +41,11 @@ func (fh *FileHeader) GetType() string {
|
|||||||
return fh.Type
|
return fh.Type
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (fh *FileHeader) GetExtension() string {
|
||||||
|
|
||||||
|
return strings.Split(fh.Name, ".")[len(strings.Split(fh.Name, "."))-1]
|
||||||
|
}
|
||||||
|
|
||||||
type BinaryFileData struct {
|
type BinaryFileData struct {
|
||||||
MongoId primitive.ObjectID `bson:"_id" json:"-"`
|
MongoId primitive.ObjectID `bson:"_id" json:"-"`
|
||||||
Bin []byte `bson:"bin" json:"-"`
|
Bin []byte `bson:"bin" json:"-"`
|
||||||
|
Loading…
Reference in New Issue
Block a user