Subversion Repositories Applications.papyrus

Rev

Rev 798 | Rev 832 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
144 jpm 1
<?php
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
7
// +------------------------------------------------------------------------------------------------------+
8
// | This library is free software; you can redistribute it and/or                                        |
9
// | modify it under the terms of the GNU Lesser General Public                                           |
10
// | License as published by the Free Software Foundation; either                                         |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
12
// |                                                                                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
16
// | Lesser General Public License for more details.                                                      |
17
// |                                                                                                      |
18
// | You should have received a copy of the GNU Lesser General Public                                     |
19
// | License along with this library; if not, write to the Free Software                                  |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
21
// +------------------------------------------------------------------------------------------------------+
799 ddelon 22
// CVS : $Id: afficheur.admin.php,v 1.17 2006-03-27 13:42:32 ddelon Exp $
144 jpm 23
/**
24
* Gestion de la rédaction du contenu pour Papyrus.
25
*
26
* Contient les fonctions nécessaires à la gestion du contenu de Papyrus.
27
*
28
*@package Afficheur
29
*@subpackage Administration
30
//Auteur original :
31
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
32
//Autres auteurs :
33
*@author        Aucun
34
*@copyright     Tela-Botanica 2000-2004
799 ddelon 35
*@version       $Revision: 1.17 $ $Date: 2006-03-27 13:42:32 $
144 jpm 36
// +------------------------------------------------------------------------------------------------------+
37
*/
38
 
39
// +------------------------------------------------------------------------------------------------------+
40
// |                                            ENTÊTE du PROGRAMME                                       |
41
// +------------------------------------------------------------------------------------------------------+
42
 
43
 
