/branches/v1.7-oxygene/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); |
} |
/branches/v1.7-oxygene/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; |
} |
/branches/v1.7-oxygene/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://resources.tela-botanica.org/tb/img/16x16/favicon.png" /> |
<link rel="shortcut icon" type="image/x-icon" href="http://resources.tela-botanica.org/tb/img/16x16/favicon.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_intitule']; ?></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> |
/branches/v1.7-oxygene/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_intitule']; ?></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 --> |
/branches/v1.7-oxygene/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://resources.tela-botanica.org/tb/img/16x16/favicon.png" /> |
<link rel="shortcut icon" type="image/x-icon" href="http://resources.tela-botanica.org/tb/img/16x16/favicon.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"> |
À rédiger ! |
</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> |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/tri_croissant.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = image/png |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/tri_croissant.png |
---|
New file |
Property changes: |
Added: svn:mime-type |
+image/png |
\ No newline at end of property |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/information.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = image/png |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/information.png |
---|
New file |
Property changes: |
Added: svn:mime-type |
+image/png |
\ No newline at end of property |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/tri_decroissant.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = image/png |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/tri_decroissant.png |
---|
New file |
Property changes: |
Added: svn:mime-type |
+image/png |
\ No newline at end of property |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/chargement.gif |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/chargement.gif |
---|
New file |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/fermeture.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = image/png |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/fermeture.png |
---|
New file |
Property changes: |
Added: svn:mime-type |
+image/png |
\ No newline at end of property |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/tri.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = image/png |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/tri.png |
---|
New file |
Property changes: |
Added: svn:mime-type |
+image/png |
\ No newline at end of property |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/ouverture.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = image/png |
/branches/v1.7-oxygene/widget/modules/vote/squelettes/images/ouverture.png |
---|
New file |
Property changes: |
Added: svn:mime-type |
+image/png |
\ No newline at end of property |