Subversion Repositories eFlore/Applications.del

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
163 aurelien 1
package org.tela_botanica.del.client.services;
2
 
3
import java.util.ArrayList;
1124 gduche 4
import java.util.Iterator;
163 aurelien 5
import java.util.List;
6
import java.util.Map;
227 aurelien 7
import java.util.Set;
163 aurelien 8
 
9
import org.tela_botanica.del.client.modeles.MoyenneVote;
10
import org.tela_botanica.del.client.modeles.PropositionDetermination;
11
import org.tela_botanica.del.client.modeles.VoteDetermination;
966 gduche 12
import com.google.gwt.user.client.Window;
163 aurelien 13
 
14
 
15
public class CalculVoteDeterminationService {
16
 
17
	public static List<MoyenneVote> calculerVoteDeterminationPlusPopulaire(List<PropositionDetermination> propositions) {
18
		List<MoyenneVote> pairesVotes = new ArrayList<MoyenneVote>();
19
 
20
		for (PropositionDetermination proposition : propositions) {
21
			pairesVotes.add(calculerVoteDetermination(proposition));
22
		}
23
 
24
		java.util.Collections.sort(pairesVotes);
25
 
26
		return pairesVotes;
27
	}
28
 
1124 gduche 29
	public static int getNombreTotalVotants(PropositionDetermination proposition) {
30
		int nbVotants = 0;
31
		List<PropositionDetermination> votes = proposition.getObservation().getPropositionDeterminations();
32
		Iterator<PropositionDetermination> itVotes =  votes.iterator();
33
		while (itVotes.hasNext()) {
34
			PropositionDetermination propositionCourante = itVotes.next();
35
			nbVotants += propositionCourante.getVotesDeterminations().size();
36
		}
37
		return nbVotants;
38
	}
39
 
163 aurelien 40
	public static MoyenneVote calculerVoteDetermination(PropositionDetermination propositionDetermination) {
41
 
1124 gduche 42
		int nbVotants = getNombreTotalVotants(propositionDetermination);
227 aurelien 43
		Map<String,VoteDetermination> votes = propositionDetermination.getVotesDeterminations();
1124 gduche 44
 
1098 aurelien 45
		double scoreVoteIdentifie = 0;
46
		double scoreVoteAnonyme = 0;
163 aurelien 47
 
1098 aurelien 48
		double scoreVote = 0;
49
 
1124 gduche 50
 
163 aurelien 51
		if(votes.size() > 0) {
227 aurelien 52
			Set<String> cles = votes.keySet();
1098 aurelien 53
 
227 aurelien 54
			for (String cle : cles) {
1098 aurelien 55
				String  idAuteur = cle;
56
				int valeurVote = votes.get(cle).getVote();
57
				if(estUnAuteurIdentifie(idAuteur)) {
58
					// un votant identifiant compte comme deux votants supplémentaires
59
					// il a donc un vote 3 fois supérieur
1124 gduche 60
					scoreVoteIdentifie += valeurVote;
61
					//nbVotants += 2;
1098 aurelien 62
				} else {
63
					scoreVoteAnonyme += valeurVote;
64
				}
163 aurelien 65
			}
66
 
1124 gduche 67
			scoreVote = ((scoreVoteAnonyme + scoreVoteIdentifie)/(nbVotants))*100;
163 aurelien 68
		} else {
69
			scoreVote = -1;
70
		}
71
 
1098 aurelien 72
		return new MoyenneVote((new Double(scoreVote)).intValue(), propositionDetermination);
163 aurelien 73
	}
1098 aurelien 74
 
75
	private static boolean estUnAuteurIdentifie(String idAuteur) {
76
		boolean estIdentifie = true;
77
	    try {
78
	        int intIdAuteur = Integer.parseInt(idAuteur);
79
	    } catch (NumberFormatException nfe) {
80
	    	estIdentifie = false;
81
	    }
82
	    return estIdentifie;
83
	}
163 aurelien 84
}