44
// +------------------------------------------------------------------------------------------------------+
45
// |                                                 CLASSE                                               |
46
// +------------------------------------------------------------------------------------------------------+
47
class Afficheur_Admin {
48
    var $objet_pear_auth;
49
    var $objet_pear_db;
50
    var $objet_pear_url;
51
    var $sortie_xhtml;
52
 
53
    /** Fonction redigerContenu() - Affiche le formulaire de rédaction
54
    *
55
    *
56
    *   @return  string  Le HTML
57
    */
58
    function afficherContenuCorps()
59
    {
361 jpm 60
        /** Inclusion du fichier de configuration de cette application.*/
61
        require_once GEN_CHEMIN_PAP.'applications/afficheur/configuration/affi_configuration.inc.php';
62
 
144 jpm 63
        //-------------------------------------------------------------------------------------------------------------------
361 jpm 64
        // Stockage des styles de l'application
65
        GEN_stockerStyleExterne('afficheur', AFFI_CHEMIN_STYLE.'afficheur.css');
66
 
67
        //-------------------------------------------------------------------------------------------------------------------
144 jpm 68
        // Initialisation des attributs
69
        $this->objet_pear_auth = $GLOBALS['_GEN_commun']['pear_auth'];
70
        $this->objet_pear_db = $GLOBALS['_GEN_commun']['pear_db'];
71
        $this->objet_pear_url = $GLOBALS['_GEN_commun']['url'];
72
        $this->sortie_xhtml = '';
73
 
74
        //-------------------------------------------------------------------------------------------------------------------
75
        // Gestion de l'interface
387 jpm 76
        if (isset($_POST['afficheur_annuler'])) {
77
            return false;
78
        } else if (isset($_POST['afficheur_enregistrer_quitter'])) {
144 jpm 79
            // Mise à jour du contenu
80
            $this->_ajouterContenu($this->objet_pear_db, $this->objet_pear_url, $this->objet_pear_auth, $_GET['adme_menu_id'], $_POST);
81
            return false;
387 jpm 82
        } else if (isset($_POST['afficheur_enregistrer_ss_entite'])) {
83
            $_POST['gmc_contenu'] = html_entity_decode($_POST['gmc_contenu']);
84
            // Mise à jour du contenu
85
            $this->_ajouterContenu($this->objet_pear_db, $this->objet_pear_url, $this->objet_pear_auth, $_GET['adme_menu_id'], $_POST);
86
        } else if (isset($_POST['afficheur_enregistrer_rester'])) {
87
            // Mise à jour du contenu
88
            $this->_ajouterContenu($this->objet_pear_db, $this->objet_pear_url, $this->objet_pear_auth, $_GET['adme_menu_id'], $_POST);
144 jpm 89
        }
387 jpm 90
        $this->sortie_xhtml .= $this->_redigerContenu($this->objet_pear_db, $this->objet_pear_url, $_GET['adme_site_id'], $_GET['adme_menu_id'], $_GET['adme_action']);
91
        return $this->sortie_xhtml;
144 jpm 92
    }
93
 
94
    /** Méthode redigerContenu() - Enregistre les infos du formulaire de saisie d'un menu
95
    *
96
    *
97
    *   @return  void  les données sont enregistrées dans la base de données.
98
    */
99
    function _redigerContenu($db, $url, $adme_site_id, $adme_menu_id, $adme_action)
796 ddelon 100
    {
101
 
102
    	$contenu='';
103
 
104
 
105
 
793 ddelon 106
	    $id_langue = $GLOBALS['_GEN_commun']['i18n'];
107
 
108
	    if (isset($id_langue) && ($id_langue!='')) {
109
			$langue_test=$id_langue;
110
		} else {
111
			$langue_test=GEN_I18N_ID_DEFAUT;
112
		}
113
 
796 ddelon 114
 
115
 
116
        //-------------------------------------------------------------------------------------------------------------------
117
        // Initialisation de variable
118
        $url->addQueryString('adme_site_id', $adme_site_id);
119
        $url->addQueryString('adme_menu_id', $adme_menu_id);
120
        $url->addQueryString('adme_action', $adme_action);
793 ddelon 121
 
144 jpm 122
        //-------------------------------------------------------------------------------------------------------------------
123
        // Récupération des informations du contenu concerné.
124
        $ligne_menu = GEN_lireInfoMenu($db, $adme_menu_id, DB_FETCHMODE_ASSOC);
754 ddelon 125
 
144 jpm 126
        if ($ligne_menu == false) {
277 jpm 127
            die('ERREUR Papyrus Administrateur de Menus: impossible de lire les infos du menu.<br />'.
144 jpm 128
                'Idenitifiant du menu n° : '. $adme_menu_id .'<br />'.
129
                'Ligne n° : '. __LINE__ .'<br />'.
130
                'Fichier n° : '. __FILE__ .'<br />');
131
        }
132
 
796 ddelon 133
 
134
    $id_langue = $GLOBALS['_GEN_commun']['i18n'];
754 ddelon 135
 
796 ddelon 136
    if (isset($id_langue) && ($id_langue!='')) {
137
		$langue_test=$id_langue;
138
	} else {
139
		$langue_test=GEN_I18N_ID_DEFAUT;
140
	}
793 ddelon 141
 
142
 
799 ddelon 143
    // Récupération du dernier contenu : cas d'un traduction
144
 
796 ddelon 145
    $requete =  'SELECT gmc_contenu , gmc_ce_type_contenu,gmc_ce_menu '.
146
                'FROM gen_menu_contenu  '.
147
                'WHERE truncate((gmc_ce_type_contenu/10),0) = '.  $adme_menu_id . ' '.
148
                'AND gmc_bool_dernier = 1';
793 ddelon 149
 
796 ddelon 150
    	$resultat = $db->query($requete);
151
    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
152
 
153
			// Cas historique
754 ddelon 154
 
796 ddelon 155
			if ( $resultat->numRows() == 0 ) {
156
 
157
				    $requete =  'SELECT gmc_contenu , gmc_ce_type_contenu,gmc_ce_menu '.
158
				                'FROM gen_menu_contenu  '.
159
				                'WHERE gmc_ce_menu = '.$adme_menu_id.' '.
160
				                'AND gmc_ce_type_contenu in (1,2) '.
161
				                'AND gmc_bool_dernier = 1';
162
 
163
				    $resultat = $db->query($requete);
164
				    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
793 ddelon 165
 
796 ddelon 166
			}
167
 
168
					// Pas de contenu, tentative de recuperation contenu non traduit (apres mutlilinguisme)
793 ddelon 169
 
796 ddelon 170
			if ( $resultat->numRows() == 0 ) {
754 ddelon 171
 
796 ddelon 172
					$requete_defaut =  'SELECT gm_id_menu, gm_code_num  '.
793 ddelon 173
				                'FROM gen_menu  '.
174
				                'WHERE gm_code_num =  '.$ligne_menu['gm_code_num'].' '.
175
				                'AND gm_ce_i18n = "'.$langue_test.'" ';
176
 
796 ddelon 177
					$resultat_defaut = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete_defaut);
754 ddelon 178
 
796 ddelon 179
					(DB::isError($resultat_defaut)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_defaut->getMessage(), $requete_defaut)) : '';
793 ddelon 180
 
799 ddelon 181
					if ( $resultat_defaut->numRows() > 0 ) {
182
 
183
						$ligne_defaut = $resultat_defaut->fetchRow(DB_FETCHMODE_OBJECT);
184
 
185
						$requete_defaut =  'SELECT gmc_contenu , gmc_ce_type_contenu, gmc_ce_menu '.
186
		        	        'FROM gen_menu_contenu  '.
187
		            	    'WHERE gmc_ce_menu = '.$ligne_menu['gm_code_num'].' '.
188
		                	'AND truncate((gmc_ce_type_contenu/10),0) = '. $ligne_defaut->gm_id_menu . ' '.
189
		                	'AND gmc_bool_dernier = 1';
793 ddelon 190
 
799 ddelon 191
						    $resultat_defaut = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete_defaut);
192
						    (DB::isError($resultat_defaut)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_defaut->getMessage(), $requete_defaut)) : '';
