Subversion Repositories eFlore/Applications.del

Compare Revisions

No changes between revisions

Ignore whitespace Rev 1027 → Rev 1535

/tags/v1.1-helium/widget/modules/vote/squelettes/vote.tpl.html
New file
0,0 → 1,113
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Votez !</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
<meta http-equiv="Content-style-type" content="text/css" />
<meta http-equiv="Content-script-type" content="text/javascript" />
<meta http-equiv="Content-language" content="fr" />
<meta name="revisit-after" content="15 days" />
<meta name="robots" content="index,follow" />
<meta name="author" content="Delphine Cauquil, Aurélien Peronnet" />
<meta name="keywords" content="Tela Botanica, photographie, DEL" />
<meta name="description" content="Widget de vote sur les dernières images proposées dans DEL" />
 
<!-- Spécial mobile -->
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<!-- Favicones -->
<link rel="icon" type="image/png" href="http://www.tela-botanica.org/sites/commun/generique/images/favicones/tela_botanica.png" />
<link rel="shortcut icon" type="image/x-icon" href="http://www.tela-botanica.org/sites/commun/generique/images/favicones/tela_botanica.ico" />
<!-- Feuilles de styles -->
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.0.1/jquery.mobile-1.0.1.min.css" />
<link rel="stylesheet" type="text/css" href="<?=$url_css?>vote.css" media="screen" />
<!-- Javascript : bibliothèques -->
<script src="http://code.jquery.com/jquery-1.6.4.min.js"></script>
<script type="text/Javascript">
 
