[PLUGINS] ~maj globale
[lhc/web/www.git] / www / plugins / menus_1 / formulaires / editer_menu.php
1 <?php
2
3 // Sécurité
4 if (!defined("_ECRIRE_INC_VERSION")) return;
5
6 include_spip('inc/editer');
7
8 function formulaires_editer_menu_charger($id_menu, $nouveau){
9 include_spip('base/abstract_sql');
10 include_spip('inc/autoriser');
11 $contexte = array();
12 $contexte['editable'] = true;
13
14 // Seulement si on a le droit de modifier les menus
15 if (autoriser('modifier', 'menu')){
16 $nouveau = ($nouveau == 'oui') ? true : false;
17 $id_menu = intval($id_menu) ? intval($id_menu) : false;
18
19 // Si on demande un id_menu
20 if ($id_menu){
21 // On désactive de toute façon le nouveau
22 $nouveau = false;
23
24 // On teste si le menu existe bien dans les menus principaux
25 $id_menu_ok = intval(sql_getfetsel(
26 'id_menu',
27 'spip_menus',
28 array(
29 array('=', 'id_menu', $id_menu),
30 array('=', 'id_menus_entree', 0)
31 )
32 ));
33
34 // S'il n'existe pas
35 if (!$id_menu_ok){
36 $contexte['editable'] = false;
37 $contexte['message_erreur'] = _T('menus:erreur_menu_inexistant', array('id'=>$id_menu));
38 }
39 }
40 elseif (!$nouveau){
41 $contexte['editable'] = false;
42 $contexte['message_erreur'] = _T('menus:erreur_parametres');
43 }
44
45 // Si on peut bien éditer le menu, on déclare ce qu'il faut
46 if ($contexte['editable']){
47 $contexte['id_menu'] = $id_menu;
48 $contexte['nouveau'] = $nouveau;
49
50 // Les champs du menu principal
51 $contexte['titre'] = '';
52 $contexte['identifiant'] = '';
53 $contexte['css'] = '';
54 $contexte['import'] = '';
55
56 $valeurs = formulaires_editer_objet_charger('menu',$id_menu,0,0,'', '', '', '');
57
58 $contexte = array_merge($contexte, $valeurs);
59
60 // Déclarer l'action pour SPIP 2.0
61 $contexte['_action'] = array('editer_menu', $id_menu);
62 // On sait toujours si on est sur un menu déjà créé ou pas
63 $contexte['_hidden'] .= '<input type="hidden" name="id_menu" value="'.$id_menu.'" />';
64 // reinjecter nouveau si besoin, sinon la page de l'espace prive ne reaffiche pas le form
65 $contexte['_hidden'] .= "<input type='hidden' name='nouveau' value='".($nouveau?'oui':'')."' />";
66 }
67 }
68 else{
69 $contexte['editable'] = false;
70 $contexte['message_erreur'] = _T('menus:erreur_autorisation');
71 }
72
73 return $contexte;
74 }
75
76 function formulaires_editer_menu_verifier($id_menu, $nouveau){
77 include_spip('base/abstract_sql');
78 $erreurs = array();
79
80 $oblis = array('titre','identifiant');
81 $erreurs = formulaires_editer_objet_verifier('menu',$id_menu,$oblis);
82
83 $identifiant = _request('identifiant');
84
85 // On vérifie que l'identifiant est bon
86 if (empty($erreurs['identifiant']) and !preg_match('/^[\w-]+$/', $identifiant))
87 $erreurs['identifiant'] = _T('menus:erreur_identifiant_forme');
88 // On vérifie que l'identifiant n'est pas déjà utilisé
89 if (empty($erreurs['identifiant'])) {
90 $deja = sql_getfetsel(
91 'id_menu',
92 'spip_menus',
93 array(
94 'identifiant = '.sql_quote($identifiant),
95 'id_menu > 0',
96 'id_menu !='.intval(_request('id_menu'))
97 )
98 );
99 if ($deja)
100 $erreurs['identifiant'] = _T('menus:erreur_identifiant_deja');
101 }
102
103 return $erreurs;
104 }
105
106 function formulaires_editer_menu_traiter($id_menu, $nouveau){
107 $res = formulaires_editer_objet_traiter('menu', $id_menu, 0, 0, '', '', '', '');
108
109 // Si ça va pas on errorise
110 if (!$res['id_menu']){
111 $res['message_erreur'] = _T('menus:erreur_mise_a_jour');
112 }
113 else{
114 // Si on est dans l'espace privé on force la redirection
115 if (_request('exec') == 'menus_editer')
116 $res['redirect'] = generer_url_ecrire('menus_editer', "id_menu=".$res['id_menu']);
117 }
118 // Dans tous les cas le formulaire est toujours éditable
119 $res['editable'] = true;
120
121 return $res;
122 }
123
124 ?>