193
 
194
					  $ligne_defaut = $resultat_defaut->fetchRow(DB_FETCHMODE_OBJECT);
195
 
196
					  $contenu = $ligne_defaut->gmc_contenu;
197
 
198
					// Pas de contenu, tentative de recuperation contenu non traduit (avant multilinguisme)
199
					}
796 ddelon 200
 
799 ddelon 201
					if ( $resultat_defaut->numRows()== 0 ) {
202
 
796 ddelon 203
							$requete_defaut =  'SELECT gm_id_menu, gm_code_num  '.
204
						                'FROM gen_menu  '.
205
						                'WHERE gm_code_num =  '.$ligne_menu['gm_code_num'].' '.
206
						                'AND gm_ce_i18n = "'.$langue_test.'" ';
207
 
208
							$resultat_defaut = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete_defaut);
209
 
210
							(DB::isError($resultat_defaut)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_defaut->getMessage(), $requete_defaut)) : '';
799 ddelon 211
 
212
							if ( $resultat_defaut->numRows() > 0 ) {
796 ddelon 213
 
799 ddelon 214
									$ligne_defaut = $resultat_defaut->fetchRow(DB_FETCHMODE_OBJECT);
215
 
216
									$requete_defaut =  'SELECT gmc_contenu , gmc_ce_type_contenu, gmc_ce_menu '.
217
					        	        'FROM gen_menu_contenu  '.
218
					            	    'WHERE gmc_ce_menu = '.$ligne_menu['gm_code_num'].' '.
219
					            	    'AND gmc_ce_type_contenu in (1,2) '.
220
								                'AND gmc_bool_dernier = 1';
221
 
222
									    $resultat_defaut = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete_defaut);
223
									    (DB::isError($resultat_defaut)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_defaut->getMessage(), $requete_defaut)) : '';
224
 
225
								  $ligne_defaut = $resultat_defaut->fetchRow(DB_FETCHMODE_OBJECT);
226
 
227
								  $contenu = $ligne_defaut->gmc_contenu;
228
 
229
							}
230
					}
796 ddelon 231
 
799 ddelon 232
					if ( $resultat_defaut->numRows()== 0 ) {
233
 
234
						$requete_defaut =  'SELECT gm_id_menu, gm_code_num  '.
235
		                'FROM gen_menu  '.
236
		                'WHERE gm_code_num =  '.$ligne_menu['gm_code_num'].' '.
237
		                'AND gm_ce_i18n = "'.GEN_I18N_ID_DEFAUT.'" ';
238
 
798 ddelon 239
							$resultat_defaut = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete_defaut);
240
 
799 ddelon 241
						 if ( $resultat_defaut->numRows() > 0 ) {
798 ddelon 242
 
799 ddelon 243
 
244
								(DB::isError($resultat_defaut)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_defaut->getMessage(), $requete_defaut)) : '';
245
 
246
								$ligne_defaut = $resultat_defaut->fetchRow(DB_FETCHMODE_OBJECT);
