2019-08-17 12:32:35 +02:00
|
|
|
/* Fonctions Principales */
|
2019-08-16 12:05:56 +02:00
|
|
|
|
2019-08-18 20:06:06 +02:00
|
|
|
// Requête à l'API openweathermap.org
|
2019-09-16 18:17:02 +02:00
|
|
|
function weatherRequest(url) {
|
2019-08-16 12:05:56 +02:00
|
|
|
$.ajax({
|
|
|
|
url : url,
|
|
|
|
dataType : "json",
|
|
|
|
success: function (json) {
|
|
|
|
let city = json.name;
|
|
|
|
let showDateTimeValue = timeZone(json);
|
2019-09-16 18:17:02 +02:00
|
|
|
if(city === 'Moscou')
|
|
|
|
{
|
|
|
|
$('.results').html(`🌎 Position : <a href='https://www.google.com/maps/place/${city}/' class="yellow-color" target="_blank">${city}, RU</a><br>⏰ Date et heure : ${showDateTimeValue}<br>☁️ Météo : ${capitalize(json.weather[0].description)}<br> 🌡️ Température : ${json.main.temp} °C<br> 💧 Humidité : ${json.main.humidity}% <br> <img src="https://openweathermap.org/img/wn/${json.weather[0].icon}@2x.png"/>`);
|
|
|
|
$("#cityName, #submitWeatherRequest").click(function() {
|
|
|
|
document.location.replace("../../views/function-views/weatherRequest.php");
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$('.results').html(`🌎 Position : <a href='https://www.google.com/maps/place/${city}/' class="yellow-color" target="_blank">${city}, ${json.sys.country}</a><br>⏰ Date et heure : ${showDateTimeValue}<br>☁️ Météo : ${capitalize(json.weather[0].description)}<br> 🌡️ Température : ${json.main.temp} °C<br> 💧 Humidité : ${json.main.humidity}% <br> <img src="https://openweathermap.org/img/wn/${json.weather[0].icon}@2x.png"/>`);
|
|
|
|
$("#cityName, #submitWeatherRequest").click(function() {
|
|
|
|
document.location.replace("../../views/function-views/weatherRequest.php");
|
|
|
|
});
|
2019-08-16 12:05:56 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
statusCode: {
|
|
|
|
404: function() {
|
2019-09-13 21:56:36 +02:00
|
|
|
document.location.replace("../error404Weather");
|
2019-08-16 12:05:56 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Génère un nombre aléatoire entre un minimum inclus et un maximum inclus
|
2019-08-18 20:06:06 +02:00
|
|
|
function randomNumber(min, max) {
|
|
|
|
min = Math.ceil(min);
|
|
|
|
max = Math.floor(max);
|
2019-08-16 12:05:56 +02:00
|
|
|
|
|
|
|
if (!isNaN(min) && !isNaN(max) && min < max)
|
|
|
|
{
|
2019-09-13 14:39:29 +02:00
|
|
|
return Math.floor(Math.random() * (max - min +1)) + min;
|
2019-08-16 12:05:56 +02:00
|
|
|
}
|
2019-09-13 14:39:29 +02:00
|
|
|
else {
|
|
|
|
return null;
|
2019-08-16 12:05:56 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Calcule l'âge de quelqu'un selon la date de naissance
|
2019-08-18 20:06:06 +02:00
|
|
|
function calculateAge(birthDateEntered) {
|
2019-08-16 12:05:56 +02:00
|
|
|
|
2019-08-18 20:06:06 +02:00
|
|
|
// Les variables de la fonction
|
|
|
|
let birthDateDay = parseInt(birthDateEntered[0] + birthDateEntered[1]);
|
|
|
|
let birthDateMonth = parseInt((birthDateEntered[3] + birthDateEntered[4]) - 1);
|
|
|
|
let birthDateYear = parseInt(birthDateEntered[6] + birthDateEntered[7] + birthDateEntered[8] + birthDateEntered[9]);
|
|
|
|
dateTimeUTC('0');
|
|
|
|
day = parseInt(day)
|
|
|
|
month = parseInt(month - 1);
|
|
|
|
year = parseInt(year);
|
2019-08-16 12:05:56 +02:00
|
|
|
|
2019-08-18 20:06:06 +02:00
|
|
|
let dateNow = moment([year, month, day]);
|
|
|
|
let birthDate = moment([birthDateYear, birthDateMonth, birthDateDay]);
|
2019-08-16 12:05:56 +02:00
|
|
|
|
2019-08-18 20:06:06 +02:00
|
|
|
// Calcule l'âge - Moment.js
|
|
|
|
let ageYears = dateNow.diff(birthDate, 'year');
|
|
|
|
birthDate.add(ageYears, 'years');
|
2019-08-16 12:05:56 +02:00
|
|
|
|
2019-08-18 20:06:06 +02:00
|
|
|
let ageMonths = dateNow.diff(birthDate, 'months');
|
|
|
|
birthDate.add(ageMonths, 'months');
|
|
|
|
|
|
|
|
let ageDays = dateNow.diff(birthDate, 'days');
|
|
|
|
|
2019-09-18 18:36:18 +02:00
|
|
|
let isValidDateFunction = isValidDate(birthDateDay + '/' + birthDateMonth + '/' + birthDateYear);
|
|
|
|
|
2019-08-18 20:06:06 +02:00
|
|
|
// Vérifie si la valeur entrée correspond à une date de naissance valide
|
2019-09-18 18:36:18 +02:00
|
|
|
if(isValidDateFunction === true)
|
2019-08-18 20:06:06 +02:00
|
|
|
{
|
|
|
|
// Si c'est ton anniversaire aujourd'hui
|
2019-09-19 09:43:36 +02:00
|
|
|
if(birthDateDay === parseInt(day) && (parseInt(birthDateMonth) + 1) === parseInt(month))
|
2019-08-18 20:06:06 +02:00
|
|
|
{
|
|
|
|
return 'Vous avez ' + ageYears + ' ans. Joyeux Anniversaire! 🥳';
|
2019-08-16 12:05:56 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-08-18 20:06:06 +02:00
|
|
|
return 'Vous avez ' + ageYears + ' ans, ' + ageMonths + ' mois et ' + ageDays + ' jour(s).';
|
2019-08-16 12:05:56 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return messageError;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-14 17:38:30 +02:00
|
|
|
// Convertis des °C en °F et l'inverse aussi
|
2019-08-16 12:05:56 +02:00
|
|
|
function convertTemperature(degree, unit) {
|
|
|
|
if (!isNaN(degree) && unit === "°C")
|
|
|
|
{
|
|
|
|
const temperatureValue = ((degree * 9/5) + 32) + " °F";
|
|
|
|
return temperatureValue;
|
|
|
|
}
|
|
|
|
else if (!isNaN(degree) && unit === "°F")
|
|
|
|
{
|
|
|
|
const temperatureValue = (degree - 32) * 5/9 + " °C";
|
|
|
|
return temperatureValue;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return messageError;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-14 17:38:30 +02:00
|
|
|
// Convertis la longueur (distance) avec les unités allant de picomètre au Téramètre
|
2019-08-16 12:05:56 +02:00
|
|
|
function convertDistance (firstValue, unitFirstValue, unitFinalValue) {
|
|
|
|
|
|
|
|
let reference = ["pm",null,null,"nm",null,null,"µm",null,null,"mm","cm","dm","m","dam","hm","km",null,null,"Mm",null,null,"Gm",null,null,"Tm"];
|
|
|
|
let index1 = reference.indexOf(unitFirstValue);
|
|
|
|
let index2 = reference.indexOf(unitFinalValue);
|
|
|
|
|
|
|
|
// Condition qui vérifie si les valeurs entrées sont justes
|
|
|
|
if (!isNaN(firstValue) && typeof unitFirstValue === 'string' && typeof unitFinalValue === 'string' && (index1.toString() && index2.toString()) != '-1')
|
|
|
|
{
|
|
|
|
// Conversion des longueurs :
|
|
|
|
let difference = index1 - index2;
|
|
|
|
let result = firstValue*Math.pow(10,difference);
|
2019-09-15 09:45:20 +02:00
|
|
|
let response = 'Conversion de longueur : ' + formatNumberResult(firstValue).toString() + ' ' + unitFirstValue + ' = ' + formatNumberResult(result) + ' ' + unitFinalValue;
|
2019-08-16 12:05:56 +02:00
|
|
|
return response;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return messageError;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-29 14:53:15 +02:00
|
|
|
// Affiche uniquement les prénoms (qui sont dans la liste) qui commence par la lettre souhaitée
|
|
|
|
function filterStudents(filteredLetter, students)
|
|
|
|
{
|
|
|
|
let filteredStudents = [];
|
|
|
|
for(let i = 0; i < students.length; i++)
|
|
|
|
{
|
2019-08-30 00:00:29 +02:00
|
|
|
let studentBoucle = capitalize(students[i]);
|
2019-08-29 14:53:15 +02:00
|
|
|
if (studentBoucle[0] === filteredLetter) {
|
|
|
|
filteredStudents.push(studentBoucle);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (filteredStudents.length === 1)
|
|
|
|
{
|
|
|
|
return ("Prénom qui commence par " + filteredLetter + " : " + filteredStudents + '.');
|
|
|
|
}
|
|
|
|
else if (filteredStudents.length >= 2)
|
|
|
|
{
|
|
|
|
// Affiche la liste des prénoms...
|
|
|
|
let last = filteredStudents[filteredStudents.length - 1]; // Accéde au dernier élément du tableau
|
|
|
|
let totalfilteredLetterStudents = filteredStudents.length;
|
|
|
|
filteredStudents.pop(); // Supprime le dernier élément du tableau
|
|
|
|
// filteredStudents.join(', ') permet de rajouter un espace entre chaque élément du tableau
|
|
|
|
return ("Prénoms qui commence par " + filteredLetter + " (" + totalfilteredLetterStudents + ") : " + filteredStudents.join(', ') + ' et ' + last + '.');
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return ("Il n'y a pas de prénom commencant par " + filteredLetter + ".");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-13 21:56:36 +02:00
|
|
|
// Génère aléatoirement une citation ou un proverbe
|
2019-09-13 14:39:29 +02:00
|
|
|
function getRandomQuote() {
|
|
|
|
let randomNbr = randomNumber(0, (quotes.length - 1));
|
|
|
|
let randomQuotes = quotes[randomNbr];
|
|
|
|
return '" ' + randomQuotes["quote"] + ' " <br> <br> - ' + randomQuotes["source"];
|
|
|
|
}
|
|
|
|
|
2019-09-16 20:39:30 +02:00
|
|
|
// Convertis une valeur dans une devise dans une autre devise
|
|
|
|
function convertCurrency(value, currency, url) {
|
2019-09-13 21:56:36 +02:00
|
|
|
$.ajax({
|
2019-09-16 20:39:30 +02:00
|
|
|
url : url,
|
2019-09-13 23:00:41 +02:00
|
|
|
dataType : "json",
|
2019-09-13 21:56:36 +02:00
|
|
|
success: function (jsonFixer) {
|
|
|
|
switch(currency) {
|
|
|
|
case '£':
|
2019-09-16 20:39:30 +02:00
|
|
|
$('.results').html(formatNumberResult(value) + ' ' + jsonFixer.base + ' = ' + ((parseFloat(jsonFixer.rates.GBP) * value)).toFixed(2) + ' ' + currency);
|
2019-09-16 21:01:02 +02:00
|
|
|
$('.rateDate').html("Dernier rafraîchissement du taux d'échange : " + jsonFixer.date);
|
2019-09-13 22:44:37 +02:00
|
|
|
break;
|
|
|
|
case '$ Américain':
|
2019-09-16 20:39:30 +02:00
|
|
|
$('.results').html(formatNumberResult(value) + ' ' + jsonFixer.base + ' = ' + ((parseFloat(jsonFixer.rates.USD) * value)).toFixed(2) + ' ' + currency);
|
2019-09-16 21:01:02 +02:00
|
|
|
$('.rateDate').html("Dernier rafraîchissement du taux d'échange : " + jsonFixer.date);
|
2019-09-13 21:56:36 +02:00
|
|
|
break;
|
2019-09-13 22:44:37 +02:00
|
|
|
case '$ Canadien':
|
2019-09-16 21:01:02 +02:00
|
|
|
$('.results').html(formatNumberResult(value) + ' ' + jsonFixer.base + ' = ' + ((parseFloat(jsonFixer.rates.CAD) * value)).toFixed(2) + ' ' + currency);
|
|
|
|
$('.rateDate').html("Dernier rafraîchissement du taux d'échange : " + jsonFixer.date);
|
|
|
|
break;
|
2019-09-13 22:44:37 +02:00
|
|
|
case '$ Australien':
|
2019-09-16 21:01:02 +02:00
|
|
|
$('.results').html(formatNumberResult(value) + ' ' + jsonFixer.base + ' = ' + ((parseFloat(jsonFixer.rates.AUD) * value)).toFixed(2) + ' ' + currency);
|
|
|
|
$('.rateDate').html("Dernier rafraîchissement du taux d'échange : " + jsonFixer.date);
|
|
|
|
break;
|
2019-09-13 22:44:37 +02:00
|
|
|
case '$ Mexicain':
|
2019-09-16 21:01:02 +02:00
|
|
|
$('.results').html(formatNumberResult(value) + ' ' + jsonFixer.base + ' = ' + ((parseFloat(jsonFixer.rates.MXN) * value)).toFixed(2) + ' ' + currency);
|
|
|
|
$('.rateDate').html("Dernier rafraîchissement du taux d'échange : " + jsonFixer.date);
|
|
|
|
break;
|
2019-09-17 19:17:30 +02:00
|
|
|
case 'CHF':
|
2019-09-16 21:01:02 +02:00
|
|
|
$('.results').html(formatNumberResult(value) + ' ' + jsonFixer.base + ' = ' + ((parseFloat(jsonFixer.rates.CHF) * value)).toFixed(2) + ' ' + currency);
|
|
|
|
$('.rateDate').html("Dernier rafraîchissement du taux d'échange : " + jsonFixer.date);
|
|
|
|
break;
|
2019-09-13 22:44:37 +02:00
|
|
|
case '₽':
|
2019-09-16 21:01:02 +02:00
|
|
|
$('.results').html(formatNumberResult(value) + ' ' + jsonFixer.base + ' = ' + ((parseFloat(jsonFixer.rates.RUB) * value)).toFixed(2) + ' ' + currency);
|
|
|
|
$('.rateDate').html("Dernier rafraîchissement du taux d'échange : " + jsonFixer.date);
|
|
|
|
break;
|
2019-09-13 22:44:37 +02:00
|
|
|
case 'R$':
|
2019-09-16 21:01:02 +02:00
|
|
|
$('.results').html(formatNumberResult(value) + ' ' + jsonFixer.base + ' = ' + ((parseFloat(jsonFixer.rates.BRL) * value)).toFixed(2) + ' ' + currency);
|
|
|
|
$('.rateDate').html("Dernier rafraîchissement du taux d'échange : " + jsonFixer.date);
|
|
|
|
break;
|
2019-09-13 22:44:37 +02:00
|
|
|
case '¥':
|
2019-09-16 21:01:02 +02:00
|
|
|
$('.results').html(formatNumberResult(value) + ' ' + jsonFixer.base + ' = ' + ((parseFloat(jsonFixer.rates.JPY) * value)).toFixed(2) + ' ' + currency);
|
|
|
|
$('.rateDate').html("Dernier rafraîchissement du taux d'échange : " + jsonFixer.date);
|
|
|
|
break;
|
2019-09-16 20:39:30 +02:00
|
|
|
case '€':
|
2019-09-16 21:01:02 +02:00
|
|
|
let rateEUR = jsonFixer.rates.EUR;
|
|
|
|
if (isNaN(rateEUR)) {
|
|
|
|
$('.results').html(formatNumberResult(value) + ' €');
|
|
|
|
} else {
|
|
|
|
$('.results').html(formatNumberResult(value) + ' ' + jsonFixer.base + ' = ' + ((parseFloat(rateEUR) * value)).toFixed(2) + ' ' + currency);
|
|
|
|
$('.rateDate').html("Dernier rafraîchissement du taux d'échange : " + jsonFixer.date);
|
|
|
|
}
|
|
|
|
break;
|
2019-09-13 21:56:36 +02:00
|
|
|
default:
|
2019-09-16 20:39:30 +02:00
|
|
|
$('.results').html(formatNumberResult(value) + ' €');
|
2019-09-13 21:56:36 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
statusCode: {
|
|
|
|
404: function() {
|
|
|
|
document.location.replace("../404.php");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2019-08-16 12:05:56 +02:00
|
|
|
|
2019-09-14 17:38:30 +02:00
|
|
|
// Convertis du texte (encodé en UTF-8) en binaire et l'inverse aussi (source : http://jsfiddle.net/47zwb41o)
|
|
|
|
// UTF-8 vers Binaire
|
|
|
|
function utf8ToBin(s) {
|
2019-09-15 22:21:02 +02:00
|
|
|
try {
|
|
|
|
s = unescape( encodeURIComponent(s));
|
|
|
|
var chr, i = 0, l = s.length, out = '';
|
|
|
|
for( ; i < l; i ++ ){
|
|
|
|
chr = s.charCodeAt( i ).toString(2);
|
|
|
|
while(chr.length % 8 != 0 ){ chr = '0' + chr; }
|
|
|
|
out += chr;
|
|
|
|
}
|
|
|
|
return out;
|
|
|
|
} catch (error) {
|
|
|
|
return s;
|
2019-09-14 17:38:30 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// Binaire vers UTF-8
|
|
|
|
function binToUtf8(s){
|
2019-09-15 22:21:02 +02:00
|
|
|
try {
|
|
|
|
var i = 0, l = s.length, chr, out = '';
|
|
|
|
for( ; i < l; i += 8){
|
|
|
|
chr = parseInt( s.substr(i, 8 ), 2).toString(16);
|
|
|
|
out += '%' + ((chr.length % 2 == 0) ? chr : '0' + chr);
|
|
|
|
}
|
|
|
|
return decodeURIComponent(out);
|
|
|
|
} catch (error) {
|
|
|
|
return s;
|
2019-09-14 17:38:30 +02:00
|
|
|
}
|
2019-09-21 19:45:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Convertis un nombre arabe en nombre romain
|
|
|
|
function convertRomanArabicNumbers(nombre) {
|
|
|
|
// Tableau contenant chaque correspondance entre un nombre arabe et un nombre romain
|
|
|
|
const correspondances =
|
|
|
|
[
|
|
|
|
[1000, "M"],
|
|
|
|
[900, "CM"],
|
|
|
|
[500, "D"],
|
|
|
|
[400, "CD"],
|
|
|
|
[100, "C"],
|
|
|
|
[90, "XC"],
|
|
|
|
[50, "L"],
|
|
|
|
[40, "XL"],
|
|
|
|
[10, "X"],
|
|
|
|
[9, "IX"],
|
|
|
|
[5, "V"],
|
|
|
|
[4, "IV"],
|
|
|
|
[1, "I"],
|
|
|
|
];
|
|
|
|
|
|
|
|
// Initialisation de la variable qui va contenir le résultat de la conversion
|
|
|
|
let chiffresRomains = "";
|
|
|
|
|
|
|
|
/*
|
|
|
|
Étapes pour écrire un nombre romain :
|
|
|
|
|
|
|
|
On vérifie quand le nombre arabe est >= à la plus grande valeur possible dans la table de correspondance des nombres romains de haut en bas puis on rajoute la lettre romaine correspondante à la plus grande valeur possible dans la variable chiffresRomains et on soustrait la valeur du chiffre romain qu'on vient d'ajouter au nombre arabe puis on répète l'opération jusqu'à nombre arabe vaut 0...
|
|
|
|
|
|
|
|
Exemple avec 27 :
|
|
|
|
27 - X (10) = 17
|
|
|
|
17 - X (10) = 7
|
|
|
|
7 - V (5) = 2
|
|
|
|
2 - I (1) = 1
|
|
|
|
1 - I (1) = 0
|
|
|
|
XXVII
|
|
|
|
*/
|
|
|
|
|
|
|
|
function extraireChiffreRomain(valeurLettre, lettres) {
|
|
|
|
while (nombre >= valeurLettre) {
|
|
|
|
chiffresRomains = chiffresRomains + lettres;
|
|
|
|
nombre = nombre - valeurLettre;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
correspondances.forEach(correspondance => {
|
|
|
|
extraireChiffreRomain(correspondance[0], correspondance[1]);
|
|
|
|
})
|
|
|
|
|
|
|
|
return chiffresRomains;
|
2019-08-16 12:05:56 +02:00
|
|
|
}
|