Subversion Repositories eFlore/Applications.cel

Compare Revisions

Ignore whitespace Rev 3133 → Rev 3134

/trunk/widget/modules/export/squelettes/export.tpl.html
33,7 → 33,10
<script type="text/javascript" src="https://www.tela-botanica.org/commun/jquery/1.7.1/jquery-1.7.1.min.js"></script>
<script type="text/javascript" src="https://www.tela-botanica.org/commun/jquery/jquery-ui/1.8.17/js/jquery-ui-1.8.17.custom.min.js"></script>
<script type="text/javascript" src="https://www.tela-botanica.org/commun/jquery/jquery-ui/1.8.17/js/jquery.ui.datepicker-fr.js"></script>
<script type="text/javascript" src="https://www.tela-botanica.org/commun/jquery/validate/1.9.0/jquery.validate.js"></script>
 
<script type="text/javascript" src="http://resources.tela-botanica.org/jquery/validate/1.11.1/jquery.validate-patched.min.js"></script>
<script type="text/javascript" src="http://resources.tela-botanica.org/jquery/validate/1.11.1/additional-methods.min.js"></script>
<script type="text/javascript" src="https://www.tela-botanica.org/commun/jquery/validate/1.9.0/messages_fr.js"></script>
<script type="text/javascript" src="https://www.tela-botanica.org/commun/jquery/form/2.95/jquery.form.min.js"></script>
<script src="https://resources.tela-botanica.org/bootstrap/3.1.0/js/bootstrap.min.js"></script>
57,6 → 60,7
// URL de base du service d'export
var SERVICE_EXPORT_URL = "<?= $url_export; ?>";
//]]>
</script>
115,12 → 119,12
<input id="dept" class="large" name="dept" type="text" placeholder="ex: 34 OU 26,84,34..." />
</div>
<div class="row-fluid">
<label for="projet">Projet </label>
<label for="projet">Mots-clés </label>
<input id="projet" class="large" name="projet" type="text" placeholder="ex: defiphoto, abba" value="<?= $projet ?>" />
</div>
<div class="row-fluid">
<label for="programme">Programme </label>
<select name="programme" id="programme" class="form-control" >
<label title="Programme de sciences participatives ou observatoire citoyen" for="programme">Programme </label>
<select name="programme" id="programme" class="form-control">
<option value="">...</option>
<option value="sauvages">Sauvages de ma rue</option>
<option value="missions-flore">Missions flore</option>
135,8 → 139,15
<input id="taxon" class="large" name="taxon" type="text" placeholder="ex: Viola OU Viola alba OU Violaceae" />
</div>
<div class="row-fluid">
<input type="checkbox" name="identiplante" value="1" />validé sur IdentiPlante<br/>
<input type="checkbox" name="identiplante"
title ="exporter uniquement les observations dont l'espèce a été validée par le réseau" value="1" />
validé sur IdentiPlante<br/>
</div>
<div class="row-fluid">
<input type="checkbox" name="standard" checked="1"
title ="exporter uniquement les observations possédant un lieu, une date et une détermination non déclarée douteuse ou à déterminer" value="1" />
données standards<br/>
</div>
<div class="row-fluid conteneur_dates">
<div class="conteneur_date">
<label for="date_debut">Date de début </label>
188,10 → 199,10
<div class="panel-body">
<!-- problème: readonly sur checkbox n'empêche pas de changer le statut (un)checked -->
<!-- <input type="checkbox" name="colonnes[]" readonly="readonly" checked="1" value="standard" />standard (nom scientifique, date, ...)<br/> -->
<input type="hidden" name="colonnes[]" value="standard" />
<input type="hidden" name="colonnes[]" value="standardexport" />
<input type="checkbox" name="colonnes[]" disabled="disabled" checked="1" value="standard" />standard (nom scientifique, date, ...)<br/>
<input type="checkbox" name="colonnes[]" value="avance" />avancées (commentaire, ordre, mots-clef, abondance, images, nom commun, ...)<br/>
<input type="checkbox" name="colonnes[]" value="etendu" />étendues (champs étendus spécifiques, eg: florilèges<br/>
<input type="checkbox" name="colonnes[]" value="avance" />avancés (commentaire, ordre, mots-clés, abondance, images, nom commun, ...)<br/>
<input type="checkbox" name="colonnes[]" value="etendu" />étendus (champs étendus spécifiques, eg: florilèges<br/>
<input type="checkbox" name="colonnes[]" value="baseflor" />écologiques (données Baseflor et syntaxons Baseveg)<br/>
<!-- <input type="checkbox" name="colonnes[]" value="auteur" checked="checked" readonly="readonly" />Observateur<br/> -->
<input type="hidden" name="colonnes[]" value="auteur" />
/trunk/jrest/bibliotheque/RechercheObservation.php
110,7 → 110,7
}
$requete .= $this->fabriquerSousRequeteRecherche($id_utilisateur, $criteres);
$requete = rtrim($requete, 'AND ');
$resultat = Cel::db()->requeter($requete);
$resultat = Cel::db()->requeter($requete);
$nb_obs = ($resultat && is_array($resultat) && count($resultat) > 0) ? $resultat[0]['nb_obs'] : '0';
return $nb_obs;
}
203,6 → 203,7
}
 
