* Copyright (C) 2014 Marcos García * Copyright (C) 2024 MDW * Copyright (C) 2024 Frédéric France * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ /** * \file htdocs/opensurvey/wizard/choix_date.php * \ingroup opensurvey * \brief Page to create a new survey (date selection) */ // Load Dolibarr environment require '../../main.inc.php'; require_once DOL_DOCUMENT_ROOT."/core/lib/admin.lib.php"; require_once DOL_DOCUMENT_ROOT."/core/lib/files.lib.php"; require_once DOL_DOCUMENT_ROOT."/opensurvey/lib/opensurvey.lib.php"; // Security check if (!$user->hasRight('opensurvey', 'write')) { accessforbidden(); } // Survey type is DATE $_SESSION["formatsondage"] = "D"; $erreur = false; $erreurNb = 0; $choixdate = ''; /* * Actions */ // Insert survey if (GETPOST('confirmation')) { // We save hours entered if (issetAndNoEmpty('totalchoixjour', $_SESSION) === true && issetAndNoEmpty('nbrecaseshoraires', $_SESSION) === true) { $nbofchoice = count($_SESSION["totalchoixjour"]); $errheure = array(); if ($nbofchoice * $_SESSION["nbrecaseshoraires"] > 200) { setEventMessages($langs->trans("ErrorFieldTooLong"), null, 'errors'); $erreurNb++; } else { for ($i = 0; $i < $nbofchoice; $i++) { // Show hours choices for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { $horairesi = GETPOST("horaires".$i); $_SESSION["horaires$i"][$j] = $horairesi[$j]; $tmphorairesi = GETPOST('horaires'.$i, 'array'); if (!is_array($tmphorairesi)) { $errheure[$i][$j] = true; $erreur = true; continue; } // A range like 8:00-11:00 $creneaux = array(); $heures = array(); if (preg_match("/(\d{1,2}:\d{2})-(\d{1,2}:\d{2})/", $tmphorairesi[$j], $creneaux)) { //on recupere les deux parties du preg_match qu'on redécoupe autour des ":" $debutcreneau = explode(":", $creneaux[1]); $fincreneau = explode(":", $creneaux[2]); // Compare hours for start and end // If correct, add the data in the session variables if ($debutcreneau[0] < 24 && $fincreneau[0] < 24 && $debutcreneau[1] < 60 && $fincreneau[1] < 60 && ($debutcreneau[0] < $fincreneau[0] || ($debutcreneau[0] == $fincreneau[0] && $debutcreneau[1] < $fincreneau[1]))) { $_SESSION["horaires$i"][$j] = $creneaux[1].'-'.$creneaux[2]; } else { //sinon message d'erreur et nettoyage de la case $errheure[$i][$j] = true; $erreur = true; } } elseif (preg_match(";^(\d{1,2}h\d{0,2})-(\d{1,2}h\d{0,2})$;i", $tmphorairesi[$j], $creneaux)) { //si c'est un creneau type 8h00-11h00 //on recupere les deux parties du preg_match qu'on redécoupe autour des "H" $debutcreneau = preg_split("/h/i", $creneaux[1]); $fincreneau = preg_split("/h/i", $creneaux[2]); // Compare hours for start and end // If correct, add the data in the session variables if ($debutcreneau[0] < 24 && $fincreneau[0] < 24 && $debutcreneau[1] < 60 && $fincreneau[1] < 60 && ($debutcreneau[0] < $fincreneau[0] || ($debutcreneau[0] == $fincreneau[0] && $debutcreneau[1] < $fincreneau[1]))) { $_SESSION["horaires$i"][$j] = $creneaux[1].'-'.$creneaux[2]; } else { //sinon message d'erreur et nettoyage de la case $errheure[$i][$j] = true; $erreur = true; } } elseif (preg_match(";^(\d{1,2}):(\d{2})$;", $tmphorairesi[$j], $heures)) { //si c'est une heure simple type 8:00 //si valeures correctes, on entre les données dans la variables de session if ($heures[1] < 24 && $heures[2] < 60) { $_SESSION["horaires$i"][$j] = $heures[0]; } else { //sinon message d'erreur et nettoyage de la case $errheure[$i][$j] = true; $erreur = true; } } elseif (preg_match(";^(\d{1,2})h(\d{0,2})$;i", $tmphorairesi[$j], $heures)) { //si c'est une heure encore plus simple type 8h //si valeures correctes, on entre les données dans la variables de session if ($heures[1] < 24 && $heures[2] < 60) { $_SESSION["horaires$i"][$j] = $heures[0]; } else { //sinon message d'erreur et nettoyage de la case $errheure[$i][$j] = true; $erreur = true; } } elseif (preg_match(";^(\d{1,2})-(\d{1,2})$;", $tmphorairesi[$j], $heures)) { //si c'est un creneau simple type 8-11 //si valeures correctes, on entre les données dans la variables de session if ($heures[1] < $heures[2] && $heures[1] < 24 && $heures[2] < 24) { $_SESSION["horaires$i"][$j] = $heures[0]; } else { //sinon message d'erreur et nettoyage de la case $errheure[$i][$j] = true; $erreur = true; } } elseif (preg_match(";^(\d{1,2})h-(\d{1,2})h$;", $tmphorairesi[$j], $heures)) { //si c'est un creneau H type 8h-11h //si valeures correctes, on entre les données dans la variables de session if ($heures[1] < $heures[2] && $heures[1] < 24 && $heures[2] < 24) { $_SESSION["horaires$i"][$j] = $heures[0]; } else { //sinon message d'erreur et nettoyage de la case $errheure[$i][$j] = true; $erreur = true; } } elseif ($tmphorairesi[$j] == "") { //Si la case est vide unset($_SESSION["horaires$i"][$j]); } else { //pour tout autre format, message d'erreur $errheure[$i][$j] = true; $erreur = true; } if (issetAndNoEmpty('horaires'.$i, $_SESSION) === false || issetAndNoEmpty((string) $j, $_SESSION['horaires'.$i]) === false) { if (issetAndNoEmpty('horaires'.$i, $_SESSION) === true) { $_SESSION["horaires$i"][$j] = ''; } else { $_SESSION["horaires$i"] = array(); $_SESSION["horaires$i"][$j] = ''; } } } if ($_SESSION["horaires$i"][0] == "" && $_SESSION["horaires$i"][1] == "" && $_SESSION["horaires$i"][2] == "" && $_SESSION["horaires$i"][3] == "" && $_SESSION["horaires$i"][4] == "") { $choixdate .= ","; $choixdate .= $_SESSION["totalchoixjour"][$i]; } else { for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { if ($_SESSION["horaires$i"][$j] != "") { $choixdate .= ","; $choixdate .= $_SESSION["totalchoixjour"][$i]; $choixdate .= "@"; // Replace the comma and the '@' token to avoid issues $choixdate .= str_replace(array(',', '@'), array(',', '@'), $_SESSION["horaires$i"][$j]); } } } } } if (!empty($errheure)) { setEventMessages($langs->trans("ErrorBadFormat"), null, 'errors'); } } //If just one day and no other time options, error message $tmphoraires0 = GETPOST('horaires0', 'array'); if (count($_SESSION["totalchoixjour"]) == "1" && $tmphoraires0[0] == "" && $tmphoraires0[1] == "" && $tmphoraires0[2] == "" && $tmphoraires0[3] == "" && $tmphoraires0[4] == "") { setEventMessages($langs->trans("MoreChoices"), null, 'errors'); $erreur = true; } // Add survey into database if (!$erreur && $erreurNb == 0) { $_SESSION["toutchoix"] = substr($choixdate, 1); unset($_SESSION["nbrecaseshoraires"]); ajouter_sondage(); } } // Reset days if (GETPOST('reset')) { $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { unset($_SESSION["horaires$i"][$j]); } } unset($_SESSION["totalchoixjour"]); unset($_SESSION["nbrecaseshoraires"]); } /* * View */ if (!isset($_SESSION['description']) && !isset($_SESSION['mail'])) { dol_print_error(null, $langs->trans('ErrorOpenSurveyFillFirstSection')); exit; } $arrayofjs = array(); $arrayofcss = array('/opensurvey/css/style.css'); llxHeader('', $langs->trans("OpenSurvey"), "", '', 0, 0, $arrayofjs, $arrayofcss); //nombre de cases par défaut if (!isset($_SESSION["nbrecaseshoraires"])) { $_SESSION["nbrecaseshoraires"] = 5; } elseif ((GETPOST('ajoutcases') || GETPOST("ajoutcases_y")) && $_SESSION["nbrecaseshoraires"] == 5) { $_SESSION["nbrecaseshoraires"] = 10; //On sauvegarde les heures deja entrées if (issetAndNoEmpty('totalchoixjour', $_SESSION) === true) { $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { //affichage des 5 cases horaires for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { $horairesi = GETPOST("horaires".$i); $_SESSION["horaires$i"][$j] = $horairesi[$j]; } } } } //valeurs de la date du jour actuel $jourAJ = date("j"); $moisAJ = date("n"); $anneeAJ = date("Y"); // Initialisation des jour, mois et année if (!isset($_SESSION['jour'])) { $_SESSION['jour'] = date('j'); } if (!isset($_SESSION['mois'])) { $_SESSION['mois'] = date('n'); } if (!isset($_SESSION['annee'])) { $_SESSION['annee'] = date('Y'); } // Update value of date period into the session if (!issetAndNoEmpty('choixjourajout') && !issetAndNoEmpty('choixjourretrait') && (issetAndNoEmpty('retourmois') || issetAndNoEmpty('retourmois_x'))) { $_SESSION["jour"] = date("j"); $_SESSION["mois"] = date("n"); $_SESSION["annee"] = date("Y"); } // Update value of date period into the session if (issetAndNoEmpty('moisavant_x') || issetAndNoEmpty('moisavant')) { if ($_SESSION["mois"] == 1) { $_SESSION["mois"] = 12; $_SESSION["annee"] -= 1; } else { $_SESSION["mois"] -= 1; } //On sauvegarde les heures deja entrées if (issetAndNoEmpty('totalchoixjour', $_SESSION) === true) { $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { //affichage des 5 cases horaires for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { $horairesi = GETPOST("horaires".$i); $_SESSION["horaires$i"][$j] = $horairesi[$j]; } } } } // Update value of date period into the session if (issetAndNoEmpty('moisapres_x') || issetAndNoEmpty('moisapres')) { if ($_SESSION["mois"] == 12) { $_SESSION["mois"] = 1; $_SESSION["annee"] += 1; } else { $_SESSION["mois"] += 1; } // On sauvegarde les heures deja entrées if (issetAndNoEmpty('totalchoixjour', $_SESSION) === true) { $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { //affichage des 5 cases horaires for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { $horairesi = GETPOST("horaires".$i); $_SESSION["horaires$i"][$j] = $horairesi[$j]; } } } } // Update value of date period into the session if (issetAndNoEmpty('anneeavant_x') || issetAndNoEmpty('anneeavant')) { $_SESSION["annee"] -= 1; //On sauvegarde les heures deja entrées if (issetAndNoEmpty('totalchoixjour', $_SESSION) === true) { $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { //affichage des 5 cases horaires for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { $horairesi = GETPOST("horaires".$i); $_SESSION["horaires$i"][$j] = $horairesi[$j]; } } } } // Update value of date period into the session if (issetAndNoEmpty('anneeapres_x') || issetAndNoEmpty('anneeapres')) { $_SESSION["annee"] += 1; //On sauvegarde les heures deja entrées if (issetAndNoEmpty('totalchoixjour', $_SESSION) === true) { $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { //affichage des 5 cases horaires for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { $horairesi = GETPOST("horaires".$i); $_SESSION["horaires$i"][$j] = $horairesi[$j]; } } } } // valeurs du nombre de jour dans le mois et du premier jour du mois $nbrejourmois = idate("t", dol_get_first_day((int) $_SESSION["annee"], (int) $_SESSION["mois"])); $premierjourmois = (int) dol_print_date(dol_get_first_day((int) $_SESSION["annee"], (int) $_SESSION["mois"]), "%w") - 1; //var_dump(dol_get_first_day((int) $_SESSION["annee"], (int) $_SESSION["mois"])); //var_dump($premierjourmois); // TODO Support option getDolGlobalString('MAIN_START_WEEK') == 0 (sunday = first day of week) // translate month if (is_int($_SESSION["mois"]) && $_SESSION["mois"] > 0 && $_SESSION["mois"] < 13) { $motmois = dol_print_date(mktime(0, 0, 0, (int) $_SESSION["mois"], 10), '%B'); } else { $motmois = dol_print_date(dol_now(), '%B'); } // Start form print '
'."\n"; print ''; print load_fiche_titre($langs->trans("CreatePoll").' (2 / 2)'); // Show help for days print '
'."\n"; print $langs->trans("OpenSurveyStep2")."\n"; print '
'."\n"; // Show array with the calendar print '
'."\n"; print '
'."\n"; print ''."\n"; // The div class=center has no effect on table, so we must keep the align=center for table print ''; print ''; print ''; print ''; print ''; print ''."\n"; print '
'; print ''; //print ''; print ''; print ''; //print ''; print ''.$motmois.' '.$_SESSION["annee"].'
'; //print ''; print '
'; print ''; //print ''; print ''; print ''; //print ''; print '
'."\n"; print '
'."\n"; print '
'; print '
'."\n"; print ''."\n"; // The div class=center has no effect on table, so we must keep the align=center for table print ''."\n"; // show list of days in title line for ($i = 0; $i < 7; $i++) { print ''; } print ''."\n"; //ajout d'une entrée dans la variable de session qui contient toutes les dates if (issetAndNoEmpty('choixjourajout')) { if (!isset($_SESSION["totalchoixjour"])) { $_SESSION["totalchoixjour"] = array(); } // Test pour éviter les doublons dans la variable qui contient toutes les dates $journeuf = true; if (issetAndNoEmpty('totalchoixjour', $_SESSION) === true && issetAndNoEmpty('choixjourajout') === true) { $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { $choixjourajout = GETPOST("choixjourajout"); if ($_SESSION["totalchoixjour"][$i] == mktime(0, 0, 0, $_SESSION["mois"], $choixjourajout[0], $_SESSION["annee"])) { $journeuf = false; } } } // Si le test est passé, alors on insere la valeur dans la variable de session qui contient les dates if ($journeuf && issetAndNoEmpty('choixjourajout') === true) { $choixjourajout = GETPOST("choixjourajout"); array_push($_SESSION["totalchoixjour"], dol_mktime(0, 0, 0, $_SESSION["mois"], $choixjourajout[0], $_SESSION["annee"])); sort($_SESSION["totalchoixjour"]); $cle = array_search(dol_mktime(0, 0, 0, $_SESSION["mois"], $choixjourajout[0], $_SESSION["annee"]), $_SESSION["totalchoixjour"]); //On sauvegarde les heures deja entrées for ($i = 0; $i < $cle; $i++) { $horairesi = GETPOST("horaires".$i); for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { if (issetAndNoEmpty('horaires'.$i) === true && issetAndNoEmpty((string) $i, $_POST['horaires'.$i]) === true) { $_SESSION["horaires$i"][$j] = $horairesi[$j]; } } } $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = $cle; $i < $nbofchoice; $i++) { $k = $i + 1; if (issetAndNoEmpty('horaires'.$i) === true && issetAndNoEmpty((string) $i, $_POST['horaires'.$i]) === true) { for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { $horairesi = GETPOST("horaires".$i, 'array'); $_SESSION["horaires$i"][$j] = $horairesi[$j]; } } } unset($_SESSION["horaires$cle"]); } } //retrait d'une entrée dans la variable de session qui contient toutes les dates if (issetAndNoEmpty('choixjourretrait')) { //On sauvegarde les heures deja entrées $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { //affichage des 5 cases horaires for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { $horairesi = GETPOST("horaires".$i); $_SESSION["horaires$i"][$j] = $horairesi[$j]; } } for ($i = 0; $i < $nbofchoice; $i++) { $choixjourretrait = GETPOST('choixjourretrait'); if ($_SESSION["totalchoixjour"][$i] == mktime(0, 0, 0, $_SESSION["mois"], $choixjourretrait[0], $_SESSION["annee"])) { for ($j = $i; $j < $nbofchoice; $j++) { $k = $j + 1; $_SESSION["horaires$j"] = $_SESSION["horaires$k"]; } array_splice($_SESSION["totalchoixjour"], $i, 1); } } } //report des horaires dans toutes les cases if (issetAndNoEmpty('reporterhoraires')) { $_SESSION["horaires0"] = GETPOST("horaires0"); $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { $j = $i + 1; $_SESSION["horaires$j"] = $_SESSION["horaires$i"]; } } //effacer les horaires dans toutes les cases if (issetAndNoEmpty('resethoraires')) { $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { unset($_SESSION["horaires$i"]); } } // affichage du calendrier print ''."\n"; for ($i = 0; $i < $nbrejourmois + $premierjourmois; $i++) { $numerojour = $i - $premierjourmois + 1; // On saute a la ligne tous les 7 jours if (($i % 7) == 0 && $i != 0) { print ''."\n"; } // On affiche les jours precedants en gris et incliquables if ($i < $premierjourmois) { print ''."\n"; } else { if (issetAndNoEmpty('totalchoixjour', $_SESSION) === true) { $nbofchoice = count($_SESSION["totalchoixjour"]); for ($j = 0; $j < $nbofchoice; $j++) { // show red buttons if (date("j", $_SESSION["totalchoixjour"][$j]) == $numerojour && date("n", $_SESSION["totalchoixjour"][$j]) == $_SESSION["mois"] && date("Y", $_SESSION["totalchoixjour"][$j]) == $_SESSION["annee"]) { print ''."\n"; $dejafait = $numerojour; } } } // If no red button, we show green or grey button with number of day if (!isset($dejafait) || $dejafait != $numerojour) { // green button if (($numerojour >= $jourAJ && $_SESSION["mois"] == $moisAJ && $_SESSION["annee"] == $anneeAJ) || ($_SESSION["mois"] > $moisAJ && $_SESSION["annee"] == $anneeAJ) || $_SESSION["annee"] > $anneeAJ) { print ''."\n"; } else { // grey button print ''."\n"; } } } } //fin du tableau print ''."\n"; print '
'; print dol_print_date(mktime(0, 0, 0, 0, $i, 10), (empty($conf->dol_optimize_smallscreen) ? '%A' : '%a')); print '
'.$numerojour.'
'."\n"; print '
'."\n"; print '
'."\n"; // affichage de tous les jours choisis if (issetAndNoEmpty('totalchoixjour', $_SESSION) || $erreur) { //affichage des jours print '
'."\n"; print '
'; print ''.$langs->trans("SelectedDays").':'."
\n"; print $langs->trans("SelectDayDesc")."
\n"; print '

'; print '
'; // You can use div-table-responsive-no-min if you don't need reserved height for your table print ''."\n"; print ''."\n"; print ''."\n"; for ($i = 0; $i < $_SESSION["nbrecaseshoraires"]; $i++) { $j = $i + 1; print ''."\n"; } if ($_SESSION["nbrecaseshoraires"] < 10) { print ''."\n"; } print ''."\n"; // Show list of selected days $nbofchoice = count($_SESSION["totalchoixjour"]); for ($i = 0; $i < $nbofchoice; $i++) { print ''."\n"; print ''; //affichage des cases d'horaires for ($j = 0; $j < $_SESSION["nbrecaseshoraires"]; $j++) { if (isset($errheure[$i][$j]) && $errheure[$i][$j]) { // When an error is found, the checkbox background is red print ''."\n"; } else { // Else the color is empty (in principle) print ''."\n"; } } print ''."\n"; } print '
'.$langs->trans("Time").' '.$j.'
'.dol_print_date($_SESSION["totalchoixjour"][$i], 'daytext').' ('.dol_print_date($_SESSION["totalchoixjour"][$i], '%A').')
'."\n"; print '
'; // show buttons to cancel, delete days or create survey print '
'; // You can use div-table-responsive-no-min if you don't need reserved height for your table print ''; print ''; print ''."\n"; print '

'."\n"; print ''."\n"; print '
'; } print ''."\n"; print ''."\n"; print ''."\n"; //fin du formulaire et bandeau de pied print ''."\n"; //bandeau de pied print '



'."\n"; print '
'."\n"; // End of page llxFooter(); $db->close();