1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/spip_ynh.git synced 2024-09-03 20:25:59 +02:00
spip_ynh/sources/prive/formulaires/dater.php
2015-04-28 17:10:23 +02:00

246 lines
7.5 KiB
PHP

<?php
/***************************************************************************\
* SPIP, Systeme de publication pour l'internet *
* *
* Copyright (c) 2001-2014 *
* Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
* *
* Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
* Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
\***************************************************************************/
if (!defined('_ECRIRE_INC_VERSION')) return;
function formulaires_dater_charger_dist($objet, $id_objet, $retour='', $options=array()){
$objet = objet_type($objet);
if (!$objet OR !intval($id_objet))
return false;
if (!is_array($options))
$options = unserialize($options);
$_id_objet = id_table_objet($objet);
$table = table_objet($objet);
$trouver_table = charger_fonction('trouver_table','base');
$desc = $trouver_table($table);
if (!$desc)
return false;
$champ_date = $desc['date']?$desc['date']:'date';
if (!isset($desc['field'][$champ_date]))
return false;
$valeurs = array(
'objet'=>$objet,
'id_objet'=>$id_objet,
'id'=>$id_objet,
);
$select = "$champ_date as date";
if (isset($desc['field']['date_redac']))
$select .= ",date_redac";
if (isset($desc['field']['statut']))
$select .= ",statut";
$row = sql_fetsel($select, $desc['table'], "$_id_objet=".intval($id_objet));
$statut = isset($row['statut'])?$row['statut']:'publie'; // pas de statut => publie
$valeurs['editable'] = autoriser('dater',$objet,$id_objet,null,array('statut'=>$statut));
$possedeDateRedac = false;
if (isset($row['date_redac']) AND
$regs = recup_date($row['date_redac'], false)) {
$annee_redac = $regs[0];
$mois_redac = $regs[1];
$jour_redac = $regs[2];
$heure_redac = $regs[3];
$minute_redac = $regs[4];
$possedeDateRedac = true;
// attention : les vrai dates de l'annee 1 sont stockee avec +9000 => 9001
// mais reviennent ici en annee 1 par recup_date
// on verifie donc que le intval($row['date_redac']) qui ressort l'annee
// est bien lui aussi <=1 : dans ce cas c'est une date sql 'nulle' ou presque, selon
// le gestionnnaire sql utilise (0001-01-01 pour PG par exemple)
if (intval($row['date_redac'])<=1 AND ($annee_redac<=1) AND ($mois_redac<=1) AND ($jour_redac<=1))
$possedeDateRedac = false;
}
else
$annee_redac = $mois_redac = $jour_redac = $heure_redac = $minute_redac = 0;
if ($regs = recup_date($row['date'], false)) {
$annee = $regs[0];
$mois = $regs[1];
$jour = $regs[2];
$heure = $regs[3];
$minute = $regs[4];
}
// attention, si la variable s'appelle date ou date_redac, le compilo va
// la normaliser, ce qu'on ne veut pas ici.
$valeurs['afficher_date_redac'] = ($possedeDateRedac?$row['date_redac']:'');
$valeurs['date_redac_jour'] = dater_formater_saisie_jour($jour_redac,$mois_redac,$annee_redac);
$valeurs['date_redac_heure'] = "$heure_redac:$minute_redac";
$valeurs['afficher_date'] = $row['date'];
$valeurs['date_jour'] = dater_formater_saisie_jour($jour,$mois,$annee);
$valeurs['date_heure'] = "$heure:$minute";
$valeurs['sans_redac'] = !$possedeDateRedac;
if (isset($options['date_redac']))
$valeurs['_editer_date_anterieure'] = $options['date_redac'];
else
$valeurs['_editer_date_anterieure'] = ($objet=='article' AND ($GLOBALS['meta']["articles_redac"] != 'non' OR $possedeDateRedac));
$valeurs['_label_date'] = (($statut == 'publie')? _T('texte_date_publication_objet'): _T('texte_date_creation_objet'));
$valeurs['_saisie_en_cours'] = (_request('date_jour')!==null);
return $valeurs;
}
function dater_formater_saisie_jour($jour,$mois,$annee,$sep="/"){
$annee = str_pad($annee,4,'0',STR_PAD_LEFT);
if (intval($jour)){
$jour = str_pad($jour,2,'0',STR_PAD_LEFT);
$mois = str_pad($mois,2,'0',STR_PAD_LEFT);
return "$jour$sep$mois$sep$annee";
}
if (intval($mois)) {
$mois = str_pad($mois,2,'0',STR_PAD_LEFT);
return "$mois$sep$annee";
}
return $annee;
}
/**
* Identifier le formulaire en faisant abstraction des parametres qui
* ne representent pas l'objet edite
*/
function formulaires_dater_identifier_dist($objet, $id_objet, $retour='', $options=array()){
return serialize(array($objet, $id_objet));
}
/**
* Verification avant traitement
*
* On verifie que l'upload s'est bien passe et
* que le document recu est une image (d'apres son extension)
*
* @param string $objet
* @param integer $id_objet
* @param string $retour
* @return Array Tableau des erreurs
*/
function formulaires_dater_verifier_dist($objet, $id_objet, $retour=''){
$erreurs = array();
foreach(array('date','date_redac') as $k){
if ($v=_request($k."_jour") AND !dater_recuperer_date_saisie($v, $k))
$erreurs[$k] = _T('format_date_incorrecte');
elseif ($v=_request($k."_heure") AND !dater_recuperer_heure_saisie($v))
$erreurs[$k] = _T('format_heure_incorrecte');
}
if (!_request('date_jour'))
$erreurs['date'] = _T('info_obligatoire');
return $erreurs;
}
/**
* Traitement
*
* @param string $objet
* @param integer $id_objet
* @param string $retour
* @return Array
*/
function formulaires_dater_traiter_dist($objet, $id_objet, $retour=''){
$res = array('editable'=>' ');
if (_request('changer')){
$_id_objet = id_table_objet($objet);
$table = table_objet($objet);
$trouver_table = charger_fonction('trouver_table','base');
$desc = $trouver_table($table);
if (!$desc)
return array('message_erreur'=>_L('erreur')); #impossible en principe
$champ_date = $desc['date']?$desc['date']:'date';
$set = array();
if (!$d = dater_recuperer_date_saisie(_request('date_jour')))
$d = array(date('Y'),date('m'),date('d'));
if (!$h = dater_recuperer_heure_saisie(_request('date_heure')))
$h = array(0,0);
$set[$champ_date] = sql_format_date($d[0], $d[1], $d[2], $h[0], $h[1]);
if (isset($desc['field']['date_redac'])){
if (!_request('date_redac_jour') OR _request('sans_redac'))
$set['date_redac'] = sql_format_date(0,0,0,0,0,0);
else {
if (!$d = dater_recuperer_date_saisie(_request('date_redac_jour'), "date_redac"))
$d = array(date('Y'),date('m'),date('d'));
if (!$h = dater_recuperer_heure_saisie(_request('date_redac_heure')))
$h = array(0,0);
$set['date_redac'] = sql_format_date($d[0], $d[1], $d[2], $h[0], $h[1]);
}
}
include_spip('action/editer_objet');
objet_modifier($objet, $id_objet, $set);
}
if ($retour)
$res['redirect'] = $retour;
set_request('date_jour');
set_request('date_redac_jour');
set_request('date_heure');
set_request('date_redac_heure');
return $res;
}
/**
* Recuperer annee,mois,jour sur la date saisie
* @param string $post
* @param string $quoi
* @return array
*/
function dater_recuperer_date_saisie($post, $quoi="date") {
if (!preg_match('#^(?:(?:([0-9]{1,2})[/-])?([0-9]{1,2})[/-])?([0-9]{4}|[0-9]{1,2})#', $post, $regs))
return '';
if ($quoi=="date_redac") {
if ($regs[3]<>'' AND $regs[3] < 1001)
$regs[3] += 9000;
return array($regs[3],$regs[2],$regs[1]);
}
else {
$t = mktime(0,0,0,$regs[2],$regs[1],$regs[3]);
// si la date n'est pas valide selon mktime, la refuser
if (!$t) return '';
return array(date('Y',$t),date('m',$t),date('d',$t));
}
}
/**
* Recuperer heures,minutes sur l'heure saisie
* @param string $post
* @return array
*/
function dater_recuperer_heure_saisie($post) {
if (!preg_match('#([0-9]{1,2})(?:[h:](?:([0-9]{1,2}))?)?#', $post, $regs))
return '';
return array($regs[1],$regs[2]);
}
?>