switch ($nom) {
case "programme";
case "mots_cles";
$sous_requete .= $this->creerSousRequeteMotsCles($valeur);
$sous_requete .= ' AND ';
298,6 → 299,10
$sous_requete .= $valeur;
$sous_requete .= ' AND ';
break;
case 'validation_identiplante':
$sous_requete .= "`id_observation` in (SELECT distinct `ce_observation` FROM tb_del.`del_commentaire` WHERE `proposition_retenue` = 1 )";
$sous_requete .= ' AND ';
break;
default:
if(!preg_match('/^[a-zA-Z0-9_-]+$/', $nom)) break;
$valeur = rtrim($valeur);
/trunk/jrest/bibliotheque/FormateurGroupeColonne.php
32,6 → 32,7
// les groupes de champs utilisables
static $fieldGroups = array(
'standard',
'standardexport',
'avance',
'etendu',
'baseflor',
81,7 → 82,7
'perceptionRiverainMauvaise',
);
 
static function colGroupsValidation($groupe_de_champs = 'standard,avance') {
static function colGroupsValidation($groupe_de_champs = 'standard,avance', $programme = "") {
if (! $groupe_de_champs) return FALSE;
if (is_string($groupe_de_champs)) {
$groupe_de_champs = array_flip(explode(',', $groupe_de_champs));
94,6 → 95,10
if (!$groupe_de_champs) {
return false;
}
if ($programme != "") {
$groupe_de_champs['avance'] = true;
$groupe_de_champs['etendu'] = true;
}
// toujours ajouter standard
$groupe_de_champs['standard'] = true;
return implode(',', array_keys($groupe_de_champs));
129,8 → 134,10
}
 
$colonnes = array();
if (isset($groupe_de_champs['standard'])) {
if (isset($groupe_de_champs['standardexport'])) {
$colonnes += Array(
'guid' => self::GenColInfo(Array('abbrev' => 'guid',
'nom' => 'Identifiant unique')),
'nom_sel' => self::GenColInfo(Array('abbrev' => 'nom_sel',
'nom' => 'Espèce')),
'nom_sel_nn' => self::GenColInfo(Array('abbrev' => 'nom_sel_nn',
183,7 → 190,68
'nom' => 'Référentiel Géographique',
'extra' => 1,
'importable' => FALSE)),
'programme' => self::GenColInfo(Array('abbrev' => 'programme',
'nom' => 'Programme de sciences participatives ou observatoire citoyen',
'importable' => FALSE)),
'validation_identiplante' => self::GenColInfo(Array('abbrev' => 'validation_identiplante',
'nom' => 'Espéce validée sur IdentiPlante',
'importable' => FALSE)),
);
} elseif (isset($groupe_de_champs['standard'])) {
$colonnes += Array(
'nom_sel' => self::GenColInfo(Array('abbrev' => 'nom_sel',
'nom' => 'Espèce')),
'nom_sel_nn' => self::GenColInfo(Array('abbrev' => 'nom_sel_nn',
'nom' => 'Numéro nomenclatural',
'importable' => FALSE)),
'nom_ret' => self::GenColInfo(Array('abbrev' => 'nom_ret',
'nom' => 'Nom retenu',
'importable' => FALSE)),
'nom_ret_nn' => self::GenColInfo(Array('abbrev' => 'nom_ret_nn',
'nom' => 'Numéro nomenclatural nom retenu',
'importable' => FALSE)),
'nt' => self::GenColInfo(Array('abbrev' => 'nt',
'nom' => 'Numéro taxonomique',
'importable' => FALSE)),
'famille' => self::GenColInfo(Array('abbrev' => 'famille',
'nom' => 'Famille',
'importable' => FALSE)),
'nom_referentiel' => self::GenColInfo(Array('abbrev' => 'nom_referentiel',
'nom' => 'Referentiel taxonomique')),
'pays' => self::GenColInfo(Array('abbrev' => 'pays',
'nom' => 'Pays')),
'zone_geo' => self::GenColInfo(Array('abbrev' => 'zone_geo',
'nom' => 'Commune')),
'ce_zone_geo' => self::GenColInfo(Array('abbrev' => 'ce_zone_geo',
'nom' => 'Identifiant Commune',
'fonction' => 'convertirCodeZoneGeoVersDepartement')),
'date_observation' => self::GenColInfo(Array('abbrev' => 'date_observation',
'nom' => 'Date',
'fonction' => 'formaterDate')),
'lieudit' => self::GenColInfo(Array('abbrev' => 'lieudit',
'nom' => 'Lieu-dit')),
'station' => self::GenColInfo(Array('abbrev' => 'station',
'nom' => 'Station')),
'milieu' => self::GenColInfo(Array('abbrev' => 'milieu',
'nom' => 'Milieu')),
'commentaire' => self::GenColInfo(Array('abbrev' => 'commentaire',
'nom' => 'Notes')),
'latitude' => self::GenColInfo(Array('abbrev' => 'latitude',
'nom' => 'Latitude',
'extra' => 1,
'fonction' => 'trim0')),
'longitude' => self::GenColInfo(Array('abbrev' => 'longitude',
'nom' => 'Longitude',
'extra' => 1,
'fonction' => 'trim0')),
'altitude' => self::GenColInfo(Array('abbrev' => 'altitude',
'nom' => 'Altitude',
'extra' => 1)), // pas de trim0 car INT(5) en DB
'geodatum' => self::GenColInfo(Array('abbrev' => 'geodatum',
'nom' => 'Référentiel Géographique',
'extra' => 1,
'importable' => FALSE)),
);
}
 
if(isset($groupe_de_champs['avance'])) {
/trunk/jrest/bibliotheque/RechercheObservationExport.php
35,7 → 35,7
 
public function rechercherObservations($id_utilisateur = null, $criteres = array(), $debut = 0, $limite = 50, $autoriser_sql_brut = FALSE) {
$requete_selection_observations = 'SELECT * FROM cel_export ';
 
unset($criteres['standard']);
if ($id_utilisateur != null) {
$requete_selection_observations .= 'WHERE ce_utilisateur = '.Cel::db()->proteger($id_utilisateur).' AND ';
} else if(count($criteres) > 0) {
70,6 → 70,7
}
 
public function compterObservations($id_utilisateur = null, $criteres = array()) {
unset($criteres['standard']);
$requete = 'SELECT COUNT(*) AS nb_obs FROM cel_export ';
if ($id_utilisateur != null) {
$requete .= 'WHERE ce_utilisateur = '.Cel::db()->proteger($id_utilisateur).' AND ';
77,8 → 78,8
$requete .= 'WHERE ';
}
$requete .= $this->fabriquerSousRequeteRecherche($id_utilisateur, $criteres);
$requete = rtrim($requete, 'AND ');
$resultat = Cel::db()->requeter($requete);
$requete = rtrim($requete, 'AND ');
$resultat = Cel::db()->requeter($requete);//print_r($requete);exit;
$nb_obs = ($resultat && is_array($resultat) && count($resultat) > 0) ? $resultat[0]['nb_obs'] : '0';
return $nb_obs;
}
/trunk/jrest/services/CelWidgetExport.php
65,6 → 65,7
'colonnes' => 'colonnes',
'transmission' => 'transmission',
'obsids' => 'obsids',
'standard' => 'standard',
);
private $limite_decoupage_defaut = 9000;
102,8 → 103,11
private function getCalcul() {
$criteres = $this->traiterParametresAutorises($_GET);
$criteres['transmission'] = 1;
if (!isset($criteres['standard'])) {
$criteres['transmission'] = 1;
} else {
unset($criteres['transmission']);
}
// Définit si l'on exporte les obs privées ainsi que les champs étendus privés
$this->export_prive = $this->doitEtPeutExporterObsPrivees($criteres);
if($this->export_prive) {
110,10 → 114,14
unset($criteres['transmission']);
$this->id_utilisateur = $criteres['id_utilisateur'];
}
$chercheur_observations = new RechercheObservationExport($this->config);
if (isset($criteres['standard']) && $criteres['standard'] == 1) {
$chercheur_observations = new RechercheObservationExport($this->config);
} else {
$chercheur_observations = new RechercheObservation($this->config);
}
$numero_page = isset($criteres['debut']) ? $criteres['debut'] : 0;
$limite = isset($criteres['limite']) ? $criteres['limite'] : 0;
$colonnes = @FormateurGroupeColonne::colGroupsValidation($criteres['colonnes']);
$colonnes = @FormateurGroupeColonne::colGroupsValidation($criteres['colonnes'], $criteres['programme']);
unset($criteres['limite']);
unset($criteres['debut']);
166,7 → 174,11
if(!$criteres) die('erreur: pas de paramètre reçu');
if(!in_array($this->format, array('pdf','csv','xls'))) die('erreur: format invalide');
//$criteres['transmission'] = 1;
if (!isset($criteres['standard'])) {
$criteres['transmission'] = 1;
} else {
unset($criteres['transmission']);
}
// Définit si l'on exporte les obs privées ainsi que les champs étendus privés
$this->export_prive = $this->doitEtPeutExporterObsPrivees($criteres);
if($this->export_prive) {
173,8 → 185,11
//unset($criteres['transmission']);
$this->id_utilisateur = $criteres['ce_utilisateur'];
}
$chercheur_observations = new RechercheObservationExport($this->config);
if (isset($criteres['standard']) && $criteres['standard'] == 1) {
$chercheur_observations = new RechercheObservationExport($this->config);
} else {
$chercheur_observations = new RechercheObservation($this->config);
}
$debut = isset($criteres['debut']) ? intval($criteres['debut']) : 0;
$limite = isset($criteres['limite']) ? intval($criteres['limite']) : 0;
$groupes = @FormateurGroupeColonne::colGroupsValidation($criteres['colonnes']);
243,7 → 258,6
$parametres_traites[$this->parametres_autorises[$cle]] = $valeur;
}
}
$parametres_traites['obsids'] = @self::traiterObsIds($parametres['obsids']);
return $parametres_traites;
}
357,32 → 371,6
return ! empty($utilisateur['id_utilisateur']) && $id_utilisateur == $utilisateur['id_utilisateur'];
}
static function traiterObsIds($range_param) {
if (!isset($range_param)) return NULL;
// trim() car: `POST http://url<<<"range=*"`
if (trim($range_param) == '*') return NULL;
return self::rangeToList(trim($range_param));
}
/*
* @param $fieldSets: un range, eg: 1-5,8,32,58-101
* @return un tableau trié, eg: 1,2,3,4,5,8,32,58,...,101
* http://stackoverflow.com/questions/7698664/converting-a-range-or-partial-array-in-the-form-3-6-or-3-6-12-into-an-arra
*/
static function rangeToList($in = '') {
$inSets = explode(',', trim($in, ','));
$outSets = array();
foreach($inSets as $inSet) {
list($start,$end) = explode('-', $inSet . '-' . $inSet);
// ignore les ranges trop importants
if($start > 10000000 || $end > 10000000 || abs($start-$end) > 10000) continue;
$outSets = array_merge($outSets,range($start,$end));
}
$outSets = array_unique($outSets);
$outSets = array_filter($outSets, 'is_numeric');
sort($outSets);
return $outSets;
}
 
}
?>