mirror of
https://github.com/khairul169/honey.git
synced 2025-04-28 23:09:32 +07:00
138 lines
3.3 KiB
JavaScript
138 lines
3.3 KiB
JavaScript
var UI = {
|
|
"dark_mode": false
|
|
}
|
|
|
|
var SERVICES = [
|
|
{
|
|
"name": "CalDav",
|
|
"desc": "Simple CalDav server for calendar sync between various devices.",
|
|
"href": "caldav",
|
|
"icon": "img/preview/caldav.png"
|
|
},
|
|
{
|
|
"name": "Files",
|
|
"desc": "Fancy file manager for the web.",
|
|
"href": "files",
|
|
"icon": "img/preview/files.png"
|
|
},
|
|
{
|
|
"name": "Gallery",
|
|
"desc": "Photo & video gallery syncable with multiple Android devices.",
|
|
"href": "gallery",
|
|
"icon": "img/preview/gallery.png"
|
|
},
|
|
{
|
|
"name": "Git",
|
|
"desc": "Self-hosted, painless, secure place for your repositories.",
|
|
"href": "git",
|
|
"icon": "img/preview/git.png"
|
|
},
|
|
{
|
|
"name": "E-Mail",
|
|
"desc": "Feature-rich, decentralized and secure E-Mail server.",
|
|
"href": "mail",
|
|
"icon": "img/preview/mail.png"
|
|
},
|
|
{
|
|
"name": "Music",
|
|
"desc": "Beautiful, moody music streaming app.",
|
|
"href": "music",
|
|
"icon": "img/preview/music.png"
|
|
},
|
|
{
|
|
"name": "Notes",
|
|
"desc": "Sweet & lightweight app for taking notes.",
|
|
"href": "notes",
|
|
"icon": "img/preview/notes.png"
|
|
}
|
|
]
|
|
|
|
function onload() {
|
|
for_all("back", (btn) => {
|
|
btn.onclick = back;
|
|
});
|
|
switch_theme(config("dark_mode") == "true");
|
|
load_apps();
|
|
setTimeout(() => {
|
|
back();
|
|
document.body.classList.remove("init");
|
|
}, 50)
|
|
}
|
|
|
|
let CURRENT_VIEW;
|
|
function show(id) {
|
|
CURRENT_VIEW = id;
|
|
for_all("page", (page) => {
|
|
page.classList.add("hidden");
|
|
});
|
|
get(id).classList.remove("hidden");
|
|
get(id).scrollTop = 0;
|
|
let bg = get("background").classList;
|
|
if (CURRENT_VIEW == "page-home") bg.add("scaled");
|
|
else bg.remove("scaled");
|
|
}
|
|
|
|
function back() {
|
|
show("page-home");
|
|
}
|
|
|
|
function switch_theme(value) {
|
|
let is_dark = get_bool("dark_mode");
|
|
if (value === undefined) is_dark = !is_dark;
|
|
config("dark_mode", is_dark);
|
|
get("css_dark").disabled = !is_dark;
|
|
let bg = get("background").classList;
|
|
let setting = get("setting-theme");
|
|
let icon = get("theme-indicator");
|
|
if (is_dark) {
|
|
setting.classList.add("checked");
|
|
icon.innerText = "dark_mode";
|
|
bg.add("dark");
|
|
get_background().src = "img/background-dark.jpg";
|
|
}
|
|
else {
|
|
setting.classList.remove("checked");
|
|
icon.innerText = "light_mode";
|
|
bg.remove("dark");
|
|
get_background().src = "img/background.jpg";
|
|
}
|
|
}
|
|
|
|
function load_apps() {
|
|
let final = "";
|
|
for (let i = 0; i < SERVICES.length; i++) {
|
|
let app = mk_entry(SERVICES[i]);
|
|
final += app;
|
|
}
|
|
get("applist").innerHTML = final;
|
|
}
|
|
|
|
function open_screen(button) {
|
|
let parent = button.parentNode;
|
|
let cursor = parent.getElementsByClassName("bg")[0];
|
|
let items = parent.getElementsByClassName("entry");
|
|
let clicked_id = 0;
|
|
for (let i = 0; i < items.length; i++) {
|
|
if (items[i] === button) {
|
|
clicked_id = i;
|
|
break;
|
|
}
|
|
}
|
|
cursor.style.left = `${100 * clicked_id / items.length}%`;
|
|
let wrapper = parent.parentNode.parentNode;
|
|
let screens = get_class("screens", wrapper)[0];
|
|
let from_height = screens.clientHeight;
|
|
for_all("screen", (screen) => {
|
|
screen.classList.add("hidden");
|
|
}, wrapper);
|
|
screens.children[clicked_id].classList.remove("hidden");
|
|
let to_height = screens.children[clicked_id].clientHeight;
|
|
screens.style.transform = `translateX(calc(-${clicked_id}% * (100 / var(--screens))))`;
|
|
screens.style.height = `${from_height}px`;
|
|
setTimeout(() => {
|
|
screens.style.height = `${to_height}px`;
|
|
}, 10);
|
|
setTimeout(() => {
|
|
screens.style.height = null;
|
|
}, 420);
|
|
} |