= $avant AND date_heure < $apres", '', 'date_heure' ); while ($row = sql_fetch($result)) { $amj = date_anneemoisjour($row['date_heure']); $id = $row['id_forum']; if (autoriser('voir', 'forum', $id)) { $evenements[$amj][] = array( 'URL' => generer_url_entite($id, 'forum'), 'CATEGORIES' => 'calendrier-couleur7', 'SUMMARY' => $row['titre'], 'DTSTART' => date_ical($row['date_heure']) ); } } } /** * Retourne la liste des articles (format ICS) publiés dans une période donnée * * @param string $avant * Date de début * @param string $apres * Date de fin * @param array $evenements * Tableau des événements déjà présents qui sera complété par la fonction. * Format : `$evenements[$amj][] = Tableau de description ICS` **/ function quete_calendrier_interval_articles($avant, $apres, &$evenements) { $result = sql_select( 'id_article, titre, date, descriptif, chapo, lang', 'spip_articles', "statut='publie' AND date >= $avant AND date < $apres", '', 'date' ); // tables traduites $objets = explode(',', $GLOBALS['meta']['multi_objets']); if (in_array('spip_articles', $objets)) { include_spip('inc/lang_liste'); $langues = $GLOBALS['codes_langues']; } else { $langues = array(); } while ($row = sql_fetch($result)) { $amj = date_anneemoisjour($row['date']); $id = $row['id_article']; if (autoriser('voir', 'article', $id)) { $langue = isset($langues[$row['lang']]) ? $langues[$row['lang']] : ""; $evenements[$amj][] = array( 'CATEGORIES' => calendrier_categories('spip_articles', $id, 'id_article'), 'DESCRIPTION' => $row['descriptif'] ?: $langue, 'SUMMARY' => $row['titre'], 'URL' => generer_url_ecrire_objet('article', $id, '', '', 'prop') ); } } } /** * Retourne la liste des rubriques (format ICS) publiées dans une période donnée * * @param string $avant * Date de début * @param string $apres * Date de fin * @param array $evenements * Tableau des événements déjà présents qui sera complété par la fonction. * Format : `$evenements[$amj][] = Tableau de description ICS` **/ function quete_calendrier_interval_rubriques($avant, $apres, &$evenements) { $result = sql_select( 'DISTINCT R.id_rubrique, titre, descriptif, date', 'spip_rubriques AS R, spip_documents_liens AS L', "statut='publie' AND date >= $avant AND date < $apres AND R.id_rubrique = L.id_objet AND L.objet='rubrique'", '', 'date' ); while ($row = sql_fetch($result)) { $amj = date_anneemoisjour($row['date']); $id = $row['id_rubrique']; if (autoriser('voir', 'rubrique', $id)) { $evenements[$amj][] = array( 'CATEGORIES' => calendrier_categories('spip_rubriques', $id, 'id_rubrique'), 'DESCRIPTION' => $row['descriptif'], 'SUMMARY' => $row['titre'], 'URL' => generer_url_ecrire_objet('rubrique', $id, '', '', 'prop') ); } } } /** * Retourne la liste des brèves (format ICS) publiées dans une période donnée * * @param string $avant * Date de début * @param string $apres * Date de fin * @param array $evenements * Tableau des événements déjà présents qui sera complété par la fonction. * Format : `$evenements[$amj][] = Tableau de description ICS` **/ function quete_calendrier_interval_breves($avant, $apres, &$evenements) { $result = sql_select( 'id_breve, titre, date_heure, id_rubrique', 'spip_breves', "statut='publie' AND date_heure >= $avant AND date_heure < $apres", '', 'date_heure' ); while ($row = sql_fetch($result)) { $amj = date_anneemoisjour($row['date_heure']); $id = $row['id_breve']; $ir = $row['id_rubrique']; if (autoriser('voir', 'breve', $id)) { $evenements[$amj][] = array( 'URL' => generer_url_ecrire_objet('breve', $id, '', '', 'prop'), 'CATEGORIES' => calendrier_categories('spip_breves', $ir, 'id_breve'), 'SUMMARY' => $row['titre'] ); } } } /** * Retourne la liste des messages (format ICS) de l'auteur connecté, * pour une période donnée * * @param string $avant * Date de début * @param string $apres * Date de fin * @return array * De la forme : `$evt[date][id_message] = Tableau des données ICS` **/ function quete_calendrier_interval_rv($avant, $apres) { include_spip('inc/session'); $connect_id_auteur = session_get('id_auteur'); $auteurs = array(); $evenements = array(); if (!$connect_id_auteur) { return $evenements; } $result = sql_select( 'M.id_message, M.titre, M.texte, M.date_heure, M.date_fin, M.type', 'spip_messages AS M LEFT JOIN spip_auteurs_liens AS L ON (L.id_objet=M.id_message)', "((L.objet='message' AND (L.id_auteur=$connect_id_auteur OR M.type='affich')) OR (L.objet IS NULL AND M.id_auteur=$connect_id_auteur AND " . sql_in( 'M.type', array('pb', 'affich') ) . '))' . " AND M.rv='oui' AND ((M.date_fin >= $avant OR M.date_heure >= $avant) AND M.date_heure <= $apres) AND M.statut='publie'", 'M.id_message', 'M.date_heure' ); while ($row = sql_fetch($result)) { $date_heure = $row['date_heure']; $date_fin = $row['date_fin']; $type = $row['type']; $id_message = $row['id_message']; if ($type == 'pb') { $cat = 'calendrier-couleur2'; } else { if ($type == 'affich') { $cat = 'calendrier-couleur4'; } else { if ($type != 'normal') { $cat = 'calendrier-couleur12'; } else { $cat = 'calendrier-couleur9'; $auteurs = array_map( 'array_shift', sql_allfetsel( 'nom', 'spip_auteurs AS A LEFT JOIN spip_auteurs_liens AS L ON L.id_auteur=A.id_auteur', "(L.objet='message' AND L.id_objet=$id_message AND (A.id_auteur!=$connect_id_auteur))" ) ); } } } $jour_avant = substr($avant, 9, 2); $mois_avant = substr($avant, 6, 2); $annee_avant = substr($avant, 1, 4); $jour_apres = substr($apres, 9, 2); $mois_apres = substr($apres, 6, 2); $annee_apres = substr($apres, 1, 4); $ical_apres = date_anneemoisjour("$annee_apres-$mois_apres-" . sprintf('%02d', $jour_apres)); // Calcul pour les semaines a cheval sur deux mois $j = 0; $amj = date_anneemoisjour("$annee_avant-$mois_avant-" . sprintf('%02d', $j + ($jour_avant))); while ($amj <= $ical_apres) { if (!($amj == date_anneemoisjour($date_fin) and preg_match( ',00:00:00,', $date_fin ))) { // Ne pas prendre la fin a minuit sur jour precedent $evenements[$amj][$id_message] = array( 'URL' => generer_url_ecrire('message', "id_message=$id_message"), 'DTSTART' => date_ical($date_heure), 'DTEND' => date_ical($date_fin), 'DESCRIPTION' => $row['texte'], 'SUMMARY' => $row['titre'], 'CATEGORIES' => $cat, 'ATTENDEE' => (count($auteurs) == 0) ? '' : join($auteurs, ', ') ); } $j++; $ladate = date('Y-m-d', mktime(1, 1, 1, $mois_avant, ($j + $jour_avant), $annee_avant)); $amj = date_anneemoisjour($ladate); } } return $evenements; } /** * Retourne la liste des rendez-vous de l'auteur connecté pour le mois indiqué * * @param int $annee * @param int $mois * @return array **/ function quete_calendrier_agenda($annee, $mois) { include_spip('inc/session'); $connect_id_auteur = session_get('id_auteur'); $rv = array(); if (!$connect_id_auteur) { return $rv; } $date = date('Y-m-d', mktime(0, 0, 0, $mois, 1, $annee)); $mois = mois($date); $annee = annee($date); // rendez-vous personnels dans le mois $result_messages = sql_select( 'M.titre AS summary, M.texte AS description, M.id_message AS uid, M.date_heure', 'spip_messages AS M, spip_auteurs_liens AS L', "((L.id_auteur=$connect_id_auteur AND L.id_objet=M.id_message AND L.objet='message') OR M.type='affich') AND M.rv='oui' AND M.date_heure >='$annee-$mois-1' AND date_heure < DATE_ADD('$annee-$mois-1', INTERVAL 1 MONTH) AND M.statut='publie'" ); while ($row = sql_fetch($result_messages)) { $rv[journum($row['date_heure'])] = $row; } return $rv; }