798 ddelon 247
 
799 ddelon 248
								$requete_defaut =  'SELECT gmc_contenu , gmc_ce_type_contenu, gmc_ce_menu '.
249
				        	        'FROM gen_menu_contenu  '.
250
				            	    'WHERE gmc_ce_menu = '.$ligne_menu['gm_code_num'].' '.
251
				                	'AND truncate((gmc_ce_type_contenu/10),0) = '. $ligne_defaut->gm_id_menu . ' '.
252
				                	'AND gmc_bool_dernier = 1';
253
 
254
								    $resultat_defaut = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete_defaut);
255
								    (DB::isError($resultat_defaut)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_defaut->getMessage(), $requete_defaut)) : '';
256
 
257
							  $ligne_defaut = $resultat_defaut->fetchRow(DB_FETCHMODE_OBJECT);
258
 
259
							  $contenu = $ligne_defaut->gmc_contenu;
260
 
261
						 }
262
					}
263
 
264
					if ( $resultat_defaut->numRows()== 0 ) {
265
 
798 ddelon 266
							$requete_defaut =  'SELECT gm_id_menu, gm_code_num  '.
799 ddelon 267
				                'FROM gen_menu  '.
268
				                'WHERE gm_code_num =  '.$ligne_menu['gm_code_num'].' '.
269
				                'AND gm_ce_i18n = "'.GEN_I18N_ID_DEFAUT.'" ';
270
 
798 ddelon 271
							$resultat_defaut = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete_defaut);
272
 
273
							(DB::isError($resultat_defaut)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_defaut->getMessage(), $requete_defaut)) : '';
799 ddelon 274
 
275
							if ( $resultat_defaut->numRows() > 0 ) {
798 ddelon 276
 
799 ddelon 277
									$ligne_defaut = $resultat_defaut->fetchRow(DB_FETCHMODE_OBJECT);
278
 
279
									$requete_defaut =  'SELECT gmc_contenu , gmc_ce_type_contenu, gmc_ce_menu '.
280
					        	        'FROM gen_menu_contenu  '.
281
					            	    'WHERE gmc_ce_menu = '.$ligne_menu['gm_code_num'].' '.
282
					            	    'AND gmc_ce_type_contenu in (1,2) '.
283
								                'AND gmc_bool_dernier = 1';
284
 
285
									    $resultat_defaut = $GLOBALS['_AFFICHEUR']['objet_pear_db']->query($requete_defaut);
286
									    (DB::isError($resultat_defaut)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat_defaut->getMessage(), $requete_defaut)) : '';
287
 
288
								  $ligne_defaut = $resultat_defaut->fetchRow(DB_FETCHMODE_OBJECT);
289
 
290
								  $contenu = $ligne_defaut->gmc_contenu;
291
							}
798 ddelon 292
					}
793 ddelon 293
 
796 ddelon 294
			}
295
 
754 ddelon 296
 
796 ddelon 297
 
144 jpm 298
        $ligne_dernier_contenu = $resultat->fetchRow(DB_FETCHMODE_ASSOC);
