355 lines
11 KiB
JavaScript
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;
|
|
}
|
|
|