89 lines
2.9 KiB
JavaScript
89 lines
2.9 KiB
JavaScript
import "./AppWindow.js"
|
|
import "./AppMenu.js"
|
|
import "./ProfileButton.js"
|
|
import "./InputBox.js"
|
|
import "./Sidebar.js"
|
|
|
|
class Home extends Shadow {
|
|
|
|
render() {
|
|
ZStack(() => {
|
|
|
|
VStack(() => {
|
|
img(document.documentElement.classList.contains("red") ? "/_/icons/quillblack.svg" : "/_/icons/quill.svg", "2.25em")
|
|
.paddingLeft(3, em)
|
|
.paddingTop(5, vh)
|
|
.onClick(() => {
|
|
window.navigateTo("/")
|
|
})
|
|
})
|
|
.paddingRight(2, em)
|
|
.position("fixed")
|
|
.x(0).y(0)
|
|
.height(100, vh)
|
|
.borderRight("0.5px solid var(--accent)")
|
|
.zIndex(3)
|
|
|
|
switch(window.location.pathname) {
|
|
case "/":
|
|
AppWindow()
|
|
AppMenu()
|
|
break
|
|
case "/app/jobs":
|
|
AppWindow("Jobs")
|
|
AppMenu("Jobs")
|
|
break;
|
|
case "/app/messages":
|
|
AppWindow("Messages")
|
|
AppMenu("Messages")
|
|
break;
|
|
case "/app/market":
|
|
AppWindow("Market")
|
|
AppMenu("Market")
|
|
break;
|
|
case "/app/forum":
|
|
AppWindow("Forum")
|
|
AppMenu("Forum")
|
|
break;
|
|
default:
|
|
throw new Error("Unknown route!")
|
|
}
|
|
|
|
|
|
HStack(() => {
|
|
// ProfileButton()
|
|
// .zIndex(1)
|
|
// .cursor("default")
|
|
|
|
a("/signout", "Sign Out")
|
|
.background("transparent")
|
|
.border(window.location.pathname === "/" ? "1px solid var(--tan)" : "0.5px solid #bb7c36")
|
|
.color(window.location.pathname === "/" ? "var(--tan)" : "var(--accent)")
|
|
.borderRadius(5, px)
|
|
.onHover(function (hovering) {
|
|
if(hovering) {
|
|
this.style.background = "var(--green)"
|
|
} else {
|
|
this.style.background = ""
|
|
}
|
|
})
|
|
.onNavigate(function () {
|
|
if(window.location.pathname === "/") {
|
|
this.style.border = "1px solid var(--tan)"
|
|
this.style.color = "var(--tan)"
|
|
} else {
|
|
this.style.border = "0.5px solid #bb7c36"
|
|
this.style.color = "var(--accent)"
|
|
}
|
|
})
|
|
})
|
|
.gap(1, em)
|
|
.xRight(2, em).y(2.3, em)
|
|
.position("fixed")
|
|
.verticalAlign("center")
|
|
|
|
})
|
|
}
|
|
}
|
|
|
|
register(Home) |