796 ddelon 299
        (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
794 ddelon 300
 
796 ddelon 301
        // Hack :
794 ddelon 302
 
144 jpm 303
 
304
 
305
        $retour = '<h1>'.'Rédaction'.'</h1>'."\n";
306
        //-------------------------------------------------------------------------------------------------------------------
307
        // Création du formulaire
361 jpm 308
        $form =& new HTML_QuickForm('form_modifier_contenu', 'post', str_replace('&amp;', '&', $url->getUrl()));
309
        $tab_index = 1000;
144 jpm 310
        $squelette =& $form->defaultRenderer();
311
        $squelette->setFormTemplate("\n".'<form{attributes}>'."\n".'<ul>'."\n".'{content}'."\n".'</ul>'."\n".'</form>'."\n");
312
        $squelette->setElementTemplate(  '<li>'."\n".
313
                                        '{label}'."\n".
314
                                        '{element}'."\n".
315
                                        '<!-- BEGIN required --><span class="symbole_obligatoire">*</span><!-- END required -->'."\n".
316
                                        '<!-- BEGIN error --><span class="erreur">{error}</span><!-- END error -->'."\n".
317
                                        '</li>'."\n");
318
        //$squelette->setHeaderTemplate('<p>{header}</p>');
319
        //$form->addElement('header', 'Entete', 'REDACTION');
361 jpm 320
        $aso_options = array();
321
        $aso_options[1] = 'XHTML';
322
        $aso_options[2] = 'WIKINI';
323
        $id = 'gmc_ce_type_contenu';
324
        $aso_attributs = array('id'=> $id, 'tabindex' => $tab_index++);
325
        $label = '<label for="'.$id.'">'.'Type de contenu : '.'</label>';
326
        $form->addElement('select', $id, $label, $aso_options, $aso_attributs);
144 jpm 327
 
394 jpm 328
        if ($GLOBALS['_AFFI_']['fckeditor']['utilisation']) {
329
            /** Inclusion du fichier de FCKeditor*/
330
            require_once AFFI_CHEMIN_FCKEDITOR.'fckeditor.php';
796 ddelon 331
            $fckeditor = new FCKeditor('gmc_contenu');
332
            if ($ligne_dernier_contenu['gmc_contenu']) {
333
	            $fckeditor->Value = $ligne_dernier_contenu['gmc_contenu'];
334
            }
335
            else {
336
            	if ($contenu) {
337
            		$fckeditor->Value = $contenu;
338
            	}
339
            	else {
340
            		$fckeditor->Value = '';
341
            	}
342
            }
343
 
394 jpm 344
            $fckeditor->Height = $GLOBALS['_AFFI_']['fckeditor']['hauteur'];
419 ddelon 345
            $fckeditor->ToolbarSet = $GLOBALS['_AFFI_']['fckeditor']['barre'];
418 ddelon 346
            $fckeditor->Config['CustomConfigurationsPath']=$GLOBALS['_AFFI_']['fckeditor']['CustomConfigurationsPath'];
394 jpm 347
            $fckeditor->Config['AutoDetectLanguage'] = false;
418 ddelon 348
            $fckeditor->Config['DefaultLanguage'] = $GLOBALS['_AFFI_']['fckeditor']['langue'];
349
 
394 jpm 350
            $fckeditor->BasePath = AFFI_CHEMIN_FCKEDITOR;
351
            if ($fckeditor->IsCompatible()) {
352
                $form->addElement('html', '<li>'.$fckeditor->CreateHtml().'</li>');
353
            } else {
354
                $GLOBALS['_AFFI_']['fckeditor']['utilisation'] = false;
355
            }
356
        }
357
        if (!$GLOBALS['_AFFI_']['fckeditor']['utilisation']) {
358
            $id = 'gmc_contenu';
359
            $aso_attributs = array('id'=> $id, 'tabindex' => $tab_index++, 'rows' => 20, 'cols' => 100);
360
            $label = '<label for="'.$id.'">'.'Contenu : '.'</label>';
361
            $form->addElement('textarea', $id, $label, $aso_attributs);
362
        }
361 jpm 363
 
364
        $aso_options = array();
365
        $aso_options[1] = 'Mineure';
366
        $aso_options[2] = 'Majeure';
367
        $id = 'gmc_ce_type_modification';
368
        $aso_attributs = array('id'=> $id, 'tabindex' => $tab_index++);
369
        $label = '<label for="'.$id.'">'.'Type de modification : '.'</label>';
370
        $form->addElement('select', $id, $label, $aso_options, $aso_attributs);
371
 
372
        $id = 'gmc_resume_modification';
373
        $aso_attributs = array('id'=> $id, 'tabindex' => $tab_index++, 'size' => 45, 'maxlength' => 255);
374
        $label = '<label for="'.$id.'">'.'Resumé modification : '.'</label>';
375
        $form->addElement('text', $id, $label, $aso_attributs);
768 ddelon 376
        $form->addElement('hidden','gmc_ce_menu',$ligne_dernier_contenu['gmc_ce_menu']);
377
        $form->addElement('hidden','gmc_ce_type_contenu_table',$ligne_dernier_contenu['gmc_ce_type_contenu']);
361 jpm 378
 
144 jpm 379
        $liste_bouton_debut = '<ul class="liste_bouton">'."\n";
380
        $form->addElement('html', $liste_bouton_debut);
387 jpm 381
        $form->addElement('submit', 'afficheur_enregistrer_quitter', 'Enregistrer et quitter');
382
        $form->addElement('submit', 'afficheur_enregistrer_rester', 'Enregistrer et rester en édition');
383
        $form->addElement('submit', 'afficheur_enregistrer_ss_entite', 'Remplacer les entités xhtml');
144 jpm 384
        $form->addElement('submit', 'afficheur_annuler', 'Annuler');
385
        $liste_bouton_fin = '</ul>'."\n";
386
        $form->addElement('html', $liste_bouton_fin);
387
 
388
        $form->setDefaults($ligne_dernier_contenu);
389
 
394 jpm 390
        $retour .= $form->toHTML()."\n";
391
 
144 jpm 392
        return $retour;
393
    }
