Newer
Older
<?php
/**
* Chargement des fonctions pour les squelettes
*
* @package SPIP\Formidable\Fonctions
**/
include_spip('inc/formidable');
include_spip('public/formidable_criteres');

rastapopoulos@spip.org
a validé
/**
* #VOIR_REPONSE{checkbox_2} dans une boucle (FORMULAIRES_REPONSES)
*
* @param Pile $p
* @return Pile
*/
function balise_VOIR_REPONSE_dist($p) {
$nom = interprete_argument_balise(1, $p);
if (!$type_retour = interprete_argument_balise(2, $p)) { $type_retour = 'null'; }
if (!$sans_reponse = interprete_argument_balise(3, $p)) { $sans_reponse = 'null'; }
$id_formulaires_reponse = champ_sql('id_formulaires_reponse', $p);
$id_formulaire = champ_sql('id_formulaire', $p);
$p->code = "calculer_voir_reponse($id_formulaires_reponse, $id_formulaire, $nom, $type_retour, $sans_reponse)";
return $p;
}

cedric@yterium.com
a validé
/**
* @param int $id_formulaires_reponse
* @param int $id_formulaire
* @param string $nom
* @param string $type_retour
* 'brut' : valeur brute
* 'valeur_uniquement' : la valeur seulement
* defaut : tout le HTML de la saisie
* @param null|string $sans_reponse
* texte affiche si aucune valeur en base pour ce champ
* @return array|string
*/

rastapopoulos@spip.org
a validé
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
function calculer_voir_reponse($id_formulaires_reponse, $id_formulaire, $nom, $type_retour=null, $sans_reponse=null){
static $formulaires_saisies = array();
static $reponses_valeurs = array();
$tenter_unserialize = charger_fonction('tenter_unserialize', 'filtre/');
// Si pas déjà présent, on cherche les saisies de ce formulaire
if (is_null($formulaires_saisies[$id_formulaire])) {
$formulaires_saisies[$id_formulaire] = unserialize(sql_getfetsel('saisies', 'spip_formulaires', 'id_formulaire = '.intval($id_formulaire)));
}
// Si pas déjà présent, on cherche les valeurs de cette réponse
if (is_null($reponses_valeurs[$id_formulaires_reponse])) {
if ($champs = sql_allfetsel('nom,valeur', 'spip_formulaires_reponses_champs', 'id_formulaires_reponse = '.intval($id_formulaires_reponse))) {
foreach ($champs as $champ) {
$reponses_valeurs[$id_formulaires_reponse][$champ['nom']] = $tenter_unserialize($champ['valeur']);
}
}
}
// Si on demande la valeur brute, on ne génère rien, on renvoie telle quelle
if ($type_retour == 'brut') {
return $reponses_valeurs[$id_formulaires_reponse][$nom];
}
// Si on trouve bien la saisie demandée
if ($saisie = saisies_chercher($formulaires_saisies[$id_formulaire], $nom)) {
// On génère la vue de cette saisie avec la valeur trouvée précédemment
return recuperer_fond(
'saisies-vues/_base',
array_merge(
array(
'type_saisie' => $saisie['saisie'],
'valeur' => $reponses_valeurs[$id_formulaires_reponse][$nom],
'valeur_uniquement' => ($type_retour == 'valeur_uniquement' ? 'oui' : 'non'),
'sans_reponse' => $sans_reponse,
),
$saisie['options']
)
);
}
}

cedric@yterium.com
a validé
/**
* Afficher le resume d'une reponse selon un modele qui contient des noms de champ "@input_1@ ..."
*
* @param int $id_formulaires_reponse
* @param int $id_formulaire
* @param string $resume_reponse
* @return string
*/
function affiche_resume_reponse($id_formulaires_reponse, $id_formulaire=null, $modele_resume=null){
static $modeles_resume = array();

cedric@yterium.com
a validé
static $modeles_vars = array();

cedric@yterium.com
a validé
if (is_null($id_formulaire)){
$id_formulaire = sql_getfetsel("id_formulaire","spip_formulaires_reponses","id_formulaires_reponse=".intval($id_formulaires_reponse));
}
if (is_null($modele_resume) AND !isset($modeles_resume[$id_formulaire])){
$modeles_resume[$id_formulaire] = sql_getfetsel("resume_reponse","spip_formulaires","id_formulaire=".intval($id_formulaire));
}
if (is_null($modele_resume))
$modele_resume = $modeles_resume[$id_formulaire];
if (!$modele_resume)
return "";

cedric@yterium.com
a validé
if (!isset($modeles_vars[$modele_resume])){
preg_match_all(",@(.*)@,Uims",$modele_resume,$matches);
$modeles_vars[$modele_resume] = $matches[1];

cedric@yterium.com
a validé
}

cedric@yterium.com
a validé
$valeurs = array();
foreach($modeles_vars[$modele_resume] as $var){
$valeur = calculer_voir_reponse($id_formulaires_reponse, $id_formulaire, $var, 'valeur_uniquement', '');
$valeur = str_ireplace("</p>","",$valeur); // on ne veut pas du \n de PtoBR, mais on ne veut pas non plus faire un trim
$valeur = PtoBR($valeur);
if (strpos($valeur,"</li>")){
$valeur = explode("</li>",$valeur);
array_pop($valeur);
$valeur = implode(", ",$valeur);
}
$valeur = supprimer_tags($valeur);
$valeurs["@$var@"] = $valeur;
}
return pipeline('formidable_affiche_resume_reponse',
array(
'args' => array(
'id_formulaire' => $id_formulaire,
'id_formulaires_reponse' => $id_formulaires_reponse,
'modele_resume' => $modele_resume,
'valeurs' => $valeurs,
),
'data' => str_replace(array_keys($valeurs),array_values($valeurs),$modele_resume),
)
);