You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

330 lines
9.3 KiB

  1. <?php
  2. /***************************************************************************\
  3. * SPIP, Systeme de publication pour l'internet *
  4. * *
  5. * Copyright (c) 2001-2020 *
  6. * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
  7. * *
  8. * Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
  9. * Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
  10. \***************************************************************************/
  11. /**
  12. * Utilisations de pipelines
  13. *
  14. * @package SPIP\Breves\Pipelines
  15. **/
  16. if (!defined("_ECRIRE_INC_VERSION")) {
  17. return;
  18. }
  19. /**
  20. * Définir les meta de configuration liées aux brèves
  21. *
  22. * @pipeline configurer_liste_metas
  23. * @param array $metas
  24. * Couples nom de la méta => valeur par défaut
  25. * @return array
  26. * Couples nom de la méta => valeur par défaut
  27. */
  28. function breves_configurer_liste_metas($metas) {
  29. $metas['activer_breves'] = 'non';
  30. return $metas;
  31. }
  32. /**
  33. * Ajouter les brèves à valider sur les rubriques
  34. *
  35. * @pipeline rubrique_encours
  36. *
  37. * @param array $flux Données du pipeline
  38. * @return array Données du pipeline
  39. **/
  40. function breves_rubrique_encours($flux) {
  41. if ($flux['args']['type'] == 'rubrique') {
  42. $lister_objets = charger_fonction('lister_objets', 'inc');
  43. $id_rubrique = $flux['args']['id_objet'];
  44. //
  45. // Les breves a valider
  46. //
  47. $flux['data'] .= $lister_objets('breves', array(
  48. 'titre' => _T('breves:info_breves_valider'),
  49. 'statut' => array('prepa', 'prop'),
  50. 'id_rubrique' => $id_rubrique,
  51. 'par' => 'date_heure'
  52. ));
  53. }
  54. return $flux;
  55. }
  56. /**
  57. * Ajouter les brèves référencées sur les vues de rubriques
  58. *
  59. * @pipeline affiche_enfants
  60. *
  61. * @param array $flux Données du pipeline
  62. * @return array Données du pipeline
  63. **/
  64. function breves_affiche_enfants($flux) {
  65. if (isset($flux['args']['exec'])
  66. and $e = trouver_objet_exec($flux['args']['exec'])
  67. and $e['type'] == 'rubrique'
  68. and $e['edition'] == false
  69. ) {
  70. $id_rubrique = $flux['args']['id_rubrique'];
  71. if ($GLOBALS['meta']["activer_breves"] == 'oui') {
  72. $lister_objets = charger_fonction('lister_objets', 'inc');
  73. $bouton_breves = '';
  74. $id_parent = sql_getfetsel('id_parent', 'spip_rubriques', 'id_rubrique=' . $id_rubrique);
  75. if (autoriser('creerbrevedans', 'rubrique', $id_rubrique, null, array('id_parent' => $id_parent))) {
  76. $bouton_breves .= icone_verticale(_T('breves:icone_nouvelle_breve'),
  77. generer_url_ecrire("breve_edit", "id_rubrique=$id_rubrique&new=oui"), "breve-24.png", "new", 'right')
  78. . "<br class='nettoyeur' />";
  79. }
  80. $flux['data'] .= $lister_objets('breves', array(
  81. 'titre' => _T('breves:icone_ecrire_nouvel_article'),
  82. 'where' => "statut != 'prop' AND statut != 'prepa'",
  83. 'id_rubrique' => $id_rubrique,
  84. 'par' => 'date_heure'
  85. ));
  86. $flux['data'] .= $bouton_breves;
  87. }
  88. }
  89. return $flux;
  90. }
  91. /**
  92. * Ajoute le nombre de brèves sur l'accueil privé
  93. *
  94. * @pipeline accueil_informations
  95. *
  96. * @param string $texte
  97. * HTML des informations générales concernant chaque type d'objet
  98. * sur la page d'accueil privée
  99. * @return string
  100. * HTML des informations générales concernant chaque type d'objet
  101. * sur la page d'accueil privée
  102. */
  103. function breves_accueil_informations($texte) {
  104. include_spip('base/abstract_sql');
  105. $q = sql_select("COUNT(*) AS cnt, statut", 'spip_breves', '', 'statut', '', '', "COUNT(*)<>0");
  106. $cpt = array();
  107. $cpt2 = array();
  108. $where = false;
  109. if ($GLOBALS['visiteur_session']['statut'] == '0minirezo') {
  110. $where = sql_allfetsel('id_objet', 'spip_auteurs_liens',
  111. "objet='rubrique' AND id_auteur=" . intval($GLOBALS['visiteur_session']['id_auteur']));
  112. if ($where) {
  113. $where = sql_in('id_rubrique', array_map('reset', $where));
  114. }
  115. }
  116. $defaut = $where ? '0/' : '';
  117. while ($row = sql_fetch($q)) {
  118. $cpt[$row['statut']] = $row['cnt'];
  119. $cpt2[$row['statut']] = $defaut;
  120. }
  121. if ($cpt) {
  122. if ($where) {
  123. $q = sql_select("COUNT(*) AS cnt, statut", 'spip_breves', $where, "statut");
  124. while ($row = sql_fetch($q)) {
  125. $r = $row['statut'];
  126. $cpt2[$r] = intval($row['cnt']) . '/';
  127. }
  128. }
  129. $texte .= "<div class='accueil_informations breves liste'>";
  130. $texte .= "<h4>" . afficher_plus_info(generer_url_ecrire("breves"), "", _T('breves:info_breves_02')) . "</h4>";
  131. $texte .= "<ul class='liste-items'>";
  132. if (isset($cpt['prop'])) {
  133. $texte .= "<li class='item'>" . _T("texte_statut_attente_validation") . ": " . $cpt2['prop'] . $cpt['prop'] . '</li>';
  134. }
  135. if (isset($cpt['publie'])) {
  136. $texte .= "<li class='item on'>" . _T("texte_statut_publies") . ": " . $cpt2['publie'] . $cpt['publie'] . '</li>';
  137. }
  138. $texte .= "</ul>";
  139. $texte .= "</div>";
  140. }
  141. return $texte;
  142. }
  143. /**
  144. * Compter les brèves dans une rubrique
  145. *
  146. * @pipeline objet_compte_enfants
  147. *
  148. * @param array $flux Données du pipeline
  149. * @return array Données du pipeline
  150. */
  151. function breves_objet_compte_enfants($flux) {
  152. if ($flux['args']['objet'] == 'rubrique'
  153. and $id_rubrique = intval($flux['args']['id_objet'])
  154. ) {
  155. // juste les publies ?
  156. if (array_key_exists('statut', $flux['args']) and ($flux['args']['statut'] == 'publie')) {
  157. $flux['data']['breve'] = sql_countsel('spip_breves',
  158. "id_rubrique=" . intval($id_rubrique) . " AND (statut='publie')");
  159. } else {
  160. $flux['data']['breve'] = sql_countsel('spip_breves',
  161. "id_rubrique=" . intval($id_rubrique) . " AND (statut='publie' OR statut='prop')");
  162. }
  163. }
  164. return $flux;
  165. }
  166. /**
  167. * Changer la langue des brèves si la rubrique change
  168. *
  169. * @pipeline trig_calculer_langues_rubriques
  170. *
  171. * @param array $flux Données du pipeline
  172. * @return array Données du pipeline
  173. */
  174. function breves_trig_calculer_langues_rubriques($flux) {
  175. $s = sql_select("A.id_breve AS id_breve, R.lang AS lang", "spip_breves AS A, spip_rubriques AS R",
  176. "A.id_rubrique = R.id_rubrique AND A.langue_choisie != 'oui' AND (A.lang='' OR R.lang<>'') AND R.lang<>A.lang");
  177. while ($row = sql_fetch($s)) {
  178. $id_breve = $row['id_breve'];
  179. sql_updateq('spip_breves', array("lang" => $row['lang'], 'langue_choisie' => 'non'), "id_breve=$id_breve");
  180. }
  181. return $flux;
  182. }
  183. /**
  184. * Publier et dater les rubriques qui ont une brève publiée
  185. *
  186. * @pipeline calculer_rubriques
  187. *
  188. * @param array $flux Données du pipeline
  189. * @return array Données du pipeline
  190. */
  191. function breves_calculer_rubriques($flux) {
  192. $r = sql_select(
  193. "R.id_rubrique AS id, max(A.date_heure) AS date_h",
  194. "spip_rubriques AS R JOIN spip_breves AS A ON R.id_rubrique = A.id_rubrique",
  195. "A.date_heure>R.date_tmp AND A.statut='publie' ", "R.id_rubrique");
  196. while ($row = sql_fetch($r)) {
  197. sql_updateq('spip_rubriques', array('statut_tmp' => 'publie', 'date_tmp' => $row['date_h']),
  198. "id_rubrique=" . $row['id']);
  199. }
  200. return $flux;
  201. }
  202. /**
  203. * Ajouter les brèves à valider sur la page d'accueil
  204. *
  205. * @pipeline accueil_encours
  206. *
  207. * @param string $flux HTML du bloc encours sur la page d'accueil privée
  208. * @return string HTML du bloc encours sur la page d'accueil privée
  209. **/
  210. function breves_accueil_encours($flux) {
  211. $lister_objets = charger_fonction('lister_objets', 'inc');
  212. $flux .= $lister_objets('breves', array(
  213. 'titre' => afficher_plus_info(generer_url_ecrire('breves')) . _T('breves:info_breves_valider'),
  214. 'statut' => array('prepa', 'prop'),
  215. 'par' => 'date_heure'
  216. ));
  217. return $flux;
  218. }
  219. /**
  220. * Optimiser la base de données en supprimant les liens de brèves orphelins
  221. *
  222. * @pipeline optimiser_base_disparus
  223. *
  224. * @param array $flux Données du pipeline
  225. * @return array Données du pipeline
  226. */
  227. function breves_optimiser_base_disparus($flux) {
  228. $n = &$flux['data'];
  229. $mydate = $flux['args']['date'];
  230. # les breves qui sont dans une id_rubrique inexistante
  231. $res = sql_select("B.id_breve AS id",
  232. "spip_breves AS B
  233. LEFT JOIN spip_rubriques AS R
  234. ON B.id_rubrique=R.id_rubrique",
  235. "R.id_rubrique IS NULL
  236. AND B.maj < " . sql_quote($mydate));
  237. $n += optimiser_sansref('spip_breves', 'id_breve', $res);
  238. //
  239. // Breves
  240. //
  241. sql_delete("spip_breves", "statut='refuse' AND maj < $mydate");
  242. return $flux;
  243. }
  244. /**
  245. * Afficher le nombre de brèves dans chaque rubrique
  246. *
  247. * @pipeline boite_infos
  248. *
  249. * @param array $flux Données du pipeline
  250. * @return array Données du pipeline
  251. */
  252. function breves_boite_infos($flux) {
  253. if (
  254. isset($flux['args']['type']) and $flux['args']['type'] == 'rubrique'
  255. and isset($flux['args']['id']) and $id_rubrique = $flux['args']['id']
  256. ) {
  257. if ($nb = sql_countsel('spip_breves', "statut='publie' AND id_rubrique=" . intval($id_rubrique))) {
  258. $nb = "<div>" . singulier_ou_pluriel($nb, "breves:info_1_breve", "breves:info_nb_breves") . "</div>";
  259. if ($p = strpos($flux['data'], "<!--nb_elements-->")) {
  260. $flux['data'] = substr_replace($flux['data'], $nb, $p, 0);
  261. }
  262. }
  263. }
  264. return $flux;
  265. }
  266. /**
  267. * Ajoute le formulaire de configuration des brèves sur la page de
  268. * configuration des contenus
  269. *
  270. * @pipeline affiche_milieu
  271. *
  272. * @param array $flux Données du pipeline
  273. * @return array Données du pipeline
  274. */
  275. function breves_affiche_milieu($flux) {
  276. if ($flux["args"]["exec"] == "configurer_contenu") {
  277. $flux["data"] .= recuperer_fond('prive/squelettes/inclure/configurer', array('configurer' => 'configurer_breves'));
  278. }
  279. return $flux;
  280. }