diff --git a/htdocs/core/js/lib_notification.js.php b/htdocs/core/js/lib_notification.js.php
index 7be8330321f..0eae59bfcb3 100644
--- a/htdocs/core/js/lib_notification.js.php
+++ b/htdocs/core/js/lib_notification.js.php
@@ -89,7 +89,7 @@ if ("Notification" in window) {
// We set a delay before launching first test so next check will arrive after the time_auto_update compared to previous one.
//var time_first_execution = (time_auto_update + (time_js_next_test - nowtime)) * 1000; //need milliseconds
- var time_first_execution = global->MAIN_BROWSER_NOTIFICATION_CHECK_FIRST_EXECUTION); ?>;
+ var time_first_execution = ;
setTimeout(first_execution, time_first_execution * 1000); // Launch a first execution after a time_first_execution delay
time_js_next_test = nowtime + time_first_execution;
@@ -112,8 +112,17 @@ function first_execution() {
function check_events() {
var result = 0;
dolnotif_nb_test_for_page += 1;
+ var methodfornotification = '';
- if (Notification.permission === "granted") {
+ permissionok = 0;
+ if (methodfornotification == "jsnotification" && Notification.permission == "granted") {
+ permissionok = 1;
+ }
+ if (methodfornotification == "jnotify") {
+ permissionok = 1;
+ }
+
+ if (permissionok == 1) {
var currentToken = 'notrequired';
const allMeta = document.getElementsByTagName("meta");
for (let i = 0; i < allMeta.length; i++) {
@@ -138,10 +147,11 @@ function check_events() {
console.log("Retrieved "+arrayofpastreminders.length+" reminders to do.");
var audio = null;
+ var icon = '';
var listofreminderids = '';
var noti = []
@@ -149,61 +159,91 @@ function check_events() {
console.log(value);
var url = "notdefined";
var title = "Not defined";
- var body = value.label;
- var icon = '';
- var image = '';
- if (value.type == 'agenda' && value.location != null && value.location != '') {
- body += '\n' + value.location;
- }
-
- if (value.type == 'agenda' && (value.event_date_start_formated != null || value.event_date_start_formated['event_date_start'] != '')) {
- body += '\n' + value.event_date_start_formated;
- }
+ var body = "";
if (value.type == 'agenda')
{
url = '' + value.id_agenda;
title = 'transnoentities('EventReminder')) ?>';
}
- var extra = {
- icon: icon,
- body: body,
- lang: 'getDefaultLang(1)); ?>',
- tag: value.id_agenda,
- requireInteraction: true /* wait that the user click or close the notification */
- /* only supported for persistent notification shown using ServiceWorkerRegistration.showNotification() so disabled */
- /* actions: [{ action: 'action1', title: 'New Button Label' }, { action: 'action2', title: 'Another Button' }] */
- };
- // We release the notify
- console.log("Send notification on browser url="+url);
- noti[index] = new Notification(title, extra);
- if (index==0 && audio)
- {
- audio.play();
+ if (methodfornotification == "jsnotification") {
+ body = value.label;
+ if (value.type == 'agenda' && value.location != null && value.location != '') {
+ body += '\n' + value.location;
+ }
+
+ if (value.type == 'agenda' && (value.event_date_start_formated != null || value.event_date_start_formated['event_date_start'] != '')) {
+ body += '\n' + value.event_date_start_formated;
+ }
+ } else {
+ if (title != "Not defined") {
+ body = title+'
';
+ }
+ body += '
';
+ if (value.type == 'agenda' && (value.event_date_start_formated != null || value.event_date_start_formated['event_date_start'] != '')) {
+ body += ' '+value.event_date_start_formated;
+ }
+ body += ' - trans("ShowDetails")); ?>';
+ body += '
'+value.label;
+ if (value.type == 'agenda' && value.location != null && value.location != '') {
+ body += '
' + value.location;
+ }
}
- if (noti[index]) {
- noti[index].onclick = function (event) {
- /* If the user has clicked on button Activate */
- console.log("A click on notification on browser has been done for url="+url);
- event.preventDefault(); // prevent the browser from focusing the Notification's tab
- window.focus();
- window.open(url, '_blank');
- noti[index].close();
+ // We release the notify
+ console.log("Send notification on browser url="+url+" using method="+methodfornotification);
+
+ // Using the js browser Notification() popup
+ if (methodfornotification == 'jsnotification') {
+ var extra = {
+ icon: icon,
+ body: body,
+ lang: 'getDefaultLang(1)); ?>',
+ tag: value.id_agenda,
+ requireInteraction: true /* wait that the user click or close the notification */
+ /* "actions:" parameter is only supported for persistent notification shown using ServiceWorkerRegistration.showNotification() so disabled */
+ /* actions: [{ action: 'action1', title: 'New Button Label' }, { action: 'action2', title: 'Another Button' }] */
};
+ noti[index] = new Notification(title, extra);
+ if (index==0 && audio)
+ {
+ audio.play();
+ }
+
+ if (noti[index]) {
+ noti[index].onclick = function (event) {
+ /* If the user has clicked on button Activate */
+ console.log("A click on notification on browser has been done for url="+url);
+ event.preventDefault(); // prevent the browser from focusing the Notification's tab
+ window.focus();
+ window.open(url, '_blank');
+ noti[index].close();
+ };
+
+ listofreminderids = (listofreminderids == '' ? '' : listofreminderids + ',') + value.id_reminder
+ }
+ }
+
+ // Using jNotify popup
+ if (methodfornotification == 'jnotify') {
+ // Output a message with level "warning"
+ $.jnotify(body, 'warning', true, { remove: function (){} } );
+
listofreminderids = (listofreminderids == '' ? '' : listofreminderids + ',') + value.id_reminder
}
});
// Update status of all notifications we sent on browser (listofreminderids)
- console.log("Flag notification as done for listofreminderids="+listofreminderids);
- $.ajax(""+listofreminderids, {
- type: "POST", // Usually post or get
- async: true,
- data: { time_js_next_test: time_js_next_test, token: currentToken }
- });
+ if (listofreminderids != '') {
+ console.log("Flag notification as done for listofreminderids="+listofreminderids);
+ $.ajax(""+listofreminderids, {
+ type: "POST",
+ async: true,
+ data: { time_js_next_test: time_js_next_test, token: currentToken }
+ });
+ }
} else {
console.log("No remind to do found, next search at "+time_js_next_test);
}
@@ -212,9 +252,9 @@ function check_events() {
result = 1;
} else {
- console.log("Cancel check_events() with dolnotif_nb_test_for_page="+dolnotif_nb_test_for_page+". Check is useless because javascript Notification.permission is "+Notification.permission+" (blocked manually or web site is not https or browser is in Private mode).");
+ console.log("Cancel check_events() with dolnotif_nb_test_for_page="+dolnotif_nb_test_for_page+". Check is useless because permission is off. Javascript Notification.permission is "+Notification.permission+" (blocked manually or web site is not https or browser is in Private mode).");
- result = 2; // We return a positive so the repeated check will done even if authorization is not yet allowed may be after this check)
+ result = 2; // We return a positive so the repeated check will be done even if authorization is not yet allowed may be after this check)
}
if (dolnotif_nb_test_for_page >= 5) {