32,7 → 32,7 |
// pris connaissance de la licence CeCILL, et que vous en avez accepté les |
// termes. |
// ---- |
// CVS : $Id: bazar.calendrier.php,v 1.2 2005-09-30 14:58:00 ddelon Exp $ |
// CVS : $Id: bazar.calendrier.php,v 1.3 2005-09-30 23:04:31 ddelon Exp $ |
/** |
* bazar_calendrier : programme affichant les evenements du bazar sous forme de Calendrier |
* |
40,7 → 40,7 |
*@package Bazar |
//Auteur original : |
*@author David DELON <david.delon@clapas.net> |
*@version $Revision: 1.2 $ $Date: 2005-09-30 14:58:00 $ |
*@version $Revision: 1.3 $ $Date: 2005-09-30 23:04:31 $ |
// +------------------------------------------------------------------------------------------------------+ |
*/ |
|
54,16 → 54,22 |
require_once 'Calendar/Day.php'; |
require_once 'Calendar/Decorator.php'; |
|
define ('BAZ_VOIR_FICHE', 8) ; |
include_once 'configuration/baz_config.inc.php'; //fichier de configuration de Bazar |
include_once 'bibliotheque/bazar.fonct.php'; //fichier des fonctions de Bazar |
|
|
|
// Classe Utilitaire pour Calendrier |
|
class DiaryEvent extends Calendar_Decorator { |
var $entry; |
var $entry=array(); |
function DiaryEvent($calendar) { |
Calendar_Decorator::Calendar_Decorator($calendar); |
} |
function setEntry($entry) { |
$this->entry = $entry; |
$this->entry[]=$entry; |
|
} |
function getEntry() { |
return $this->entry; |
72,6 → 78,11 |
|
|
function afficherContenuCorps() { |
|
// Ajout d'une feuille de style externe |
GEN_stockerStyleExterne ('wikini', 'client/bazar/presentations/styles/calendrier.css') ; |
|
$retour=''; |
|
$url = $GLOBALS['_GEN_commun']['url'] ; |
$db = &$GLOBALS['_GEN_commun']['pear_db'] ; |
85,15 → 96,15 |
$_GET['m'] = date('m'); |
} |
|
if (!isset($_GET['d'])) { |
$_GET['d'] = date('d'); |
} |
|
|
|
// Construction Mois en Cours |
$month = new Calendar_Month_Weekdays($_GET['y'],$_GET['m']); |
|
$curStamp=$month->getTimeStamp(); |
$url->addQueryString ('y', date('Y',$curStamp)); |
$url->addQueryString ('m', date('n',$curStamp)); |
$url->addQueryString ('d', date('j',$curStamp)); |
$cur = $url->getUrl(); |
|
// Navigation |
$prevStamp = $month->prevMonth(true); |
107,129 → 118,146 |
$url->addQueryString ('d', date('j',$nextStamp)); |
$next = $url->getUrl(); |
|
$fr_month=array("1"=>"Janvier","2"=>"Fevrier","3"=>"Mars","4"=>"Avril","5"=>"Mai","6"=>"Juin","7"=>"Juillet","8"=>"Aout","9"=>"Septembre","10"=>"Octobre","11"=>"Novembre","12"=>"Decembre"); |
$fr_month=array("1"=>BAZ_JANVIER,"2"=>BAZ_FEVRIER,"3"=>BAZ_MARS,"4"=>BAZ_AVRIL,"5"=>BAZ_MAI,"6"=>BAZ_JUIN,"7"=>BAZ_JUILLET,"8"=>BAZ_AOUT,"9"=>BAZ_SEPTEMBRE,"10"=>BAZ_OCTOBRE,"11"=>BAZ_NOVEMBRE,"12"=>BAZ_DECEMBRE); |
|
$retour.= "<div class=\"navi\">"; |
$retour.= "<a href=\"".$prev."\"> << </a>"; |
|
echo "<div class=\"navi\">"; |
echo "<a href=\"".$prev."\"> << </a>"; |
$retour.= " "; |
$retour.= "<a href=\"".$cur; |
$retour.= "\"> "; |
$retour.= $fr_month[(date('n',$curStamp))]; |
$retour.= " "; |
$retour.= (date('Y',$curStamp)); |
$retour.= "</a>"; |
$retour.= " "; |
$retour.= "<a href=\"".$next."\"> >> </a>"; |
|
echo $fr_month[(date('n',$curStamp))]; |
echo " "; |
echo (date('Y',$curStamp)); |
$retour.= "</div>"; |
|
echo "<a href=\"".$next."\"> >> </a>"; |
$retour.="<br></br>"; |
|
echo "</div>"; |
|
|
// Recherche evenement de la periode selectionnée |
|
$EvenementSelection=$this->tag.date('Y',$curStamp).date('m',$curStamp); |
|
$selection = array(); |
|
|
// TODO : Selectionner element du mois en cours |
|
$requete_evenements = "SELECT DISTINCT bf_id_fiche, bf_titre, bf_lieu_evenement, bf_date_debut_evenement, bf_date_fin_evenement, bf_description FROM bazar_fiche, bazar_nature where bf_date_debut_evenement=".$EvenementSelection." and bf_ce_nature=bn_id_nature and bn_label_nature='Évènements'"; |
|
|
$resultat_evenement = $db->query($requete_evenements); |
|
(DB::isError($resultat_evenement)) |
? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_evenement->getMessage(), $requete_evenements)) |
: ''; |
|
$calcom=""; |
|
while ($ligne_evenements = $resultat_evenement->fetchRow(DB_FETCHMODE_OBJECT)) { |
// Vue Mois |
if (!isset($_GET['id_fiche'])) { |
|
// Recherche evenement de la periode selectionnée |
|
$Day = new Calendar_Day(date('Y',$curStamp),date('m',$curStamp), substr($page ['tag'], -2)); |
// TODO : Selectionner element du mois en cours |
|
$requete_evenements = "SELECT DISTINCT bf_id_fiche, bf_titre, bf_lieu_evenement, day(bf_date_debut_evenement) as bf_jour_debut_evenement , bf_date_fin_evenement, bf_description FROM bazar_fiche, bazar_nature where year(bf_date_debut_evenement) =".date('Y',$curStamp)." and month(bf_date_debut_evenement)=".date('m',$curStamp)." and bf_ce_nature=bn_id_nature and bn_label_nature='Évènements'"; |
|
|
$resultat_evenement = $db->query($requete_evenements); |
|
(DB::isError($resultat_evenement)) |
? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_evenement->getMessage(), $requete_evenements)) |
: ''; |
|
$DiaryEvent = new DiaryEvent($Day); |
$calcom=""; |
|
$selection=array(); |
$evenements=array(); |
|
$prev_curday_ymd=0; |
|
while ($ligne_evenements = $resultat_evenement->fetchRow(DB_FETCHMODE_OBJECT)) { |
|
$curday_ymd=date('Ym',$curStamp).$ligne_evenements->bf_jour_debut_evenement; |
if ($curday_ymd!=$prev_curday_ymd) { |
$Day = new Calendar_Day(date('Y',$curStamp),date('m',$curStamp), $ligne_evenements->bf_jour_debut_evenement); |
$DiaryEvent = new DiaryEvent($Day); |
$prev_curday_ymd=$curday_ymd; |
} |
|
$DiaryEvent->setEntry($ligne_evenements); |
|
// Add the decorator to the selection |
$selection[] = $DiaryEvent; |
|
$dayStamp = $Day->thisDay(true); |
$url->addQueryString ('y', date('Y',$dayStamp)); |
$url->addQueryString ('m', date('n',$dayStamp)); |
$url->addQueryString ('d', date('j',$dayStamp)); |
$ref = $url->getUrl(); |
} |
|
// Affichage Calendrier |
|
|
$calcom="</br>".$ligne_evenements->bf_titre.$calcom; |
|
// Attach the payload |
$DiaryEvent->setEntry($calcom); |
$month->build($selection); |
|
// Add the decorator to the selection |
$selection[] = $DiaryEvent; |
$retour.= "<table class=\"calendar\"> |
<tr> |
|
} |
|
// Affichage Calendrier |
<th> ". BAZ_LUNDI ."</th> |
<th> ". BAZ_MARDI ."</th> |
<th> ". BAZ_MERCREDI ."</th> |
<th> ". BAZ_JEUDI ."</th> |
<th> ". BAZ_VENDREDI ."</th> |
<th> ". BAZ_SAMEDI ."</th> |
<th> ". BAZ_DIMANCHE ."</th> |
</tr> |
"; |
|
$todayStamp=time(); |
|
$today_ymd=date('Ymd',$todayStamp); |
|
|
$month->build($selection); |
|
echo ( "<tr>\n" ); |
echo ( "<td>\n" ); |
|
|
echo "<table class=\"calendar\"> |
<tr> |
|
<th> Lundi </th> |
<th> Mardi </th> |
<th> Mercredi </th> |
<th> Jeudi </th> |
<th> Vendredi </th> |
|
<th> Samedi </th> |
<th> Dimanche </th> |
</tr> |
"; |
|
$todayStamp=time(); |
|
while ( $day = $month->fetch() ) { |
|
$dayStamp = $day->thisDay(true); |
|
if ( $day->isEmpty() ) { |
$class = "other_month"; |
} |
else { |
if ($todayStamp>$dayStamp) { |
$class="previous_month"; |
// Other month : mois |
// |
|
while ($day = $month->fetch() ) { |
|
$dayStamp = $day->thisDay(true); |
$day_ymd=date('Ymd',$dayStamp); |
|
if ( $day->isEmpty() ) { |
$class = "other_month"; |
} |
else { |
$class="current_month"; |
if (($day_ymd < $today_ymd)) { |
$class="previous_month"; |
} |
else { |
$class="current_month"; |
} |
} |
} |
|
$link = |
$_SERVER['PHP_SELF'].'?wiki='.$this->tag.date('Y',$dayStamp).date('m',$dayStamp).date('d',$dayStamp); |
|
// isFirst() to find start of week |
if ( $day->isFirst() ) |
echo ( "<tr>\n" ); |
|
|
echo ( "<td class=\"".$class."\"><a href=\"".$link."\">".$day->thisDay()."</a>\n" ); |
$url->addQueryString ('y', date('Y',$dayStamp)); |
$url->addQueryString ('m', date('n',$dayStamp)); |
$url->addQueryString ('d', date('j',$dayStamp)); |
|
$link = $url->getUrl(); |
|
if ( $day->isSelected() ) { |
// isFirst() to find start of week |
if ($day->isFirst()) |
$retour.= ( "<tr>\n" ); |
|
echo ( "<a href=\"".$link."\">".$day->getEntry()."</a>\n" ); |
$retour.= ( "<td class=\"".$class."\"><a href=\"".$link."\">".$day->thisDay()."</a>\n" ); |
|
if ($day->isSelected() ) { |
$evenements=$day->getEntry(); |
while ($ligne_evenement=array_pop($evenements)) { |
$url->addQueryString ('id_fiche',$ligne_evenement->bf_id_fiche); |
$link = $url->getUrl(); |
$retour.= ( "<a href=\"".$link."\">".$ligne_evenement->bf_titre."</a>\n" ); |
} |
|
} |
|
$retour.= ( "</td>\n" ); |
|
// isLast() to find end of week |
if ( $day->isLast() ) |
$retour.= ( "</tr>\n" ); |
} |
echo ( "</td>\n" ); |
|
$retour.= "</table>"; |
|
// isLast() to find end of week |
if ( $day->isLast() ) |
echo ( "</tr>\n" ); |
return $retour; |
|
} |
|
echo "</table>"; |
|
else { |
// Vue jour |
if (isset($_GET['id_fiche'])) { |
return $retour.baz_voir_fiche(0, $_GET['id_fiche']); |
} |
} |
} |
|
?> |