d138999d98eb61acf6d6806c5433ce803efa2623
3 * Plugin Agenda 4 pour Spip 3.0
7 * Auteurs : cf paquet.xml
10 if (!defined("_ECRIRE_INC_VERSION")) return;
13 * #URL_EVENEMENT envoie sur la page de l'evenement
14 * ou sur la page de l'article avec un &id_evenement=xxx
15 * selon la configuration de l'agenda
20 function balise_URL_EVENEMENT_dist($p) {
22 include_spip("inc/config");
23 include_spip("balise/url_");
25 if (lire_config("agenda/url_evenement",'evenement')!=='article'){
26 $code = generer_generer_url('evenement', $p);
29 $_ide = interprete_argument_balise(1,$p);
31 $_ide = champ_sql('id_evenement', $p);
32 $_ida = "generer_info_entite($_ide,'evenement','id_article')";
34 $code = generer_generer_url_arg('article', $p, $_ida);
35 $code = "parametre_url($code,'id_evenement',$_ide,'&')";
38 $code = champ_sql('url_evenement', $p, $code);
41 $p->code
= "vider_url($code)";
42 $p->interdire_scripts
= false;
49 * fonction sous jacente pour les 3 criteres
50 * fusion_par_jour, fusion_par_mois, fusion_par_annee
52 * @param string $format
55 * @param object $boucles
58 function agenda_critere_fusion_par_xx($format, $as, $idb, &$boucles, $crit){
59 $boucle = &$boucles[$idb];
60 $type = $boucle->type_requete
;
61 $_date = isset($crit->param
[0]) ?
calculer_liste($crit->param
[0], array(), $boucles, $boucles[$idb]->id_parent
)
62 : "'".(isset($GLOBALS['table_date'][$type])?
$GLOBALS['table_date'][$type]:"date")."'";
64 $date = $boucle->id_table
. '.' .substr($_date,1,-1);
66 // annuler une eventuelle fusion sur cle primaire !
67 foreach($boucles[$idb]->group
as $k=>$g)
68 if ($g==$boucle->id_table
.'.'.$boucle->primary
)
69 unset($boucles[$idb]->group
[$k]);
70 $boucles[$idb]->group
[] = 'DATE_FORMAT('.$boucle->id_table
.'.".'.$_date.'.", ' . "'$format')";
71 $boucles[$idb]->select
[] = 'DATE_FORMAT('.$boucle->id_table
.'.".'.$_date.'.", ' . "'$format') AS $as";
75 * {fusion_par_jour date_debut}
76 * {fusion_par_jour date_fin}
79 * @param object $boucles
82 function critere_fusion_par_jour_dist($idb, &$boucles, $crit) {
83 agenda_critere_fusion_par_xx('%Y-%m-%d','jour',$idb, $boucles, $crit);
87 * {fusion_par_mois date_debut}
88 * {fusion_par_mois date_fin}
91 * @param object $boucles
94 function critere_fusion_par_mois_dist($idb, &$boucles, $crit) {
95 agenda_critere_fusion_par_xx('%Y-%m','mois',$idb, $boucles, $crit);
99 * {fusion_par_annee date_debut}
100 * {fusion_par_annee date_fin}
103 * @param object $boucles
104 * @param object $crit
106 function critere_fusion_par_annee_dist($idb, &$boucles, $crit) {
107 agenda_critere_fusion_par_xx('%Y','annee',$idb, $boucles, $crit);
111 * {evenement_a_venir}
112 * {evenement_a_venir #ENV{date}}
115 * @param object $boucles
116 * @param object $crit
118 function critere_evenement_a_venir_dist($idb, &$boucles, $crit) {
119 $boucle = &$boucles[$idb];
120 $id_table = $boucle->id_table
;
122 $_dateref = agenda_calculer_date_reference($idb, $boucles, $crit);
123 $_date = "$id_table.date_debut";
124 $op = $crit->not ?
"<=":">";
126 // si on ne sait pas si les heures comptent, on utilise toute la journee.
127 // sinon, on s'appuie sur le champ 'horaire=oui'
128 // pour savoir si les dates utilisent les heures ou pas.
129 $where_futur_sans_heure =
130 array("'$op'", "'$_date'", "sql_quote(date('Y-m-d 23:59:59', strtotime($_dateref)))");
132 if (array_key_exists('horaire', $boucle->show
['field'])) {
136 array("'='", "'horaire'", "sql_quote('oui')"),
137 array("'$op'","'$_date'","sql_quote($_dateref)")
140 array("'!='", "'horaire'", "sql_quote('oui')"),
141 $where_futur_sans_heure
145 $where = $where_futur_sans_heure;
149 $boucle->where
[] = $where;
154 * {evenement_passe #ENV{date}}
157 * @param object $boucles
158 * @param object $crit
160 function critere_evenement_passe_dist($idb, &$boucles, $crit) {
161 $boucle = &$boucles[$idb];
162 $id_table = $boucle->id_table
;
164 $_dateref = agenda_calculer_date_reference($idb, $boucles, $crit);
165 $_date = "$id_table.date_fin";
166 $op = $crit->not ?
">=":"<";
168 // si on ne sait pas si les heures comptent, on utilise toute la journee.
169 // sinon, on s'appuie sur le champ 'horaire=oui'
170 // pour savoir si les dates utilisent les heures ou pas.
171 $where_passe_sans_heure =
172 array("'$op'", "'$_date'", "sql_quote(date('Y-m-d 00:00:00', strtotime($_dateref)))");
174 if (array_key_exists('horaire', $boucle->show
['field'])) {
178 array("'='", "'horaire'", "sql_quote('oui')"),
179 array("'$op'","'$_date'","sql_quote($_dateref)")
182 array("'!='", "'horaire'", "sql_quote('oui')"),
183 $where_passe_sans_heure
187 $where = $where_passe_sans_heure;
191 $boucle->where
[] = $where;
195 * {evenement_en_cours}
196 * {evenement_en_cours #ENV{date}}
199 * @param object $boucles
200 * @param object $crit
202 function critere_evenement_en_cours_dist($idb, &$boucles, $crit) {
203 $boucle = &$boucles[$idb];
204 $id_table = $boucle->id_table
;
206 $_dateref = agenda_calculer_date_reference($idb, $boucles, $crit);
207 $_date_debut = "$id_table.date_debut";
208 $_date_fin = "$id_table.date_fin";
210 // si on ne sait pas si les heures comptent, on utilise toute la journee.
211 // sinon, on s'appuie sur le champ 'horaire=oui'
212 // pour savoir si les dates utilisent les heures ou pas.
213 $where_jour_sans_heure =
215 array("'<='", "'$_date_debut'", "sql_quote(date('Y-m-d 23:59:59', strtotime($_dateref)))"),
216 array("'>='", "'$_date_fin'", "sql_quote(date('Y-m-d 00:00:00', strtotime($_dateref)))")
219 if (array_key_exists('horaire', $boucle->show
['field'])) {
223 array("'='", "'horaire'", "sql_quote('oui')"),
225 array("'<='", "'$_date_debut'", "sql_quote($_dateref)"),
226 array("'>='", "'$_date_fin'", "sql_quote($_dateref)")
230 array("'!='", "'horaire'", "sql_quote('oui')"),
231 $where_jour_sans_heure
235 $where = $where_jour_sans_heure;
239 $where = array("'NOT'",$where);
240 $boucle->where
[] = $where;
244 * {evenementrelatif #ENV{choix}}
245 * {evenementrelatif #ENV{choix}, #ENV{date}}
246 * #ENV{choix} peut prendre 6 valeurs : tout, a_venir, en_cours, passe, en_cours_a_venir ou passe_en_cours
249 * @param object $boucles
250 * @param object $crit
252 function critere_evenementrelatif_dist($idb, &$boucles, $crit) {
253 $boucle = &$boucles[$idb];
254 $id_table = $boucle->id_table
;
255 if (isset($crit->param
[1]))
256 $_dateref = calculer_liste($crit->param
[1], array(), $boucles, $boucles[$idb]->id_parent
);
258 $_dateref = "date('Y-m-d H:i:00')";
259 $not = $crit->not ?
'oui' : '';
260 $choix = isset($crit->param
[0]) ?
calculer_liste($crit->param
[0], array(), $boucles, $boucles[$idb]->id_parent
) : "''";
261 $horaire = array_key_exists('horaire', $boucle->show
['field']) ?
'oui' : '';
263 $boucle->where
[] = "agenda_calculer_critere_evenementrelatif('$id_table',$_dateref,'$not',$choix,'$horaire')";
267 * Fonction interne utilisee par le critere {evenementrelatif}
268 * @param string $id_table
269 * @param string $_dateref
271 * @param string $choix
272 * @param string $horaire
275 function agenda_calculer_critere_evenementrelatif($id_table,$_dateref,$not,$choix,$horaire){
276 $_date_debut = "$id_table.date_debut";
277 $_date_fin = "$id_table.date_fin";
278 if ($choix == 'en_cours_a_venir') {
280 $not = ($not) ?
'' : 'oui';
282 if ($choix == 'passe_en_cours') {
284 $not = ($not) ?
'' : 'oui';
289 $op_a_venir = $not ?
"<=":">";
290 $where_a_venir_sans_heure =
291 array($op_a_venir, $_date_debut, sql_quote(date('Y-m-d 23:59:59', strtotime($_dateref))));
296 array('=', 'horaire', sql_quote('oui')),
297 array($op_a_venir,$_date_debut,sql_quote($_dateref))
300 array('!=', 'horaire', sql_quote('oui')),
301 $where_a_venir_sans_heure
305 $where = $where_a_venir_sans_heure;
311 $op_passe = $not ?
">=":"<";
312 $where_passe_sans_heure =
313 array($op_passe, $_date_fin, sql_quote(date('Y-m-d 00:00:00', strtotime($_dateref))));
318 array('=', 'horaire', sql_quote('oui')),
319 array($op_passe,$_date_fin,sql_quote($_dateref))
322 array('!=', 'horaire', sql_quote('oui')),
323 $where_passe_sans_heure
327 $where = $where_passe_sans_heure;
333 $where_en_cours_sans_heure =
335 array('<=', $_date_debut, sql_quote(date('Y-m-d 23:59:59', strtotime($_dateref)))),
336 array('>=', $_date_fin, sql_quote(date('Y-m-d 00:00:00', strtotime($_dateref))))
342 array('=', 'horaire', sql_quote('oui')),
344 array('<=', $_date_debut, sql_quote($_dateref)),
345 array('>=', $_date_fin, sql_quote($_dateref))
349 array('!=', 'horaire', sql_quote('oui')),
350 $where_en_cours_sans_heure
354 $where = $where_en_cours_sans_heure;
356 return ($not) ?
array('NOT' , $where) : $where;
366 * Fonction privee pour mutualiser de code des criteres_evenement_*
367 * Retourne le code php pour obtenir la date de reference de comparaison
368 * des evenements a trouver
371 * @param object $boucles
372 * @param object $crit
374 * @return string code PHP concernant la date.
376 function agenda_calculer_date_reference($idb, &$boucles, $crit) {
377 if (isset($crit->param
[0]))
378 return calculer_liste($crit->param
[0], array(), $boucles, $boucles[$idb]->id_parent
);
380 return "date('Y-m-d H:i:00')";
385 * Balise #NB_INSCRITS
386 * pour afficher le nombre d'inscrits (qui ont repondu oui) a un evenement
391 function balise_NB_INSCRITS_dist($p) {
392 $id_evenement = champ_sql('id_evenement', $p);
393 $p->code
= "sql_countsel('spip_evenements_participants','id_evenement='.intval($id_evenement).' AND reponse=\'oui\'')";