Browse Source

PSR

svn/root/tags/plugins/breves/1.4.0
kent1@arscenic.info 6 years ago
parent
commit
92d4f1ceb9
  1. 50
      action/editer_breve.php
  2. 30
      base/breves.php
  3. 6
      breves_administrations.php
  4. 15
      breves_autoriser.php
  5. 2
      breves_ieconfig.php
  6. 104
      breves_pipelines.php
  7. 11
      formulaires/configurer_breves.php
  8. 33
      formulaires/editer_breve.php

50
action/editer_breve.php

@ -15,7 +15,7 @@
*
* @package SPIP\Breves\Actions
*/
if (!defined("_ECRIRE_INC_VERSION")) {
if (!defined('_ECRIRE_INC_VERSION')) {
return;
}
@ -73,11 +73,11 @@ function breve_inserer($id_rubrique, $set = null) {
// Si id_rubrique vaut 0 ou n'est pas definie, creer la breve
// dans la premiere rubrique racine
if (!$id_rubrique = intval($id_rubrique)) {
$id_rubrique = sql_getfetsel("id_rubrique", "spip_rubriques", "id_parent=0", '', '0+titre,titre', "1");
$id_rubrique = sql_getfetsel('id_rubrique', 'spip_rubriques', 'id_parent=0', '', '0+titre,titre', '1');
}
// La langue a la creation : c'est la langue de la rubrique
$row = sql_fetsel("lang, id_secteur", "spip_rubriques", "id_rubrique=$id_rubrique");
$row = sql_fetsel('lang, id_secteur', 'spip_rubriques', 'id_rubrique='.intval($id_rubrique));
$lang = $row['lang'];
$id_rubrique = $row['id_secteur']; // garantir la racine
@ -94,7 +94,8 @@ function breve_inserer($id_rubrique, $set = null) {
}
// Envoyer aux plugins
$champs = pipeline('pre_insertion',
$champs = pipeline(
'pre_insertion',
array(
'args' => array(
'table' => 'spip_breves',
@ -102,8 +103,9 @@ function breve_inserer($id_rubrique, $set = null) {
'data' => $champs
)
);
$id_breve = sql_insertq("spip_breves", $champs);
pipeline('post_insertion',
$id_breve = sql_insertq('spip_breves', $champs);
pipeline(
'post_insertion',
array(
'args' => array(
'table' => 'spip_breves',
@ -135,7 +137,7 @@ function breve_modifier($id_breve, $set = null) {
include_spip('inc/modifier');
$c = collecter_requests(
// white list
// white list
array('titre', 'texte', 'lien_titre', 'lien_url'),
// black list
array('id_parent', 'statut'),
@ -147,21 +149,23 @@ function breve_modifier($id_breve, $set = null) {
$indexation = false;
// Si la breve est publiee, invalider les caches et demander sa reindexation
$t = sql_getfetsel("statut", "spip_breves", "id_breve=$id_breve");
$t = sql_getfetsel('statut', 'spip_breves', 'id_breve='.intval($id_breve));
if ($t == 'publie') {
$invalideur = "id='breve/$id_breve'";
$indexation = true;
}
if ($err = objet_modifier_champs('breve', $id_breve,
if ($err = objet_modifier_champs(
'breve',
$id_breve,
array(
'data' => $set,
'nonvide' => array('titre' => _T('breves:titre_nouvelle_breve') . " " . _T('info_numero_abbreviation') . $id_breve),
'nonvide' => array('titre' => _T('breves:titre_nouvelle_breve') . ' ' . _T('info_numero_abbreviation') . $id_breve),
'invalideur' => $invalideur,
'indexation' => $indexation
),
$c)
) {
$c
)) {
return $err;
}
@ -189,7 +193,7 @@ function breve_instituer($id_breve, $c) {
$champs = array();
// Changer le statut de la breve ?
$row = sql_fetsel("statut, id_rubrique,lang, langue_choisie", "spip_breves", "id_breve=" . intval($id_breve));
$row = sql_fetsel('statut, id_rubrique,lang, langue_choisie', 'spip_breves', 'id_breve=' . intval($id_breve));
$id_rubrique = $row['id_rubrique'];
$statut_ancien = $statut = $row['statut'];
@ -209,12 +213,14 @@ function breve_instituer($id_breve, $c) {
// de la rubrique actuelle
if ($id_parent = intval($c['id_parent'])
and $id_parent != $id_rubrique
and (null !== ($lang = sql_getfetsel('lang', 'spip_rubriques',
"id_parent=0 AND id_rubrique=" . intval($id_parent))))
) {
and (null !== ($lang = sql_getfetsel(
'lang',
'spip_rubriques',
'id_parent=0 AND id_rubrique=' . intval($id_parent)
)))) {
$champs['id_rubrique'] = $id_parent;
// - changer sa langue (si heritee)
if ($langue_choisie_old != "oui") {
if ($langue_choisie_old != 'oui') {
if ($lang != $langue_old) {
$champs['lang'] = $lang;
}
@ -230,7 +236,8 @@ function breve_instituer($id_breve, $c) {
}
// Envoyer aux plugins
$champs = pipeline('pre_edition',
$champs = pipeline(
'pre_edition',
array(
'args' => array(
'table' => 'spip_breves',
@ -246,7 +253,7 @@ function breve_instituer($id_breve, $c) {
return;
}
sql_updateq('spip_breves', $champs, "id_breve=" . intval($id_breve));
sql_updateq('spip_breves', $champs, 'id_breve=' . intval($id_breve));
//
// Post-modifications
@ -256,12 +263,13 @@ function breve_instituer($id_breve, $c) {
include_spip('inc/invalideur');
suivre_invalideur("id='breve/$id_breve'");
// Au besoin, changer le statut des rubriques concernees
// Au besoin, changer le statut des rubriques concernees
include_spip('inc/rubriques');
calculer_rubriques_if($id_rubrique, $champs, $statut_ancien);
// Pipeline
pipeline('post_edition',
pipeline(
'post_edition',
array(
'args' => array(
'table' => 'spip_breves',

30
base/breves.php

@ -69,25 +69,25 @@ function breves_declarer_tables_objets_sql($tables) {
'principale' => 'oui',
'introduction_longueur' => '300',
'field' => array(
"id_breve" => "bigint(21) NOT NULL",
"date_heure" => "datetime DEFAULT '0000-00-00 00:00:00' NOT NULL",
"titre" => "text DEFAULT '' NOT NULL",
"texte" => "longtext DEFAULT '' NOT NULL",
"lien_titre" => "text DEFAULT '' NOT NULL",
"lien_url" => "text DEFAULT '' NOT NULL",
"statut" => "varchar(6) DEFAULT '0' NOT NULL",
"id_rubrique" => "bigint(21) DEFAULT '0' NOT NULL",
"lang" => "VARCHAR(10) DEFAULT '' NOT NULL",
"langue_choisie" => "VARCHAR(3) DEFAULT 'non'",
"maj" => "TIMESTAMP"
'id_breve' => 'bigint(21) NOT NULL',
'date_heure' => "datetime DEFAULT '0000-00-00 00:00:00' NOT NULL",
'titre' => "text DEFAULT '' NOT NULL",
'texte' => "longtext DEFAULT '' NOT NULL",
'lien_titre' => "text DEFAULT '' NOT NULL",
'lien_url' => "text DEFAULT '' NOT NULL",
'statut' => "varchar(6) DEFAULT '0' NOT NULL",
'id_rubrique' => "bigint(21) DEFAULT '0' NOT NULL",
'lang' => "VARCHAR(10) DEFAULT '' NOT NULL",
'langue_choisie' => "VARCHAR(3) DEFAULT 'non'",
'maj' => 'TIMESTAMP'
),
'key' => array(
"PRIMARY KEY" => "id_breve",
"KEY id_rubrique" => "id_rubrique",
'PRIMARY KEY' => 'id_breve',
'KEY id_rubrique' => 'id_rubrique',
),
'join' => array(
"id_breve" => "id_breve",
"id_rubrique" => "id_rubrique"
'id_breve' => 'id_breve',
'id_rubrique' => 'id_rubrique'
),
'statut' => array(
array(

6
breves_administrations.php

@ -63,9 +63,7 @@ function breves_upgrade($nom_meta_base_version, $version_cible) {
* Nom de la meta informant de la version du schéma de données du plugin installé dans SPIP
**/
function breves_vider_tables($nom_meta_base_version) {
sql_drop_table("spip_breves");
effacer_meta("activer_breves");
sql_drop_table('spip_breves');
effacer_meta('activer_breves');
effacer_meta($nom_meta_base_version);
}

15
breves_autoriser.php

@ -24,7 +24,8 @@ if (!defined('_ECRIRE_INC_VERSION')) {
*
* @pipeline autoriser
*/
function breves_autoriser() { }
function breves_autoriser() {
}
/**
@ -38,7 +39,7 @@ function breves_autoriser() { }
* @return bool true s'il a le droit, false sinon
*/
function autoriser_breves_menu_dist($faire, $type = '', $id = 0, $qui = null, $opt = null) {
return ($GLOBALS['meta']["activer_breves"] != "non");
return ($GLOBALS['meta']['activer_breves'] != 'non');
}
/**
@ -52,7 +53,7 @@ function autoriser_breves_menu_dist($faire, $type = '', $id = 0, $qui = null, $o
* @return bool true s'il a le droit, false sinon
*/
function autoriser_brevecreer_menu_dist($faire, $type, $id, $qui, $opt) {
return ($GLOBALS['meta']["activer_breves"] != "non")
return ($GLOBALS['meta']['activer_breves'] != 'non')
and verifier_table_non_vide();
}
@ -70,7 +71,7 @@ function autoriser_brevecreer_menu_dist($faire, $type, $id, $qui, $opt) {
**/
function autoriser_breve_creer_dist($faire, $type, $id, $qui, $opt) {
return
($GLOBALS['meta']["activer_breves"] != "non")
($GLOBALS['meta']['activer_breves'] != 'non')
and (sql_countsel('spip_rubriques') > 0);
}
@ -85,12 +86,12 @@ function autoriser_breve_creer_dist($faire, $type, $id, $qui, $opt) {
* @return bool true s'il a le droit, false sinon
*/
function autoriser_rubrique_creerbrevedans_dist($faire, $type, $id, $qui, $opt) {
$r = sql_fetsel("id_parent", "spip_rubriques", "id_rubrique=" . intval($id));
$r = sql_fetsel('id_parent', 'spip_rubriques', 'id_rubrique=' . intval($id));
return
$id
and ($r['id_parent'] == 0)
and ($GLOBALS['meta']["activer_breves"] != "non")
and ($GLOBALS['meta']['activer_breves'] != 'non')
and autoriser('voir', 'rubrique', $id);
}
@ -109,7 +110,7 @@ function autoriser_rubrique_creerbrevedans_dist($faire, $type, $id, $qui, $opt)
* @return bool true s'il a le droit, false sinon
*/
function autoriser_breve_modifier_dist($faire, $type, $id, $qui, $opt) {
$r = sql_fetsel("id_rubrique,statut", "spip_breves", "id_breve=" . intval($id));
$r = sql_fetsel('id_rubrique,statut', 'spip_breves', 'id_breve=' . intval($id));
return
$r and (

2
breves_ieconfig.php

@ -6,7 +6,7 @@
* @package SPIP\Breves\Pipelines
**/
if (!defined("_ECRIRE_INC_VERSION")) {
if (!defined('_ECRIRE_INC_VERSION')) {
return;
}

104
breves_pipelines.php

@ -15,7 +15,7 @@
*
* @package SPIP\Breves\Pipelines
**/
if (!defined("_ECRIRE_INC_VERSION")) {
if (!defined('_ECRIRE_INC_VERSION')) {
return;
}
@ -80,13 +80,18 @@ function breves_affiche_enfants($flux) {
) {
$id_rubrique = $flux['args']['id_rubrique'];
if ($GLOBALS['meta']["activer_breves"] == 'oui') {
if ($GLOBALS['meta']['activer_breves'] == 'oui') {
$lister_objets = charger_fonction('lister_objets', 'inc');
$bouton_breves = '';
$id_parent = sql_getfetsel('id_parent', 'spip_rubriques', 'id_rubrique=' . $id_rubrique);
if (autoriser('creerbrevedans', 'rubrique', $id_rubrique, null, array('id_parent' => $id_parent))) {
$bouton_breves .= icone_verticale(_T('breves:icone_nouvelle_breve'),
generer_url_ecrire("breve_edit", "id_rubrique=$id_rubrique&new=oui"), "breve-24.png", "new", 'right')
$bouton_breves .= icone_verticale(
_T('breves:icone_nouvelle_breve'),
generer_url_ecrire('breve_edit', "id_rubrique=$id_rubrique&new=oui"),
'breve-24.png',
'new',
'right'
)
. "<br class='nettoyeur' />";
}
@ -119,14 +124,17 @@ function breves_affiche_enfants($flux) {
function breves_accueil_informations($texte) {
include_spip('base/abstract_sql');
$q = sql_select("COUNT(*) AS cnt, statut", 'spip_breves', '', 'statut', '', '', "COUNT(*)<>0");
$q = sql_select('COUNT(*) AS cnt, statut', 'spip_breves', '', 'statut', '', '', 'COUNT(*)<>0');
$cpt = array();
$cpt2 = array();
$where = false;
if ($GLOBALS['visiteur_session']['statut'] == '0minirezo') {
$where = sql_allfetsel('id_objet', 'spip_auteurs_liens',
"objet='rubrique' AND id_auteur=" . intval($GLOBALS['visiteur_session']['id_auteur']));
$where = sql_allfetsel(
'id_objet',
'spip_auteurs_liens',
"objet='rubrique' AND id_auteur=" . intval($GLOBALS['visiteur_session']['id_auteur'])
);
if ($where) {
$where = sql_in('id_rubrique', array_map('reset', $where));
}
@ -139,23 +147,23 @@ function breves_accueil_informations($texte) {
if ($cpt) {
if ($where) {
$q = sql_select("COUNT(*) AS cnt, statut", 'spip_breves', $where, "statut");
$q = sql_select('COUNT(*) AS cnt, statut', 'spip_breves', $where, 'statut');
while ($row = sql_fetch($q)) {
$r = $row['statut'];
$cpt2[$r] = intval($row['cnt']) . '/';
}
}
$texte .= "<div class='accueil_informations breves liste'>";
$texte .= "<h4>" . afficher_plus_info(generer_url_ecrire("breves"), "", _T('breves:info_breves_02')) . "</h4>";
$texte .= '<h4>' . afficher_plus_info(generer_url_ecrire('breves'), '', _T('breves:info_breves_02')) . '</h4>';
$texte .= "<ul class='liste-items'>";
if (isset($cpt['prop'])) {
$texte .= "<li class='item'>" . _T("texte_statut_attente_validation") . ": " . $cpt2['prop'] . $cpt['prop'] . '</li>';
$texte .= "<li class='item'>" . _T('texte_statut_attente_validation') . ': ' . $cpt2['prop'] . $cpt['prop'] . '</li>';
}
if (isset($cpt['publie'])) {
$texte .= "<li class='item on'>" . _T("texte_statut_publies") . ": " . $cpt2['publie'] . $cpt['publie'] . '</li>';
$texte .= "<li class='item on'>" . _T('texte_statut_publies') . ': ' . $cpt2['publie'] . $cpt['publie'] . '</li>';
}
$texte .= "</ul>";
$texte .= "</div>";
$texte .= '</ul>';
$texte .= '</div>';
}
return $texte;
@ -176,11 +184,15 @@ function breves_objet_compte_enfants($flux) {
) {
// juste les publies ?
if (array_key_exists('statut', $flux['args']) and ($flux['args']['statut'] == 'publie')) {
$flux['data']['breve'] = sql_countsel('spip_breves',
"id_rubrique=" . intval($id_rubrique) . " AND (statut='publie')");
$flux['data']['breve'] = sql_countsel(
'spip_breves',
'id_rubrique=' . intval($id_rubrique) . " AND (statut='publie')"
);
} else {
$flux['data']['breve'] = sql_countsel('spip_breves',
"id_rubrique=" . intval($id_rubrique) . " AND (statut='publie' OR statut='prop')");
$flux['data']['breve'] = sql_countsel(
'spip_breves',
'id_rubrique=' . intval($id_rubrique) . " AND (statut='publie' OR statut='prop')"
);
}
}
@ -197,12 +209,18 @@ function breves_objet_compte_enfants($flux) {
* @return array Données du pipeline
*/
function breves_trig_calculer_langues_rubriques($flux) {
$s = sql_select("A.id_breve AS id_breve, R.lang AS lang", "spip_breves AS A, spip_rubriques AS R",
"A.id_rubrique = R.id_rubrique AND A.langue_choisie != 'oui' AND (A.lang='' OR R.lang<>'') AND R.lang<>A.lang");
$s = sql_select(
'A.id_breve AS id_breve, R.lang AS lang',
'spip_breves AS A, spip_rubriques AS R',
"A.id_rubrique = R.id_rubrique AND A.langue_choisie != 'oui' AND (A.lang='' OR R.lang<>'') AND R.lang<>A.lang"
);
while ($row = sql_fetch($s)) {
$id_breve = $row['id_breve'];
sql_updateq('spip_breves', array("lang" => $row['lang'], 'langue_choisie' => 'non'), "id_breve=$id_breve");
sql_updateq(
'spip_breves',
array('lang' => $row['lang'], 'langue_choisie' => 'non'),
'id_breve='.intval($id_breve)
);
}
return $flux;
@ -218,14 +236,18 @@ function breves_trig_calculer_langues_rubriques($flux) {
* @return array Données du pipeline
*/
function breves_calculer_rubriques($flux) {
$r = sql_select(
"R.id_rubrique AS id, max(A.date_heure) AS date_h",
"spip_rubriques AS R JOIN spip_breves AS A ON R.id_rubrique = A.id_rubrique",
"A.date_heure>R.date_tmp AND A.statut='publie' ", "R.id_rubrique");
'R.id_rubrique AS id, max(A.date_heure) AS date_h',
'spip_rubriques AS R JOIN spip_breves AS A ON R.id_rubrique = A.id_rubrique',
"A.date_heure>R.date_tmp AND A.statut='publie' ",
'R.id_rubrique'
);
while ($row = sql_fetch($r)) {
sql_updateq('spip_rubriques', array('statut_tmp' => 'publie', 'date_tmp' => $row['date_h']),
"id_rubrique=" . $row['id']);
sql_updateq(
'spip_rubriques',
array('statut_tmp' => 'publie', 'date_tmp' => $row['date_h']),
'id_rubrique=' . intval($row['id'])
);
}
return $flux;
@ -243,7 +265,6 @@ function breves_calculer_rubriques($flux) {
function breves_accueil_encours($flux) {
$lister_objets = charger_fonction('lister_objets', 'inc');
$flux .= $lister_objets('breves', array(
'titre' => afficher_plus_info(generer_url_ecrire('breves')) . _T('breves:info_breves_valider'),
'statut' => array('prepa', 'prop'),
@ -268,24 +289,23 @@ function breves_optimiser_base_disparus($flux) {
# les breves qui sont dans une id_rubrique inexistante
$res = sql_select("B.id_breve AS id",
"spip_breves AS B
LEFT JOIN spip_rubriques AS R
ON B.id_rubrique=R.id_rubrique",
"R.id_rubrique IS NULL
AND B.maj < " . sql_quote($mydate));
$res = sql_select(
'B.id_breve AS id',
'spip_breves AS B
LEFT JOIN spip_rubriques AS R
ON B.id_rubrique=R.id_rubrique',
'R.id_rubrique IS NULL
AND B.maj < ' . sql_quote($mydate)
);
$n += optimiser_sansref('spip_breves', 'id_breve', $res);
//
// Breves
//
sql_delete("spip_breves", "statut='refuse' AND maj < $mydate");
sql_delete('spip_breves', "statut='refuse' AND maj < $mydate");
return $flux;
}
/**
@ -302,8 +322,8 @@ function breves_boite_infos($flux) {
and isset($flux['args']['id']) and $id_rubrique = $flux['args']['id']
) {
if ($nb = sql_countsel('spip_breves', "statut='publie' AND id_rubrique=" . intval($id_rubrique))) {
$nb = "<div>" . singulier_ou_pluriel($nb, "breves:info_1_breve", "breves:info_nb_breves") . "</div>";
if ($p = strpos($flux['data'], "<!--nb_elements-->")) {
$nb = '<div>' . singulier_ou_pluriel($nb, 'breves:info_1_breve', 'breves:info_nb_breves') . '</div>';
if ($p = strpos($flux['data'], '<!--nb_elements-->')) {
$flux['data'] = substr_replace($flux['data'], $nb, $p, 0);
}
}
@ -322,8 +342,8 @@ function breves_boite_infos($flux) {
* @return array Données du pipeline
*/
function breves_affiche_milieu($flux) {
if ($flux["args"]["exec"] == "configurer_contenu") {
$flux["data"] .= recuperer_fond('prive/squelettes/inclure/configurer', array('configurer' => 'configurer_breves'));
if ($flux['args']['exec'] == 'configurer_contenu') {
$flux['data'] .= recuperer_fond('prive/squelettes/inclure/configurer', array('configurer' => 'configurer_breves'));
}
return $flux;

11
formulaires/configurer_breves.php

@ -15,7 +15,7 @@
*
* @package SPIP\Breves\Formulaires
**/
if (!defined("_ECRIRE_INC_VERSION")) {
if (!defined('_ECRIRE_INC_VERSION')) {
return;
}
@ -26,9 +26,10 @@ if (!defined("_ECRIRE_INC_VERSION")) {
* Environnement du formulaire
**/
function formulaires_configurer_breves_charger_dist() {
$valeurs = array();
foreach (array(
"activer_breves",
) as $m) {
'activer_breves',
) as $m) {
$valeurs[$m] = $GLOBALS['meta'][$m];
}
@ -44,8 +45,8 @@ function formulaires_configurer_breves_charger_dist() {
function formulaires_configurer_breves_traiter_dist() {
$res = array('editable' => true);
foreach (array(
"activer_breves",
) as $m) {
'activer_breves',
) as $m) {
if (!is_null($v = _request($m))) {
ecrire_meta($m, $v == 'oui' ? 'oui' : 'non');
}

33
formulaires/editer_breve.php

@ -15,7 +15,7 @@
*
* @package SPIP\Breves\Formulaires
**/
if (!defined("_ECRIRE_INC_VERSION")) {
if (!defined('_ECRIRE_INC_VERSION')) {
return;
}
@ -53,13 +53,24 @@ function formulaires_editer_breve_charger_dist(
$row = array(),
$hidden = ''
) {
$valeurs = formulaires_editer_objet_charger('breve', $id_breve, $id_rubrique, $lier_trad, $retour, $config_fonc, $row,
$hidden);
$valeurs = formulaires_editer_objet_charger(
'breve',
$id_breve,
$id_rubrique,
$lier_trad,
$retour,
$config_fonc,
$row,
$hidden
);
// un bug a permis a un moment que des breves soient dans des sous rubriques
// lorsque ce cas se presente, il faut relocaliser la breve dans son secteur, plutot que n'importe ou
if ($valeurs['id_parent']) {
$valeurs['id_parent'] = sql_getfetsel('id_secteur', 'spip_rubriques',
'id_rubrique=' . intval($valeurs['id_parent']));
$valeurs['id_parent'] = sql_getfetsel(
'id_secteur',
'spip_rubriques',
'id_rubrique=' . intval($valeurs['id_parent'])
);
}
return $valeurs;
@ -190,6 +201,14 @@ function formulaires_editer_breve_traiter_dist(
$row = array(),
$hidden = ''
) {
return formulaires_editer_objet_traiter('breve', $id_breve, $id_rubrique, $lier_trad, $retour, $config_fonc, $row,
$hidden);
return formulaires_editer_objet_traiter(
'breve',
$id_breve,
$id_rubrique,
$lier_trad,
$retour,
$config_fonc,
$row,
$hidden
);
}

Loading…
Cancel
Save