sousmenu['cfg']= new Bouton(
_DIR_PLUGIN_CFG.$icone, // icone
_T('cfg:CFG'));
}
return $flux;
}
/**
* Rajoute à gauche de la page d'admin des plugins un lien vers
* la page de CFG
*
* @param Array $flux
* @return Array
*/
function cfg_affiche_gauche($flux){
if ($flux['args']['exec']=='admin_plugin'){
$flux['data'] =
debut_cadre_enfonce('',true)
. icone_horizontale('CFG – '._T('configuration'), generer_url_ecrire('cfg'), _DIR_PLUGIN_CFG.'cfg-22.png', '', false)
. fin_cadre_enfonce(true)
. $flux['data'];
}
return $flux;
}
/**
* Gerer l'option des fonds CFG
* uniquement dans le prive
*
* @param Array $flux
* @return Array
*/
function cfg_header_prive($flux){
if (!_request('cfg') || (!_request('exec') == 'cfg')) {
return $flux;
}
// Ajout des css de cfg
$flux .= '';
include_spip('inc/filtres');
include_spip('inc/cfg_formulaire');
$config = new cfg_formulaire(
sinon(_request('cfg'), ''),
sinon(_request('cfg_id'),''));
if ($config->param['head'])
$flux .= "\n".$config->param['head'];
return $flux;
}
/**
* CSS à ajouter lors du #INSERT_HEAD
*
* @param Array $flux
* @return Array
*/
function cfg_insert_head_css($flux){
// Ajout des css de cfg
static $done = false;
if (!$done) {
$done = true;
if (_INSERT_HEAD_CFG)
$flux .= '';
}
return $flux;
}
/**
* CSS à ajouter lors du #INSERT_HEAD_CSS
*
* @param Array $flux
* @return Array
*/
function cfg_insert_head($flux){
$flux = cfg_insert_head_css($flux); // au cas ou il n'est pas implemente
return $flux;
}
/**
* teste si $form n'est pas un formulaire CVT deja existant
* (et non un formulaire CFG nomme $form en CVT)
*
* #FORMULAIRE_TOTO <> #FORMULAIRE_CFG{toto}
*
* @param string $form Nom du formulaire
* @return boolean TRUE si formulaire_$form est un CVT deja existant
*/
function est_cvt($form){
$f = 'formulaires_' . $form;
return (function_exists($f . '_stat')
OR function_exists($f . '_charger_dist')
OR function_exists($f . '_charger')
OR function_exists($f . '_verifier_dist')
OR function_exists($f . '_verifier')
OR function_exists($f . '_traiter_dist')
OR function_exists($f . '_traiter')
);
}
/**
* Formulaires CFG CVT : Charger
*
* @param Array $flux
* @return Array
*/
function cfg_formulaire_charger($flux){
// s'il n'y a pas de fonction charger, on utilise le parseur de CFG
$form = $flux['args']['form'];
if (!est_cvt($form) AND !count($flux['data'])){
// ici, on a le nom du fond cfg...
// on recupere donc les parametres du formulaire.
include_spip('inc/cfg_formulaire');
#$config = &new cfg_formulaire($cfg, $cfg_id);
$cfg_id = isset($flux['args']['args'][0]) ? $flux['args']['args'][0] : '';
$config = new cfg_formulaire($form, $cfg_id);
$valeurs = array(
'_cfg_fond' => 'formulaires/'.$form,
'_cfg_nom' => $form,
'id' => $cfg_id,
'_param' => $config->param,
// passer aussi les arguments spécifiques a cfg
'_cfg_' => $config->creer_hash_cfg(), // passer action=cfg pour avoir un hash formulaire correct
'_hidden' => ""
);
// il faut passer les noms des champs (input et consoeurs) de CFG dans l'environnement
// pour pouvoir faire #ENV{nom_du_champ}
if (is_array($config->val)){
foreach($config->val as $nom=>$val){
$valeurs[$nom] = $val;
}
}
if (!$config->autoriser()) {
$valeurs['editable'] = false;
} else {
$valeurs['editable'] = true;
}
$valeurs['_pipeline'] = array('editer_contenu_formulaire_cfg',
'args'=>array(
'nom'=>$form,
'contexte'=>$valeurs,
'ajouter'=>$config->param['inline'])
);
$flux['data'] = $valeurs;
// return $valeurs; // retourner simplement les valeurs
#return array(true,$valeurs); // forcer l'etat editable du formulaire et retourner les valeurs
}
return $flux;
}
/**
* Formulaires CFG CVT : Vérifier
*
* @param Array $flux
* @return Array
*/
function cfg_formulaire_verifier($flux){
$form = $flux['args']['form'];
if (_request('_cfg_is_cfg') AND !est_cvt($form)){
include_spip('inc/cfg_formulaire');
#$config = &new cfg_formulaire($cfg, $cfg_id);
$cfg_id = isset($flux['args']['args'][0]) ? $flux['args']['args'][0] : '';
$config = new cfg_formulaire($form, $cfg_id);
$err = array();
if (!$config->verifier() && $e = $config->messages){
if (isset($e['message_refus'])) {
$err['message_erreur'] = $e['message_refus'];
} else {
if (count($e['erreurs'])) $err = $e['erreurs'];
if (count($e['message_erreur'])) $err['message_erreur'] = join(' ',$e['message_erreur']);
if (count($e['message_ok'])) $err['message_ok'] = join(' ',$e['message_ok']);
}
}
$flux['data'] = $err;
// si c'est vide, modifier sera appele, sinon le formulaire sera resoumis
// a ce moment la, on transmet $config pour eviter de le recreer
// juste ensuite (et de refaire les analyse et la validation)
if (!$err) cfg_instancier($config);
}
return $flux;
}
/**
* sauve ou redonne une instance de la classe cfg.
* sert a transmettre $config entre verifier() et traiter()
* car $flux le perd en cours de route si on lui donne...
*
* @staticvar boolean|Object $cfg
* @param boolean|Object $config $config est de type cfg_formulaire
* @return boolean|Object
*/
function cfg_instancier($config=false){
static $cfg=false;
if (!$config) return $cfg;
return $cfg = $config;
}
/**
* Formulaires CFG CVT : Traiter
*
* @param $flux
* @return
*/
function cfg_formulaire_traiter($flux){
$form = $flux['args']['form'];
if (_request('_cfg_is_cfg') AND !est_cvt($form)){
$config = cfg_instancier();
$config->traiter();
$message = join(' ',$config->messages['message_ok']);
$redirect = $config->messages['redirect'];
$flux['data'] = array('editable'=>true,'message_ok' => $message,'redirect' => $redirect); // forcer l'etat editable du formulaire et retourner le message
}
return $flux;
}
/**
* pipeline sur l'affichage du contenu
* pour supprimer les parametres CFG du formulaire
*
* @param Array $flux
* @return Array
*/
function cfg_editer_contenu_formulaire_cfg($flux){
$flux['data'] = preg_replace('/(/sim', '', $flux['data']);
$flux['data'] .= $flux['args']['ajouter'];
return $flux;
}
?>