/** * Ajouter les champs extras sur les formulaires CVT editer_xx * * Liste les champs extras de l'objet, et s'il y en a les ajoute * sur le formulaire d'édition en ayant filtré uniquement les saisies * que peut voir le visiteur et en ayant ajouté des champs hidden * servant à champs extras. * * @pipeline editer_contenu_objet * @param array $flux Données du pipeline * @return array Données du pipeline **/ function cextras_editer_contenu_objet($flux){ // recuperer les saisies de l'objet en cours $objet = $flux['args']['type']; include_spip('inc/cextras'); if ($saisies = champs_extras_objet( table_objet_sql($objet) )) { // filtrer simplement les saisies que la personne en cours peut voir $saisies = champs_extras_autorisation('modifier', $objet, $saisies, $flux['args']); // pour chaque saisie presente, de type champs extras (hors fieldset et autres) // ajouter un flag d'edition $saisies = champs_extras_ajouter_drapeau_edition($saisies); // ajouter au formulaire $ajout = recuperer_fond('inclure/generer_saisies', array_merge($flux['args']['contexte'], array('saisies'=>$saisies))); // div par défaut en 3.1+, mais avant ul / li $balise = saisie_balise_structure_formulaire('ul'); $flux['data'] = preg_replace( '%(<!--extra-->)%is', "<$balise class='editer-groupe champs_extras'>$ajout</$balise>\n" . '$1', $flux['data'] ); } return $flux; }
/** * Ajouter les saisies de champs extras sur des formulaires spécifiques * * Les champs extras s'ajoutent déjà automatiquement sur les formulaires d'édition * des objets éditoriaux. Pour d'autres formulaires plus spécifiques, tel * que des formulaires d'inscriptions, il est possible d'envoyer, * dans la partie 'charger' du formulaire en question la clé * `_champs_extras_saisies`, listant les saisies à afficher dedans. * * Elles seront ajoutées automatiquement à l'endroit où le code * html `<!--extra-->` est présent dans le formulaire. * * @see cextras_obtenir_saisies_champs_extras() qui aide à récupérer les saisies. * * @param array $flux * @return array **/ function cextras_formulaire_fond($flux) { if (!empty($flux['args']['contexte']['_champs_extras_saisies'])) { $saisies = $flux['args']['contexte']['_champs_extras_saisies']; // ajouter au formulaire $ajout = recuperer_fond('inclure/generer_saisies', array_merge($flux['args']['contexte'], array('saisies' => $saisies))); // div par défaut en 3.1+, mais avant ul / li $balise = saisie_balise_structure_formulaire('ul'); $flux['data'] = preg_replace('%(<!--extra-->)%is', "<{$balise} class='editer-groupe champs_extras'>{$ajout}</{$balise}>\n" . '$1', $flux['data']); } return $flux; }
function formidable_generer_saisie_configurable($saisie, $env){ // On récupère le nom $nom = $saisie['options']['nom']; $identifiant = isset($saisie['identifiant']) ? $saisie['identifiant'] : ""; // On cherche si ya un formulaire de config $formulaire_config = isset($env['erreurs']['configurer_'.$nom]) ? $env['erreurs']['configurer_'.$nom] : ""; // On ajoute une classe if (!isset($saisie['options']['conteneur_class'])) { $saisie['options']['conteneur_class'] = ''; // initialisation } // Compat ancien nom li_class if (isset($saisie['options']['li_class'])) { $saisie['options']['conteneur_class'] .= " " . $saisie['options']['li_class']; // initialisation } $saisie['options']['conteneur_class'] .= ' configurable'; // On ajoute l'option "tout_afficher" $saisie['options']['tout_afficher'] = 'oui'; // On ajoute les boutons d'actions, mais seulement s'il n'y a pas de configuration de lancée if (!$env['erreurs']) { $saisie = saisies_inserer_html( $saisie, recuperer_fond( 'formulaires/inc-construire_formulaire-actions', array( 'nom' => $nom, 'identifiant' => $identifiant, 'formulaire_config' => $formulaire_config, 'deplacable' => $env['_chemin_ui'] ) ), 'debut' ); } // On ajoute une ancre pour s'y déplacer $saisie = saisies_inserer_html( $saisie, "\n<a id=\"configurer_$nom\"></a>\n", 'debut' ); // Si ya un form de config on l'ajoute à la fin if (is_array($formulaire_config)){ // On double l'environnement $env2 = $env; // On ajoute une classe $saisie['options']['conteneur_class'] .= ' en_configuration'; // Si possible on met en readonly $saisie['options']['readonly'] = 'oui'; // On vire les sous-saisies s'il y en a if (isset($saisie['saisies']) and $saisie['saisies'] and is_array($saisie['saisies'])){ $nb_champs_masques = count(saisies_lister_champs($saisie['saisies'])); $saisie['saisies'] = array( array( 'saisie' => 'explication', 'options' => array( 'nom' => 'truc', 'texte' => _T('saisies:construire_info_nb_champs_masques', array('nb'=>$nb_champs_masques)), ) ) ); } // On va ajouter le champ pour la position if (!($chemin_description = saisies_chercher($formulaire_config, "saisie_modifiee_${nom}[options][description]", true))){ $chemin_description = array(0); $formulaire_config = saisies_inserer( $formulaire_config, array( 'saisie' => 'fieldset', 'options' => array( 'nom' => "saisie_modifiee_${nom}[options][description]", 'label' => _T('saisies:option_groupe_description') ), 'saisies' => array() ), 0 ); } $chemin_description[] = 'saisies'; $chemin_description[] = '0'; // tout au début $formulaire_config = saisies_inserer( $formulaire_config, array( 'saisie' => 'position_construire_formulaire', 'options' => array( 'nom' => "saisie_modifiee_${nom}[position]", 'label' => _T('saisies:construire_position_label'), 'explication' => _T('saisies:construire_position_explication'), 'formulaire' => $env['_contenu'], 'saisie_a_positionner' => $nom ) ), $chemin_description ); $env2['saisies'] = $formulaire_config; // Un test pour savoir si on prend le _request ou bien $erreurs_test = $env['erreurs']; unset($erreurs_test['configurer_'.$nom]); unset($erreurs_test['positionner']); unset($erreurs_test['message_erreur']); if ($erreurs_test){ // Là aussi on désinfecte à la main if (isset($env2["saisie_modifiee_$nom"]['options']) and is_array($env2["saisie_modifiee_$nom"]['options'])) { spip_desinfecte($env2["saisie_modifiee_$nom"]['options']); } } else{ $env2["saisie_modifiee_$nom"] = $env2['_saisies_par_nom'][$nom]; // il n'y a pas toujours de verification... if (isset($env2["saisie_modifiee_$nom"]['verifier'])) { $env2["saisie_modifiee_$nom"]['verifier'][ $env2["saisie_modifiee_$nom"]['verifier']['type'] ] = $env2["saisie_modifiee_$nom"]['verifier']['options']; } } $env2['fond_generer'] = 'inclure/generer_saisies'; $saisie = saisies_inserer_html( $saisie, '<div class="formulaire_configurer"><'.saisie_balise_structure_formulaire('ul').' class="editer-groupe formulaire_configurer-contenus">' .recuperer_fond( 'inclure/generer_saisies', $env2 ) .'<'.saisie_balise_structure_formulaire('li').' class="boutons"> <input type="hidden" name="enregistrer_saisie" value="'.$nom.'" /> <button type="submit" class="submit link" name="enregistrer_saisie" value="">'._T('bouton_annuler').'</button> <input type="submit" class="submit" name="enregistrer" value="'._T('bouton_valider').'" /> </'.saisie_balise_structure_formulaire('li').'>' .'</'.saisie_balise_structure_formulaire('ul').'></div>', 'fin' ); } // On génère le HTML de la saisie $html = saisies_generer_html($saisie, $env); return $html; }