394
 
395
    /** Méthode ajouterContenu() - Enregistre les infos du formulaire de saisie d'un menu
396
    *
397
    *
398
    *   @return  void  les données sont enregistrées dans la base de données.
399
    */
400
    function _ajouterContenu($db, $url, $auth, $adme_menu_id, $tab_valeur)
401
    {
754 ddelon 402
    	//-------------------------------------------------------------------------------------------------------------------
403
        // Récupération des informations du contenu concerné.
404
        $ligne_menu = GEN_lireInfoMenu($db, $adme_menu_id, DB_FETCHMODE_ASSOC);
405
 
767 ddelon 406
 
407
 
408
	    $id_langue = $GLOBALS['_GEN_commun']['i18n'];
409
 
410
	    if (isset($id_langue) && ($id_langue!='')) {
411
			$langue_test=$id_langue;
412
		} else {
413
			$langue_test=GEN_I18N_ID_DEFAUT;
414
		}
415
 
754 ddelon 416
 
767 ddelon 417
 
754 ddelon 418
        if ($ligne_menu == false) {
419
            die('ERREUR Papyrus Administrateur de Menus: impossible de lire les infos du menu.<br />'.
420
                'Idenitifiant du menu n° : '. $adme_menu_id .'<br />'.
421
                'Ligne n° : '. __LINE__ .'<br />'.
422
                'Fichier n° : '. __FILE__ .'<br />');
423
        }
424
 
769 ddelon 425
        if ((isset($tab_valeur['gmc_ce_menu']) && $tab_valeur['gmc_ce_menu']!='') && (isset($tab_valeur['gmc_ce_type_contenu_table']) && $tab_valeur['gmc_ce_type_contenu_table']!='')) {
426
 
427
	        //-------------------------------------------------------------------------------------------------------------------
428
	        // Mise à jour de l'ancien contenu du menu
429
	        $requete =  'UPDATE gen_menu_contenu SET '.
430
	                    'gmc_bool_dernier = 0 '.
431
	                    'WHERE gmc_ce_menu = '.$tab_valeur['gmc_ce_menu'] . ' '.
432
		                'AND gmc_ce_type_contenu = '. $tab_valeur['gmc_ce_type_contenu_table']. ' ';
433
 
434
 
435
	        $result = $db->query($requete);
436
	        (DB::isError($result)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $result->getMessage(), $requete)) : '';
437
 
438
        }
768 ddelon 439
 
144 jpm 440
        //-------------------------------------------------------------------------------------------------------------------
441
        // Obtention d'un nouvel identifiant de contenu
442
        $nouveau_id_contenu = SQL_obtenirNouveauId($db, 'gen_menu_contenu', 'gmc_id_contenu');
443
 
444
        //-------------------------------------------------------------------------------------------------------------------
445
        // Ajout du nouveau contenu pour ce menu
754 ddelon 446
        $tab_valeur['gmc_ce_type_contenu']=$tab_valeur['gmc_ce_type_contenu']+(10*$adme_menu_id);
144 jpm 447
        $requete =  'INSERT INTO gen_menu_contenu SET '.
448
                    'gmc_id_contenu = '.$nouveau_id_contenu.', '.
449
                    'gmc_ce_admin = '.$auth->getAuthData('ga_id_administrateur').', '.
754 ddelon 450
                    'gmc_ce_menu = '.$ligne_menu['gm_code_num'].', '.
144 jpm 451
                    'gmc_ce_type_contenu = '.$tab_valeur['gmc_ce_type_contenu'].', '.
452
                    'gmc_contenu = "'.$tab_valeur['gmc_contenu'].'", '.
