BrainMinder/assets/static/js/main.js
2025-01-06 17:07:18 +01:00

355 lines
11 KiB
JavaScript

if (typeof(registerServiceWorker) === undefined) {
const registerServiceWorker = async () => {
if ("serviceWorker" in navigator) {
try {
const registration = await navigator.serviceWorker.register("/static/js/serviceWorker.js", {
scope: "/",
});
if (registration.installing) {
console.log("Service worker installing");
} else if (registration.waiting) {
console.log("Service worker installed");
} else if (registration.active) {
console.log("Service worker active");
}
} catch (error) {
console.error("Registration failed with ${error}");
}
}
};
registerServiceWorker();
}
//Variable for gestures
if (typeof(_bm_xDown) == undefined) {
let _bm_xDown;
}
if (typeof(_bm_yDown) == undefined) {
let _bm_yDown;
}
function bm_toggle_dropdown(list_id) {
var list = document.getElementById(list_id);
if (list.className.indexOf("show") === -1) {
list.className += "show";
} else {
list.className = list.className.replace("show", "");
}
}
function bm_overlay_off(sidebar_id) {
document.getElementById("overlay").style.display = "none";
bm_hide_sidebar(sidebar_id);
}
function bm_toggle_sidebar(sidebar_id) {
sidebar = document.getElementById(sidebar_id);
if (sidebar.style.display === "block") {
document.getElementById("overlay").style.display = "none";
sidebar.style.display = "none";
sidebar.classList.remove("mobile-sidebar");
} else {
document.getElementById("overlay").style.display = "block";
sidebar.style.display = "block";
sidebar.classList.add("mobile-sidebar");
}
}
function bm_hide_sidebar(sidebar_id) {
document.getElementById("overlay").style.display = "none";
sidebar = document.getElementById(sidebar_id);
sidebar.style.display = "none";
sidebar.classList.remove("mobile-sidebar")
}
function bm_sidebar_click(sidebar_id) {
sidebar = document.getElementById(sidebar_id);
if(sidebar.classList.contains("mobile-sidebar")) {
bm_hide_sidebar(sidebar_id);
bm_hide_quickbox();
}
}
function bm_toggle_visibility(element_id) {
element = document.getElementById(element_id);
if (element.classList.contains("hidden")) {
element.classList.remove("hidden");
} else {
element.classList.add("hidden");
}
var x = document.getElementsByClassName(element_id);
for (var i = 0; i < x.length; i++) {
if (x[i].classList.contains("hidden")) {
x[i].classList.remove("hidden");
} else {
x[i].classList.add("hidden");
}
}
}
function bm_toggle_visibility_list_search(element_id) {
element = document.getElementById(element_id);
element.hidden = !element.hidden;
var x = document.getElementsByClassName("stickyheader");
for (var i = 0; i < x.length; i++) {
if (x[i].classList.contains("searchopened")) {
x[i].classList.remove("searchopened");
} else {
x[i].classList.add("searchopened");
}
}
}
function bm_open_tab(element, tab_button_class, tab_class, tab_id) {
var x = document.getElementsByClassName("tab-button");
for (var i = 0; i < x.length; i++) {
x[i].classList.remove("active");
}
element.classList.add("active");
var x = document.getElementsByClassName("tab");
for (var i = 0; i < x.length; i++) {
x[i].style.display = "none";
}
document.getElementById(tab_id).style.display = "block";
}
function bm_show_quickbox() {
htmx.ajax('GET', '/quickbox/all', {target:'#quickbox-notes', swap:'innerHTML'})
document.getElementById("quickbox").style.display = "block";
}
function bm_hide_quickbox() {
document.getElementById("quickbox").style.display = "none";
}
function bm_toggle_quickbox() {
quickbox = document.getElementById("quickbox");
console.log(quickbox);
if(quickbox.style.display == "block") {
bm_hide_quickbox();
}
else {
bm_show_quickbox();
}
}
function bm_show_confirm_delete(sender, title, message) {
document.querySelector("#dialog-confirm-delete h5").innerHTML = title;
document.querySelector("#dialog-confirm-delete p").innerHTML = message;
document.querySelector("#dialog-confirm-delete").showModal();
document.getElementById("modal-confirm-delete").addEventListener('click', (event) => {
htmx.trigger(sender, 'confirmed', null);
document.querySelector("#dialog-confirm-delete").close();
});
}
function bm_show_confirm(sender, title, message) {
document.querySelector("#dialog-confirm h5").innerHTML = title;
document.querySelector("#dialog-confirm p").innerHTML = message;
document.querySelector("#dialog-confirm").showModal();
document.getElementById("modal-confirm").addEventListener('click', (event) => {
htmx.trigger(sender, 'confirmed', null);
document.querySelector("#dialog-confirm").close();
});
}
function bm_item_field_add(type_field_id, widget) {
let template = Handlebars.templates['field-' + widget]
let fields_list = document.getElementById('fields-' + type_field_id);
let counter = parseInt(document.getElementById('fields-' + type_field_id + '-counter').innerHTML);
fields_list.insertAdjacentHTML('beforeend', template({type_field_id:type_field_id,counter:counter, value:""}));
document.getElementById('fields-' + type_field_id + '-counter').innerHTML = (counter + 1).toString();
}
function bm_item_field_delete(sender, field_name) {
document.getElementById('FieldsValuesToRemove-' + field_name).value = '1';
sender.hidden = true;
document.getElementById('Undelete-' + field_name).hidden = false;
document.getElementById('FieldsValues-' + field_name).classList.add('field-opaque');
}
function bm_item_field_undelete(sender, field_name) {
document.getElementById('FieldsValuesToRemove-' + field_name).value = '';
sender.hidden = true;
document.getElementById('Delete-' + field_name).hidden = false;
document.getElementById('FieldsValues-' + field_name).classList.remove('field-opaque');
}
function bm_type_field_delete(sender, type_field_id) {
document.getElementById('Fields-' + type_field_id + '-ToRemove').value = '1';
sender.hidden = true;
document.getElementById('Undelete-' + type_field_id).hidden = false;
document.getElementById('Field-' + type_field_id).classList.add('field-opaque');
}
function bm_type_field_undelete(sender, type_field_id) {
document.getElementById('Fields-' + type_field_id + '-ToRemove').value = '';
sender.hidden = true;
document.getElementById('Delete-' + type_field_id).hidden = false;
document.getElementById('Field-' + type_field_id).classList.remove('field-opaque');
}
function bm_item_relation_delete(sender, relation_name, relation_name_remove) {
document.getElementById(relation_name_remove).value = '1';
sender.hidden = true;
document.getElementById('Undelete-' + relation_name).hidden = false;
var x = document.getElementsByClassName(relation_name + "-Col");
for (var i = 0; i < x.length; i++) {
x[i].classList.add("field-opaque");
}
}
function bm_item_relation_undelete(sender, relation_name, relation_name_remove) {
document.getElementById(relation_name_remove).value = '';
sender.hidden = true;
document.getElementById('Delete-' + relation_name).hidden = false;
var x = document.getElementsByClassName(relation_name + "-Col");
for (var i = 0; i < x.length; i++) {
x[i].classList.remove("field-opaque");
}
}
function bm_showMessage() {
document.getElementById('message').show();
setTimeout(() => {
document.getElementById('message').close();
document.getElementById('message').innerHTML = '';
}, "5000");
}
document.addEventListener("DOMContentLoaded", function(event){
// const easyMDE = new EasyMDE({autosave: {enabled: true, uniqueId: 'eMDE-item-descriotion'}, element: document.getElementById('item-description')});
/*
//Swipe on body, disabled due to conflicts
document.querySelector('body')
.addEventListener(
'touchstart',
bm_handleTouchStart,
false
);
document.querySelector('body')
.addEventListener(
'touchmove',
bm_handleTouchMove,
false
);
*/
document.getElementById('dialog-confirm').addEventListener('click', (event) => {
if (event.target.classList.contains("close-dialog-confirm")) {
event.target.closest('dialog').close();
}
});
document.getElementById('dialog-confirm-delete').addEventListener('click', (event) => {
if (event.target.classList.contains("close-dialog-confirm")) {
event.target.closest('dialog').close();
}
});
document.querySelector('body').addEventListener('click', (event) => {
if (event.target.classList.contains("close-dialog")) {
event.target.closest('#dialog').close();
event.target.closest('#dialog').remove();
}
});
document.body.addEventListener("showModalDialog", function(evt){
document.getElementById("dialog").showModal();
});
document.body.addEventListener("closeModalDialog", function(evt){
document.getElementById('dialog').close();
document.getElementById('dialog').remove();
});
document.body.addEventListener("quickboxNoteClear", function(evt){
document.getElementById("quickbox-notetext").value = ''
});
document.body.addEventListener("closeQuickboxTransformModal", function(evt){
bm_showMessage();
document.getElementById('dialog').close();
document.getElementById('dialog').remove();
if(evt.detail.keepQuickNote == 0){
htmx.ajax('DELETE', '/quickbox/delete/' + evt.detail.quickNoteId, {target:'#quicknote-' + evt.detail.quickNoteId, swap:'outerHTML swap:1s'})
}
});
document.body.addEventListener("activateEasyMDE", function(evt){
const easyMDE = new EasyMDE({element: document.getElementById(evt.detail.value), forceSync: true});
});
document.body.addEventListener("showMessage", function(evt){
bm_showMessage();
});
new SlimSelect({select: '.slim-select'});
htmx.on('htmx:afterSettle', (event) => {
new SlimSelect({select: '.slim-select'});
});
});
function bm_ignoreSwipe(event) {
// if some touches come from elements with ignoreswipe class > ignore
return Array.from(event.touches).some((t) =>
t.target.classList.contains('noswipe')
);
}
function bm_handleTouchStart(event) {
if (bm_ignoreSwipe(event)) {
_bm_xDown = undefined;
_bm_yDown = undefined;
return;
}
const firstTouch = event.touches[0];
_bm_xDown = firstTouch.clientX;
_bm_yDown = firstTouch.clientY;
}
function bm_handleTouchMove(event) {
if (!_bm_xDown || !_bm_yDown) {
return;
}
const xUp = event.touches[0].clientX;
const yUp = event.touches[0].clientY;
const xDiff = _bm_xDown - xUp;
const yDiff = _bm_yDown - yUp;
if (Math.abs(xDiff) > Math.abs(yDiff)) {
/*most significant*/
if (xDiff > 1) {
/* left swipe */
//console.log('app: left swipe ', true);
bm_show_quickbox();
} else {
/* right swipe */
//console.log('app: right swipe ', true);
bm_toggle_sidebar("main-sidebar");
}
} else {
if (yDiff > 1) {
/* up swipe */
console.log('app: up swipe ', true);
} else {
/* down swipe */
console.log('app: down swipe ', true);
}
}
/* reset values */
_bm_xDown = null;
_bm_yDown = null;
}