897d4062251101aabe05a8a4872cecc92a8b2b8a
4 if (!defined("_ECRIRE_INC_VERSION")) return;
6 include_spip('inc/editer');
8 function formulaires_editer_menu_charger($id_menu, $nouveau){
9 include_spip('base/abstract_sql');
10 include_spip('inc/autoriser');
12 $contexte['editable'] = true;
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;
19 // Si on demande un id_menu
21 // On désactive de toute façon le nouveau
24 // On teste si le menu existe bien dans les menus principaux
25 $id_menu_ok = intval(sql_getfetsel(
29 array('=', 'id_menu', $id_menu),
30 array('=', 'id_menus_entree', 0)
36 $contexte['editable'] = false;
37 $contexte['message_erreur'] = _T('menus:erreur_menu_inexistant', array('id'=>$id_menu));
41 $contexte['editable'] = false;
42 $contexte['message_erreur'] = _T('menus:erreur_parametres');
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;
50 // Les champs du menu principal
51 $contexte['titre'] = '';
52 $contexte['identifiant'] = '';
53 $contexte['css'] = '';
54 $contexte['import'] = '';
56 $valeurs = formulaires_editer_objet_charger('menu',$id_menu,0,0,'', '', '', '');
58 $contexte = array_merge($contexte, $valeurs);
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':'')."' />";
69 $contexte['editable'] = false;
70 $contexte['message_erreur'] = _T('menus:erreur_autorisation');
76 function formulaires_editer_menu_verifier($id_menu, $nouveau){
77 include_spip('base/abstract_sql');
80 $oblis = array('titre','identifiant');
81 $erreurs = formulaires_editer_objet_verifier('menu',$id_menu,$oblis);
83 $identifiant = _request('identifiant');
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(
94 'identifiant = '.sql_quote($identifiant),
96 'id_menu !='.intval(_request('id_menu'))
100 $erreurs['identifiant'] = _T('menus:erreur_identifiant_deja');
106 function formulaires_editer_menu_traiter($id_menu, $nouveau){
107 $res = formulaires_editer_objet_traiter('menu', $id_menu, 0, 0, '', '', '', '');
109 // Si ça va pas on errorise
110 if (!$res['id_menu']){
111 $res['message_erreur'] = _T('menus:erreur_mise_a_jour');
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']);
118 // Dans tous les cas le formulaire est toujours éditable
119 $res['editable'] = true;