ji_louis Smarty Rookie
Joined: 27 Jan 2011 Posts: 5 Location: Saint Malo / Paris
|
Posted: Thu Dec 01, 2011 1:39 pm Post subject: html_select_date |
|
|
For my personnal purpose, I have changed some code in the html_select_date (file ....lib\smarty\plugins\function.html_select_date.php).
Explainations:
I need date lists for optionally entering dates : Lists must be able to present an empty option as selected value at start, and return a value considered as null (like date 0000-00-00).
I want also those lists to be able to have a selected date (given as parameter) shown selected at start.
I want to have several html_select_date lists in the same form to be able to select interval dates
So I added 3 optionnal parameters:
'selected date' = $value where $value is a yyyy-mm-dd date
'zero' = $value where $value take any not null value.
'postfix' = $value (where $value uses to be "[]"). This $value is concatened at the end of the name of lists. "[]" enable PHP to take is as an array member.
My code may be improved (the "date_default_timezone_set('Europe/Paris')" as to be changed or removed) but if functions well right now. My comments are in french. This is my version of the html_select_date.php file.
Code: | function smarty_function_html_select_date($params, &$smarty)
{
require_once $smarty->_get_plugin_filepath('shared','escape_special_chars');
require_once $smarty->_get_plugin_filepath('shared','make_timestamp');
require_once $smarty->_get_plugin_filepath('function','html_options');
/* Default values. */
date_default_timezone_set('Europe/Paris');
$postfix = "";
$prefix = "Date_";
$start_year = strftime("%Y");
$end_year = $start_year;
$display_days = true;
$display_months = true;
$display_years = true;
$month_format = "%B";
/* Write months as numbers by default GL */
$month_value_format = "%m";
$day_format = "%02d";
/* Write day values using this format MB */
$day_value_format = "%d";
$year_as_text = false;
/* Display years in reverse order? Ie. 2000,1999,.... */
$reverse_years = false;
/* Should the select boxes be part of an array when returned from PHP?
e.g. setting it to "birthday", would create "birthday[Day]",
"birthday[Month]" & "birthday[Year]". Can be combined with prefix */
$field_array = null;
/* <select size>'s of the different <select> tags.
If not set, uses default dropdown. */
$day_size = null;
$month_size = null;
$year_size = null;
/* Unparsed attributes common to *ALL* the <select>/<input> tags.
An example might be in the template: all_extra ='class ="foo"'. */
$all_extra = null;
/* Separate attributes for the tags. */
$day_extra = null;
$month_extra = null;
$year_extra = null;
/* Order in which to display the fields.
"D" -> day, "M" -> month, "Y" -> year. */
$field_order = 'DMY';
/* String printed between the different fields. */
$field_separator = "\n";
$time = time();
$all_empty = null;
$day_empty = null;
$month_empty = null;
$year_empty = null;
$extra_attrs = '';
$selected_day = null;
$selected_month = null;
$selected_year = null;
foreach ($params as $_key=>$_value) {
switch ($_key) {
// une date au format yyyy-mm-dd est passée en paramètre comme date sélectionnée
case 'zero': $zero = true;
$selected_day = "00";
$selected_month = "00";
$selected_year = "0000";
break;
case 'selected_date':
$selected_day = substr($_value, 8, 2);
$selected_month = substr($_value, 5, 2);
$selected_year = substr($_value, 0, 4);
break;
case 'prefix':
case 'postfix': $postfix = $_value;
case 'time':
case 'start_year':
case 'end_year':
case 'month_format':
case 'day_format':
case 'day_value_format':
case 'field_array':
case 'day_size':
case 'month_size':
case 'year_size':
case 'all_extra':
case 'day_extra':
case 'month_extra':
case 'year_extra':
case 'field_order':
case 'field_separator':
case 'month_value_format':
case 'month_empty':
case 'day_empty':
case 'year_empty':
$$_key = (string)$_value;
break;
case 'all_empty':
$$_key = (string)$_value;
$day_empty = $month_empty = $year_empty = $all_empty;
break;
case 'display_days':
case 'display_months':
case 'display_years':
case 'year_as_text':
case 'reverse_years':
$$_key = (bool)$_value;
break;
default:
if(!is_array($_value)) {
$extra_attrs .= ' '.$_key.'="'.smarty_function_escape_special_chars($_value).'"';
} else {
$smarty->trigger_error("html_select_date: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
}
break;
}
}
if (preg_match('!^-\d+$!', $time)) {
// negative timestamp, use date()
$time = date('Y-m-d', $time);
}
// If $time is not in format yyyy-mm-dd
if (preg_match('/^(\d{0,4}-\d{0,2}-\d{0,2})/', $time, $found)) {
$time = $found[1];
} else {
// use smarty_make_timestamp to get an unix timestamp and
// strftime to make yyyy-mm-dd
$time = strftime('%Y-%m-%d', smarty_make_timestamp($time));
}
// Now split this in pieces, which later can be used to set the select
$time = explode("-", $time);
// make syntax "+N" or "-N" work with start_year and end_year
if (preg_match('!^(\+|\-)\s*(\d+)$!', $end_year, $match)) {
if ($match[1] == '+') {
$end_year = strftime('%Y') + $match[2];
} else {
$end_year = strftime('%Y') - $match[2];
}
}
if (preg_match('!^(\+|\-)\s*(\d+)$!', $start_year, $match)) {
if ($match[1] == '+') {
$start_year = strftime('%Y') + $match[2];
} else {
$start_year = strftime('%Y') - $match[2];
}
}
if (strlen($time[0]) > 0) {
if ($start_year > $time[0] && !isset($params['start_year'])) {
// force start year to include given date if not explicitly set
$start_year = $time[0];
}
if($end_year < $time[0] && !isset($params['end_year'])) {
// force end year to include given date if not explicitly set
$end_year = $time[0];
}
}
$field_order = strtoupper($field_order);
$html_result = $month_result = $day_result = $year_result = "";
$field_separator_count = -1;
if ($display_months) {
$field_separator_count++;
$month_names = array();
$month_values = array();
if(isset($month_empty)) {
$month_names[''] = $month_empty;
$month_values[''] = '';
}
for ($i = 1; $i <= 12; $i++) {
$month_names[$i] = strftime($month_format, mktime(0, 0, 0, $i, 1, 2000));
$month_values[$i] = strftime($month_value_format, mktime(0, 0, 0, $i, 1, 2000));
}
if ($zero == true) {
$month_values[] = "00";
}
$month_result .= '<select name=';
if (null !== $field_array){
$month_result .= $field_array . '[' . $prefix . 'Month]' . $postfix;
} else {
$month_result .= $prefix . 'Month' . $postfix;
}
if (null !== $month_size){
$month_result .= ' size="' . $month_size . '"';
}
if (null !== $month_extra){
$month_result .= ' ' . $month_extra;
}
if (null !== $all_extra){
$month_result .= ' ' . $all_extra;
}
$month_result .= $extra_attrs . '>'."\n";
if (!isset($selected_month)) {
$mois = (int)$time[1];
} elseif ($selected_month === "00") {
$mois = 0;
} else {
$mois = strftime($month_value_format, mktime(0, 0, 0, $selected_month, 1, 2000));
}
$month_result .= smarty_function_html_options(array('output' => $month_names,
'values' => $month_values,
'selected' => $mois,
'print_result' => false),
$smarty);
$month_result .= '</select>';
}
if ($display_days) {
$field_separator_count++;
$days = array();
if (isset($day_empty)) {
$days[''] = $day_empty;
$day_values[''] = '';
}
for ($i = 1; $i <= 31; $i++) {
$days[] = sprintf($day_format, $i);
$day_values[] = sprintf($day_value_format, $i);
}
if ($zero == true) {
$day_values[] = "00";
}
$day_result .= '<select name=';
if (null !== $field_array){
$day_result .= $field_array . '[' . $prefix . 'Day]' . $postfix;
} else {
$day_result .= $prefix . 'Day' . $postfix;
}
if (null !== $day_size){
$day_result .= ' size="' . $day_size . '"';
}
if (null !== $all_extra){
$day_result .= ' ' . $all_extra;
}
if (null !== $day_extra){
$day_result .= ' ' . $day_extra;
}
$day_result .= $extra_attrs . '>'."\n";
$jour = (isset($selected_day) ? $selected_day : (int)$time[2]);
$day_result .= smarty_function_html_options(array('output' => $days,
'values' => $day_values,
'selected' => $jour,
'print_result' => false),
$smarty);
$day_result .= '</select>';
}
if ($display_years) {
$field_separator_count++;
if (null !== $field_array){
$year_name = $field_array . '[' . $prefix . 'Year]' . $postfix;
} else {
$year_name = $prefix . 'Year' . $postfix;
}
if ($year_as_text) {
$year_result .= '<input type="text" name="' . $year_name . '" value="' . $time[0] . '" size="4" maxlength="4"';
if (null !== $all_extra){
$year_result .= ' ' . $all_extra;
}
if (null !== $year_extra){
$year_result .= ' ' . $year_extra;
}
$year_result .= ' />';
} else {
$years = range((int)$start_year, (int)$end_year);
if ($reverse_years) {
rsort($years, SORT_NUMERIC);
} else {
sort($years, SORT_NUMERIC);
}
$yearvals = $years;
if(isset($year_empty)) {
array_unshift($years, $year_empty);
array_unshift($yearvals, '');
} elseif ($zero == true) {
$yearvals[] = "0000";
}
$year_result .= '<select name="' . $year_name . '"';
if (null !== $year_size){
$year_result .= ' size="' . $year_size . '"';
}
if (null !== $all_extra){
$year_result .= ' ' . $all_extra;
}
if (null !== $year_extra){
$year_result .= ' ' . $year_extra;
}
$year_result .= $extra_attrs . '>'."\n";
$annee = (isset($selected_year) ? $selected_year : (int)$time[0]);
$year_result .= smarty_function_html_options(array('output' => $years,
'values' => $yearvals,
'selected' => $annee,
'print_result' => false),
$smarty);
$year_result .= '</select>';
}
}
// Loop thru the field_order field
for ($i = 0; $i <= 2; $i++){
$c = substr($field_order, $i, 1);
switch ($c){
case 'D':
$html_result .= $day_result;
break;
case 'M':
$html_result .= $month_result;
break;
case 'Y':
$html_result .= $year_result;
break;
}
// Add the field seperator
if($i < $field_separator_count) {
$html_result .= $field_separator;
}
}
return $html_result;
} |
Exemples of use:
Modifiable date in a presentation form:
{html_select_date id="DATE[]" start_year="1984" end_year="+1" selected_date=$MyObject->getMyDate()}
Optional date in a search form:
{html_select_date zero="true" id="DATE[]" start_year="1984" end_year="+1"}
Group of html_select_date lists to select an interval of time:
{html_select_date id="DATE[]" postfix="[]" start_year="-10"}{html_select_date id="DATE[]" postfix="[]" end_year="+10"}
All those parameters at the same time:
{html_select_date zero="true" id="DATE[]" postfix="[]" start_year="-10" selected_date=$yesterday}
{html_select_date zero="true" id="DATE[]" postfix="[]" end_year="+10" selected_date=$tomorrow} |
|