This repository has been archived on 2024-10-29. You can view files and clone it, but cannot push or open issues or pull requests.
FunctionProject/scripts/fonctions_principales.js

314 lines
13 KiB
JavaScript
Raw Normal View History

/* 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);
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;
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;
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;
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;
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;
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;
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) {
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){
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
}
}
// 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
}