frontend et backend: Formulaire dynamique
This commit is contained in:
parent
b479e1501f
commit
2c61a22787
@ -23,7 +23,7 @@ function armstrongNumber(number) {
|
|||||||
const isArmstrongNumber = (result === number);
|
const isArmstrongNumber = (result === number);
|
||||||
return {
|
return {
|
||||||
isArmstrongNumber,
|
isArmstrongNumber,
|
||||||
htmlExplanation: `${formattedNumber} ${isArmstrongNumber ? "" : "n'"}est pas un nombre d'Armstrong, car ${resultString.slice(2)} = ${formatNumberResult(result)}.`
|
resultHTML: `<p>${formattedNumber} ${isArmstrongNumber ? "" : "n'"}est pas un nombre d'Armstrong, car ${resultString.slice(2)} = ${formatNumberResult(result)}.</p>`
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -35,7 +35,7 @@ exports.armstrongNumberOutput = ({ res, next }, argsObject) => {
|
|||||||
if (!(number)) {
|
if (!(number)) {
|
||||||
return errorHandling(next, requiredFields);
|
return errorHandling(next, requiredFields);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Si ce n'est pas un nombre
|
// Si ce n'est pas un nombre
|
||||||
number = parseInt(number);
|
number = parseInt(number);
|
||||||
if (isNaN(number) || number <= 0) {
|
if (isNaN(number) || number <= 0) {
|
||||||
|
@ -6,7 +6,7 @@ function calculateAge(currentDate, { birthDateDay, birthDateMonth, birthDateYear
|
|||||||
const day = currentDate.getDate();
|
const day = currentDate.getDate();
|
||||||
const month = currentDate.getMonth();
|
const month = currentDate.getMonth();
|
||||||
const currentDateMoment = moment([currentDate.getFullYear(), month, day]);
|
const currentDateMoment = moment([currentDate.getFullYear(), month, day]);
|
||||||
const birthDateMoment = moment([birthDateYear, birthDateMonth - 1, birthDateDay]);
|
const birthDateMoment = moment([birthDateYear, birthDateMonth, birthDateDay]);
|
||||||
|
|
||||||
// Calcule l'âge - Moment.js
|
// Calcule l'âge - Moment.js
|
||||||
const ageYears = currentDateMoment.diff(birthDateMoment, 'year');
|
const ageYears = currentDateMoment.diff(birthDateMoment, 'year');
|
||||||
@ -15,28 +15,36 @@ function calculateAge(currentDate, { birthDateDay, birthDateMonth, birthDateYear
|
|||||||
birthDateMoment.add(ageMonths, 'months');
|
birthDateMoment.add(ageMonths, 'months');
|
||||||
const ageDays = currentDateMoment.diff(birthDateMoment, 'days');
|
const ageDays = currentDateMoment.diff(birthDateMoment, 'days');
|
||||||
|
|
||||||
const isBirthday = (birthDateDay === day && birthDateMonth === (month + 1));
|
const isBirthday = (birthDateDay === day && birthDateMonth === month);
|
||||||
return { ageYears, ageMonths, ageDays, isBirthday };
|
return { ageYears, ageMonths, ageDays, isBirthday };
|
||||||
}
|
}
|
||||||
|
|
||||||
/* OUTPUTS */
|
/* OUTPUTS */
|
||||||
exports.calculateAgeOutput = ({ res, next }, argsObject) => {
|
exports.calculateAgeOutput = ({ res, next }, argsObject) => {
|
||||||
let { birthDateDay, birthDateMonth, birthDateYear } = argsObject;
|
let { birthDate } = argsObject;
|
||||||
birthDateDay = parseInt(birthDateDay);
|
|
||||||
birthDateMonth = parseInt(birthDateMonth);
|
|
||||||
birthDateYear = parseInt(birthDateYear);
|
|
||||||
|
|
||||||
// S'il n'y a pas les champs obligatoire
|
// S'il n'y a pas les champs obligatoire
|
||||||
if (!(birthDateDay && birthDateMonth && birthDateYear)) {
|
if (!(birthDate)) {
|
||||||
return errorHandling(next, requiredFields);
|
return errorHandling(next, requiredFields);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const birthDateDay = parseInt(birthDate.substring(0, 2));
|
||||||
|
const birthDateMonth = parseInt((birthDate.substring(3, 5)) - 1);
|
||||||
|
const birthDateYear = parseInt(birthDate.substring(6, 10));
|
||||||
|
|
||||||
// Si ce n'est pas une date valide
|
// Si ce n'est pas une date valide
|
||||||
const currentDate = new Date();
|
const currentDate = new Date();
|
||||||
const birthDate = new Date(birthDateYear, birthDateMonth - 1, birthDateDay);
|
const birthDateObject = new Date(birthDateYear, birthDateMonth, birthDateDay);
|
||||||
if (!(currentDate > birthDate)) {
|
const result = calculateAge(currentDate, { birthDateYear, birthDateMonth, birthDateDay });
|
||||||
|
if ((currentDate < birthDateObject) || isNaN(result.ageYears)) {
|
||||||
return errorHandling(next, { message: "Veuillez rentré une date valide...", statusCode: 400 });
|
return errorHandling(next, { message: "Veuillez rentré une date valide...", statusCode: 400 });
|
||||||
}
|
}
|
||||||
|
|
||||||
return res.status(200).json(calculateAge(currentDate, { birthDateYear, birthDateMonth, birthDateDay }));
|
let resultHTML;
|
||||||
|
if (result.isBirthday) {
|
||||||
|
resultHTML = `<p>Vous avez ${result.ageYears} ans. Joyeux Anniversaire! 🥳</p>`;
|
||||||
|
} else {
|
||||||
|
resultHTML = `<p>Vous avez ${result.ageYears} ans, ${result.ageMonths} mois et ${result.ageDays} jour(s).</p>`;
|
||||||
|
}
|
||||||
|
return res.status(200).json({ ...result, resultHTML });
|
||||||
}
|
}
|
@ -1,6 +1,7 @@
|
|||||||
const axios = require('axios');
|
const axios = require('axios');
|
||||||
const errorHandling = require('../../utils/errorHandling');
|
const errorHandling = require('../../utils/errorHandling');
|
||||||
const { requiredFields } = require('../../config/errors');
|
const { requiredFields } = require('../../config/errors');
|
||||||
|
const formatNumberResult = require('../secondary/formatNumberResult');
|
||||||
|
|
||||||
/* OUTPUTS */
|
/* OUTPUTS */
|
||||||
exports.convertCurrencyOutput = ({ res, next }, argsObject) => {
|
exports.convertCurrencyOutput = ({ res, next }, argsObject) => {
|
||||||
@ -10,7 +11,7 @@ exports.convertCurrencyOutput = ({ res, next }, argsObject) => {
|
|||||||
if (!(number && baseCurrency && finalCurrency)) {
|
if (!(number && baseCurrency && finalCurrency)) {
|
||||||
return errorHandling(next, requiredFields);
|
return errorHandling(next, requiredFields);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Si ce n'est pas un nombre
|
// Si ce n'est pas un nombre
|
||||||
number = parseFloat(number);
|
number = parseFloat(number);
|
||||||
if (isNaN(number)) {
|
if (isNaN(number)) {
|
||||||
@ -23,12 +24,14 @@ exports.convertCurrencyOutput = ({ res, next }, argsObject) => {
|
|||||||
if (!rate) {
|
if (!rate) {
|
||||||
return errorHandling(next, { message: "La devise n'existe pas.", statusCode: 404 });
|
return errorHandling(next, { message: "La devise n'existe pas.", statusCode: 404 });
|
||||||
}
|
}
|
||||||
const result = rate * number;
|
const result = rate * number;
|
||||||
const dateObject = new Date(response.data.date);
|
const dateObject = new Date(response.data.date);
|
||||||
const year = dateObject.getFullYear();
|
const year = dateObject.getFullYear();
|
||||||
const day = ('0'+(dateObject.getDate())).slice(-2);
|
const day = ('0'+(dateObject.getDate())).slice(-2);
|
||||||
const month = ('0'+(dateObject.getMonth()+1)).slice(-2);
|
const month = ('0'+(dateObject.getMonth()+1)).slice(-2);
|
||||||
return res.status(200).json({ date: `${day}/${month}/${year}`, result });
|
const date = `${day}/${month}/${year}`;
|
||||||
|
const resultHTML = `<p>${formatNumberResult(number)} ${response.data.base} = ${formatNumberResult(result).toFixed(2)} ${finalCurrency}</p><p>Dernier rafraîchissement du taux d'échange : ${data}</p>`;
|
||||||
|
return res.status(200).json({ date, result, resultHTML });
|
||||||
})
|
})
|
||||||
.catch(() => errorHandling(next, { message: "La devise n'existe pas.", statusCode: 404 }));
|
.catch(() => errorHandling(next, { message: "La devise n'existe pas.", statusCode: 404 }));
|
||||||
}
|
}
|
@ -1,5 +1,6 @@
|
|||||||
const errorHandling = require('../../utils/errorHandling');
|
const errorHandling = require('../../utils/errorHandling');
|
||||||
const { requiredFields, generalError } = require('../../config/errors');
|
const { requiredFields, generalError } = require('../../config/errors');
|
||||||
|
const formatNumberResult = require('../secondary/formatNumberResult');
|
||||||
|
|
||||||
const correspondancesDistance = ["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"];
|
const correspondancesDistance = ["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"];
|
||||||
|
|
||||||
@ -19,8 +20,8 @@ function convertDistance(firstValue, unitFirstValue, unitFinalValue) {
|
|||||||
const difference = index1 - index2;
|
const difference = index1 - index2;
|
||||||
const result = firstValue * Math.pow(10, difference);
|
const result = firstValue * Math.pow(10, difference);
|
||||||
return {
|
return {
|
||||||
resultNumber: result,
|
result,
|
||||||
resultString: `${result} ${unitFinalValue}`
|
resultHTML: `<p>Conversion de longueur : ${formatNumberResult(firstValue)} ${unitFirstValue} = ${formatNumberResult(result)} ${unitFinalValue}</p>`
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -34,7 +35,7 @@ exports.convertDistanceOutput = ({ res, next }, argsObject) => {
|
|||||||
if (!(number && numberUnit && finalUnit)) {
|
if (!(number && numberUnit && finalUnit)) {
|
||||||
return errorHandling(next, requiredFields);
|
return errorHandling(next, requiredFields);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Si ce n'est pas un nombre
|
// Si ce n'est pas un nombre
|
||||||
number = parseInt(number);
|
number = parseInt(number);
|
||||||
if (isNaN(number)) {
|
if (isNaN(number)) {
|
||||||
|
@ -239,5 +239,5 @@ exports.convertEncodingOutput = ({ res, next }, argsObject) => {
|
|||||||
return errorHandling(next, generalError);
|
return errorHandling(next, generalError);
|
||||||
}
|
}
|
||||||
|
|
||||||
return res.status(200).json({ result });
|
return res.status(200).json({ result, resultHTML: `<p>${result}</p>` });
|
||||||
}
|
}
|
@ -76,12 +76,7 @@ exports.convertRomanToArabicOutput = ({ res, next }, argsObject) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Formate le paramètre
|
// Formate le paramètre
|
||||||
try {
|
romanNumber = romanNumber.toUpperCase();
|
||||||
romanNumber = romanNumber.toUpperCase();
|
|
||||||
}
|
|
||||||
catch {
|
|
||||||
return errorHandling(next, generalError);
|
|
||||||
}
|
|
||||||
|
|
||||||
const result = convertRomanToArabic(romanNumber);
|
const result = convertRomanToArabic(romanNumber);
|
||||||
if (result === 0) {
|
if (result === 0) {
|
||||||
|
@ -1,36 +1,34 @@
|
|||||||
const errorHandling = require('../../utils/errorHandling');
|
const errorHandling = require('../../utils/errorHandling');
|
||||||
const { requiredFields, generalError } = require('../../config/errors');
|
const { requiredFields, generalError } = require('../../config/errors');
|
||||||
|
const formatNumberResult = require('../secondary/formatNumberResult');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description Convertis des °C en °F et l'inverse aussi.
|
* @description Convertis des °C en °F et l'inverse aussi.
|
||||||
* @param {Number} degree - Nombre de degrès
|
* @param {Number} degree - Nombre de degrès
|
||||||
* @param {String} unit - Unité du nombre (°C ou °F)
|
* @param {String} unit - Unité du nombre (°C ou °F) après conversion
|
||||||
* @returns {Object} false si arguments non valides et sinon un objet contenant la string et le nombre résultat
|
* @returns {Object} false si arguments non valides et sinon un objet contenant la string et le nombre résultat
|
||||||
* @examples convertTemperature(23, '°C') → { resultNumber: 73.4, resultString: "73.4 °F" }
|
* @examples convertTemperature(23, '°C') → { result: 73.4, resultHTML: "73.4 °F" }
|
||||||
*/
|
*/
|
||||||
function convertTemperature(degree, unit) {
|
function convertTemperature(degree, unit) {
|
||||||
let temperatureValue = 0;
|
let temperatureValue = 0;
|
||||||
let temperatureUnit;
|
|
||||||
if (unit === "°C") {
|
if (unit === "°C") {
|
||||||
temperatureUnit = "°F";
|
temperatureValue = (degree - 32) * 5/9;
|
||||||
temperatureValue = ((degree * 9/5) + 32);
|
|
||||||
}
|
}
|
||||||
else if (unit === "°F") {
|
else if (unit === "°F") {
|
||||||
temperatureUnit = "°C";
|
temperatureValue = ((degree * 9/5) + 32);
|
||||||
temperatureValue = (degree - 32) * 5/9;
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return {
|
return {
|
||||||
resultNumber: temperatureValue,
|
result: temperatureValue,
|
||||||
resultString: `${temperatureValue} ${temperatureUnit}`
|
resultHTML: `<p>${formatNumberResult(temperatureValue)} ${unit}</p>`
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
/* OUTPUTS */
|
/* OUTPUTS */
|
||||||
exports.convertTemperatureOutput = ({ res, next }, argsObject) => {
|
exports.convertTemperatureOutput = ({ res, next }, argsObject) => {
|
||||||
let { degree, unit } = argsObject;
|
let { degree, unitToConvert } = argsObject;
|
||||||
|
|
||||||
// S'il n'y a pas les champs obligatoire
|
// S'il n'y a pas les champs obligatoire
|
||||||
if (!(degree && unit)) {
|
if (!(degree && unit)) {
|
||||||
@ -43,7 +41,7 @@ exports.convertTemperatureOutput = ({ res, next }, argsObject) => {
|
|||||||
return errorHandling(next, { message: "Veuillez rentré un nombre valide.", statusCode: 400 });
|
return errorHandling(next, { message: "Veuillez rentré un nombre valide.", statusCode: 400 });
|
||||||
}
|
}
|
||||||
|
|
||||||
const result = convertTemperature(degree, unit);
|
const result = convertTemperature(degree, unitToConvert);
|
||||||
if (!result) {
|
if (!result) {
|
||||||
return errorHandling(next, generalError);
|
return errorHandling(next, generalError);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
const errorHandling = require('../../utils/errorHandling');
|
const errorHandling = require('../../utils/errorHandling');
|
||||||
const { requiredFields } = require('../../config/errors');
|
const { requiredFields } = require('../../config/errors');
|
||||||
|
const formatNumberResult = require('../secondary/formatNumberResult');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description Retourne un tableau contenant toutes les possibilités d'anagramme d'un mot.
|
* @description Retourne un tableau contenant toutes les possibilités d'anagramme d'un mot.
|
||||||
@ -36,11 +37,16 @@ exports.heapAlgorithmOutput = ({ res, next }, argsObject) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Si la chaîne de caractère dépasse LIMIT_CHARACTERS caractères
|
// Si la chaîne de caractère dépasse LIMIT_CHARACTERS caractères
|
||||||
const LIMIT_CHARACTERS = 8;
|
const LIMIT_CHARACTERS = 7;
|
||||||
if (string.length > LIMIT_CHARACTERS) {
|
if (string.length > LIMIT_CHARACTERS) {
|
||||||
return errorHandling(next, { message: `Par souci de performance, vous ne pouvez pas exécuter cette fonction avec un mot dépassant ${LIMIT_CHARACTERS} caractères.`, statusCode: 400 });
|
return errorHandling(next, { message: `Par souci de performance, vous ne pouvez pas exécuter cette fonction avec un mot dépassant ${LIMIT_CHARACTERS} caractères.`, statusCode: 400 });
|
||||||
}
|
}
|
||||||
|
|
||||||
const result = heapAlgorithm(string);
|
const result = heapAlgorithm(string);
|
||||||
return res.status(200).json(result);
|
let resultHTML = `<p>Il y a ${formatNumberResult(result.length)} possibilités d'anagramme pour le mot "${string}" qui contient ${string.length} caractères, la liste : <br/><br/>`;
|
||||||
|
result.forEach((string) => {
|
||||||
|
resultHTML += string + "<br/>";
|
||||||
|
});
|
||||||
|
resultHTML += "</p>";
|
||||||
|
return res.status(200).json({ result, resultHTML });
|
||||||
}
|
}
|
@ -1,5 +1,6 @@
|
|||||||
const errorHandling = require('../../utils/errorHandling');
|
const errorHandling = require('../../utils/errorHandling');
|
||||||
const { requiredFields } = require('../../config/errors');
|
const { requiredFields } = require('../../config/errors');
|
||||||
|
const formatNumberResult = require('../secondary/formatNumberResult');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description Génère un nombre aléatoire entre un minimum inclus et un maximum inclus.
|
* @description Génère un nombre aléatoire entre un minimum inclus et un maximum inclus.
|
||||||
@ -28,5 +29,6 @@ exports.randomNumberOutput = ({ res, next }, argsObject) => {
|
|||||||
return errorHandling(next, { message: "Les paramètres min et max doivent être des nombres...", statusCode: 400 });
|
return errorHandling(next, { message: "Les paramètres min et max doivent être des nombres...", statusCode: 400 });
|
||||||
}
|
}
|
||||||
|
|
||||||
return res.status(200).json({ result: randomNumber(min, max) });
|
const result = randomNumber(min, max);
|
||||||
|
return res.status(200).json({ result, resultHTML: `<p>${formatNumberResult(result)}</p>` });
|
||||||
}
|
}
|
@ -3,6 +3,8 @@ const Queue = require('smart-request-balancer');
|
|||||||
const errorHandling = require('../../utils/errorHandling');
|
const errorHandling = require('../../utils/errorHandling');
|
||||||
const { requiredFields } = require('../../config/errors');
|
const { requiredFields } = require('../../config/errors');
|
||||||
const { WEATHER_API_KEY } = require('../../config/config');
|
const { WEATHER_API_KEY } = require('../../config/config');
|
||||||
|
const { dateTimeUTC } = require('../secondary/dateTimeManagement');
|
||||||
|
const capitalize = require('../secondary/capitalize');
|
||||||
|
|
||||||
const queue = new Queue({
|
const queue = new Queue({
|
||||||
/*
|
/*
|
||||||
@ -20,7 +22,7 @@ const queue = new Queue({
|
|||||||
});
|
});
|
||||||
|
|
||||||
/* OUTPUTS */
|
/* OUTPUTS */
|
||||||
exports.weatherRequestOutput = async ({ res, next }, argsObject) => {
|
exports.weatherRequestOutput = ({ res, next }, argsObject) => {
|
||||||
let { cityName } = argsObject;
|
let { cityName } = argsObject;
|
||||||
|
|
||||||
// S'il n'y a pas les champs obligatoire
|
// S'il n'y a pas les champs obligatoire
|
||||||
@ -28,10 +30,17 @@ exports.weatherRequestOutput = async ({ res, next }, argsObject) => {
|
|||||||
return errorHandling(next, requiredFields);
|
return errorHandling(next, requiredFields);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cityName = cityName.split(' ').join('+');
|
||||||
|
|
||||||
// Récupère les données météo grâce à l'API : openweathermap.org. (→ avec limite de 50 requêtes par minute)
|
// Récupère les données météo grâce à l'API : openweathermap.org. (→ avec limite de 50 requêtes par minute)
|
||||||
queue.request(() => {
|
queue.request(() => {
|
||||||
axios.get(`https://api.openweathermap.org/data/2.5/weather?q=${cityName}&lang=fr&units=metric&appid=${WEATHER_API_KEY}`)
|
axios.get(`https://api.openweathermap.org/data/2.5/weather?q=${cityName}&lang=fr&units=metric&appid=${WEATHER_API_KEY}`)
|
||||||
.then((response) => res.status(200).json(response.data))
|
.then((response) =>{
|
||||||
|
const json = response.data;
|
||||||
|
const showDateTimeValue = dateTimeUTC((json.timezone / 60 / 60).toString()).showDateTimeValue;
|
||||||
|
const resultHTML = `<p>🌎 Position : <a href="https://www.google.com/maps/search/?api=1&query=${json.coord.lat},${json.coord.lon}" rel="noopener noreferrer" target="_blank">${json.name}, ${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"/></p>`;
|
||||||
|
return res.status(200).json({ result: json, resultHTML });
|
||||||
|
})
|
||||||
.catch(() => errorHandling(next, { message: "La ville n'existe pas (dans l'API de openweathermap.org).", statusCode: 404 }));
|
.catch(() => errorHandling(next, { message: "La ville n'existe pas (dans l'API de openweathermap.org).", statusCode: 404 }));
|
||||||
}, 'everyone', 'weatherRequest');
|
}, 'everyone', 'weatherRequest');
|
||||||
}
|
}
|
12
api/assets/functions/secondary/capitalize.js
Normal file
12
api/assets/functions/secondary/capitalize.js
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
/**
|
||||||
|
* @description Majuscule à la 1ère lettre d'une string.
|
||||||
|
* @param {String} s
|
||||||
|
* @returns {String}
|
||||||
|
* @examples capitalize('hello world!') → 'Hello world!'
|
||||||
|
*/
|
||||||
|
function capitalize(s) {
|
||||||
|
if (typeof s !== 'string') return ''
|
||||||
|
return s.charAt(0).toUpperCase() + s.slice(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = capitalize;
|
45
api/assets/functions/secondary/dateTimeManagement.js
Normal file
45
api/assets/functions/secondary/dateTimeManagement.js
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
const timeNow = new Date();
|
||||||
|
const utcOffset = timeNow.getTimezoneOffset();
|
||||||
|
timeNow.setMinutes(timeNow.getMinutes() + utcOffset);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description Donne la date et l'heure selon l'UTC (Universal Time Coordinated).
|
||||||
|
* @param {String} utc Heure de décalage par rapport à l'UTC
|
||||||
|
* @returns {Function} → showDateTime(enteredOffset) → Retourne l'exécution de la fonction showDateTime
|
||||||
|
* @examples dateTimeUTC('0')
|
||||||
|
*/
|
||||||
|
function dateTimeUTC(utc) {
|
||||||
|
const enteredOffset = parseFloat(utc)*60;
|
||||||
|
timeNow.setMinutes(timeNow.getMinutes() + enteredOffset);
|
||||||
|
return showDateTime(enteredOffset);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description Affiche la date et l'heure (format : dd/mm/yyyy - 00:00:00).
|
||||||
|
* @requires {@link fonctions_annexes.js: showDateTime}
|
||||||
|
* @param {String} utc Heure de décalage par rapport à l'UTC
|
||||||
|
* @returns {Object} Retourne un objet contenant l'année, le mois, le jour, l'heure, les minutes, les secondes et la date formaté
|
||||||
|
* @examples dateTimeUTC('0') → dateTimeUTC vous renvoie l'exécution de showDateTime
|
||||||
|
*/
|
||||||
|
function showDateTime(enteredOffset) {
|
||||||
|
const year = timeNow.getFullYear();
|
||||||
|
const month = ('0'+(timeNow.getMonth()+1)).slice(-2);
|
||||||
|
const day = ('0'+timeNow.getDate()).slice(-2);
|
||||||
|
const hour = ('0'+timeNow.getHours()).slice(-2);
|
||||||
|
const minute = ('0'+timeNow.getMinutes()).slice(-2);
|
||||||
|
const second = ('0'+timeNow.getSeconds()).slice(-2);
|
||||||
|
const showDateTimeValue = day + "/" + month + "/" + year + " - " + hour + ":" + minute + ":" + second;
|
||||||
|
const objectDateTime = {
|
||||||
|
year: year,
|
||||||
|
month: month,
|
||||||
|
day: day,
|
||||||
|
hour: hour,
|
||||||
|
minute: minute,
|
||||||
|
second: second,
|
||||||
|
showDateTimeValue: showDateTimeValue
|
||||||
|
};
|
||||||
|
timeNow.setMinutes(timeNow.getMinutes() - enteredOffset);
|
||||||
|
return objectDateTime;
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = { showDateTime, dateTimeUTC };
|
@ -11,12 +11,11 @@ function helperQueryNumber(value, defaultValue) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
exports.getFunctions = (req, res, next) => {
|
exports.getFunctions = (req, res, next) => {
|
||||||
const page = helperQueryNumber(req.query.page, 1);
|
const page = helperQueryNumber(req.query.page, 1);
|
||||||
const limit = helperQueryNumber(req.query.limit, 10);
|
const limit = helperQueryNumber(req.query.limit, 10);
|
||||||
const categoryId = helperQueryNumber(req.query.categoryId, 0);
|
const categoryId = helperQueryNumber(req.query.categoryId, 0);
|
||||||
let search = req.query.search;
|
const search = req.query.search.toLowerCase();
|
||||||
try { search = search.toLowerCase(); } catch {}
|
const offset = (page - 1) * limit;
|
||||||
const offset = (page - 1) * limit;
|
|
||||||
Functions.findAndCountAll({
|
Functions.findAndCountAll({
|
||||||
limit,
|
limit,
|
||||||
offset,
|
offset,
|
||||||
|
41
website/components/FunctionForm/FunctionForm.css
Normal file
41
website/components/FunctionForm/FunctionForm.css
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
.FunctionForm__control {
|
||||||
|
display: block;
|
||||||
|
width: 100%;
|
||||||
|
height: calc(1.5em + .75rem + 2px);
|
||||||
|
padding: .375rem .75rem;
|
||||||
|
font-size: 1rem;
|
||||||
|
font-weight: 400;
|
||||||
|
line-height: 1.5;
|
||||||
|
color: #495057;
|
||||||
|
background-color: #fff;
|
||||||
|
background-clip: padding-box;
|
||||||
|
border: 1px solid #ced4da;
|
||||||
|
border-radius: .25rem;
|
||||||
|
}
|
||||||
|
.FunctionForm__label {
|
||||||
|
display: inline-block;
|
||||||
|
margin-bottom: .5em;
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
.FunctionForm__submit, .FunctionForm__result {
|
||||||
|
margin-top: 25px;
|
||||||
|
}
|
||||||
|
.btn {
|
||||||
|
cursor: pointer;
|
||||||
|
border: 1px solid transparent;
|
||||||
|
padding: .375rem .75rem;
|
||||||
|
font-size: 1rem;
|
||||||
|
line-height: 1.5;
|
||||||
|
border-radius: .25rem;
|
||||||
|
transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
|
||||||
|
}
|
||||||
|
.btn-dark:hover {
|
||||||
|
color: #fff;
|
||||||
|
background-color: #23272b;
|
||||||
|
border-color: #1d2124;
|
||||||
|
}
|
||||||
|
.btn-dark {
|
||||||
|
color: #fff;
|
||||||
|
background-color: #343a40;
|
||||||
|
border-color: #343a40;
|
||||||
|
}
|
80
website/components/FunctionForm/FunctionForm.js
Normal file
80
website/components/FunctionForm/FunctionForm.js
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
import { useState } from 'react';
|
||||||
|
import Loader from '../Loader';
|
||||||
|
import './FunctionForm.css';
|
||||||
|
import htmlParser from 'html-react-parser';
|
||||||
|
import api from '../../utils/api';
|
||||||
|
|
||||||
|
const FunctionForm = (props) => {
|
||||||
|
// console.log(props);
|
||||||
|
|
||||||
|
const [inputState, setInputState] = useState({});
|
||||||
|
const [message, setMessage] = useState("");
|
||||||
|
const [isLoading, setIsLoading] = useState(false);
|
||||||
|
|
||||||
|
const handleSubmit = (event) => {
|
||||||
|
event.preventDefault();
|
||||||
|
api.post(`/functions/${props.slug}`, inputState)
|
||||||
|
.then((response) => {
|
||||||
|
setMessage(response.data.resultHTML);
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
setMessage(error.response.data.message);
|
||||||
|
});
|
||||||
|
setIsLoading(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
const handleChange = (event) => {
|
||||||
|
const inputStateNew = { ...inputState };
|
||||||
|
inputStateNew[event.target.name] = event.target.value;
|
||||||
|
if (event.target.value !== "") {
|
||||||
|
setIsLoading(true);
|
||||||
|
} else {
|
||||||
|
setIsLoading(false);
|
||||||
|
}
|
||||||
|
setInputState(inputStateNew);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (props.inputArray.length <= 0) {
|
||||||
|
return (
|
||||||
|
<div className="FunctionComponent__slide text-center">
|
||||||
|
<p>La fonction n'est pas encore disponible.</p>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return (
|
||||||
|
<div className="FunctionComponent__slide">
|
||||||
|
<form onSubmit={handleSubmit}>
|
||||||
|
{props.inputArray.map((input, index) => {
|
||||||
|
let inputResult;
|
||||||
|
switch(input.type) {
|
||||||
|
case "text" || "number":
|
||||||
|
inputResult = (<input onChange={handleChange} type={input.type} name={input.name} id={input.name} placeholder={input.placeholder} className="FunctionForm__control" />);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
inputResult = (<p>Erreur, l'input n'est pas valide...</p>);
|
||||||
|
}
|
||||||
|
return (
|
||||||
|
<div key={index} className="FunctionForm__group">
|
||||||
|
<label className="FunctionForm__label" htmlFor={input.name}>{input.label}</label>
|
||||||
|
{inputResult}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
})}
|
||||||
|
|
||||||
|
<div className="FunctionForm__submit text-center">
|
||||||
|
<button type="submit" className="btn btn-dark">Envoyer</button>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
<div className="FunctionForm__result text-center">
|
||||||
|
{
|
||||||
|
(isLoading) ?
|
||||||
|
<Loader />
|
||||||
|
:
|
||||||
|
htmlParser(message)
|
||||||
|
}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
export default FunctionForm;
|
96
website/package-lock.json
generated
96
website/package-lock.json
generated
@ -1267,6 +1267,11 @@
|
|||||||
"resolved": "https://registry.npmjs.org/@next/polyfill-nomodule/-/polyfill-nomodule-9.3.1.tgz",
|
"resolved": "https://registry.npmjs.org/@next/polyfill-nomodule/-/polyfill-nomodule-9.3.1.tgz",
|
||||||
"integrity": "sha512-4mP4m7cuobjLcjltQzPrv9/b/C/AQR3Q1PwQw/0VLkZTsC8HxCt/gbafXdyDmalDPsp6EEZ6IaHUpuFBz+QBmw=="
|
"integrity": "sha512-4mP4m7cuobjLcjltQzPrv9/b/C/AQR3Q1PwQw/0VLkZTsC8HxCt/gbafXdyDmalDPsp6EEZ6IaHUpuFBz+QBmw=="
|
||||||
},
|
},
|
||||||
|
"@types/domhandler": {
|
||||||
|
"version": "2.4.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/@types/domhandler/-/domhandler-2.4.1.tgz",
|
||||||
|
"integrity": "sha512-cfBw6q6tT5sa1gSPFSRKzF/xxYrrmeiut7E0TxNBObiLSBTuFEHibcfEe3waQPEDbqBsq+ql/TOniw65EyDFMA=="
|
||||||
|
},
|
||||||
"@webassemblyjs/ast": {
|
"@webassemblyjs/ast": {
|
||||||
"version": "1.8.5",
|
"version": "1.8.5",
|
||||||
"resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.8.5.tgz",
|
"resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.8.5.tgz",
|
||||||
@ -3757,11 +3762,84 @@
|
|||||||
"resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.8.tgz",
|
"resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.8.tgz",
|
||||||
"integrity": "sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg=="
|
"integrity": "sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg=="
|
||||||
},
|
},
|
||||||
|
"html-dom-parser": {
|
||||||
|
"version": "0.2.3",
|
||||||
|
"resolved": "https://registry.npmjs.org/html-dom-parser/-/html-dom-parser-0.2.3.tgz",
|
||||||
|
"integrity": "sha512-GdzE63/U0IQEvcpAz0cUdYx2zQx0Ai+HWvE9TXEgwP27+SymUzKa7iB4DhjYpf2IdNLfTTOBuMS5nxeWOosSMQ==",
|
||||||
|
"requires": {
|
||||||
|
"@types/domhandler": "2.4.1",
|
||||||
|
"domhandler": "2.4.2",
|
||||||
|
"htmlparser2": "3.10.1"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"domelementtype": {
|
||||||
|
"version": "1.3.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz",
|
||||||
|
"integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w=="
|
||||||
|
},
|
||||||
|
"domhandler": {
|
||||||
|
"version": "2.4.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.4.2.tgz",
|
||||||
|
"integrity": "sha512-JiK04h0Ht5u/80fdLMCEmV4zkNh2BcoMFBmZ/91WtYZ8qVXSKjiw7fXMgFPnHcSZgOo3XdinHvmnDUeMf5R4wA==",
|
||||||
|
"requires": {
|
||||||
|
"domelementtype": "1"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"domutils": {
|
||||||
|
"version": "1.7.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/domutils/-/domutils-1.7.0.tgz",
|
||||||
|
"integrity": "sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg==",
|
||||||
|
"requires": {
|
||||||
|
"dom-serializer": "0",
|
||||||
|
"domelementtype": "1"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"entities": {
|
||||||
|
"version": "1.1.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/entities/-/entities-1.1.2.tgz",
|
||||||
|
"integrity": "sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w=="
|
||||||
|
},
|
||||||
|
"htmlparser2": {
|
||||||
|
"version": "3.10.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.10.1.tgz",
|
||||||
|
"integrity": "sha512-IgieNijUMbkDovyoKObU1DUhm1iwNYE/fuifEoEHfd1oZKZDaONBSkal7Y01shxsM49R4XaMdGez3WnF9UfiCQ==",
|
||||||
|
"requires": {
|
||||||
|
"domelementtype": "^1.3.1",
|
||||||
|
"domhandler": "^2.3.0",
|
||||||
|
"domutils": "^1.5.1",
|
||||||
|
"entities": "^1.1.1",
|
||||||
|
"inherits": "^2.0.1",
|
||||||
|
"readable-stream": "^3.1.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"readable-stream": {
|
||||||
|
"version": "3.6.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz",
|
||||||
|
"integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==",
|
||||||
|
"requires": {
|
||||||
|
"inherits": "^2.0.3",
|
||||||
|
"string_decoder": "^1.1.1",
|
||||||
|
"util-deprecate": "^1.0.1"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"html-entities": {
|
"html-entities": {
|
||||||
"version": "1.2.1",
|
"version": "1.2.1",
|
||||||
"resolved": "https://registry.npmjs.org/html-entities/-/html-entities-1.2.1.tgz",
|
"resolved": "https://registry.npmjs.org/html-entities/-/html-entities-1.2.1.tgz",
|
||||||
"integrity": "sha1-DfKTUfByEWNRXfueVUPl9u7VFi8="
|
"integrity": "sha1-DfKTUfByEWNRXfueVUPl9u7VFi8="
|
||||||
},
|
},
|
||||||
|
"html-react-parser": {
|
||||||
|
"version": "0.10.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/html-react-parser/-/html-react-parser-0.10.2.tgz",
|
||||||
|
"integrity": "sha512-CXAtbO0bMB8/TuMXgClap6C7SIcZvA5AP0inTJ93JZTryNiHUkCo5shsNBfegW9aqfdh1iWNGSy/dCku5vwdcw==",
|
||||||
|
"requires": {
|
||||||
|
"@types/domhandler": "2.4.1",
|
||||||
|
"html-dom-parser": "0.2.3",
|
||||||
|
"react-property": "1.0.1",
|
||||||
|
"style-to-object": "0.3.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"htmlparser2": {
|
"htmlparser2": {
|
||||||
"version": "4.0.0",
|
"version": "4.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-4.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-4.0.0.tgz",
|
||||||
@ -3897,6 +3975,11 @@
|
|||||||
"resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
|
"resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
|
||||||
"integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
|
"integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
|
||||||
},
|
},
|
||||||
|
"inline-style-parser": {
|
||||||
|
"version": "0.1.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/inline-style-parser/-/inline-style-parser-0.1.1.tgz",
|
||||||
|
"integrity": "sha512-7NXolsK4CAS5+xvdj5OMMbI962hU/wvwoxk+LWR9Ek9bVtyuuYScDN6eS0rUm6TxApFpw7CX1o4uJzcd4AyD3Q=="
|
||||||
|
},
|
||||||
"invariant": {
|
"invariant": {
|
||||||
"version": "2.2.4",
|
"version": "2.2.4",
|
||||||
"resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz",
|
"resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz",
|
||||||
@ -5968,6 +6051,11 @@
|
|||||||
"resolved": "https://registry.npmjs.org/react-is/-/react-is-16.8.6.tgz",
|
"resolved": "https://registry.npmjs.org/react-is/-/react-is-16.8.6.tgz",
|
||||||
"integrity": "sha512-aUk3bHfZ2bRSVFFbbeVS4i+lNPZr3/WM5jT2J5omUVV1zzcs1nAaf3l51ctA5FFvCRbhrH0bdAsRRQddFJZPtA=="
|
"integrity": "sha512-aUk3bHfZ2bRSVFFbbeVS4i+lNPZr3/WM5jT2J5omUVV1zzcs1nAaf3l51ctA5FFvCRbhrH0bdAsRRQddFJZPtA=="
|
||||||
},
|
},
|
||||||
|
"react-property": {
|
||||||
|
"version": "1.0.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/react-property/-/react-property-1.0.1.tgz",
|
||||||
|
"integrity": "sha512-1tKOwxFn3dXVomH6pM9IkLkq2Y8oh+fh/lYW3MJ/B03URswUTqttgckOlbxY2XHF3vPG6uanSc4dVsLW/wk3wQ=="
|
||||||
|
},
|
||||||
"react-swipeable-views": {
|
"react-swipeable-views": {
|
||||||
"version": "0.13.9",
|
"version": "0.13.9",
|
||||||
"resolved": "https://registry.npmjs.org/react-swipeable-views/-/react-swipeable-views-0.13.9.tgz",
|
"resolved": "https://registry.npmjs.org/react-swipeable-views/-/react-swipeable-views-0.13.9.tgz",
|
||||||
@ -6818,6 +6906,14 @@
|
|||||||
"schema-utils": "^2.0.1"
|
"schema-utils": "^2.0.1"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"style-to-object": {
|
||||||
|
"version": "0.3.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/style-to-object/-/style-to-object-0.3.0.tgz",
|
||||||
|
"integrity": "sha512-CzFnRRXhzWIdItT3OmF8SQfWyahHhjq3HwcMNCNLn+N7klOOqPjMeG/4JSu77D7ypZdGvSzvkrbyeTMizz2VrA==",
|
||||||
|
"requires": {
|
||||||
|
"inline-style-parser": "0.1.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
"styled-jsx": {
|
"styled-jsx": {
|
||||||
"version": "3.2.5",
|
"version": "3.2.5",
|
||||||
"resolved": "https://registry.npmjs.org/styled-jsx/-/styled-jsx-3.2.5.tgz",
|
"resolved": "https://registry.npmjs.org/styled-jsx/-/styled-jsx-3.2.5.tgz",
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@zeit/next-css": "^1.0.1",
|
"@zeit/next-css": "^1.0.1",
|
||||||
"axios": "^0.19.2",
|
"axios": "^0.19.2",
|
||||||
|
"html-react-parser": "^0.10.2",
|
||||||
"next": "9.3.1",
|
"next": "9.3.1",
|
||||||
"next-fonts": "^1.0.3",
|
"next-fonts": "^1.0.3",
|
||||||
"nprogress": "^0.2.0",
|
"nprogress": "^0.2.0",
|
||||||
|
@ -3,6 +3,7 @@ import HeadTag from '../../components/HeadTag';
|
|||||||
import FunctionComponentTop from '../../components/FunctionComponentTop';
|
import FunctionComponentTop from '../../components/FunctionComponentTop';
|
||||||
import FunctionTabsTop from '../../components/FunctionTabs/FunctionTabsTop';
|
import FunctionTabsTop from '../../components/FunctionTabs/FunctionTabsTop';
|
||||||
import FunctionTabs from '../../components/FunctionTabs/FunctionTabs';
|
import FunctionTabs from '../../components/FunctionTabs/FunctionTabs';
|
||||||
|
import FunctionForm from '../../components/FunctionForm/FunctionForm';
|
||||||
import redirect from '../../utils/redirect';
|
import redirect from '../../utils/redirect';
|
||||||
import api from '../../utils/api';
|
import api from '../../utils/api';
|
||||||
import { API_URL } from '../../utils/config';
|
import { API_URL } from '../../utils/config';
|
||||||
@ -24,7 +25,11 @@ const FunctionComponent = (props) => {
|
|||||||
<FunctionComponentTop { ...props } API_URL={API_URL} publicationDate={publicationDate} />
|
<FunctionComponentTop { ...props } API_URL={API_URL} publicationDate={publicationDate} />
|
||||||
|
|
||||||
<FunctionTabs type={props.type}>
|
<FunctionTabs type={props.type}>
|
||||||
<div className="FunctionComponent__slide text-center">Slide 1</div>
|
{(props.type !== "article") ?
|
||||||
|
<FunctionForm inputArray={ [...props.utilizationForm || []] } slug={props.slug} />
|
||||||
|
:
|
||||||
|
<div className="FunctionComponent__slide text-center">Slide 1</div>
|
||||||
|
}
|
||||||
<div className="FunctionComponent__slide text-center">Slide 2</div>
|
<div className="FunctionComponent__slide text-center">Slide 2</div>
|
||||||
<div className="FunctionComponent__slide text-center">Slide 3</div>
|
<div className="FunctionComponent__slide text-center">Slide 3</div>
|
||||||
</FunctionTabs>
|
</FunctionTabs>
|
||||||
|
@ -96,23 +96,4 @@ a, .important {
|
|||||||
background-clip: padding-box;
|
background-clip: padding-box;
|
||||||
border: 1px solid #ced4da;
|
border: 1px solid #ced4da;
|
||||||
border-radius: .5em;
|
border-radius: .5em;
|
||||||
}
|
|
||||||
.btn {
|
|
||||||
cursor: pointer;
|
|
||||||
border: 1px solid transparent;
|
|
||||||
padding: .375rem .75rem;
|
|
||||||
font-size: 1rem;
|
|
||||||
line-height: 1.5;
|
|
||||||
border-radius: .25rem;
|
|
||||||
transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
|
|
||||||
}
|
|
||||||
.btn-dark:hover {
|
|
||||||
color: #fff;
|
|
||||||
background-color: #23272b;
|
|
||||||
border-color: #1d2124;
|
|
||||||
}
|
|
||||||
.btn-dark {
|
|
||||||
color: #fff;
|
|
||||||
background-color: #343a40;
|
|
||||||
border-color: #343a40;
|
|
||||||
}
|
}
|
Reference in New Issue
Block a user