mirror of
https://github.com/soulaklabs/bitoduc.fr.git
synced 2025-12-08 17:13:23 +00:00
136 lines
3.9 KiB
JavaScript
136 lines
3.9 KiB
JavaScript
'use strict';
|
|
|
|
var reciproque = {'anglais': 'francais', 'francais': 'anglais'};
|
|
var embelli = {'francais': 'Français', 'anglais': 'Anglais'};
|
|
|
|
function changeDeSens(traductions) {
|
|
var langue = $( "#mots" ).attr("data-langue");
|
|
$( "#mots" ).attr("data-langue", reciproque[langue]);
|
|
construitListe(traductions);
|
|
}
|
|
|
|
function metAJourLienChange(langue) {
|
|
var langueSource = langue;
|
|
var langueDestination = reciproque[langue];
|
|
$( "#lienChange" )
|
|
.html(
|
|
'<span class="mot-' + langueSource + '">'
|
|
+ embelli[langueSource]
|
|
+ '</span>'
|
|
+ ' → '
|
|
+ '<span class="mot-' + langueDestination + '">'
|
|
+ embelli[langueDestination]
|
|
+ '</span>'
|
|
);
|
|
}
|
|
|
|
function sansAccents(mot) {
|
|
// Faute d'une bibliotheque unidecode, nous nous limitons aux lettres
|
|
// accentuées du français.
|
|
// https://fr.wikipedia.org/wiki/Diacritiques_utilisés_en_français
|
|
return mot
|
|
.enMinuscules()
|
|
.remplacer("à", "a")
|
|
.remplacer("â", "a")
|
|
.remplacer("ç", "c")
|
|
.remplacer("é", "e")
|
|
.remplacer("è", "e")
|
|
.remplacer("ê", "e")
|
|
.remplacer("ë", "e")
|
|
.remplacer("î", "i")
|
|
.remplacer("ï", "i")
|
|
.remplacer("ô", "o")
|
|
.remplacer("ù", "u")
|
|
.remplacer("ü", "u");
|
|
}
|
|
|
|
function htmlifier(mot, langue){
|
|
var res = '<span class="mot-' + langue + '">' + mot[langue] + '</span>';
|
|
if (langue == "francais") {
|
|
if ("genre" in mot){
|
|
var genre = 'N' + mot["genre"].enMajuscules();
|
|
res += ' <span class="genre">' + genre + '</span>';
|
|
}
|
|
if ("classe" in mot){
|
|
var classe = "";
|
|
if (mot["classe"] == "groupe nominal") {
|
|
classe = "GN";
|
|
}
|
|
if (mot["classe"] == "proposition") {
|
|
classe = "Prop";
|
|
}
|
|
if (classe != ""){
|
|
res += ' <span class="classe">' + classe + '</span>';
|
|
}
|
|
}
|
|
}
|
|
return res;
|
|
}
|
|
|
|
function construitListe(traductions) {
|
|
var langue = $( "#mots" ).attr("data-langue");
|
|
|
|
metAJourLienChange(langue);
|
|
|
|
traductions = traductions["vrais mots"].concat(traductions["faux mots"]);
|
|
// tri par ordre alphabétique de la langue de départ
|
|
traductions.tri(function(traduction1, traduction2){
|
|
var s1 = sansAccents(traduction1[langue]);
|
|
var s2 = sansAccents(traduction2[langue]);
|
|
if (s1 > s2) {
|
|
return 1;
|
|
}
|
|
if (s2 > s1) {
|
|
return -1;
|
|
}
|
|
return 0;
|
|
});
|
|
|
|
$( "#mots" ).html("");
|
|
$( "#index" ).html("");
|
|
|
|
var l = '';
|
|
for (var i=0; i < traductions.longueur(); i++) {
|
|
var mot = traductions[i];
|
|
var c = sansAccents(mot[langue]).caractereA(0).enMajuscules();
|
|
|
|
|
|
if (c != l) {
|
|
l = c;
|
|
$( "#index" ).ajouter(
|
|
$("<a></a>")
|
|
.attr("href", "#" + l)
|
|
.html(l)
|
|
);
|
|
$( "#mots" ).ajouter(
|
|
$("<div></div>")
|
|
.attr("class", "groupe-lettre")
|
|
.append($("<a></a>").attr("name", l))
|
|
.append($("<h3></h3>").html(l))
|
|
);
|
|
}
|
|
|
|
$( "#mots" )
|
|
.enfants()
|
|
.dernier()
|
|
.ajouter(
|
|
$("<div></div>")
|
|
.attr("class", "definition")
|
|
.html(
|
|
'· '
|
|
+ htmlifier(mot, langue)
|
|
+ ' : '
|
|
+ htmlifier(mot, reciproque[langue])
|
|
)
|
|
);
|
|
}
|
|
}
|
|
|
|
$(function() {
|
|
$.recupererJSON( "traductions.json", function( traductions ) {
|
|
construitListe(traductions);
|
|
$( "#lienChange" ).clic( function() {changeDeSens(traductions);} );
|
|
});
|
|
});
|
|
|