</script>
<script src="http://code.jquery.com/mobile/1.0.1/jquery.mobile-1.0.1.min.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/jquery-ui.min.js"></script>
<!-- attention le script suivant a besoin des variables globales initialisées ci dessous, donc, ne rien utiliser
avant le document.ready() -->
<script src="<?=$url_js?>vote.js"></script>
</head>
<body>
<!-- WIDGET:DEL:VOTE - DEBUT -->
<div data-role="page">
<!-- Variables globales à réinjecter à chaque changement de page
(hors jquery mobile ne recharge pas le contenu du header -->
<script type="text/Javascript">
//<![CDATA[
var g_urlServiceVotes = "<?= $donnees['url_service_votes']; ?>";
var g_urlServiceUtilisateurs = "<?= $donnees['url_service_utilisateurs']; ?>";
var g_idObservation = "<?= $donnees['id_observation']; ?>";
<?= $donnees['votes_js']; ?>;
//]]>
</script>
<!-- /navbar -->
<div data-role="header" data-position="fixed">
<div data-role="navbar" >
<ul>
<?php if($donnees['urls_navigation']['url_precedent'] != null) { ?>
<li><a id="url_precedent" href="<?= $donnees['urls_navigation']['url_precedent']; ?>" data-transition="reverse slide">Précédent</a></li>
<?php } ?>
<?php if($donnees['urls_navigation']['url_suivant'] != null) { ?>
<li><a id="url_suivant" href="<?= $donnees['urls_navigation']['url_suivant']; ?>" data-transition="slide">Suivant</a></li>
<?php } ?>
</ul>
</div>
</div>
<!-- /navbar -->
<div class="del-vote-contenu">
<div class="images">
<div style="height:305px">
<img class="image_principale" src="<?= str_replace('XL', 'CRS', $donnees['url']); ?>" alt="image" />
</div>
<div class="conteneur_image_secondaire">
<?php $premiere_image = true; ?>
<?php foreach($donnees['images'] as $image) : ?>
<img class="image_secondaire <?php if($premiere_image) { echo 'image_active';} ?>" src="<?= str_replace('XL', 'CRX2S', $image['binaire.href']); ?>" alt="image" />
<?php $premiere_image = false; ?>
<?php endforeach ?>
</div>
</div>
<div class="info_observation">
<?= $donnees['titre']; ?>
</div>
<ul class="ui-listview" data-role="listview">
<?php foreach($donnees['liste_votes_determination'] as $vote_determination) : ?>
<li class="ui-li ui-li-static ui-body-c">
<div class="intitule_determination">
<div><?= $vote_determination['nom_sel']; ?></div>
<div class="auteur_determination">Proposé par : <?= $vote_determination['auteur.prenom']; ?> <?= $vote_determination['auteur.nom']; ?></div>
</div>
<div id="vote_determination_<?= $vote_determination['id_commentaire']; ?>" class="votes_determination">
<a href="#" class="bouton_vote bouton_vote_oui" data-role="button" data-mini="true" data-inline="true"> oui</a>
<span class="nb_votes nb_votes_oui">
<?= $vote_determination['votes']['oui']; ?>
</span>
<a href="#" class="bouton_vote bouton_vote_non" data-role="button" data-mini="true" data-inline="true"> non</a>
<span class="nb_votes nb_votes_non">
<?= $vote_determination['votes']['non']; ?>
</span>
</div>
<hr style="visibility:hidden;clear:both" />
</li>
<?php endforeach ?>
</ul>
</div>
<div data-role="footer" data-theme="b">
<div data-role="navbar" >
<ul>
<li><a href="">Aide</a></li>
<li><a href="">Se connecter</a></li>
</ul>
</div>
</div>
</div>
<!-- WIDGET:DEL:VOTE - FIN -->
</body>
</html>
/tags/v1.1-helium/widget/modules/vote/squelettes/vote_ajax.tpl.html
New file
0,0 → 1,54
<!-- WIDGET:DEL:VOTE - DEBUT -->
<div id="contenu" data-role="page">
<!-- /navbar -->
<div data-role="header" data-position="fixed">
<div data-role="navbar" >
<ul>
<?php if($donnees['urls_navigation']['url_precedent'] != null) { ?>
<li><a href="<?= $donnees['urls_navigation']['url_precedent']; ?>" class="ui-btn-active">Précédent</a></li>
<?php } ?>
<?php if($donnees['urls_navigation']['url_suivant'] != null) { ?>
<li><a href="<?= $donnees['urls_navigation']['url_suivant']; ?>">Suivant</a></li>
<?php } ?>
</ul>
</div>
</div>
<!-- /navbar -->
<div class="del-vote-contenu">
<img id="image_principale" src="<?= str_replace('XL', 'CRS', $donnees['url']); ?>" alt="image" />
<div class="conteneur_image_secondaire">
<?php $premiere_image = true; ?>
<?php foreach($donnees['images'] as $image) : ?>
<img class="image_secondaire <?php if($premiere_image) { echo 'image_active';} ?>" src="<?= str_replace('XL', 'CRX2S', $image['binaire.href']); ?>" alt="image" />
<?php $premiere_image = false; ?>
<?php endforeach ?>
</div>
<div class="info_observation">
<?= $donnees['titre']; ?>
</div>
<ul class="ui-listview" data-role="listview">
<?php foreach($donnees['liste_votes_determination'] as $vote_determination) : ?>
<li class="ui-li ui-li-static ui-body-c">
<div class="intitule_determination">
<div><?= $vote_determination['nom_sel']; ?></div>
<div class="auteur_determination">Proposé par : <?= $vote_determination['auteur.prenom']; ?> <?= $vote_determination['auteur.nom']; ?></div>
</div>
<div id="vote_determination_<?= $vote_determination['id_commentaire']; ?>" class="votes_determination">
<a href="#" class="bouton_vote bouton_vote_oui" data-role="button" data-mini="true" data-inline="true"> oui</a>
<span class="nb_votes nb_votes_oui">
<?= $vote_determination['votes']['oui']; ?>
</span>
<a href="#" class="bouton_vote bouton_vote_non" data-role="button" data-mini="true" data-inline="true"> non</a>
<span class="nb_votes nb_votes_non">
<?= $vote_determination['votes']['non']; ?>
</span>
</div>
<hr style="visibility:hidden;clear:both" />
</li>
<?php endforeach ?>
</ul>
</div>
<div data-role="footer" data-theme="b" data-position="fixed">
</div>
</div>
<!-- WIDGET:DEL:VOTE - FIN -->
/tags/v1.1-helium/widget/modules/vote/squelettes/aide.tpl.html
New file
0,0 → 1,60
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Votez !</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
<meta http-equiv="Content-style-type" content="text/css" />
<meta http-equiv="Content-script-type" content="text/javascript" />
<meta http-equiv="Content-language" content="fr" />
<meta name="revisit-after" content="15 days" />
<meta name="robots" content="index,follow" />
<meta name="author" content="Delphine Cauquil, Aurélien Peronnet" />
<meta name="keywords" content="Tela Botanica, photographie, DEL" />
<meta name="description" content="Widget de vote sur les dernières images proposées dans DEL" />
 
<!-- Spécial mobile -->
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<!-- Favicones -->
<link rel="icon" type="image/png" href="http://www.tela-botanica.org/sites/commun/generique/images/favicones/tela_botanica.png" />
<link rel="shortcut icon" type="image/x-icon" href="http://www.tela-botanica.org/sites/commun/generique/images/favicones/tela_botanica.ico" />
<!-- Feuilles de styles -->
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.0.1/jquery.mobile-1.0.1.min.css" />
<link rel="stylesheet" type="text/css" href="<?=$url_css?>vote.css" media="screen" />
<!-- Javascript : bibliothèques -->
<script src="http://code.jquery.com/jquery-1.6.4.min.js"></script>
<script type="text/Javascript">
//<![CDATA[
$(document).bind("mobileinit", function(){
$.extend( $.mobile , {
ajaxEnabled: false
});
});
//]]>
</script>
<script src="http://code.jquery.com/mobile/1.0.1/jquery.mobile-1.0.1.min.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/jquery-ui.min.js"></script>
<script src="<?=$url_js?>vote.js"></script>
</head>
<body>
<!-- WIDGET:DEL:VOTE - DEBUT -->
<div data-role="page">
<div class="aide-contenu">
</div>
<div data-role="footer" data-theme="b" data-position="fixed">
<div data-role="navbar" >
<ul>
<li><a href="">Aide</a></li>
<li><a href="">Se connecter</a></li>
</ul>
</div>
</div>
</div>
<!-- WIDGET:DEL:VOTE - FIN -->
</body>
</html>
/tags/v1.1-helium/widget/modules/vote/squelettes/images/tri_decroissant.png
Cannot display: file marked as a binary type.
svn:mime-type = image/png
/tags/v1.1-helium/widget/modules/vote/squelettes/images/tri_decroissant.png
New file
Property changes:
Added: svn:mime-type
+image/png
\ No newline at end of property
/tags/v1.1-helium/widget/modules/vote/squelettes/images/chargement.gif
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream
/tags/v1.1-helium/widget/modules/vote/squelettes/images/chargement.gif
New file
Property changes:
Added: svn:mime-type
+application/octet-stream
\ No newline at end of property
/tags/v1.1-helium/widget/modules/vote/squelettes/images/fermeture.png
Cannot display: file marked as a binary type.
svn:mime-type = image/png
/tags/v1.1-helium/widget/modules/vote/squelettes/images/fermeture.png
New file
Property changes:
Added: svn:mime-type
+image/png
\ No newline at end of property
/tags/v1.1-helium/widget/modules/vote/squelettes/images/tri.png
Cannot display: file marked as a binary type.
svn:mime-type = image/png
/tags/v1.1-helium/widget/modules/vote/squelettes/images/tri.png
New file
Property changes:
Added: svn:mime-type
+image/png
\ No newline at end of property
/tags/v1.1-helium/widget/modules/vote/squelettes/images/ouverture.png
Cannot display: file marked as a binary type.
svn:mime-type = image/png
/tags/v1.1-helium/widget/modules/vote/squelettes/images/ouverture.png
New file
Property changes:
Added: svn:mime-type
+image/png
\ No newline at end of property
/tags/v1.1-helium/widget/modules/vote/squelettes/images/tri_croissant.png
Cannot display: file marked as a binary type.
svn:mime-type = image/png
/tags/v1.1-helium/widget/modules/vote/squelettes/images/tri_croissant.png
New file
Property changes:
Added: svn:mime-type
+image/png
\ No newline at end of property
/tags/v1.1-helium/widget/modules/vote/squelettes/images/information.png
Cannot display: file marked as a binary type.
svn:mime-type = image/png
/tags/v1.1-helium/widget/modules/vote/squelettes/images/information.png
New file
Property changes:
Added: svn:mime-type
+image/png
\ No newline at end of property
/tags/v1.1-helium/widget/modules/vote/squelettes/scripts/vote.js
New file
0,0 → 1,162
/**----------------------------------------------------------------------------------------------------------*/
/** Variables globales et initialisation
* Variables crées par php dans le squelettes
*
* var g_idObservation : id de l'observation en cours de consultation
* var g_urlServiceVotes : url du service web des votes à appeler
* var g_urlServiceUtilisateurs : url du service web utilisateur à appeler
* var g_votes : tableau des votes
*
*/
var boutonClique = null;
var g_idUtilisateur = null;
 
$(document).ready(function() {
getIdUtilisateur();
gererEvenementsClicsVotes();
gererEvenementClicImageSecondaire();
});
 
$(document).bind('pageload', function() {
gererEvenementsClicsVotes();
mettreEnValeurVotesUtilisateur();
});
 
function getIdUtilisateur() {
$.getJSON(g_urlServiceUtilisateurs, function(data) {
g_idUtilisateur = data.id_utilisateur;
mettreEnValeurVotesUtilisateur();
});
}
 
function gererEvenementsClicsVotes() {
$('.bouton_vote').unbind('click');
$('.bouton_vote').click(function(event) {
boutonClique = $(this);
voter(getValeurVote());
});
}
 
function gererEvenementClicImageSecondaire() {
$('.image_secondaire').live('click', function(event) {
$('.image_secondaire').removeClass('image_active');
var urlImageSecondaire = $(this).attr('src');
urlImageSecondaireAgrandie = urlImageSecondaire.replace('CRX2S','CRS');
var urlImagePrincipale = $('.image_principale').attr('src');
urlImagePrincipaleMiniature = urlImagePrincipale.replace('CRS','CRX2S');
$(this).addClass('image_active');
$('.image_principale').attr('src', urlImageSecondaireAgrandie);
});
}
 
 
function getValeurVote() {
valeur = 0;
if(boutonClique.hasClass('bouton_vote_oui')) {
valeur = 1;
}
return valeur;
}
 
function getIdProposition() {
var chaineProposition = boutonClique.parent().attr('id');
return chaineProposition.replace('vote_determination_', '');
}
 
 
/**----------------------------------------------------------------------------------------------------------*/
/** Affichage **/
 
function mettreEnValeurBoutonClique() {
boutonClique.parent().find(".bouton_vote").removeClass("bouton_selectionne");
boutonClique.effect("highlight", {}, 500, function() {$(this).addClass("bouton_selectionne");});
}
 
function mettreEnValeurVotesUtilisateur() {
$('.votes_determination').each(function() {
var id_proposition = $(this).attr('id').replace('vote_determination_', '');
if(g_votes[id_proposition] != undefined && g_votes[id_proposition][g_idUtilisateur] != undefined) {
if(g_votes[id_proposition][g_idUtilisateur] == 1) {
$(this).children('.bouton_vote_oui').addClass("bouton_selectionne");
} else {
$(this).children('.bouton_vote_non').addClass("bouton_selectionne");
}
}
});
}
 
function mettreAJourAffichageNbVotes(idProposition) {
affichageVotes = boutonClique.parent().find(".nb_votes");
affichageVotes.each(function() {
if($(this).hasClass("nb_votes_oui")) {
$(this).html(calculerVotes(idProposition,1));
}
if($(this).hasClass("nb_votes_non")) {
$(this).html(calculerVotes(idProposition,0));
}
});
}
 
/**----------------------------------------------------------------------------------------------------------*/
/** Requetes **/
 
function getUrlVoteProposition(idProposition) {
return g_urlServiceVotes+'/'+idProposition+'/vote/';
}
 
function getMethodeRequete(idProposition, idUtilisateur) {
var methode = "PUT";
if(g_votes[idProposition] != undefined && g_votes[idProposition] != null &&
g_votes[idProposition][idUtilisateur] != undefined && g_votes[idProposition][idUtilisateur] != null) {
methode = "POST";
}
return methode;
}
 
function voter(ouiOuNon) {
var idProposition = getIdProposition();
var urlVote = getUrlVoteProposition(idProposition);
var type = getMethodeRequete(idProposition, g_idUtilisateur);
if(!voteEstIdentique(idProposition, g_idUtilisateur, ouiOuNon)) {
$.ajax({
url : urlVote,
type: type,
data: "utilisateur="+g_idUtilisateur+"&valeur="+ouiOuNon
}).done(function(data) {
mettreAjourTableauVotes(idProposition, g_idUtilisateur, ouiOuNon);
mettreAJourAffichageNbVotes(idProposition);
mettreEnValeurBoutonClique();
boutonClique = null;
});
}
}
 
/**----------------------------------------------------------------------------------------------------------*/
/** Mise à jour et accès au tableau des votes **/
 
function mettreAjourTableauVotes(idProposition, idUtilisateur, valeurVote) {
if(g_votes[idProposition] == undefined) {
g_votes[idProposition] = new Array();
}
g_votes[idProposition][idUtilisateur] = valeurVote;
}
 
function calculerVotes(id_proposition, ouiOuNon) {
var nb = 0;
for (var votant in g_votes[id_proposition]) {
if(g_votes[id_proposition][votant] == ouiOuNon) {
nb++;
}
}
return nb;
}
 
function voteEstIdentique(id_proposition, id_utilisateur, ouiOuNon) {
return (g_votes[id_proposition] != undefined &&
g_votes[id_proposition][id_utilisateur] != undefined &&
g_votes[id_proposition][id_utilisateur] == ouiOuNon);
}
/tags/v1.1-helium/widget/modules/vote/squelettes/css/vote.css
New file
0,0 → 1,53
@charset "UTF-8";
/*+-----------------------------------------------------------------------------------------------------------------+*/
/* Widget */
.intitule_determination {
float:left;
}
 
.votes_determination {
float:right;
}
 
.auteur_determination {
font-style:italic;
}
 
.image_secondaire {
height: 40px;
cursor:pointer;
}
 
.nb_votes {
position: relative;
top: -12px;
}
 
.image_active {
border: solid 1px black;
}
 
.bouton_selectionne > * {
background-color: #BBBBBB;
cursor: default;
}
 
.bouton_selectionne {
cursor: default;
}
 
.lien_connexion {
float: right;
}
 
.info_observation {
font-size: 14px;
font-weight: bold;
padding-bottom: 5px;
padding-left: 10px;
padding-top: 5px;
}
 
.images {
text-align: center;
}