2008-07-18 16:02:46 +02:00
|
|
|
<?php
|
|
|
|
/*******************************************************************************
|
|
|
|
* Copyright (C) 2007 Easter-eggs
|
2021-04-13 18:04:19 +02:00
|
|
|
* https://ldapsaisie.org
|
2008-07-18 16:02:46 +02:00
|
|
|
*
|
|
|
|
* Author: See AUTHORS file in top-level directory.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License version 2
|
|
|
|
* as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Element date d'un formulaire pour LdapSaisie
|
|
|
|
*
|
|
|
|
* Cette classe définis les éléments dates des formulaires.
|
|
|
|
* Elle étant la classe basic LSformElement.
|
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
class LSformElement_date extends LSformElement {
|
|
|
|
|
2008-10-16 17:00:21 +02:00
|
|
|
var $fieldTemplate = 'LSformElement_date_field.tpl';
|
|
|
|
|
2008-07-18 16:02:46 +02:00
|
|
|
var $_php2js_format = array(
|
|
|
|
"a" => "a",
|
|
|
|
"A" => "A",
|
|
|
|
"b" => "b",
|
|
|
|
"B" => "B",
|
2011-06-24 15:42:06 +02:00
|
|
|
"c" => "c",
|
2008-07-18 16:02:46 +02:00
|
|
|
"d" => "d",
|
|
|
|
"e" => "e",
|
|
|
|
"H" => "H",
|
|
|
|
"I" => "I",
|
|
|
|
"j" => "j",
|
|
|
|
"m" => "m",
|
|
|
|
"M" => "M",
|
|
|
|
"p" => "p",
|
2011-06-24 15:42:06 +02:00
|
|
|
"s" => "s",
|
2008-07-18 16:02:46 +02:00
|
|
|
"S" => "S",
|
2011-06-24 15:42:06 +02:00
|
|
|
"T" => "T",
|
2008-07-18 16:02:46 +02:00
|
|
|
"U" => "U",
|
|
|
|
"w" => "w",
|
|
|
|
"y" => "y",
|
|
|
|
"Y" => "Y",
|
2011-06-24 15:42:06 +02:00
|
|
|
"z" => "z",
|
|
|
|
"Z" => "Z",
|
|
|
|
"%" => "%",
|
2008-07-18 16:02:46 +02:00
|
|
|
);
|
2011-06-24 15:42:06 +02:00
|
|
|
|
2008-07-18 16:02:46 +02:00
|
|
|
var $_cache_php2js_format=array();
|
|
|
|
|
2011-06-24 15:42:06 +02:00
|
|
|
var $default_style="vista";
|
|
|
|
|
2008-07-18 16:02:46 +02:00
|
|
|
/**
|
|
|
|
* Définis la valeur de l'élément date
|
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @param string|array $data La futur valeur de l'élément
|
2008-07-18 16:02:46 +02:00
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @return boolean Retourne True
|
2008-07-18 16:02:46 +02:00
|
|
|
*/
|
2019-03-12 11:42:53 +01:00
|
|
|
public function setValue($data) {
|
2020-09-09 18:40:44 +02:00
|
|
|
$special_values = $this -> getSpecialValues();
|
|
|
|
$values = array();
|
2020-11-30 19:43:52 +01:00
|
|
|
foreach (ensureIsArray($data) as $value) {
|
2020-09-09 18:40:44 +02:00
|
|
|
if(is_numeric($value)) {
|
|
|
|
if (array_key_exists($value, $special_values)) {
|
|
|
|
$values[] = $special_values[$value];
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$values[] = strftime($this -> getFormat(), $value);
|
2011-06-24 15:42:06 +02:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
$this -> form -> setElementError($this -> attr_html);
|
2020-09-09 18:40:44 +02:00
|
|
|
return false;
|
2011-06-24 15:42:06 +02:00
|
|
|
}
|
2008-07-18 16:02:46 +02:00
|
|
|
}
|
2020-09-09 18:40:44 +02:00
|
|
|
self :: log_trace("$this -> setValue():".varDump($data)." => ".varDump($values));
|
|
|
|
$this -> values = $values;
|
2008-07-18 16:02:46 +02:00
|
|
|
return true;
|
|
|
|
}
|
2020-04-29 15:54:21 +02:00
|
|
|
|
2008-07-18 16:02:46 +02:00
|
|
|
/**
|
|
|
|
* Exporte les valeurs de l'élément
|
2020-04-29 15:54:21 +02:00
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @return array Les valeurs de l'élement
|
2008-07-18 16:02:46 +02:00
|
|
|
*/
|
2019-03-12 11:42:53 +01:00
|
|
|
public function exportValues(){
|
2008-07-18 16:02:46 +02:00
|
|
|
$retval=array();
|
|
|
|
if (is_array($this -> values)) {
|
2020-09-09 18:40:44 +02:00
|
|
|
$special_values = $this -> getSpecialValues();
|
2008-07-18 16:02:46 +02:00
|
|
|
foreach($this -> values as $val) {
|
2020-09-09 18:40:44 +02:00
|
|
|
if (array_key_exists($val, $special_values)) {
|
|
|
|
$retval[] = $val;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$date = strptime($val, $this -> getFormat());
|
2008-07-18 16:02:46 +02:00
|
|
|
if (is_array($date)) {
|
2020-04-29 15:54:21 +02:00
|
|
|
$retval[] = mktime($date['tm_hour'],$date['tm_min'],$date['tm_sec'],$date['tm_mon']+1,$date['tm_mday'],$date['tm_year']+1900);
|
2008-07-18 16:02:46 +02:00
|
|
|
}
|
2020-09-09 18:40:44 +02:00
|
|
|
else {
|
|
|
|
self :: log_warning("exportValues($val): Fail to parse value from form.");
|
|
|
|
}
|
2008-07-18 16:02:46 +02:00
|
|
|
}
|
|
|
|
}
|
2020-09-09 18:40:44 +02:00
|
|
|
self :: log_trace("$this -> exportValues():".varDump($this -> values)." => ".varDump($retval));
|
2008-07-18 16:02:46 +02:00
|
|
|
return $retval;
|
|
|
|
}
|
2020-04-29 15:54:21 +02:00
|
|
|
|
2008-07-18 16:02:46 +02:00
|
|
|
/**
|
|
|
|
* Retourne le format d'affichage de la date
|
2020-04-29 15:54:21 +02:00
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @return string Le format de la date
|
2008-07-18 16:02:46 +02:00
|
|
|
**/
|
2019-03-12 11:42:53 +01:00
|
|
|
public function getFormat() {
|
2019-03-11 22:21:25 +01:00
|
|
|
return $this -> getParam('html_options.format', ($this -> getParam('html_options.time', true)?'%d/%m/%Y, %T':'%d/%m/%Y'));
|
2008-07-18 16:02:46 +02:00
|
|
|
}
|
|
|
|
|
2011-06-24 15:42:06 +02:00
|
|
|
/**
|
|
|
|
* Return date picker style value
|
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @return string The date picker style
|
2011-06-24 15:42:06 +02:00
|
|
|
**/
|
2019-03-12 11:42:53 +01:00
|
|
|
public function getStyle() {
|
2019-03-11 22:21:25 +01:00
|
|
|
$style = $this -> getParam('html_options.style', $this -> default_style, 'string');
|
|
|
|
if ($style) {
|
|
|
|
if (is_dir(LS_LIB_DIR.'arian-mootools-datepicker/datepicker_'.$style)) {
|
|
|
|
return $style;
|
2011-06-24 15:42:06 +02:00
|
|
|
}
|
2019-03-11 22:21:25 +01:00
|
|
|
LSdebug('LSformElement :: Date => unknown style parameter value '.$style);
|
2011-06-24 15:42:06 +02:00
|
|
|
}
|
|
|
|
return $this -> default_style;
|
|
|
|
}
|
|
|
|
|
2008-07-18 16:02:46 +02:00
|
|
|
/**
|
|
|
|
* Retourne les infos d'affichage de l'élément
|
2020-04-29 15:54:21 +02:00
|
|
|
*
|
2008-07-18 16:02:46 +02:00
|
|
|
* Cette méthode retourne les informations d'affichage de l'élement
|
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @return array
|
2008-07-18 16:02:46 +02:00
|
|
|
*/
|
2019-03-12 11:42:53 +01:00
|
|
|
public function getDisplay(){
|
2008-07-18 16:02:46 +02:00
|
|
|
$return = $this -> getLabelInfos();
|
|
|
|
// value
|
|
|
|
if (!$this -> isFreeze()) {
|
2008-11-10 03:32:18 +01:00
|
|
|
// Help Infos
|
2020-06-04 19:04:48 +02:00
|
|
|
LStemplate :: addHelpInfo(
|
2008-11-10 03:32:18 +01:00
|
|
|
'LSformElement_date',
|
|
|
|
array(
|
2011-06-27 15:48:54 +02:00
|
|
|
'now' => _('Now.'),
|
2020-09-11 13:38:07 +02:00
|
|
|
'today' => _('Today.'),
|
|
|
|
'clear' => _('Clear selected date.'),
|
2008-11-10 03:32:18 +01:00
|
|
|
)
|
|
|
|
);
|
2020-04-29 15:54:21 +02:00
|
|
|
|
2008-10-16 17:00:21 +02:00
|
|
|
$params = array(
|
|
|
|
'format' => $this -> php2js_format($this -> getFormat()),
|
2011-06-24 15:42:06 +02:00
|
|
|
'style' => $this -> getStyle(),
|
2019-03-11 22:21:25 +01:00
|
|
|
'time' => $this -> getParam('html_options.time', true, 'bool'),
|
|
|
|
'manual' => $this -> getParam('html_options.manual', true, 'bool'),
|
|
|
|
'showNowButton' => $this -> getParam('html_options.showNowButton', true, 'bool'),
|
|
|
|
'showTodayButton' => $this -> getParam('html_options.showTodayButton', true, 'bool'),
|
2008-10-16 17:00:21 +02:00
|
|
|
);
|
2020-05-28 16:56:36 +02:00
|
|
|
LStemplate :: addJSconfigParam($this -> name, $params);
|
2020-04-29 15:54:21 +02:00
|
|
|
|
2020-05-06 16:06:05 +02:00
|
|
|
$codeLang = str_replace('_','-',preg_replace('/\..*$/','', LSlang :: getLang()));
|
2011-06-24 15:42:06 +02:00
|
|
|
|
2020-05-28 16:56:36 +02:00
|
|
|
LStemplate :: addLibJSscript('arian-mootools-datepicker/Picker.js');
|
|
|
|
LStemplate :: addLibJSscript('arian-mootools-datepicker/Picker.Attach.js');
|
|
|
|
LStemplate :: addLibJSscript('arian-mootools-datepicker/Picker.Date.js');
|
|
|
|
LStemplate :: addLibJSscript('arian-mootools-datepicker/Locale.'.$codeLang.'.DatePicker.js');
|
|
|
|
LStemplate :: addLibCssFile('arian-mootools-datepicker/datepicker_'.$params['style'].'/datepicker_'.$params['style'].'.css');
|
2011-06-24 15:42:06 +02:00
|
|
|
|
2020-05-28 16:56:36 +02:00
|
|
|
LStemplate :: addJSscript('LSformElement_date_field.js');
|
|
|
|
LStemplate :: addJSscript('LSformElement_date.js');
|
2008-07-18 16:02:46 +02:00
|
|
|
}
|
2020-09-09 18:40:44 +02:00
|
|
|
|
2008-10-16 17:00:21 +02:00
|
|
|
$return['html'] = $this -> fetchTemplate();
|
2008-07-18 16:02:46 +02:00
|
|
|
return $return;
|
|
|
|
}
|
2020-04-29 15:54:21 +02:00
|
|
|
|
2020-09-09 18:40:44 +02:00
|
|
|
/**
|
|
|
|
* Retournne un template Smarty compilé dans le contexte d'un LSformElement
|
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @param string $template Le template à retourner
|
|
|
|
* @param array $variables Variables Smarty à assigner avant l'affichage
|
2020-09-09 18:40:44 +02:00
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @return string Le HTML compilé du template
|
2020-09-09 18:40:44 +02:00
|
|
|
*/
|
|
|
|
public function fetchTemplate($template=NULL, $variables=array()) {
|
|
|
|
$variables['special_values'] = $this -> getSpecialValues();
|
|
|
|
return parent :: fetchTemplate($template, $variables);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Recupère la valeur de l'élement passée en POST
|
|
|
|
*
|
|
|
|
* Cette méthode vérifie la présence en POST de la valeur de l'élément et la récupère
|
|
|
|
* pour la mettre dans le tableau passer en paramètre avec en clef le nom de l'élément
|
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @param array &$return Reference of the array for retrieved values
|
|
|
|
* @param boolean $onlyIfPresent If true and data of this element is not present in POST data,
|
2020-09-09 18:40:44 +02:00
|
|
|
* just ignore it.
|
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @return boolean true si la valeur est présente en POST, false sinon
|
2020-09-09 18:40:44 +02:00
|
|
|
*/
|
|
|
|
public function getPostData(&$return, $onlyIfPresent=false) {
|
|
|
|
if($this -> isFreeze()) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
$values = self :: getData($_POST, $this -> name);
|
|
|
|
self :: log_trace($this." -> getPostData(): values=".varDump($values));
|
2021-02-03 14:40:28 +01:00
|
|
|
if ($this -> form -> api_mode) {
|
|
|
|
$special_values = false;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$special_values = self :: getData($_POST, $this -> name.'__special_value');
|
|
|
|
self :: log_trace($this." -> getPostData(): special_values=".varDump($special_values));
|
|
|
|
}
|
2020-09-09 18:40:44 +02:00
|
|
|
if (!is_array($values) && !is_array($special_values)) {
|
|
|
|
self :: log_trace($this." -> getPostData(): not in POST data");
|
|
|
|
if ($onlyIfPresent) {
|
|
|
|
self :: log_debug($this -> name.": not in POST data => ignore it");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$return[$this -> name] = array();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
2020-12-01 16:42:20 +01:00
|
|
|
$return[$this -> name] = array();
|
|
|
|
if ($special_values !== false)
|
|
|
|
$return[$this -> name] += ensureIsArray($special_values);
|
|
|
|
if ($values !== false)
|
|
|
|
$return[$this -> name] += ensureIsArray($values);
|
2020-09-09 18:40:44 +02:00
|
|
|
self :: log_trace($this." -> merged values=".varDump($return[$this -> name]));
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve list of special values with translated labels
|
|
|
|
*
|
|
|
|
* @return array Associative array with special values as keys and corresponding translated labels as values
|
|
|
|
*/
|
|
|
|
public function getSpecialValues() {
|
|
|
|
$special_values = array();
|
|
|
|
foreach ($this -> getParam('html_options.special_values', array()) as $value => $label)
|
|
|
|
$special_values[strval($value)] = __($label);
|
|
|
|
self :: log_trace("getSpecialValues(): ".varDump($special_values));
|
|
|
|
return $special_values;
|
|
|
|
}
|
|
|
|
|
2008-07-18 16:02:46 +02:00
|
|
|
/**
|
|
|
|
* Convertis un format de date Php (strftime) en JS (jscalendar)
|
2020-04-29 15:54:21 +02:00
|
|
|
*
|
2022-12-31 05:52:31 +01:00
|
|
|
* @return mixed Format de date jscalendar (string) ou False si la convertion
|
2008-07-18 16:02:46 +02:00
|
|
|
* n'a pas réussi.
|
|
|
|
*/
|
2019-03-12 11:42:53 +01:00
|
|
|
public function php2js_format($format) {
|
2008-07-18 16:02:46 +02:00
|
|
|
if (isset($this -> _cache_php2js_format[$format])) {
|
|
|
|
return $this -> _cache_php2js_format[$format];
|
|
|
|
}
|
|
|
|
$new="";
|
|
|
|
for($i=0;$i<strlen($format);$i++) {
|
|
|
|
if ($format[$i]=="%") {
|
|
|
|
if (isset($this -> _php2js_format[$format[$i+1]])) {
|
|
|
|
$new.="%".$this -> _php2js_format[$format[$i+1]];
|
|
|
|
$i++;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$this -> _cache_php2js_format[$format]=false;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$new.=$format[$i];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$this -> _cache_php2js_format[$format]=$new;
|
|
|
|
return $new;
|
|
|
|
}
|
|
|
|
}
|