[80] | 1 | <?php |
---|
| 2 | |
---|
| 3 | if (!defined("_ECRIRE_INC_VERSION")) return; |
---|
| 4 | include_spip('inc/presentation'); |
---|
| 5 | include_spip('inc/layer'); |
---|
| 6 | include_spip('inc/getdocument'); |
---|
| 7 | include_spip('inc/upload-image'); |
---|
| 8 | include_spip('inc/extra'); |
---|
| 9 | |
---|
| 10 | include_spip('inc/arty_selecteur'); |
---|
| 11 | include_spip('inc/user_session'); |
---|
| 12 | |
---|
| 13 | function exec_avance() { |
---|
| 14 | |
---|
| 15 | global $connect_statut; |
---|
| 16 | if ($connect_statut != "0minirezo" ) { |
---|
| 17 | echo "<p><b>"._T('magusine:acces_a_la_page')."</b></p>"; |
---|
| 18 | fin_page(); |
---|
| 19 | exit; |
---|
| 20 | } |
---|
| 21 | |
---|
| 22 | $message_upload = traiter_post(); |
---|
| 23 | |
---|
| 24 | traiter_get(); |
---|
| 25 | |
---|
| 26 | |
---|
| 27 | echo debut_page(); |
---|
| 28 | echo barre_onglets("arty", "avance"); //affiche la barre des onglets du groupe "magusine", l'onglet courant est "avance". |
---|
| 29 | echo debut_gauche(); |
---|
| 30 | if ($message_upload && $message_upload != "arty:upload_reussi") { |
---|
| 31 | echo debut_cadre_relief(_DIR_PLUGIN_ARTY.'/images/emblem-important.png', true, "", _T('arty:erreur')); |
---|
| 32 | echo "<p style='font-weight:bold; color:red;'>"._T($message_upload)."</p>"; |
---|
| 33 | echo fin_cadre_relief(true); |
---|
| 34 | } |
---|
| 35 | echo debut_cadre_relief(_DIR_PLUGIN_ARTY.'/images/aide.png', true, "", _T('arty:info')); |
---|
| 36 | echo _T("arty:sideinfo_avance"); |
---|
| 37 | echo fin_cadre_relief(true); |
---|
| 38 | echo debut_droite(); |
---|
| 39 | |
---|
| 40 | gros_titre(_T("arty:gestion_bloc_libre")); |
---|
| 41 | |
---|
| 42 | echo debut_cadre_trait_couleur(_DIR_PLUGIN_ARTY."/images/config.png", true, "", _T('arty:creer_un_bloc_libre')); |
---|
| 43 | echo "<div style='padding-left:5px;'>"; |
---|
| 44 | echo "<br />"; |
---|
| 45 | echo _T('arty:entrez_donnees_nouveau_bloc'); |
---|
| 46 | echo "<form action='".generer_url_ecrire('avance')."' method='post' enctype=\"multipart/form-data\" name='formulaire' id='formulaire'>\n"; |
---|
| 47 | echo "<input type='hidden' name='action' value='nouveaubloc' />\n"; |
---|
| 48 | echo "<input type='text' name='titre' style='width:90%; color:#666; font-weight:bold;' value='"._T('arty:titre')."' onfocus='if(this.value==\""._T('arty:titre')."\"){this.value="";}' maxlength='255' size='50' />\n"; |
---|
| 49 | echo "<textarea name='texte' style='width:90%; color:#444;' cols='50' rows='4' id='texte1'></textarea>\n"; |
---|
| 50 | echo "<br /><br />"._T('arty:bloc_lien')."<br />\n"; |
---|
| 51 | echo "<input type='text' name='lien' value='http://' maxlength='255' style='width:90%' size='50' />\n"; |
---|
| 52 | echo "<br /><br />"._T('arty:bloc_image')."<br />\n"; |
---|
| 53 | |
---|
| 54 | echo "<input type=\"file\" name=\"illu_bloc_libre\" size=\"55\" style='width:95%' /><br />\n"; |
---|
| 55 | echo "<br /><input type='submit' value='"._T("arty:enregistrer")."' class='fondo' />\n"; |
---|
| 56 | echo "</form>\n"; |
---|
| 57 | echo "</div>\n"; |
---|
| 58 | echo fin_cadre_trait_couleur(); |
---|
| 59 | $tousblocs = spip_query("SELECT * FROM spip_arty_bloclibre"); |
---|
| 60 | |
---|
| 61 | while ($row=spip_fetch_array($tousblocs)) { |
---|
| 62 | echo debut_cadre_trait_couleur(_DIR_PLUGIN_ARTY."/images/config.png", true, "", htmlspecialchars($row['titre'])); |
---|
| 63 | echo "<a name='".$row['id_bloc_libre']."'></a>"; |
---|
| 64 | $chem = creer_repertoire_documents("illu-bloc-libre"); |
---|
| 65 | |
---|
| 66 | $chem=_DIR_DOC."illu-bloc-libre/"; |
---|
| 67 | $handle = @opendir($chem); |
---|
| 68 | $logo = false; |
---|
| 69 | while($fichier = @readdir($handle)) { |
---|
| 70 | |
---|
| 71 | if (ereg("^illu_bloc_libre-".$row['id_bloc_libre']."\.(jpg|png|gif)$", $fichier)) { |
---|
| 72 | $logo = $fichier; |
---|
| 73 | } |
---|
| 74 | } |
---|
| 75 | if ($logo){ |
---|
| 76 | // le nombre aléatoire permet d'éviter que le navigateur affiche la version en cache de l'image. |
---|
| 77 | $image = "<div style='padding-left:5px'><p>"._T("arty:logo_actuel").":</p><img width=\"190\" src=\""._DIR_DOC."illu-bloc-libre/$logo?".uniqid(rand())."\" />"; |
---|
| 78 | $image .="<form style='display:inline;' action='".generer_url_ecrire('avance')."' method='post'>\n" |
---|
| 79 | ."<input type='hidden' name='action' value='supprimerillu' />" |
---|
| 80 | ."<input type='hidden' name='id_bloc' value='".$row['id_bloc_libre']."' />" |
---|
| 81 | ."<input type='submit' title='"._T("arty:supprimer_illu")."' value='X' class='fondo' style='position:relative; border-color:red; background-color:red; left:-30px; font-size:10px;' /><br /><br />" |
---|
| 82 | ."</form>"; |
---|
| 83 | } else { |
---|
| 84 | $image=""; |
---|
| 85 | } |
---|
| 86 | |
---|
| 87 | $texte = $image."<form action='".generer_url_ecrire('avance')."' method='post' enctype=\"multipart/form-data\">\n" |
---|
| 88 | ."<input type='hidden' name='action' value='modifierbloc' />" |
---|
| 89 | ."<input type='hidden' name='id_bloc' value='".$row['id_bloc_libre']."' />" |
---|
| 90 | .(isset($_POST['retour']) ? "<input type='hidden' name='retour' value='".$_POST['retour']."' />" : "") |
---|
| 91 | ."<input type='text' name='titre' value='".htmlspecialchars($row['titre'], ENT_QUOTES)."' maxlength='255' size='50' style='width:90%; color:#666; font-weight:bold;' />" |
---|
| 92 | ."<textarea name='texte' cols='50' style='width:90%; color:#444;' rows='4'>".htmlspecialchars($row['contenu'])."</textarea>" |
---|
| 93 | ."<br /><br />"._T('arty:bloc_lien')."<br />" |
---|
| 94 | ."<input type='text' name='lien' value='".htmlspecialchars($row['lien'], ENT_QUOTES)."' maxlength='255' size='50' style='width:90%' />" |
---|
| 95 | ."<br /><br />"._T('arty:bloc_image')."<br />" |
---|
| 96 | ."<input type=\"file\" name=\"illu_bloc_libre\" size=\"55\" style='width:90%' /><br /><br /><br />" |
---|
| 97 | ."<input type='submit' value='".(isset($_POST['retour']) ? _T("arty:modifier_et_retour") : _T("arty:enregistrer") )."' class='fondo' style='float:right; margin-right:45px;' />" |
---|
| 98 | ._T("arty:attention_modif_globale")."<br />" |
---|
| 99 | ."</form>" |
---|
| 100 | ."<form action='".generer_url_ecrire('avance')."' method='post'>\n" |
---|
| 101 | ."<input type='hidden' name='action' value='supprimerbloc' />" |
---|
| 102 | ."<input type='hidden' name='id_bloc' value='".$row['id_bloc_libre']."' />" |
---|
| 103 | ."<br /><div style='text-align:center;'><input type='submit' value='"._T("arty:supprimer_ce_bloc")."' class='fondo' style='background-color:red; border-color:red; font-size:9px; font-weight:normal; margin:10px auto;' /></div>" |
---|
| 104 | ."</form></div>"; |
---|
| 105 | |
---|
| 106 | $visible = ($_POST['bloc'] == $row['id_bloc_libre']) ? true : false; |
---|
| 107 | |
---|
| 108 | echo block_parfois_visible("bloc".$row['id_bloc_libre'], _T('arty:modifier_ce_bloc'), $texte, '', $visible); |
---|
| 109 | echo fin_cadre_trait_couleur(); |
---|
| 110 | } |
---|
| 111 | |
---|
| 112 | echo fin_gauche(); |
---|
| 113 | |
---|
| 114 | echo fin_page(); |
---|
| 115 | |
---|
| 116 | } |
---|
| 117 | |
---|
| 118 | |
---|
| 119 | function traiter_post() { |
---|
| 120 | $message_upload = ""; |
---|
| 121 | |
---|
| 122 | if ($_POST['action']=='nouveaubloc' && isset($_POST['titre']) && isset($_POST['texte']) ) { |
---|
| 123 | $titre=trim(addslashes($_POST['titre'])); |
---|
| 124 | $texte=trim(addslashes($_POST['texte'])); |
---|
| 125 | $lien=trim(addslashes($_POST['lien'])); |
---|
| 126 | |
---|
| 127 | if($lien=="http://") { $lien=""; } |
---|
| 128 | |
---|
| 129 | if ($titre!="") { // && $texte!="") { |
---|
| 130 | spip_query("INSERT INTO spip_arty_bloclibre(titre, contenu,lien) VALUES('$titre', '$texte', '$lien')"); |
---|
| 131 | $result = spip_query("SELECT LAST_INSERT_ID();"); |
---|
| 132 | if ($result){ |
---|
| 133 | $arr = spip_fetch_array($result); |
---|
| 134 | $id = (int) current($arr); |
---|
| 135 | |
---|
| 136 | if (!is_nan($id)){ |
---|
| 137 | $message_upload = traiter_upload_image('illu_bloc_libre','illu-bloc-libre',$id); |
---|
| 138 | } |
---|
| 139 | } |
---|
| 140 | } |
---|
| 141 | } |
---|
| 142 | |
---|
| 143 | if ($_POST['action']=='supprimerbloc' && isset($_POST['id_bloc'])) { |
---|
| 144 | |
---|
| 145 | $id_bloc=(int) $_POST['id_bloc']; |
---|
| 146 | |
---|
| 147 | if (!is_nan($id_bloc)) { |
---|
| 148 | spip_query("DELETE FROM spip_arty_bloclibre WHERE id_bloc_libre= $id_bloc"); |
---|
| 149 | supprimer_illu_bloc($id_bloc); |
---|
| 150 | |
---|
| 151 | // supprimer les associations |
---|
| 152 | spip_query("DELETE FROM spip_arty_bloclibreassoc WHERE id_bloc_libre= $id_bloc"); |
---|
| 153 | } |
---|
| 154 | } |
---|
| 155 | |
---|
| 156 | if ($_POST['action']=='supprimerillu' && isset($_POST['id_bloc'])) { |
---|
| 157 | |
---|
| 158 | $id_bloc=(int) $_POST['id_bloc']; |
---|
| 159 | |
---|
| 160 | if (!is_nan($id_bloc)) { |
---|
| 161 | //spip_query("DELETE FROM spip_arty_bloclibre WHERE id_bloc_libre= $id_bloc"); |
---|
| 162 | supprimer_illu_bloc($id_bloc); |
---|
| 163 | } |
---|
| 164 | } |
---|
| 165 | |
---|
| 166 | |
---|
| 167 | if ($_POST['action']=='modifierbloc' && isset($_POST['id_bloc']) && isset($_POST['titre']) && isset($_POST['texte']) ) { |
---|
| 168 | |
---|
| 169 | //print_r($_POST); |
---|
| 170 | $id_bloc=(int) $_POST['id_bloc']; |
---|
| 171 | $titre=trim(addslashes($_POST['titre'])); |
---|
| 172 | $texte=trim(addslashes($_POST['texte'])); |
---|
| 173 | $lien=trim(addslashes($_POST['lien'])); |
---|
| 174 | if($lien=="http://") { $lien=""; } |
---|
| 175 | |
---|
| 176 | if ($titre!="" && !is_nan($id_bloc)) { |
---|
| 177 | spip_query("UPDATE spip_arty_bloclibre SET titre='$titre', contenu='$texte', lien='$lien' WHERE id_bloc_libre=$id_bloc"); |
---|
| 178 | $message_upload = traiter_upload_image('illu_bloc_libre','illu-bloc-libre',$id_bloc); |
---|
| 179 | } |
---|
| 180 | |
---|
| 181 | //redirection vers la page d'origine |
---|
| 182 | if (isset($_POST['retour'])) { |
---|
| 183 | header('Location: '.$_POST['retour']); |
---|
| 184 | } |
---|
| 185 | |
---|
| 186 | } |
---|
| 187 | |
---|
| 188 | return $message_upload; |
---|
| 189 | |
---|
| 190 | } |
---|
| 191 | |
---|
| 192 | |
---|
| 193 | function supprimer_illu_bloc($id_bloc) { |
---|
| 194 | //$chem = creer_repertoire_documents("illu-bloc-libre"); |
---|
| 195 | $chem = _DIR_DOC."illu-bloc-libre/"; |
---|
| 196 | $handle = @opendir($chem); |
---|
| 197 | while($fichier = @readdir($handle)) { |
---|
| 198 | if (!$id_bloc) { |
---|
| 199 | if (ereg("^illu_bloc_libre\.(jpg|png|gif)$", $fichier)){ |
---|
| 200 | @unlink($chem.$fichier); |
---|
| 201 | } |
---|
| 202 | } else { |
---|
| 203 | if (ereg("^illu_bloc_libre-$id_bloc\.(jpg|png|gif)$", $fichier)){ |
---|
| 204 | @unlink($chem.$fichier); |
---|
| 205 | } |
---|
| 206 | } |
---|
| 207 | } |
---|
| 208 | } |
---|
| 209 | |
---|
| 210 | function traiter_get() { |
---|
| 211 | //print_r($_GET); |
---|
| 212 | |
---|
| 213 | $param_accepte=array('edito'); |
---|
| 214 | |
---|
| 215 | if(isset($_GET['ajouter']) && isset($_GET['verif'])){ |
---|
| 216 | $param=$_GET['ajouter']; |
---|
| 217 | if(in_array($param, $param_accepte) && $_GET['verif']==$_SESSION['id_check']) { |
---|
| 218 | |
---|
| 219 | if(isset($_GET['id_rubrique'])) { |
---|
| 220 | $id_rubrique=(int) $_GET['id_rubrique']; |
---|
| 221 | |
---|
| 222 | if(is_numeric($id_rubrique)){ |
---|
| 223 | $resultat = spip_query("SELECT * FROM spip_arty_paramassoc WHERE param = '$param' AND id_rubrique = $id_rubrique"); |
---|
| 224 | if(!spip_num_rows($resultat)) { |
---|
| 225 | spip_query("INSERT INTO spip_arty_paramassoc (param, id_rubrique) VALUES ('$param', $id_rubrique)"); |
---|
| 226 | } |
---|
| 227 | |
---|
| 228 | } |
---|
| 229 | |
---|
| 230 | } elseif(isset($_GET['id_article'])) { |
---|
| 231 | $id_article=(int) $_GET['id_article']; |
---|
| 232 | |
---|
| 233 | if(is_numeric($id_article)){ |
---|
| 234 | $resultat = spip_query("SELECT * FROM spip_arty_paramassoc WHERE param = '$param' AND id_article = $id_article"); |
---|
| 235 | if(!spip_num_rows($resultat)) { |
---|
| 236 | spip_query("INSERT INTO spip_arty_paramassoc (param, id_article) VALUES ('$param', $id_article)"); |
---|
| 237 | } |
---|
| 238 | |
---|
| 239 | } |
---|
| 240 | |
---|
| 241 | } |
---|
| 242 | |
---|
| 243 | |
---|
| 244 | } |
---|
| 245 | |
---|
| 246 | } |
---|
| 247 | |
---|
| 248 | if(isset($_GET['supprimer']) && isset($_GET['verif'])){ |
---|
| 249 | $id_assoc=(int) $_GET['supprimer']; |
---|
| 250 | if( is_numeric($id_assoc) && $_GET['verif']==$_SESSION['id_check']) { |
---|
| 251 | spip_query("DELETE FROM spip_arty_paramassoc WHERE id_assoc = $id_assoc"); |
---|
| 252 | } |
---|
| 253 | } |
---|
| 254 | |
---|
| 255 | } |
---|
| 256 | |
---|
| 257 | |
---|
| 258 | ?> |
---|