453
                    'gmc_ce_type_modification = '.$tab_valeur['gmc_ce_type_modification'].', '.
454
                    'gmc_resume_modification = "'.$tab_valeur['gmc_resume_modification'].'", '.
455
                    'gmc_date_modification = "'.date('Y-m-d H:i:s').'", '.
456
                    'gmc_bool_dernier = 1';
457
 
458
        $result = $db->query($requete);
459
        (DB::isError($result)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $result->getMessage(), $requete)) : '';
460
    }
461
}// Fin de la classe
462
 
463
// +------------------------------------------------------------------------------------------------------+
464
// |                                            PIED du PROGRAMME                                         |
465
// +------------------------------------------------------------------------------------------------------+
466
 
467
 
468
/* +--Fin du code ----------------------------------------------------------------------------------------+
469
*
470
* $Log: not supported by cvs2svn $
799 ddelon 471
* Revision 1.16  2006/03/27 11:21:49  ddelon
472
* Still some pb
473
*
798 ddelon 474
* Revision 1.15  2006/03/27 10:14:43  ddelon
475
* Still some pb
476
*
793 ddelon 477
* Revision 1.11  2006/03/13 22:27:23  ddelon
478
* bug afficheur multilinguisme
479
*
769 ddelon 480
* Revision 1.10  2006/03/13 22:12:20  ddelon
481
* bug afficheur multilinguisme
482
*
768 ddelon 483
* Revision 1.9  2006/03/13 21:00:20  ddelon
484
* Suppression messages d'erreur multilinguisme
485
*
767 ddelon 486
* Revision 1.8  2006/03/02 10:49:49  ddelon
487
* Fusion branche multilinguisme dans branche principale
488
*
754 ddelon 489
* Revision 1.7.2.1  2006/02/28 14:02:11  ddelon
490
* Finition multilinguisme
491
*
492
* Revision 1.7  2005/07/18 08:53:14  ddelon
493
* Configuration Fcsk et menage
494
*
419 ddelon 495
* Revision 1.6  2005/07/15 17:10:08  ddelon
496
* Configuration Fcsk et menage
497
*
418 ddelon 498
* Revision 1.5  2005/06/03 18:39:30  jpm
499
* Ajout de la barre d'outil Papyrus FCKeditor.
500
*
394 jpm 501
* Revision 1.4  2005/05/31 13:43:57  jpm
502
* Ajout d'un bouton pour remplacer les entités html.
503
*
387 jpm 504
* Revision 1.3  2005/04/25 13:56:31  jpm
505
* Ajout de styles.
506
*
361 jpm 507
* Revision 1.2  2005/02/28 10:34:15  jpm
508
* Changement de nom Genesia en Papyrus.
509
*
277 jpm 510
* Revision 1.1  2004/11/09 17:53:49  jpm
511
* Interface d'administration de l'application afficheur.
512
*
144 jpm 513
* Revision 1.4  2004/11/08 17:40:33  jpm
514
* Mise en conformité avec la convention de codage.
515
* Légères corrections.
516
*
517
* Revision 1.3  2004/09/23 17:45:13  jpm
518
* Amélioration de la gestion des liens annuler et du selecteur de sites.
519
*
520
* Revision 1.2  2004/07/06 17:07:37  jpm
521
* Modification de la documentation pour une mailleur analyse par PhpDocumentor.
522
*
523
* Revision 1.1  2004/06/16 15:04:32  jpm
524
* Changement de nom de Génésia en Papyrus.
525
* Changement de l'arborescence.
526
*
527
* Revision 1.5  2004/05/07 16:32:27  jpm
528
* Modification des commentaires.
529
*
530
* Revision 1.4  2004/05/07 07:23:53  jpm
531
* Amélioration du code, des commentaires et correction de bogues.
532
*
533
* Revision 1.3  2004/05/04 16:27:55  jpm
534
* Amélioration gestion du déplacement des menus.
535
*
536
* Revision 1.2  2004/05/03 14:51:59  jpm
537
* Normalisation du nom d'une fonction et ajout de la gestion d'une erreur.
538
*
539
* Revision 1.1  2004/04/30 16:21:30  jpm
540
* Ajout de la rédaction de contenu.
541
*
542
*
543
* +-- Fin du code ----------------------------------------------------------------------------------------+
544
*/
545
?>