{html_checkboxes}

{html_checkboxes} est une fonction utilisateur qui crée un groupe de cases à cocher avec les données fournies. Elle prend en compte la liste des éléments sélectionnés par défaut. Les attributs requis sont values et output, à moins que vous n'utilisiez options à la place. La sortie générée est compatible XHTML.

Nom attributTypeRequisDefautDescription
namechaîne de caractèresNoncheckboxNom de la liste de cases à cocher
valuesarrayOui, à moins que vous n'utilisiez l'attribut optionn/aUn tableau de valeurs pour les cases à cocher
outputarrayOui, à moins que vous n'utilisiez l'attribut optionn/aUn tableau de sortie pour les cases à cocher
selectedchaîne de caractères/tableauNonemptyLes éléments cochés de la liste
optionsTableau associatifOui, à moins que vous n'utilisiez values et outputn/aUn tableau associatif de valeurs et sorties
separatorchaîne de caractèresNonemptychaîne de caractère pour séparer chaque case à cocher
labelsbooléenNontrueajoute la balise <label>- à la sortie

Tous les paramètres qui ne sont pas listés ci-dessus sont affichés en tant que paires nom/valeur dans chaque balise <input> crée.

Exemple 8-7. {html_checkboxes}

<?php

$smarty
->assign('cust_ids', array(1000,1001,1002,1003));
$smarty->assign('cust_names', array(
                                
'Joe Schmoe',
                                
'Jack Smith',
                                
'Jane Johnson',
                                
'Charlie Brown')
                              );
$smarty->assign('customer_id'1001);

?>

où index.tpl est :

{html_checkboxes name="id" values=$cust_ids output=$cust_names
   selected=$customer_id  separator="<br />"}

ou bien, le code PHP est :

<?php

$smarty
->assign('cust_checkboxes', array(
                                
1000 => 'Joe Schmoe',
                                
1001 => 'Jack Smith',
                                
1002 => 'Jane Johnson',
                                
1003 => 'Charlie Brown')
                              );
$smarty->assign('customer_id'1001);

?>

et index.tpl est :

{html_checkboxes name="id" options=$cust_checkboxes selected=$customer_id separator="<br />"}

Les deux examples donnent à l'écran :

<label><input type="checkbox" name="id[]" value="1000" />Joe Schmoe</label><br />
<label><input type="checkbox" name="id[]" value="1001" checked="checked" />Jack Smith</label>
<br />
<label><input type="checkbox" name="id[]" value="1002" />Jane Johnson</label><br />
<label><input type="checkbox" name="id[]" value="1003" />Charlie Brown</label><br />

Exemple 8-8. Exemple avec une base de données (eg PEAR ou ADODB) :

<?php

$sql 
'select type_id, types from types order by type';
$smarty->assign('types',$db->getAssoc($sql));

$sql 'select * from contacts where contact_id=12';
$smarty->assign('contact',$db->getRow($sql));

?>
{html_checkboxes name="type" options=$types selected=$contact.type_id separator="<br />"}

Voir aussi {html_radios} et {html_options}.