Subversion Repositories Applications.bazar

Compare Revisions

Ignore whitespace Rev 16 → Rev 17

/trunk/bazar.calendrier.php
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."\"> &lt;&lt; </a>";
 
echo "<div class=\"navi\">";
echo "<a href=\"".$prev."\"> &lt;&lt; </a>";
$retour.= "&nbsp;&nbsp;";
$retour.= "<a href=\"".$cur;
$retour.= "\"> ";
$retour.= $fr_month[(date('n',$curStamp))];
$retour.= "&nbsp;";
$retour.= (date('Y',$curStamp));
$retour.= "</a>";
$retour.= "&nbsp;&nbsp;";
$retour.= "<a href=\"".$next."\"> &gt;&gt; </a>";
 
echo $fr_month[(date('n',$curStamp))];
echo "&nbsp;";
echo (date('Y',$curStamp));
$retour.= "</div>";
 
echo "<a href=\"".$next."\"> &gt;&gt; </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']);
}
}
}
?>