code = $code; if (!$p->etoile) $p->code = "vider_url($code)"; $p->interdire_scripts = false; return $p; } /** * fonction sous jacente pour les 3 criteres * fusion_par_jour, fusion_par_mois, fusion_par_annee * * @param string $format * @param strinf $as * @param string $idb * @param object $boucles * @param object $crit */ function agenda_critere_fusion_par_xx($format, $as, $idb, &$boucles, $crit){ $boucle = &$boucles[$idb]; $type = $boucle->type_requete; $_date = isset($crit->param[0]) ? calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent) : "'".(isset($GLOBALS['table_date'][$type])?$GLOBALS['table_date'][$type]:"date")."'"; $date = $boucle->id_table. '.' .substr($_date,1,-1); // annuler une eventuelle fusion sur cle primaire ! foreach($boucles[$idb]->group as $k=>$g) if ($g==$boucle->id_table.'.'.$boucle->primary) unset($boucles[$idb]->group[$k]); $boucles[$idb]->group[] = 'DATE_FORMAT('.$boucle->id_table.'.".'.$_date.'.", ' . "'$format')"; $boucles[$idb]->select[] = 'DATE_FORMAT('.$boucle->id_table.'.".'.$_date.'.", ' . "'$format') AS $as"; } /** * {fusion_par_jour date_debut} * {fusion_par_jour date_fin} * * @param string $idb * @param object $boucles * @param object $crit */ function critere_fusion_par_jour_dist($idb, &$boucles, $crit) { agenda_critere_fusion_par_xx('%Y-%m-%d','jour',$idb, $boucles, $crit); } /** * {fusion_par_mois date_debut} * {fusion_par_mois date_fin} * * @param string $idb * @param object $boucles * @param object $crit */ function critere_fusion_par_mois_dist($idb, &$boucles, $crit) { agenda_critere_fusion_par_xx('%Y-%m','mois',$idb, $boucles, $crit); } /** * {fusion_par_annee date_debut} * {fusion_par_annee date_fin} * * @param string $idb * @param object $boucles * @param object $crit */ function critere_fusion_par_annee_dist($idb, &$boucles, $crit) { agenda_critere_fusion_par_xx('%Y','annee',$idb, $boucles, $crit); } /** * {evenement_a_venir} * {evenement_a_venir #ENV{date}} * * @param string $idb * @param object $boucles * @param object $crit */ function critere_evenement_a_venir_dist($idb, &$boucles, $crit) { $boucle = &$boucles[$idb]; $id_table = $boucle->id_table; $_dateref = agenda_calculer_date_reference($idb, $boucles, $crit); $_date = "$id_table.date_debut"; $op = $crit->not ? "<=":">"; // si on ne sait pas si les heures comptent, on utilise toute la journee. // sinon, on s'appuie sur le champ 'horaire=oui' // pour savoir si les dates utilisent les heures ou pas. $where_futur_sans_heure = array("'$op'", "'$_date'", "sql_quote(date('Y-m-d 23:59:59', strtotime($_dateref)))"); if (array_key_exists('horaire', $boucle->show['field'])) { $where = array("'OR'", array("'AND'", array("'='", "'horaire'", "sql_quote('oui')"), array("'$op'","'$_date'","sql_quote($_dateref)") ), array("'AND'", array("'!='", "'horaire'", "sql_quote('oui')"), $where_futur_sans_heure ) ); } else { $where = $where_futur_sans_heure; } $boucle->where[] = $where; } /** * {evenement_passe} * {evenement_passe #ENV{date}} * * @param string $idb * @param object $boucles * @param object $crit */ function critere_evenement_passe_dist($idb, &$boucles, $crit) { $boucle = &$boucles[$idb]; $id_table = $boucle->id_table; $_dateref = agenda_calculer_date_reference($idb, $boucles, $crit); $_date = "$id_table.date_fin"; $op = $crit->not ? ">=":"<"; // si on ne sait pas si les heures comptent, on utilise toute la journee. // sinon, on s'appuie sur le champ 'horaire=oui' // pour savoir si les dates utilisent les heures ou pas. $where_passe_sans_heure = array("'$op'", "'$_date'", "sql_quote(date('Y-m-d 00:00:00', strtotime($_dateref)))"); if (array_key_exists('horaire', $boucle->show['field'])) { $where = array("'OR'", array("'AND'", array("'='", "'horaire'", "sql_quote('oui')"), array("'$op'","'$_date'","sql_quote($_dateref)") ), array("'AND'", array("'!='", "'horaire'", "sql_quote('oui')"), $where_passe_sans_heure ) ); } else { $where = $where_passe_sans_heure; } $boucle->where[] = $where; } /** * {evenement_en_cours} * {evenement_en_cours #ENV{date}} * * @param string $idb * @param object $boucles * @param object $crit */ function critere_evenement_en_cours_dist($idb, &$boucles, $crit) { $boucle = &$boucles[$idb]; $id_table = $boucle->id_table; $_dateref = agenda_calculer_date_reference($idb, $boucles, $crit); $_date_debut = "$id_table.date_debut"; $_date_fin = "$id_table.date_fin"; // si on ne sait pas si les heures comptent, on utilise toute la journee. // sinon, on s'appuie sur le champ 'horaire=oui' // pour savoir si les dates utilisent les heures ou pas. $where_jour_sans_heure = array("'AND'", array("'<='", "'$_date_debut'", "sql_quote(date('Y-m-d 23:59:59', strtotime($_dateref)))"), array("'>='", "'$_date_fin'", "sql_quote(date('Y-m-d 00:00:00', strtotime($_dateref)))") ); if (array_key_exists('horaire', $boucle->show['field'])) { $where = array("'OR'", array("'AND'", array("'='", "'horaire'", "sql_quote('oui')"), array("'AND'", array("'<='", "'$_date_debut'", "sql_quote($_dateref)"), array("'>='", "'$_date_fin'", "sql_quote($_dateref)") ) ), array("'AND'", array("'!='", "'horaire'", "sql_quote('oui')"), $where_jour_sans_heure ) ); } else { $where = $where_jour_sans_heure; } if ($crit->not) $where = array("'NOT'",$where); $boucle->where[] = $where; } /** * {evenementrelatif #ENV{choix}} * {evenementrelatif #ENV{choix}, #ENV{date}} * #ENV{choix} peut prendre 6 valeurs : tout, a_venir, en_cours, passe, en_cours_a_venir ou passe_en_cours * * @param string $idb * @param object $boucles * @param object $crit */ function critere_evenementrelatif_dist($idb, &$boucles, $crit) { $boucle = &$boucles[$idb]; $id_table = $boucle->id_table; if (isset($crit->param[1])) $_dateref = calculer_liste($crit->param[1], array(), $boucles, $boucles[$idb]->id_parent); else $_dateref = "date('Y-m-d H:i:00')"; $not = $crit->not ? 'oui' : ''; $choix = isset($crit->param[0]) ? calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent) : "''"; $horaire = array_key_exists('horaire', $boucle->show['field']) ? 'oui' : ''; $boucle->where[] = "agenda_calculer_critere_evenementrelatif('$id_table',$_dateref,'$not',$choix,'$horaire')"; } /** * Fonction interne utilisee par le critere {evenementrelatif} * @param string $id_table * @param string $_dateref * @param string $not * @param string $choix * @param string $horaire * @return array */ function agenda_calculer_critere_evenementrelatif($id_table,$_dateref,$not,$choix,$horaire){ $_date_debut = "$id_table.date_debut"; $_date_fin = "$id_table.date_fin"; if ($choix == 'en_cours_a_venir') { $choix = 'passe'; $not = ($not) ? '' : 'oui'; } if ($choix == 'passe_en_cours') { $choix = 'a_venir'; $not = ($not) ? '' : 'oui'; } switch($choix) { case 'a_venir': $op_a_venir = $not ? "<=":">"; $where_a_venir_sans_heure = array($op_a_venir, $_date_debut, sql_quote(date('Y-m-d 23:59:59', strtotime($_dateref)))); if ($horaire) { $where = array('OR', array('AND', array('=', 'horaire', sql_quote('oui')), array($op_a_venir,$_date_debut,sql_quote($_dateref)) ), array('AND', array('!=', 'horaire', sql_quote('oui')), $where_a_venir_sans_heure ) ); } else { $where = $where_a_venir_sans_heure; } return $where; break; case 'passe': $op_passe = $not ? ">=":"<"; $where_passe_sans_heure = array($op_passe, $_date_fin, sql_quote(date('Y-m-d 00:00:00', strtotime($_dateref)))); if ($horaire) { $where = array('OR', array('AND', array('=', 'horaire', sql_quote('oui')), array($op_passe,$_date_fin,sql_quote($_dateref)) ), array('AND', array('!=', 'horaire', sql_quote('oui')), $where_passe_sans_heure ) ); } else { $where = $where_passe_sans_heure; } return $where; break; case 'en_cours': $where_en_cours_sans_heure = array('AND', array('<=', $_date_debut, sql_quote(date('Y-m-d 23:59:59', strtotime($_dateref)))), array('>=', $_date_fin, sql_quote(date('Y-m-d 00:00:00', strtotime($_dateref)))) ); if ($horaire) { $where = array('OR', array('AND', array('=', 'horaire', sql_quote('oui')), array('AND', array('<=', $_date_debut, sql_quote($_dateref)), array('>=', $_date_fin, sql_quote($_dateref)) ) ), array('AND', array('!=', 'horaire', sql_quote('oui')), $where_en_cours_sans_heure ) ); } else { $where = $where_en_cours_sans_heure; } return ($not) ? array('NOT' , $where) : $where; break; default: return array(); break; } } /** * Fonction privee pour mutualiser de code des criteres_evenement_* * Retourne le code php pour obtenir la date de reference de comparaison * des evenements a trouver * * @param string $idb * @param object $boucles * @param object $crit * * @return string code PHP concernant la date. **/ function agenda_calculer_date_reference($idb, &$boucles, $crit) { if (isset($crit->param[0])) return calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent); else return "date('Y-m-d H:i:00')"; } /** * Balise #NB_INSCRITS * pour afficher le nombre d'inscrits (qui ont repondu oui) a un evenement * * @param Object $p * @return object */ function balise_NB_INSCRITS_dist($p) { $id_evenement = champ_sql('id_evenement', $p); $p->code = "sql_countsel('spip_evenements_participants','id_evenement='.intval($id_evenement).' AND reponse=\'oui\'')"; return $p; } ?>