1556 lines
224 KiB
JavaScript
1556 lines
224 KiB
JavaScript
/******/ (function() { // webpackBootstrap
|
||
/******/ var __webpack_modules__ = ({
|
||
|
||
/***/ "../config/instance.js":
|
||
/*!*****************************!*\
|
||
!*** ../config/instance.js ***!
|
||
\*****************************/
|
||
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
|
||
|
||
const users = __webpack_require__(/*! ./users */ "../config/users.js");
|
||
|
||
const questionnaires = __webpack_require__(/*! ./questionnaires */ "../config/questionnaires.js");
|
||
|
||
module.exports = {
|
||
apiUrl: "http://localhost:3000/api",
|
||
siteUrl: "http://localhost:8080",
|
||
adminName: "Fabrice",
|
||
adminEmail: "dev@wikilerni.com",
|
||
senderName: "WikiLerni (local)",
|
||
senderEmail: "bonjour@wikilerni.com",
|
||
adminLang: "fr",
|
||
theme: "wikilerni",
|
||
// le thème utilisé (dans /views) pour générer les pages HTML. Contient ses propres fichiers de configuration.
|
||
availableLangs: ["fr"],
|
||
// Languages in which the site is available. The first one is the default one.
|
||
siteName: "WikiLerni (local)",
|
||
beginCodeGodfather: "WL",
|
||
// case-sensitive and can't contain "@" !
|
||
defaultReceiptDays: "147",
|
||
// Par défaut, quel(s) jour(s) de la semaine, l'utilisateur reçoit-il quelque chose ? (1=dimanche, 2=lundi... 7=samedi)
|
||
cronTimingAlertInSeconde: 120,
|
||
// for logs
|
||
responseTimingAlertInSeconde: 3,
|
||
// idem
|
||
tokenSignupValidationTimeInHours: "48h",
|
||
// https://github.com/zeit/ms
|
||
tokenLoginLinkTimeInHours: "1h",
|
||
tokenConnexionMinTimeInHours: "24h",
|
||
tokenConnexionMaxTimeInDays: "180 days",
|
||
tokenLoginChangingTimeInHours: "1h",
|
||
// for email & password changing
|
||
tokenDeleteUserTimeInHours: "1h",
|
||
tokenUnsubscribeLinkTimeInDays: "7 days",
|
||
// token send with subscription's emails
|
||
freeAccountTimingInDays: 0,
|
||
// if 0 = unlimited
|
||
freeAccountExpirationNotificationInDays: 3,
|
||
accountExpirationFirstNotificationInDays: 10,
|
||
accountExpirationSecondNotificationInDays: 3,
|
||
inactiveAccountTimeToDeleteInDays: 180,
|
||
// Questionnaires:
|
||
nbQuestionsMin: 1,
|
||
// minimum number of questions for the questionnaire to be publishable
|
||
nbQuestionsMax: 2,
|
||
// if 0 = not maximum
|
||
nbChoicesMax: 10,
|
||
nbNewQuestionnaires: 12,
|
||
// for RSS, etc.
|
||
hourGiveNewQuestionnaireBegin: 7,
|
||
// in user local time
|
||
hourGiveNewQuestionnaireEnd: 21,
|
||
// idem
|
||
maxQuestionnaireSendedAtSameTime: 50,
|
||
// for subscription's e-mailing
|
||
minSearchQuestionnaires: 3,
|
||
fieldNewQuestionnaires: "publishingAt",
|
||
// field to be used to create the list of the last questionnaires, can be "createdAt", "updatedAt" or "publishingAt"
|
||
// Groups :
|
||
nbQuestionnairesByGroupMin: 1,
|
||
nbQuestionnairesByGroupMax: 0,
|
||
// Illustrations:
|
||
nbIllustrationsMin: 1,
|
||
nbIllustrationsMax: 1,
|
||
maxIllustrationSizeinOctet: 1000000,
|
||
// pas contrôlé pour l'instant. À revoir.
|
||
mimeTypesForIllustration: ["image/jpg", "image/jpeg", "image/png", "image/gif", "image/png"],
|
||
// -- Upload and resize:
|
||
illustrationsWidthMaxInPx: 500,
|
||
illustrationsMiniaturesWidthMaxInPx: 200,
|
||
// Links:
|
||
nbLinksMin: 1,
|
||
nbLinksMax: 0,
|
||
// Questions & responses:
|
||
nbQuestionsMin: 1,
|
||
nbQuestionsMax: 0,
|
||
nbChoicesMax: 10,
|
||
// à supprimer quand tous les "require" à jour:
|
||
passwordMinLength: users.password.minlength,
|
||
dirCacheUsers: users.dirCacheUsers,
|
||
dirCacheUsersAnswers: users.dirCacheUsersAnswers,
|
||
dirCacheQuestionnaires: questionnaires.dirCacheQuestionnaires,
|
||
dirCacheQuestions: questionnaires.dirCacheQuestions,
|
||
dirCacheUsersQuestionnaires: questionnaires.dirCacheUsersQuestionnaires,
|
||
dirHTMLQuestionnaires: questionnaires.dirHTMLQuestionnaires,
|
||
dirWebQuestionnaires: questionnaires.dirWebQuestionnaires
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../config/questionnaires.js":
|
||
/*!***********************************!*\
|
||
!*** ../config/questionnaires.js ***!
|
||
\***********************************/
|
||
/***/ (function(module) {
|
||
|
||
module.exports = {
|
||
// API'routes (after "apiUrl" defined in instance.js)
|
||
questionnaireRoutes: "/questionnaire",
|
||
// la base à laquelle s'ajoute les routes suivantes
|
||
getListNextQuestionnaires: "/getlistnextquestionnaires/",
|
||
getQuestionnaireRoutes: "/get",
|
||
getRandomQuestionnairesRoute: "/getrandom",
|
||
getStatsQuestionnaires: "/stats/",
|
||
previewQuestionnaireRoutes: "/preview",
|
||
publishedQuestionnaireRoutes: "/quiz/",
|
||
regenerateHTML: "/htmlregenerated",
|
||
searchAdminQuestionnairesRoute: "/searchadmin",
|
||
searchQuestionnairesRoute: "/search",
|
||
// -- groupes :
|
||
groupRoutes: "/group",
|
||
getGroupRoute: "/get/",
|
||
previewGroupRoutes: "/preview",
|
||
searchGroupsRoute: "/search",
|
||
// -- questions & choices :
|
||
questionsRoute: "/question/",
|
||
// -- tags :
|
||
tagsSearchRoute: "/tags/search/",
|
||
// -- answers :
|
||
getAdminStats: "/getadminstats/",
|
||
getPreviousAnswers: "/user/answers/",
|
||
getStatsAnswers: "/user/anwswers/stats/",
|
||
// fonctionne aussi pour les groupes
|
||
saveAnswersRoute: "/answer/",
|
||
// idem
|
||
// forms : à compléter avec valeurs par défaut, etc. cf modèle
|
||
Questionnaire: {
|
||
title: {
|
||
maxlength: 255,
|
||
required: true
|
||
},
|
||
slug: {
|
||
maxlength: 150
|
||
},
|
||
// champ requis mais calculé à partir du titre qd laissé vide dans le formulaire
|
||
introduction: {
|
||
required: true
|
||
}
|
||
},
|
||
searchQuestionnaires: {
|
||
minlength: 3,
|
||
required: true
|
||
},
|
||
Group: {
|
||
title: {
|
||
maxlength: 255,
|
||
required: true
|
||
},
|
||
slug: {
|
||
maxlength: 150
|
||
} // champ requis mais calculé à partir du titre qd laissé vide dans le formulaire
|
||
|
||
},
|
||
Question: {
|
||
text: {
|
||
maxlength: 255,
|
||
required: true
|
||
},
|
||
rank: {
|
||
required: true,
|
||
min: 1,
|
||
defaultValue: 1
|
||
}
|
||
},
|
||
Choice: {
|
||
text: {
|
||
maxlength: 255,
|
||
required: true
|
||
}
|
||
},
|
||
search: {
|
||
minlength: 3,
|
||
required: true
|
||
},
|
||
searchGroups: {
|
||
minlength: 3,
|
||
required: true
|
||
},
|
||
// Emplacement des fichiers JSON générés :
|
||
dirCacheGroups: "datas/questionnaires/groups",
|
||
dirCacheQuestionnaires: "datas/questionnaires",
|
||
dirCacheQuestions: "datas/questionnaires/questions",
|
||
dirCacheTags: "datas/questionnaires/tags",
|
||
dirCacheUsersQuestionnaires: "datas/users/questionnaires",
|
||
// Emplacement des fichiers HTML générés :
|
||
dirHTMLGroups: "front/public/quiz/gp",
|
||
dirHTMLQuestionnaires: "front/public/quiz",
|
||
dirHTMLNews: "front/public/quizs",
|
||
dirHTMLTags: "front/public/quizs",
|
||
// Idem mais pour urls :
|
||
dirWebGroups: "quiz/gp",
|
||
dirWebQuestionnaires: "quiz",
|
||
dirWebNews: "quizs/",
|
||
dirWebTags: "quizs/",
|
||
// limite des résultat du moteur de recherche, quand demande de résultats au hasard :
|
||
nbRandomResults: 3,
|
||
|
||
/* Valeurs en fait définies dans instance.js donc à supprimer quand plus utilisées ailleurs : */
|
||
nbQuestionsMin: 1,
|
||
nbQuestionsMax: 0,
|
||
nbChoicesMax: 10,
|
||
nbTagsMin: 0,
|
||
nbTagsMax: 0 // 0 = not max
|
||
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../config/users.js":
|
||
/*!**************************!*\
|
||
!*** ../config/users.js ***!
|
||
\**************************/
|
||
/***/ (function(module) {
|
||
|
||
module.exports = {
|
||
// API'routes (after "apiUrl" defined in instance.js)
|
||
userRoutes: "/user",
|
||
checkDeleteLinkRoute: "/confirmdelete/",
|
||
checkIfIsEmailfreeRoute: "/isemailfree",
|
||
checkLoginRoute: "/checklogin/",
|
||
checkNewLoginLinkRoute: "/confirmnewlogin/",
|
||
checkSubscribeTokenRoute: "/validation/",
|
||
connectionRoute: "/login",
|
||
connectionWithLinkRoute: "/checkloginlink",
|
||
createUserRoute: "/create",
|
||
getAdminStats: "/getadminstats/",
|
||
getGodChilds: "/getgodchilds/",
|
||
getGodfatherRoute: "/getgodfatherid",
|
||
getLoginLinkRoute: "/getloginlink",
|
||
getPayments: "/payment/getforoneuser/",
|
||
getUserInfos: "/get/",
|
||
getUsersQuestionnairesRoute: "/getusersquestionnaires/",
|
||
// les questionnaires auxquels l'utilisateur a déjà eu accès via son abonnement
|
||
searchUserRoute: "/search/",
|
||
signupCompletionRoute: "/signupcompletion/",
|
||
subscribeRoute: "/signup",
|
||
unsubscribeRoute: "/subscription/stop/",
|
||
updateUserInfos: "/modify/",
|
||
validateUserRoute: "/validate/",
|
||
// forms : à compléter avec valeurs par défaut, etc. cf modèle
|
||
name: {
|
||
maxlength: 70,
|
||
required: true
|
||
},
|
||
email: {
|
||
maxlength: 255,
|
||
required: true
|
||
},
|
||
password: {
|
||
minlength: 8,
|
||
maxlength: 72,
|
||
required: true
|
||
},
|
||
// https://www.npmjs.com/package/bcrypt#security-issues-and-concerns
|
||
newPassword: {
|
||
minlength: 8,
|
||
maxlength: 72
|
||
},
|
||
codeGodfather: {
|
||
maxlength: 255
|
||
},
|
||
cguOk: {
|
||
value: "true",
|
||
required: true
|
||
},
|
||
search: {
|
||
minlength: 1,
|
||
required: true
|
||
},
|
||
timeDifferenceMin: -720,
|
||
timeDifferenceMax: 840,
|
||
// JSON dir
|
||
dirCacheUsers: "datas/users",
|
||
dirCacheUsersAnswers: "datas/users/questionnaires/answers",
|
||
dirCacheUsersWithoutAnswers: "datas/users/questionnaires/without"
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "./src/tools/clientstorage.js":
|
||
/*!************************************!*\
|
||
!*** ./src/tools/clientstorage.js ***!
|
||
\************************************/
|
||
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
||
|
||
"use strict";
|
||
__webpack_require__.r(__webpack_exports__);
|
||
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
||
/* harmony export */ "saveLocaly": function() { return /* binding */ saveLocaly; },
|
||
/* harmony export */ "getLocaly": function() { return /* binding */ getLocaly; },
|
||
/* harmony export */ "removeLocaly": function() { return /* binding */ removeLocaly; }
|
||
/* harmony export */ });
|
||
// FONCTIONS UTILES AU STOCKAGE LOCAL (SESSION, COOKIES, INDEXDB, ETC.)
|
||
// Revenir pour gérer le cas où local.storage n'est pas connu pour utiliser cookie
|
||
const saveLocaly = (name, data) => {
|
||
localStorage.setItem(name, JSON.stringify(data));
|
||
};
|
||
const getLocaly = (name, json = false) => {
|
||
if (json) return JSON.parse(localStorage.getItem(name));else return localStorage.getItem(name);
|
||
};
|
||
const removeLocaly = name => {
|
||
localStorage.removeItem(name);
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "./src/tools/dom.js":
|
||
/*!**************************!*\
|
||
!*** ./src/tools/dom.js ***!
|
||
\**************************/
|
||
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
||
|
||
"use strict";
|
||
__webpack_require__.r(__webpack_exports__);
|
||
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
||
/* harmony export */ "addElement": function() { return /* binding */ addElement; }
|
||
/* harmony export */ });
|
||
/* harmony import */ var _tools_main__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../../tools/main */ "../tools/main.js");
|
||
/* harmony import */ var _tools_main__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_tools_main__WEBPACK_IMPORTED_MODULE_0__);
|
||
// Fonction associant les attributs fournis à un champ de formulaire
|
||
|
||
const addElement = (eltParent, eltType, eltContent = "", eltId = "", eltClass = [], eltAttributes = {}, replace = true) => {
|
||
if ((0,_tools_main__WEBPACK_IMPORTED_MODULE_0__.isEmpty)(eltType) || (0,_tools_main__WEBPACK_IMPORTED_MODULE_0__.isEmpty)(eltParent)) return false;else {
|
||
const newElement = document.createElement(eltType);
|
||
if (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_0__.isEmpty)(eltId)) // tester si l'id n'est pas déjà utilisé dans le DOM ?
|
||
newElement.id = eltId;
|
||
|
||
if (Array.isArray(eltClass) && eltClass.length != 0) {
|
||
for (let i in eltClass) newElement.classList.add(eltClass[i]);
|
||
}
|
||
|
||
if (typeof eltAttributes === "object") // !! tous les objets ne sont pas ok
|
||
{
|
||
for (let attributName in eltAttributes) newElement.setAttribute(attributName, eltAttributes[attributName]);
|
||
}
|
||
|
||
if (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_0__.isEmpty)(eltContent)) newElement.innerHTML = eltContent.replace(/\n/g, "<br>"); // innerHTML permet d'ajouter du texte ayant lui-même des balises, etc.
|
||
|
||
if (replace) eltParent.innerHTML = "";
|
||
eltParent.appendChild(newElement);
|
||
}
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "./src/tools/everywhere.js":
|
||
/*!*********************************!*\
|
||
!*** ./src/tools/everywhere.js ***!
|
||
\*********************************/
|
||
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
||
|
||
"use strict";
|
||
__webpack_require__.r(__webpack_exports__);
|
||
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
||
/* harmony export */ "helloDev": function() { return /* binding */ helloDev; },
|
||
/* harmony export */ "updateAccountLink": function() { return /* binding */ updateAccountLink; }
|
||
/* harmony export */ });
|
||
// Ce script fournit des fonctions utilisées sur toutes les pages du site
|
||
const helloDev = () => {
|
||
console.log("**** Hello ami développeur :-)\n\nLe code de WikiLerni est libre et vous pouvez le trouver à cette adresse :\nhttps://forge.chapril.org/Fab_Blab/WikiLerni\n\nPour les suggestions d'amélioration ou questions : dev@wililerni.com ****");
|
||
return true;
|
||
};
|
||
const updateAccountLink = (status, configTemplate) => {
|
||
const link = document.getElementById("accountHeadLink");
|
||
const homePage = status + "HomePage";
|
||
link.href = "/" + configTemplate[homePage];
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "./src/tools/forms.js":
|
||
/*!****************************!*\
|
||
!*** ./src/tools/forms.js ***!
|
||
\****************************/
|
||
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
||
|
||
"use strict";
|
||
__webpack_require__.r(__webpack_exports__);
|
||
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
||
/* harmony export */ "setAttributesToInputs": function() { return /* binding */ setAttributesToInputs; },
|
||
/* harmony export */ "getDatasFromInputs": function() { return /* binding */ getDatasFromInputs; },
|
||
/* harmony export */ "empyForm": function() { return /* binding */ empyForm; },
|
||
/* harmony export */ "empyAndHideForm": function() { return /* binding */ empyAndHideForm; }
|
||
/* harmony export */ });
|
||
/* harmony import */ var _tools_main__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../../tools/main */ "../tools/main.js");
|
||
/* harmony import */ var _tools_main__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_tools_main__WEBPACK_IMPORTED_MODULE_0__);
|
||
// Fonction associant les attributs fournis à un champ de formulaire
|
||
|
||
const setAttributesToInputs = (inputsConf, myForm) => {
|
||
for (let i in myForm.elements) {
|
||
if (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_0__.isEmpty)(myForm.elements[i].id)) {
|
||
let idInput = myForm.elements[i].id;
|
||
|
||
if (inputsConf[idInput] !== undefined) {
|
||
let inputHTML = document.getElementById(idInput);
|
||
|
||
for (let attribute in inputsConf[idInput]) inputHTML.setAttribute(attribute, inputsConf[idInput][attribute]);
|
||
}
|
||
}
|
||
}
|
||
|
||
return true;
|
||
}; // Récupère toutes les valeurs de champs en omettant les checkbox non cochées, etc.
|
||
|
||
const getDatasFromInputs = myForm => {
|
||
const datas = {};
|
||
const formData = new FormData(myForm);
|
||
|
||
for (let entrie of formData.entries()) datas[entrie[0]] = entrie[1];
|
||
|
||
return datas;
|
||
}; // Vide tous les champs d'un formulaire, y compris hidden, checkbox, etc.
|
||
// Revoir pour les select
|
||
|
||
const empyForm = myForm => {
|
||
const formData = new FormData(myForm);
|
||
|
||
for (let entrie of formData.entries()) {
|
||
if (myForm.elements[entrie[0]].type == "checkbox" || myForm.elements[entrie[0]].type == "radio") myForm.elements[entrie[0]].checked = false;else myForm.elements[entrie[0]].value = "";
|
||
}
|
||
|
||
return true;
|
||
}; // Vide et cache le formulaire
|
||
|
||
const empyAndHideForm = myForm => {
|
||
empyForm(myForm);
|
||
myForm.style.display = "none";
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "./src/tools/users.js":
|
||
/*!****************************!*\
|
||
!*** ./src/tools/users.js ***!
|
||
\****************************/
|
||
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
||
|
||
"use strict";
|
||
__webpack_require__.r(__webpack_exports__);
|
||
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
||
/* harmony export */ "getTimeDifference": function() { return /* binding */ getTimeDifference; },
|
||
/* harmony export */ "setSession": function() { return /* binding */ setSession; },
|
||
/* harmony export */ "checkAnswerDatas": function() { return /* binding */ checkAnswerDatas; },
|
||
/* harmony export */ "checkSession": function() { return /* binding */ checkSession; }
|
||
/* harmony export */ });
|
||
/* harmony import */ var _config_instance_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../../config/instance.js */ "../config/instance.js");
|
||
/* harmony import */ var _config_instance_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_config_instance_js__WEBPACK_IMPORTED_MODULE_0__);
|
||
/* harmony import */ var _config_users_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../config/users.js */ "../config/users.js");
|
||
/* harmony import */ var _config_users_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_config_users_js__WEBPACK_IMPORTED_MODULE_1__);
|
||
/* harmony import */ var _clientstorage_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./clientstorage.js */ "./src/tools/clientstorage.js");
|
||
/* harmony import */ var _tools_main__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../tools/main */ "../tools/main.js");
|
||
/* harmony import */ var _tools_main__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_tools_main__WEBPACK_IMPORTED_MODULE_3__);
|
||
|
||
const lang = _config_instance_js__WEBPACK_IMPORTED_MODULE_0__.availableLangs[0];
|
||
|
||
const configTemplate = __webpack_require__("../views sync recursive ^\\.\\/.*\\.js$")("./" + _config_instance_js__WEBPACK_IMPORTED_MODULE_0__.theme + "/config/" + lang + ".js");
|
||
|
||
|
||
|
||
|
||
const getTimeDifference = () => {
|
||
// multiplier par -1, car c'est ce qu'il faut "ajouter" à l'heure UTC pour revenir en heure locale qui m'intéresse et non l'inverse
|
||
const timeLocal = new Date().getTimezoneOffset() * -1;
|
||
if (timeLocal > _config_users_js__WEBPACK_IMPORTED_MODULE_1__.timeDifferenceMax || timeLocal < _config_users_js__WEBPACK_IMPORTED_MODULE_1__.timeDifferenceMin) return 0;else return timeLocal;
|
||
}; // J'utilise le stockage local du navigateur pour enregistrer les données permettant de reconnaître l'utilisateur par la suite
|
||
// Seul le serveur pourra vérifier que les identifiants sont (toujours) valides.
|
||
|
||
const setSession = (userId, token, durationTS) => {
|
||
const storageUser = {
|
||
id: userId,
|
||
token: token,
|
||
duration: durationTS
|
||
};
|
||
(0,_clientstorage_js__WEBPACK_IMPORTED_MODULE_2__.saveLocaly)("user", storageUser);
|
||
}; // Vérifie qu'il y a des données locales concernant le résultat d'un quiz ou d'un groupe de quizs
|
||
// Et les ajoute aux données envoyées par les formulaires d'inscription/connexion si c'est le cas
|
||
|
||
const checkAnswerDatas = datas => {
|
||
const lastAnswer = (0,_clientstorage_js__WEBPACK_IMPORTED_MODULE_2__.getLocaly)("lastAnswer");
|
||
|
||
if (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(lastAnswer)) {
|
||
const answer = JSON.parse(lastAnswer);
|
||
|
||
if (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(answer.duration) && !(0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(answer.nbCorrectAnswers) && !(0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(answer.nbQuestions) && (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(answer.QuestionnaireId) || !(0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(answer.GroupId))) {
|
||
datas.duration = answer.duration;
|
||
datas.nbCorrectAnswers = answer.nbCorrectAnswers;
|
||
datas.nbQuestions = answer.nbQuestions;
|
||
if (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(answer.QuestionnaireId)) datas.QuestionnaireId = answer.QuestionnaireId;else datas.GroupId = answer.GroupId;
|
||
}
|
||
}
|
||
|
||
return datas;
|
||
}; // Cette fonction teste la connexion de l'utilisateur d'une page
|
||
// On peut fournis une liste de statuts acceptés (si vide = tous), ainsi qu'une url de redirection si non connecté, un message d'erreur à afficher sur la page de destination et l'url sur laquelle revenir une fois connecté
|
||
|
||
const checkSession = async (status = [], urlRedirection, message, urlWanted) => {
|
||
return new Promise((resolve, reject) => {
|
||
const userDatas = (0,_clientstorage_js__WEBPACK_IMPORTED_MODULE_2__.getLocaly)("user");
|
||
|
||
if ((0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(userDatas)) {
|
||
redirectUser(urlRedirection, message, urlWanted);
|
||
resolve(false);
|
||
} else {
|
||
const user = JSON.parse(userDatas);
|
||
|
||
if ((0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(user.id) || (0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(user.token) || (0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(user.duration) || user.duration < Date.now()) {
|
||
(0,_clientstorage_js__WEBPACK_IMPORTED_MODULE_2__.removeLocaly)("user");
|
||
redirectUser(urlRedirection, message, urlWanted);
|
||
resolve(false);
|
||
} else {
|
||
const xhr = new XMLHttpRequest();
|
||
xhr.open("GET", _config_instance_js__WEBPACK_IMPORTED_MODULE_0__.apiUrl + _config_users_js__WEBPACK_IMPORTED_MODULE_1__.userRoutes + _config_users_js__WEBPACK_IMPORTED_MODULE_1__.checkLoginRoute + user.token);
|
||
|
||
xhr.onload = () => {
|
||
let response = JSON.parse(xhr.responseText);
|
||
|
||
if (xhr.status === 200 && response.isValid && response.id != undefined) {
|
||
if (response.id === user.id) {
|
||
user.name = response.name;
|
||
user.language = response.language;
|
||
user.timeDifference = response.timeDifference;
|
||
user.status = response.status; // c'est le token qui sert à vérifier le statut à chaque requête à l'API
|
||
|
||
(0,_clientstorage_js__WEBPACK_IMPORTED_MODULE_2__.saveLocaly)("user", user); // si il s'agit d'un "user" et que son abonnement a expiré, je le redirige vers la caisse :-)
|
||
|
||
if (response.status === "user" && response.nbDaysOk <= 0) {
|
||
const urlAccount = _config_instance_js__WEBPACK_IMPORTED_MODULE_0__.siteUrl + "/" + configTemplate.accountPage;
|
||
if (window.location.href.indexOf(urlAccount) === -1) window.location.assign("/" + configTemplate.accountPage + "#subscribe"); // passée directement ici, l'ancre #subscribe ne fonctionne pas !?
|
||
|
||
resolve(true);
|
||
} else {
|
||
if (status.length !== 0 && status.indexOf(response.status) === -1) {
|
||
redirectUser(urlRedirection, message, urlWanted);
|
||
resolve(false);
|
||
} else resolve(true);
|
||
}
|
||
} else {
|
||
(0,_clientstorage_js__WEBPACK_IMPORTED_MODULE_2__.removeLocaly)("user");
|
||
redirectUser(urlRedirection, message, urlWanted);
|
||
resolve(false);
|
||
}
|
||
} else {
|
||
(0,_clientstorage_js__WEBPACK_IMPORTED_MODULE_2__.removeLocaly)("user");
|
||
redirectUser(urlRedirection, message, urlWanted);
|
||
resolve(false);
|
||
}
|
||
};
|
||
|
||
xhr.onerror = () => reject(xhr.statusText);
|
||
|
||
xhr.send();
|
||
}
|
||
}
|
||
});
|
||
}; // Cette fonction sert à la précédente en cas de connexion non valide
|
||
|
||
const redirectUser = (urlRedirection, message, urlWanted) => {
|
||
if (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(message)) (0,_clientstorage_js__WEBPACK_IMPORTED_MODULE_2__.saveLocaly)("message", message);
|
||
if (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(urlWanted)) (0,_clientstorage_js__WEBPACK_IMPORTED_MODULE_2__.saveLocaly)("url", urlWanted);
|
||
if (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_3__.isEmpty)(urlRedirection)) window.location.assign(urlRedirection);
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "./src/tools/webportage.js":
|
||
/*!*********************************!*\
|
||
!*** ./src/tools/webportage.js ***!
|
||
\*********************************/
|
||
/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
|
||
|
||
"use strict";
|
||
__webpack_require__.r(__webpack_exports__);
|
||
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
||
/* harmony export */ "unCheckAllOthers": function() { return /* binding */ unCheckAllOthers; },
|
||
/* harmony export */ "showBtnPayment": function() { return /* binding */ showBtnPayment; }
|
||
/* harmony export */ });
|
||
const checkBoxes = {
|
||
"CGV": document.getElementById("CGVOk"),
|
||
"abo1": document.getElementById("abo1"),
|
||
"abo2": document.getElementById("abo2"),
|
||
"abo3": document.getElementById("abo3"),
|
||
"abo4": document.getElementById("abo4")
|
||
};
|
||
const divWPBtns = document.getElementById("WPBtns"); // Lorsque l'on sélectionne un montant, les autres options + les CGV sont désélectionnés
|
||
|
||
const unCheckAllOthers = choice => {
|
||
for (let id in checkBoxes) {
|
||
if (id !== choice) checkBoxes[id].checked = false;
|
||
divWPBtns.style.display = "none";
|
||
}
|
||
};
|
||
const btns = {
|
||
"btn1": document.getElementById("WPBtn1"),
|
||
"btn2": document.getElementById("WPBtn2"),
|
||
"btn3": document.getElementById("WPBtn3"),
|
||
"btn4": document.getElementById("WPBtn4")
|
||
}; // Affiche le bon bouton de paiement et cache les autres
|
||
|
||
const showBtnPayment = choice => {
|
||
for (let id in btns) {
|
||
if (id !== choice) btns[id].style.display = "none";else btns[id].style.display = "block";
|
||
}
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../lang/fr/general.js":
|
||
/*!*****************************!*\
|
||
!*** ../lang/fr/general.js ***!
|
||
\*****************************/
|
||
/***/ (function(module) {
|
||
|
||
module.exports = {
|
||
addBtnTxt: "Ajouter",
|
||
addOkMessage: "Les données ont bien été enregistrées.",
|
||
alertNewWindow: "nouvelle fenêtre",
|
||
badUrl: "Tentative d'accès à une page n'existant pas :",
|
||
btnLinkToQuestionnaire: "Afficher !",
|
||
btnProposeConnection: "Je me connecte.",
|
||
btnProposeSubscribe: "Je crée mon compte.",
|
||
btnShowOnWebSite: "Lire la suite sur #SITE_NAME",
|
||
deleteBtnTxt: "Supprimer",
|
||
deleteFailMessage: "La suppression de l'enregistrement #ID a échoué.",
|
||
deleteOkMessage: "La suppression a bien été enregistrée.",
|
||
failAuth: "Erreur d'authentification.",
|
||
failAuthCron: "Tentative de lancement d'un cron sans le bon token.",
|
||
failAuthHeader: "Absence de header Authorization.",
|
||
failAuthId: "Identifiant non valide : ",
|
||
failAuthToken: "Token invalide ou utilisateur non trouvé.",
|
||
neededParams: "Des paramètres nécessaires manquants sont manquants.",
|
||
nextPage: "Page suivante",
|
||
notAllowed: "Vous n'avez pas les droits nécessaires pour cette action.",
|
||
notRequired: "Facultatif.",
|
||
notValidFormat: "Format non valide.",
|
||
previousPage: "Page précédente",
|
||
serverError: "Désolé. Une erreur imprévue est survenue. Si cela persiste, n'hésitez à prévenir l'administrateur du site.",
|
||
serverErrorAdmin: "Bug de l'application :",
|
||
siteHTMLTitle: "WikiLerni : la culture générale en liberté",
|
||
siteMetaDescription: "Avec WikiLerni, vous apprenez régulièrement de nouvelles choses. Vous recevez de courts articles lisibles en quelques minutes. Des quizs vous permettent ensuite de tester ce que vous avez retenu.",
|
||
scriptTimingAlert: "*** Script lent : SCRIPT_TIMING millisecondes, route : SCRIPT_URL",
|
||
scriptTimingInfo: "Durée de la réponse : SCRIPT_TIMING millisecondes, route : SCRIPT_URL",
|
||
statsAdmin: "Durant les dernières 24h : NB_USERS_24H comptes ont été créés, NB_SUBSCRIPTIONS_24H validés et NB_USERS_DELETED_24H supprimés. NB_ANSWERS_24H réponses aux quizs ont été enregistrées.<br>En tout, il y a : NB_USERS_TOT comptes, dont NB_SUBSCRIPTIONS_TOT validés et NB_SUBSCRIPTIONS_PREMIUM comptes prémium. NB_ANSWERS_TOT réponses aux quizs ont été enregistrées.<br>Parmi les NB_USERS_DELETED_TOT comptes supprimés, NB_USERS_DELETED_VALIDED avaient validé leur compte et NB_USERS_DELETED_PREMIUM avaient souscrit un compte prémium.",
|
||
subscriptionCall: "Inscrivez-vous !",
|
||
updateBtnTxt: "Modifier",
|
||
updateOkMessage: "La mise à jour à jour a bien été enregistrée."
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../lang/fr/subscription.js":
|
||
/*!**********************************!*\
|
||
!*** ../lang/fr/subscription.js ***!
|
||
\**********************************/
|
||
/***/ (function(module) {
|
||
|
||
module.exports = {
|
||
allSubscriptionProcessed: "Tous les abonnés ont été traités pour le moment.",
|
||
infosExpirated: "Votre abonnement a expiré, mais il vous reste encore quelques jours avant que votre compte et vos données ne soient complètement supprimées.<br>Pour ce faire, suivez sans tarder les indications ci-dessous :",
|
||
infosExpiratedAdmin: "Cet abonnement a expiré.",
|
||
infosNbDays: "Votre abonnement est encore valable <b>pendant NB_DAYS jours</b>.<br>Vous pouvez à tout moment prolonger votre abonnement en suivant les indications ci-dessous :",
|
||
infosNbDaysAdmin: "Cet abonnement est encore valable <b>pendant NB_DAYS jours</b>.",
|
||
infosPaymentsAdmin: "DATE_PAYMENT : paiement de AMOUNT € au nom de CLIENT_NAME.",
|
||
isNotValided: "Cet utilisateur n'a pas encore validé son compte.<br>Vous pouvez le faire à sa place <a href='#validationOk'>en cochant la case indiquée</a> et enregistrant.",
|
||
mailEndFreeTimeBodyHTML: "<h3>Bonjour USER_NAME,</h3><p>Votre abonnement gratuit à SITE_NAME va expirer d'ici quelques jours.<br><br>Pour continuer à utiliser le site, vous pouvez souscrire à un abonnement sans tarder en cliquant sur le lien ci-dessous.</p>",
|
||
mailEndFreeTimeBodyTxt: "Bonjour USER_NAME,\n\nVotre abonnement gratuit à SITE_NAME va expirer d'ici quelques jours.\n\nPour continuer à utiliser le site, vous pouvez sans attendre souscrire à un abonnement :\nLINK_URL",
|
||
mailEndFreeTimeLinkTxt: "M'abonner.",
|
||
mailEndFreeTimeMessage: " relances envoyées.",
|
||
mailEndFreeTimeSubject: "Votre abonnement gratuit va expirer",
|
||
mailExpirationBodyHTML: "<h3>Bonjour USER_NAME,</h3><p>Votre abonnement à SITE_NAME va expirer d'ici quelques jours.<br><br>Pour continuer à utiliser SITE_NAME, vous pouvez le prolonger dès aujourd'hui en cliquant sur le lien ci-dessous.</p>",
|
||
mailExpirationBodyTxt: "Bonjour USER_NAME,\n\nVotre abonnement à SITE_NAME va expirer d'ici quelques jours.\n\nPour continuer à utiliser SITE_NAME, vous pouvez le prolonger dès aujourd'hui :\nLINK_URL",
|
||
mailExpirationLinkTxt: "Prolonger mon abonnement.",
|
||
mailExpirationMessage: "FIRST premières et SECOND deuxièmes relances envoyées pour des abonnements expirant d'ici peu.",
|
||
mailExpirationRelaunchTxt: "[Rappel] ",
|
||
mailExpirationSubject: "Votre abonnement va bientôt expirer",
|
||
mailNewElementForGroupTxt: "Bonjour USER_NAME,\n\nVoici le lien vers le nouvel article à lire :\n\nQUESTIONNAIRE_URL\n\nBonne lecture !\n\nStopper les envois ?\nUNSUBSCRIBE_URL",
|
||
mailNewQuestionnaireBodyTxt: "Bonjour USER_NAME,\n\nVoici le lien vers le nouveau quiz :\n\nQUESTIONNAIRE_URL\n\nBonne lecture !\n\nStopper les envois ?\nUNSUBSCRIBE_URL",
|
||
mailStopMailLinkTxt: "Stopper les envois.",
|
||
needKnowIfNoticeOk: "Il manque l'information sur l'acceptation ou non de recevoir des notifications.",
|
||
needIntegerNumberOfDays: "Le nombre de jours de l'abonnement doit être un nombre entier.",
|
||
needMinNumberOfDays: "Le nombre de jours de l'abonnement ne peut être négatif !",
|
||
needNotTooLongDaysList: "La liste de jours sélectionnés n'a pas le bon format (trop longue).",
|
||
needNumberOfDays: "Il faut un nombre de jours pour l'abonnement.",
|
||
needUniqueDaysList: "La liste de jours sélectionnés n'a pas le bon format. Doublon : ",
|
||
needValidDaysList: "La liste de jours sélectionnés n'a pas le bon format. Caractère non valide : ",
|
||
noNewQuestionnaireForUser: "Aucun nouveau questionnaire trouvé pour un abonné : ",
|
||
unsubscriptionOk: "Votre demande a bien été prise en compte. Vous ne recevrez plus de messages venant du site, sauf pour vous signaler la fin de votre abonnement.<br>N'hésitez pas <a href='/#URL'>à accéder à votre compte</a> pour de nouveau autoriser certains envois.",
|
||
unsubscriptionFail: "Si vous voyez ce message, c'est que votre lien de désabonnement ne fonctionne pas.<br>Vous pouvez <a href='/#URL'>accéder à votre compte</a> pour désactiver les envois manuellement."
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../lang/fr/user.js":
|
||
/*!**************************!*\
|
||
!*** ../lang/fr/user.js ***!
|
||
\**************************/
|
||
/***/ (function(module) {
|
||
|
||
module.exports = {
|
||
alreadyConnected: "Vous êtes déjà connecté au site !",
|
||
badLinkValidationMessage: "Votre lien de confirmation ne semble pas valide ou bien il a expiré. Vous pouvez en recevoir un nouveau <a href='#URL'>en cliquant ici</a>.",
|
||
badPassword: "Aucun compte utilisateur ne correspond aux informations saisies.",
|
||
byebyeMessage: "Si vous voyez ce message, c'est que votre déconnexion s'est bien déroulée.<br>À bientôt !",
|
||
connectionOk: "Connexion réussie.",
|
||
creationOkMessage: "Le nouvel utilisateur a bien été enregistré.",
|
||
cronDeleteUnvalidedUsersMessage: " comptes utilisateurs non validés ont été supprimés.",
|
||
deleteFailMessage: "Tentative de suppression d'un utilisateur inexistant : ",
|
||
deleteInactiveUsersMessage: " comptes utilisateurs inactifs ont été supprimés.",
|
||
deleteOkMessage: "L'utilisateur a bien été supprimé.",
|
||
emailNotFound: "Aucun compte utilisateur n'a été trouvé pour cette adresse e-mail.",
|
||
failBotTest: "Un problème a été rencontré durant votre inscription. En cas de difficulté, n'hésitez pas contacter l'administrateur du site.",
|
||
failBotTestLog: "Une inscription a été bloquée, parce que le champ email2 était renseigné avec : ",
|
||
formsEmailLabel: "E-mail :",
|
||
formsEmailPlaceholder: "Votre adresse e-mail",
|
||
formsEmail2Placeholder: "Si vous voyez ce champ, laissez-le vide",
|
||
//champ qui ne devrait pas être visible par des humains
|
||
formsCGUOkLabel: "J'accepte <a href=#link target=\"_blank\" rel=\"noopener\" title=\"À lire :)\">les Conditions Générale d'Utilisation</a> du site (requis).",
|
||
formsSubmitTxt: "Je m'abonne !",
|
||
godfatherFound: "Votre \"parrain\" a bien été trouvé. Cette personne sera avertie que vous l'avez désignée.",
|
||
godfatherNotFound: "Désolé mais aucun utilisateur n'a été trouvé pour ce code / e-mail de parrainage :(",
|
||
infosAdminGodfather: "Cet utilisateur a été parrainé par ",
|
||
infosAdminNbGodChilds: "Ses #NB filleuls : ",
|
||
infosUserForAdmin: "Cet utilisateur (id: ID_USER) a <b>créé son compte le DATE_CREA</b>, la dernière mise à jour datant du DATE_UPDATE.<br><b>Date de sa dernière connexion : DATE_CONNECTION.</b>",
|
||
infosUserNbGodChilds: "Voici les #NB utilisateur(s) inscrit(s) en vous désignant comme \"parrain\" : ",
|
||
infosUserNoGodchilds: "Pour l'instant, aucune personne ne s'est inscrite, en vous désignant comme \"parrain\".",
|
||
mailDeleteBodyHTML: "<h3>Bonjour USER_NAME,</h3><p>Pour confirmer la suppression de votre compte, cliquez sur le lien ci-dessous sans tarder.</p>",
|
||
mailDeleteBodyTxt: "Bonjour USER_NAME,\n\nPour confirmer la suppression de votre compte, cliquez sur le lien suivant sans tarder :\nLINK_URL",
|
||
mailDeleteLinkAlreadyMessage: "Il semble que vous ayez déjà validé la suppression de votre compte.",
|
||
mailDeleteLinkFailMessage: "Votre lien de suppression n'est pas valide ou alors il a expiré.",
|
||
mailDeleteLinkMessage: "Votre demande de suppression a bien été enregistrée. Merci de cliquer sans tarder sur le lien qui vient de vous être envoyé par e-mail pour confirmer.",
|
||
mailDeleteLinkOkMessage: "Votre compte a bien été supprimé. Merci d'avoir utilisé nos services.",
|
||
mailDeleteLinkTxt: "Confirmer.",
|
||
mailDeleteSubject: "Confirmer la suppression de votre compte.",
|
||
mailLoginLinkBodyHTML: "<h3>Bonjour USER_NAME,</h3><p>Pour vous connecter à votre compte, cliquez sur le lien suivant sans tarder :</p>",
|
||
mailLoginLinkBodyTxt: "Bonjour USER_NAME,\n\nPour vous connecter à votre compte, cliquez sur le lien suivant sans tarder :\nLINK_URL",
|
||
mailLoginLinkMessage: "Un lien de connexion vient de vous être envoyé sur votre adresse e-mail. Ne tardez pas à l'utiliser, car il n'est valable que durant *TIMING* !",
|
||
mailLoginLinkSubject: "Votre lien de connexion.",
|
||
mailLoginLinkTxt: "Me connecter.",
|
||
mailThankGodfatherBodyHTML: "<h3>Bonjour USER_NAME,</h3><p>Grâce à vous, un nouvel utilisateur (EMAIL) vient de s'inscrire sur NOM_SITE.<br>Si dans l'avenir cette personne souscrit un abonnement prémium, votre propre abonnement sera prolongé de 30 jours.</p><p>Encore merci et à bientôt !</p>",
|
||
mailThankGodfatherBodyTxt: "Bonjour USER_NAME,\nGrâce à vous, un nouvel utilisateur (EMAIL) vient de s'inscrire sur NOM_SITE.\nSi dans l'avenir cette personne souscrit un abonnement prémium, votre propre abonnement sera prolongé de 30 jours.\nEncore merci et à bientôt !",
|
||
mailThankGodfatherLinkTxt: "Me connecter à mon compte.",
|
||
mailThankGodfatherSubject: "Merci !",
|
||
mailUpdateLoginBodyHTML: "<h3>Bonjour USER_NAME,</h3><p>Pour valider vos nouveaux identifiants de connexion, cliquez sur le lien ci-dessous sans tarder.</p>",
|
||
mailUpdateLoginBodyTxt: "Bonjour USER_NAME,\n\nPour valider vos nouveaux identifiants de connexion, cliquez sur le lien suivant sans tarder :\nLINK_URL",
|
||
mailUpdateLoginLinkMessage: "Cependant, vous avez modifié au moins un de vos identifiants de connexion (e-mail et/ou mot de passe) et <b>vous devez cliquer sur le lien qui vient de vous êtres envoyé sur votre adresse (NEW_EMAIL) pour valider ce changement</b>.<br>En attendant, merci de continuer à utiliser vos anciens identifiants.",
|
||
mailUpdateLoginLinkTxt: "Valider.",
|
||
mailUpdateLoginOkMessage: "La mise à jour de vos identifiants a bien été enregistrée.",
|
||
mailUpdateLoginSubject: "Merci de valider vos nouveaux identifiants.",
|
||
mailValidationLinkSBodyHTML: "<h3>Bonjour USER_NAME,</h3><p>Pour valider et compléter votre inscription, merci de cliquer sur le lien ci-dessous dans les 24h.</p>",
|
||
mailValidationLinkSBodyTxt: "Bonjour USER_NAME,\n\nPour valider et compléter votre inscription, merci de cliquer sur le lien suivant dans les 24h :\nLINK_URL",
|
||
mailValidationLinkSubject: "Merci de valider votre inscription",
|
||
mailValidationLinkTxt: "Valider mon compte.",
|
||
mailValidationMessage: "Votre inscription est bien enregistrée.\nPour la finaliser, merci de cliquer dans les 24 H sur le lien de confirmation qui vient d'être envoyé à votre adresse e-mail (#EMAIL).",
|
||
mailWelcomeBodyHTML: "<h3>Bonjour USER_NAME,</h3><p>Vous venez de valider votre inscription à NOM_SITE. Merci et bienvenue !<br><br>Si vous avez la moindre question ou suggestion concernant NOM_SITE, n'hésitez pas à me contacter en écrivant à <b>EMAIL</b>.<br><br>Je vous conseille d'ailleurs d'ajouter <b>EMAIL</b> à votre carnet d'adresses <b>pour éviter que les prochains envois de NOM_SITE n'arrivent en <i>spam</i></b>.<br><br>Par ailleurs, pour gérer votre abonnement, accéder à vos informations ou encore chercher plus facilement parmi le contenu du site, vous pouvez à tout moment vous connecter à votre compte utilisateur.<br><br>Pour ce faire, utilisez le lien ci-dessous.<br><br>À bientôt sur NOM_SITE.",
|
||
mailWelcomeBodyTxt: "Bonjour USER_NAME,\n\nVous venez de valider votre inscription à NOM_SITE. Merci et bienvenue !\n\nSi vous avez la moindre question ou suggestion concernant NOM_SITE, n'hésitez pas à me contacter en écrivant à EMAIL.\n\nJe vous conseille d'ailleurs d'ajouter EMAIL à votre carnet d'adresses pour éviter que les prochains envois de NOM_SITE n'arrivent en \"spam\".\n\nPar ailleurs, pour gérer votre abonnement, accéder à vos informations ou encore chercher plus facilement parmi le contenu du site, vous pouvez à tout moment vous connecter à votre compte utilisateur.\n\nPour ce faire, utilisez le lien suivant : LINK_URL\n\nÀ bientôt sur NOM_SITE.",
|
||
mailWelcomeLinkTxt: "Me connecter à mon compte.",
|
||
mailWelcomeSubject: "Bienvenue !",
|
||
needBeConnected: "Vous devez être connecté pour accéder à cette page.",
|
||
needChooseLoginWay: "Vous devez soit saisir votre mot de passe, soit cocher la case vous permettant de recevoir un lien de connexion par e-mail.",
|
||
needEmail: "Merci de saisir votre adresse e-mail.",
|
||
needKnowNewsletterOk: "Il faut savoir si l'utilisateur accepte ou refuse de recevoir la newsletter.",
|
||
needLanguage: "Il manque le code langue.",
|
||
needLongPassWord: "Merci de fournir un mot de passe d'au moins MIN_LENGTH caractères.",
|
||
needMaxTimeDifference: "Il faut fournir un nombre de minutes à ajouter à l'heure GMT ne dépassant pas 840.",
|
||
needMinTimeDifference: "Il faut fournir un nombre de minutes à enlever à l'heure GMT ne dépassant pas 720.",
|
||
needName: "Merci de choisir un nom d'utilisateur.",
|
||
needNotTooLongName: "Merci de choisir un nom d'utilisateur ne comptant pas plus de 70 caractères.",
|
||
needNotTooLongEmail: "Merci de saisir une adresse e-mail ne comptant pas plus de 255 caractères.",
|
||
needPassWord: "Merci de fournir un mot de passe.",
|
||
needSMTP: "Il manque le serveur SMTP.",
|
||
needSMTPNotFound: "Il manque un serveur SMTP valide.",
|
||
needStatus: "Il manque le statut.",
|
||
needTimeDifference: "Il faut connaître le nombre de minutes du décalage horaire.",
|
||
needUGCOk: "Merci d'accepter les CGU pour créer votre compte.",
|
||
needUniqueEmail: "L'adresse e-mail que vous avez saisie est déjà utilisée pour un compte utilisateur. Si vous avez déjà un compte, <a href='/#URL'>cliquez-ici pour vous connecter</a>.",
|
||
needValidationToLogin: "Vous devez d'abord valider votre compte avant de pouvoir vous connecter. Pour ce faire, un nouveau lien vient de vous être envoyé par e-mail.",
|
||
needValidLastConnectionDate: "La date de dernière connexion n'est pas valide.",
|
||
passwordCopied: "Le mot de passe généré a été copié dans le presse-papier de votre ordinateur (ou mobile). Vous pouvez le \"coller\" où vous le souhaitez.",
|
||
searchUsersWithoutResult: "L'utilisateur n'a pas été trouvé.",
|
||
tooManyLoginFails: "Désolé mais il y a eu trop de tentatives de connexion infructueuses pour cette adresse e-mail. Vous devez attendre MINUTES minutes pour essayer de nouveau.",
|
||
updatedFailedGodfatherNotFound: "L'identifiant fourni pour le parrain ne correspond à aucun utilisateur.",
|
||
updatedNeedGoodEmail: "Mais la nouvelle adresse e-mail n'a pu être enregistrée, car elle n'a pas un format correct.",
|
||
updatedNeedGoodGodfather: "Mais le nouveau code parrain n'a pu être retenu, car il ne correspond à aucun compte utilisateur ou à l'utilisateur lui-même.",
|
||
updatedNeedUniqueEmail: "Mais la nouvelle adresse e-mail saisie (NEW_EMAIL) n'a pu être enregistrée, car elle est déjà utilisée pour un autre compte.",
|
||
updatedNeedValidatedUser: "L'utilisateur que vous souhaitez modifier n'existe pas/plus ou n'a pas encore validé son compte.",
|
||
updatedOkMessage: "Vos informations ont bien été mises à jour.",
|
||
validationAlreadyMessage: "Il semble que vous ayez déjà validé votre compte. Vous pouvez vous y connecter <a href='#URL'>en cliquant ici</a>.",
|
||
validationAlreadyMessageAdmin: "Ce compte a déjà été validé.",
|
||
validationMessage: "Votre compte vient bien d'être validé. Merci et bienvenue !<br>Vous pouvez compléter les informations de votre abonnement ci-dessous.",
|
||
validationMessageAdmin: "Le compte a bien été validé.",
|
||
welcomeMessage: "Bienvenue #NAME !"
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../tools/main.js":
|
||
/*!************************!*\
|
||
!*** ../tools/main.js ***!
|
||
\************************/
|
||
/***/ (function(module) {
|
||
|
||
// Quelques fonctions utiles pour les chaînes
|
||
class Tool {
|
||
static isEmpty(myVar) {
|
||
if (myVar === undefined || myVar === null) return true;else {
|
||
myVar += ""; // si autre chose qu'une chaîne envoyé...
|
||
|
||
myVar = myVar.trim();
|
||
if (myVar === "") return true;else return false;
|
||
}
|
||
}
|
||
|
||
static trimIfNotNull(myString) {
|
||
if (Tool.isEmpty(myString)) myString = null;else {
|
||
myString += ""; // si autre chose qu'une chaîne envoyé...
|
||
|
||
myString = myString.trim();
|
||
}
|
||
return myString;
|
||
}
|
||
|
||
static shortenIfLongerThan(myString, max) {
|
||
myString += ""; // au cas où cela ne serait pas une chaîne...
|
||
|
||
if (myString.length > max) myString = myString.substring(0, max - 3) + "…";
|
||
return myString;
|
||
} // source : https://stackoverflow.com/questions/15604140/replace-multiple-strings-with-multiple-other-strings
|
||
|
||
|
||
static replaceAll(myString, mapObj) {
|
||
const replaceElts = new RegExp(Object.keys(mapObj).join("|"), "gi");
|
||
return myString.replace(replaceElts, matched => {
|
||
return mapObj[matched];
|
||
});
|
||
} // source : https://developer.mozilla.org/fr/docs/Web/JavaScript/Reference/Objets_globaux/Math/random
|
||
|
||
|
||
static getRandomInt(min, max) {
|
||
min = Math.ceil(min);
|
||
max = Math.floor(max);
|
||
return Math.floor(Math.random() * (max - min)) + min;
|
||
} // à compléter : https://en.wikipedia.org/wiki/Date_format_by_country
|
||
|
||
|
||
static dateFormat(dateString, lang = "fr") {
|
||
if (Tool.isEmpty(dateString)) return "";
|
||
let myDate = new Date(dateString);
|
||
let myDay = myDate.getDate() + "";
|
||
if (myDay.length === 1) myDay = "0" + myDay;
|
||
let myMounth = myDate.getMonth() + 1 + "";
|
||
if (myMounth.length === 1) myMounth = "0" + myMounth;
|
||
let myYear = myDate.getFullYear();
|
||
if (lang === "fr") return myDay + "/" + myMounth + "/" + myYear;else if (lang === "form") // 2014-02-09
|
||
return myYear + "-" + myMounth + "-" + myDay;else return myMounth + "/" + myDay + "/" + myYear;
|
||
} // On enlève volontairement les 0/O pour éviter les confusions !
|
||
// Et mieux vaut aussi débuter et finir par une lettre simple.
|
||
|
||
|
||
static getPassword(nbCarMin, nbCarMax) {
|
||
const nbCar = nbCarMin + Math.floor(Math.random() * (nbCarMax - nbCarMin));
|
||
const letters = "ABCDEFGHIJKLMNPQRSTUVWXYZabcdefghijklmnpqrstuvwxyz";
|
||
const others = "123456789!?.*-_%@&ÉÀÈÙ€$ÂÊÛÎ";
|
||
let password = letters[Math.floor(Math.random() * letters.length)];
|
||
|
||
for (let i = 1; i < nbCar - 1; i++) {
|
||
if (i % 2 === 1) password += others[Math.floor(Math.random() * others.length)];else password += letters[Math.floor(Math.random() * letters.length)];
|
||
}
|
||
|
||
password += letters[Math.floor(Math.random() * letters.length)];
|
||
return password;
|
||
}
|
||
|
||
}
|
||
|
||
module.exports = Tool;
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../views/default/config/fr.js":
|
||
/*!*************************************!*\
|
||
!*** ../views/default/config/fr.js ***!
|
||
\*************************************/
|
||
/***/ (function(module) {
|
||
|
||
module.exports = {
|
||
headLinks: [{
|
||
anchor: "Accueil",
|
||
attributes: {
|
||
href: "/"
|
||
}
|
||
}, {
|
||
anchor: "Mon compte",
|
||
attributes: {
|
||
href: "/connexion.html",
|
||
id: "accountHeadLink"
|
||
}
|
||
}, {
|
||
anchor: "À propos",
|
||
attributes: {
|
||
href: "/a-propos.html"
|
||
}
|
||
}, {
|
||
anchor: "Contact",
|
||
attributes: {
|
||
href: "/contact.html"
|
||
}
|
||
}],
|
||
footLinks: [{
|
||
anchor: "Crédits",
|
||
attributes: {
|
||
href: "/credits.html"
|
||
}
|
||
}, {
|
||
anchor: "Mentions légales",
|
||
attributes: {
|
||
href: "/mentions-legales.html",
|
||
rel: "nofollow"
|
||
}
|
||
}, {
|
||
anchor: "Données personnelles",
|
||
attributes: {
|
||
href: "/donnees.html"
|
||
}
|
||
}, {
|
||
anchor: "C.G.U.",
|
||
attributes: {
|
||
href: "/cgu.html",
|
||
rel: "nofollow"
|
||
}
|
||
}, {
|
||
anchor: "C.G.V.",
|
||
attributes: {
|
||
href: "/cgv.html",
|
||
rel: "nofollow"
|
||
}
|
||
}],
|
||
maxQuestionnairesByPage: 10,
|
||
userHomePage: "accueil.html",
|
||
adminHomePage: "admin.html",
|
||
managerHomePage: "gestion.html",
|
||
subscribePage: "inscription.html",
|
||
connectionPage: "connexion.html",
|
||
accountPage: "compte.html",
|
||
questionnairesManagementPage: "gestion-quizs.html",
|
||
usersManagementPage: "gestion-utilisateurs.html",
|
||
nbQuestionnairesUserHomePage: 10,
|
||
illustrationDir: "/img/quizs/",
|
||
siteSlogan: "Cultivons notre jardin !",
|
||
homeTitle1: "De nature curieuse ?",
|
||
homeP1: "Avec WikiLerni vous apprenez chaque jour de nouvelles choses.<br>Des articles de Wikipédia sont sélectionnés pour vous et sont suivis d'un quiz vous permettant de tester ce que vous en avez retenu.<br>De jour en jour de nouvelles graines de savoir sont ainsi semées dans votre \"jardin\".",
|
||
homeTitle2: "La culture en liberté",
|
||
homeP2: "Tout comme sur Wikipédia (*), le logiciel et le contenu partagé sur WikiLerni sont libres.<br>Vous pouvez les utiliser, les modifier et les diffuser selon votre souhait.<br>Sur WikiLerni, pas de publicité, ni de commercialisation de vos données personnelles.<br>Vous pouvez venir y \"cultiver votre jardin\" en toute tranquillité.<br><br><small><em>(*) Bien que partageant ses valeurs, WikiLerni est un projet indépendant de la fondation Wikipédia.</em></small>",
|
||
newQuestionnairesTitle: "Les derniers quizs publiés sur WikiLerni",
|
||
newQuestionnairesIntro: "Liste des derniers quizs publiés sur WikiLerni.",
|
||
explanationTitle: "Vous découvrez WikiLerni ?",
|
||
explanationTxt: "Le principe est simple : vous commencez par lire l'article Wikipédia dont le lien vous est proposé.<br>Puis vous afficher le quiz pour vérifier ce que vous en avez retenu de votre lecture. Vous obtenez alors votre résultat immédiatement.<br><br>Toutes les réponses se trouvent dans l'article proposé à la lecture. <b>Vous êtes ici pour apprendre de nouvelles choses</b>, mais libre à vous d'essayer d'y répondre immédiatement.<br><br>Quand le sujet s'y prête, ne vous étonnez pas si certaines des réponses proposées peuvent être un peu décalées, absurdes... On peut apprendre avec le sourire, non ? :-)<br><br>Une fois votre résultat obtenu, il vous sera proposé de créer un compte pour le sauvegarder.<br>Ce compte vous permettra de tester de nouveau ce quiz pour vérifier ce que vous en avez retenu plusieurs jours, semaines, mois... Et de recevoir régulièrement de nouvelles suggestions de lectures.<br><br>Mais <b>la création de ce compte est facultative</b> et <a href='/quizs/' title='Les derniers quizs publiés'>vous pouvez parcourir WikiLerni librement</a>.",
|
||
noJSNotification: "Désolé, mais pour l'instant, l'utilisation de WikiLerni nécessite l'activation du JavaScript.",
|
||
tagsListTxt: "Parcourir les rubriques :"
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../views/wikilerni/config/fr.js":
|
||
/*!***************************************!*\
|
||
!*** ../views/wikilerni/config/fr.js ***!
|
||
\***************************************/
|
||
/***/ (function(module) {
|
||
|
||
module.exports = {
|
||
// liens de l'interface
|
||
headLinks: [{
|
||
anchor: "Contact",
|
||
attributes: {
|
||
href: "/contact.html",
|
||
rel: "nofollow"
|
||
}
|
||
}, {
|
||
anchor: "Parcourir",
|
||
attributes: {
|
||
href: "/quizs/",
|
||
id: "indexHeadLink",
|
||
title: "Les dernières publications"
|
||
}
|
||
}, {
|
||
anchor: "Mon compte",
|
||
attributes: {
|
||
href: "/connexion.html",
|
||
id: "accountHeadLink",
|
||
title: "Accéder ou créez votre compte WikiLerni"
|
||
}
|
||
}, {
|
||
anchor: "À propos",
|
||
attributes: {
|
||
href: "/a-propos.html",
|
||
title: "En savoir + sur WikiLerni"
|
||
}
|
||
}, {
|
||
anchor: "Accueil",
|
||
attributes: {
|
||
href: "/",
|
||
title: "Page d'accueil"
|
||
}
|
||
}],
|
||
footLinks: [{
|
||
anchor: "Blog",
|
||
attributes: {
|
||
href: "https://framasphere.org/people/7e54b7a0b53201389eef2a0000053625",
|
||
title: "Le blog WikiLerni sur diaspora*"
|
||
}
|
||
}, {
|
||
anchor: "Crédits",
|
||
attributes: {
|
||
href: "/credits.html",
|
||
title: "Qui a créé WikiLerni ? Quels sont vos droits ?"
|
||
}
|
||
}, {
|
||
anchor: "Mentions légales",
|
||
attributes: {
|
||
href: "/mentions-legales.html",
|
||
rel: "nofollow"
|
||
}
|
||
}, {
|
||
anchor: "Données personnelles",
|
||
attributes: {
|
||
href: "/donnees.html",
|
||
title: "Vos données personnelles sur WikiLerni"
|
||
}
|
||
}, {
|
||
anchor: "CGV & CGU",
|
||
attributes: {
|
||
href: "/CGV-CGU.html",
|
||
rel: "nofollow"
|
||
}
|
||
}],
|
||
accountPage: "compte.html",
|
||
aboutPage: "a-propos.html",
|
||
adminHomePage: "admin.html",
|
||
cguPage: "CGV-CGU.html",
|
||
connectionPage: "connexion.html",
|
||
deleteLinkPage: "aurevoir.html?t=",
|
||
loginLinkPage: "login.html?t=",
|
||
managerHomePage: "gestion.html",
|
||
newLoginLinkPage: "newlogin.html?t=",
|
||
questionnairesManagementPage: "gestion-quizs.html",
|
||
stopMailPage: "stop-mail.html?t=",
|
||
subscribePage: "inscription.html",
|
||
updateAccountPage: "compte.html",
|
||
userHomePage: "accueil.html",
|
||
userHomePageTxt: "Ma page d'accueil.",
|
||
usersManagementPage: "gestion-utilisateurs.html",
|
||
validationLinkPage: "validation.html?t=",
|
||
|
||
/* Textes (général) */
|
||
siteSlogan: "Cultivons notre jardin !",
|
||
noJSNotification: "Désolé, mais pour l'instant, l'utilisation de WikiLerni nécessite l'activation du JavaScript.",
|
||
mailRecipientTxt: "Message envoyé à :",
|
||
licenceTxt: "@copyleft Le contenu de WikiLerni <a href=\"/credits.html\" title=\"En savoir plus ?\">est libre</a> et vous est offert sans publicité. Vous pouvez <a href=\"/participer-financement.html\" title=\"Financement participatif avec contre-parties\">participer à son financement en cliquant ici</a>.",
|
||
|
||
/* Page d'accueil */
|
||
homePageTxt: "Page d'accueil",
|
||
homeTitle1: "De nature curieuse ?",
|
||
homeP1: "<b>Avec WikiLerni, vous apprenez régulièrement de nouvelles choses</b>.<br>Vous recevez de courts articles, lisibles en quelques minutes.<br>Des quizs vous permettent ensuite de tester ce que vous avez retenu.<br>De jour en jour <b>de nouvelles graines de culture sont ainsi semées dans votre jardin</b>.",
|
||
homeTitle2: "La culture générale en liberté",
|
||
homeP2: "<b>Pas de faits alternatifs</b>, tous les contenus sont <b>sourcés par des articles Wikipédia</b>.<br>Et tout comme sur Wikipédia, le logiciel et le contenu publié sur WikiLerni <a href=\"/credits.html\" title=\"En savoir plus sur ce sujet\">sont partagés sous licences libres</a>.<br>Le tout sans publicité, ni commercialisation de vos données.<br><b>Sur WikiLerni, vous cultivez votre jardin en toute tranquillité.</b>",
|
||
homeBtnAboutTxt: "En savoir plus sur WikiLerni ?",
|
||
homeBtnSubscribeTxt: "Testez WikiLerni",
|
||
homeSubcriptionFormTitle: "Recevez les prochains articles WikiLerni",
|
||
|
||
/* Page dernières publications... */
|
||
newQuestionnairesTitle: "Culture générale - apprenez de nouvelles choses avec WikiLerni",
|
||
newQuestionnairesIntro: "WikiLerni : testez vos connaissances et apprenez de nouvelles choses avec WikiLerni.",
|
||
newsListTitle: "<p><b>Avec WikiLerni, vous apprenez chaque jour quelque chose de nouveau</b><br>Si dessous les dernières publications. Vous pouvez aussi <a href='/quizs/themes.html'>parcourir le site par thèmes ou mots-clés</a>.</p>",
|
||
|
||
/* Plan du site, liste des tags */
|
||
tagListTitle: "Culture générale - des articles et quizs sur de nombreux thèmes !",
|
||
tagListMetaDesc: "WikiLerni : découvrir les différents thèmes abordés par WikiLerni. Inxex du site.",
|
||
tagListIntro: "<h3>Avec WikiLerni, devenez fort en thèmes... Oui mais quels thèmes ? :)</h3><blockquote>Aristote : « L’homme a naturellement la passion de connaître… »</blockquote>",
|
||
|
||
/* Page quizs */
|
||
answersExplanationsLinkText: "Relire",
|
||
quizElementLinksIntro: "En savoir plus",
|
||
quizElementSubcriptionFormTitle: "Recevez les prochains articles WikiLerni",
|
||
explanationTitle: "Vous découvrez WikiLerni ?",
|
||
explanationTxt: "<p>Le principe est simple : <b>vous commencez par lire l’article Wikipédia dont le lien vous est proposé</b>. Puis vous <b>afficher le quiz pour vérifier ce que vous avez retenu de votre lecture</b>. Suivant les questions, <b>une ou plusieurs réponses peuvent être correctes</b> et doivent donc être cochées. C’est toujours <b>le contenu de l’article Wikipédia qui fait foi</b> concernant les « bonnes » réponses. C’est une façon de tester à la fois votre capacité d’attention et votre mémoire. Les articles de Wikipédia peuvent évoluer, donc n’hésitez pas <a href='/contact.html'>à me signaler une erreur</a>.</p><p><b>WikiLerni vous propose d’autres solutions pour améliorer votre culture générale</b>. Pour en savoir plus, cliquez sur le bouton ci-dessous.</p>",
|
||
explanationElementTxt: "<p>WikiLerni vous propose de <b>recevoir par e-mail à la fréquence choisie, de courts articles lisibles en quelques minutes</b> et portant sur des sujets très variés de <b>culture générale</b> (arts, histoire, littérature, sciences, etc.).</p><p>Ces articles sont basés sur <b>une ou plusieurs pages de Wikipédia</b> (fournies en lien), dont <b>ils extraient certaines informations</b>.</p><p>Chaque série d’articles est <b>suivie d’un quiz</b> permettant de tester ce que vous en avez retenu.</p><p><b>Vous apprenez ainsi régulièrement de nouvelles choses</b> très simplement.</p>",
|
||
|
||
/* Autres */
|
||
illustrationDir: "/img/quizs/",
|
||
twitterAccount: "WikiLerni",
|
||
maxQuestionnairesByPage: 12,
|
||
maxQuestionnairesSiteHomePage: 3,
|
||
nbQuestionnairesUserHomePage: 3
|
||
};
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../lang sync recursive ^\\.\\/.*\\/general$":
|
||
/*!***************************************!*\
|
||
!*** ../lang/ sync ^\.\/.*\/general$ ***!
|
||
\***************************************/
|
||
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
|
||
|
||
var map = {
|
||
"./fr/general": "../lang/fr/general.js"
|
||
};
|
||
|
||
|
||
function webpackContext(req) {
|
||
var id = webpackContextResolve(req);
|
||
return __webpack_require__(id);
|
||
}
|
||
function webpackContextResolve(req) {
|
||
if(!__webpack_require__.o(map, req)) {
|
||
var e = new Error("Cannot find module '" + req + "'");
|
||
e.code = 'MODULE_NOT_FOUND';
|
||
throw e;
|
||
}
|
||
return map[req];
|
||
}
|
||
webpackContext.keys = function webpackContextKeys() {
|
||
return Object.keys(map);
|
||
};
|
||
webpackContext.resolve = webpackContextResolve;
|
||
module.exports = webpackContext;
|
||
webpackContext.id = "../lang sync recursive ^\\.\\/.*\\/general$";
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../lang sync recursive ^\\.\\/.*\\/subscription$":
|
||
/*!********************************************!*\
|
||
!*** ../lang/ sync ^\.\/.*\/subscription$ ***!
|
||
\********************************************/
|
||
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
|
||
|
||
var map = {
|
||
"./fr/subscription": "../lang/fr/subscription.js"
|
||
};
|
||
|
||
|
||
function webpackContext(req) {
|
||
var id = webpackContextResolve(req);
|
||
return __webpack_require__(id);
|
||
}
|
||
function webpackContextResolve(req) {
|
||
if(!__webpack_require__.o(map, req)) {
|
||
var e = new Error("Cannot find module '" + req + "'");
|
||
e.code = 'MODULE_NOT_FOUND';
|
||
throw e;
|
||
}
|
||
return map[req];
|
||
}
|
||
webpackContext.keys = function webpackContextKeys() {
|
||
return Object.keys(map);
|
||
};
|
||
webpackContext.resolve = webpackContextResolve;
|
||
module.exports = webpackContext;
|
||
webpackContext.id = "../lang sync recursive ^\\.\\/.*\\/subscription$";
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../lang sync recursive ^\\.\\/.*\\/user$":
|
||
/*!************************************!*\
|
||
!*** ../lang/ sync ^\.\/.*\/user$ ***!
|
||
\************************************/
|
||
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
|
||
|
||
var map = {
|
||
"./fr/user": "../lang/fr/user.js"
|
||
};
|
||
|
||
|
||
function webpackContext(req) {
|
||
var id = webpackContextResolve(req);
|
||
return __webpack_require__(id);
|
||
}
|
||
function webpackContextResolve(req) {
|
||
if(!__webpack_require__.o(map, req)) {
|
||
var e = new Error("Cannot find module '" + req + "'");
|
||
e.code = 'MODULE_NOT_FOUND';
|
||
throw e;
|
||
}
|
||
return map[req];
|
||
}
|
||
webpackContext.keys = function webpackContextKeys() {
|
||
return Object.keys(map);
|
||
};
|
||
webpackContext.resolve = webpackContextResolve;
|
||
module.exports = webpackContext;
|
||
webpackContext.id = "../lang sync recursive ^\\.\\/.*\\/user$";
|
||
|
||
/***/ }),
|
||
|
||
/***/ "../views sync recursive ^\\.\\/.*\\.js$":
|
||
/*!***********************************!*\
|
||
!*** ../views/ sync ^\.\/.*\.js$ ***!
|
||
\***********************************/
|
||
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
|
||
|
||
var map = {
|
||
"./default/config/fr.js": "../views/default/config/fr.js",
|
||
"./wikilerni/config/fr.js": "../views/wikilerni/config/fr.js"
|
||
};
|
||
|
||
|
||
function webpackContext(req) {
|
||
var id = webpackContextResolve(req);
|
||
return __webpack_require__(id);
|
||
}
|
||
function webpackContextResolve(req) {
|
||
if(!__webpack_require__.o(map, req)) {
|
||
var e = new Error("Cannot find module '" + req + "'");
|
||
e.code = 'MODULE_NOT_FOUND';
|
||
throw e;
|
||
}
|
||
return map[req];
|
||
}
|
||
webpackContext.keys = function webpackContextKeys() {
|
||
return Object.keys(map);
|
||
};
|
||
webpackContext.resolve = webpackContextResolve;
|
||
module.exports = webpackContext;
|
||
webpackContext.id = "../views sync recursive ^\\.\\/.*\\.js$";
|
||
|
||
/***/ })
|
||
|
||
/******/ });
|
||
/************************************************************************/
|
||
/******/ // The module cache
|
||
/******/ var __webpack_module_cache__ = {};
|
||
/******/
|
||
/******/ // The require function
|
||
/******/ function __webpack_require__(moduleId) {
|
||
/******/ // Check if module is in cache
|
||
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
||
/******/ if (cachedModule !== undefined) {
|
||
/******/ return cachedModule.exports;
|
||
/******/ }
|
||
/******/ // Create a new module (and put it into the cache)
|
||
/******/ var module = __webpack_module_cache__[moduleId] = {
|
||
/******/ // no module.id needed
|
||
/******/ // no module.loaded needed
|
||
/******/ exports: {}
|
||
/******/ };
|
||
/******/
|
||
/******/ // Execute the module function
|
||
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
||
/******/
|
||
/******/ // Return the exports of the module
|
||
/******/ return module.exports;
|
||
/******/ }
|
||
/******/
|
||
/************************************************************************/
|
||
/******/ /* webpack/runtime/compat get default export */
|
||
/******/ !function() {
|
||
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
||
/******/ __webpack_require__.n = function(module) {
|
||
/******/ var getter = module && module.__esModule ?
|
||
/******/ function() { return module['default']; } :
|
||
/******/ function() { return module; };
|
||
/******/ __webpack_require__.d(getter, { a: getter });
|
||
/******/ return getter;
|
||
/******/ };
|
||
/******/ }();
|
||
/******/
|
||
/******/ /* webpack/runtime/define property getters */
|
||
/******/ !function() {
|
||
/******/ // define getter functions for harmony exports
|
||
/******/ __webpack_require__.d = function(exports, definition) {
|
||
/******/ for(var key in definition) {
|
||
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
||
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
||
/******/ }
|
||
/******/ }
|
||
/******/ };
|
||
/******/ }();
|
||
/******/
|
||
/******/ /* webpack/runtime/hasOwnProperty shorthand */
|
||
/******/ !function() {
|
||
/******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }
|
||
/******/ }();
|
||
/******/
|
||
/******/ /* webpack/runtime/make namespace object */
|
||
/******/ !function() {
|
||
/******/ // define __esModule on exports
|
||
/******/ __webpack_require__.r = function(exports) {
|
||
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
||
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
||
/******/ }
|
||
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
||
/******/ };
|
||
/******/ }();
|
||
/******/
|
||
/************************************************************************/
|
||
var __webpack_exports__ = {};
|
||
// This entry need to be wrapped in an IIFE because it need to be in strict mode.
|
||
!function() {
|
||
"use strict";
|
||
/*!****************************!*\
|
||
!*** ./src/accountUser.js ***!
|
||
\****************************/
|
||
__webpack_require__.r(__webpack_exports__);
|
||
/* harmony import */ var _config_instance_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../config/instance.js */ "../config/instance.js");
|
||
/* harmony import */ var _config_instance_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_config_instance_js__WEBPACK_IMPORTED_MODULE_0__);
|
||
/* harmony import */ var _tools_clientstorage_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./tools/clientstorage.js */ "./src/tools/clientstorage.js");
|
||
/* harmony import */ var _tools_dom_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./tools/dom.js */ "./src/tools/dom.js");
|
||
/* harmony import */ var _tools_everywhere_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./tools/everywhere.js */ "./src/tools/everywhere.js");
|
||
/* harmony import */ var _tools_forms_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./tools/forms.js */ "./src/tools/forms.js");
|
||
/* harmony import */ var _tools_main__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../tools/main */ "../tools/main.js");
|
||
/* harmony import */ var _tools_main__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_tools_main__WEBPACK_IMPORTED_MODULE_5__);
|
||
/* harmony import */ var _tools_users_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./tools/users.js */ "./src/tools/users.js");
|
||
/* harmony import */ var _tools_webportage_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./tools/webportage.js */ "./src/tools/webportage.js");
|
||
// -- GESTION DES FORMULAIRES PERMETTANT AUX UTILISATEURS DE METTRE À JOUR LEURS INFORMATIONS + LEUR ABONNEMENT
|
||
/// Vérifier que l'utilisateur est bien connecté, a le bon statut et le rediriger vers le formulaire d'inscription si ce n'est pas le cas.
|
||
/// Si c'est ok, on récupère les infos de son compte et son abonnement et les affiche dans le formulaire.
|
||
/// Une information est affichée concernant la possibilité de parrainage et liste les filleuls existants.
|
||
/// Un menu permet à l'utilisateur d'accéder à la modification de ses infos, etc.
|
||
/// Des boutons de paiement sont aussi affichés suivant le choix de l'utilisateur pour lui permettre de prolonger son abonnement.
|
||
/// Un message venant d'une autre page peut aussi être à afficher lors du premier chargement.
|
||
// Fichier de configuration côté client :
|
||
|
||
const lang = _config_instance_js__WEBPACK_IMPORTED_MODULE_0__.availableLangs[0];
|
||
|
||
const configTemplate = __webpack_require__("../views sync recursive ^\\.\\/.*\\.js$")("./" + _config_instance_js__WEBPACK_IMPORTED_MODULE_0__.theme + "/config/" + lang + ".js"); // besoin de toutes les déclarations pour la fonction : updateAccountLink()
|
||
|
||
|
||
const {
|
||
beginCodeGodfather
|
||
} = __webpack_require__(/*! ../../config/instance */ "../config/instance.js");
|
||
|
||
const configUsers = __webpack_require__(/*! ../../config/users */ "../config/users.js"); // besoin de tous le fichier pour configurer le formulaire
|
||
// Fonctions utiles au script
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
// Spécifique WebPortage pour paiements:
|
||
|
||
// Dictionnaires :
|
||
|
||
const {
|
||
serverError
|
||
} = __webpack_require__("../lang sync recursive ^\\.\\/.*\\/general$")("./" + lang + "/general");
|
||
|
||
const {
|
||
infosUserNbGodChilds,
|
||
infosUserNoGodchilds,
|
||
needBeConnected
|
||
} = __webpack_require__("../lang sync recursive ^\\.\\/.*\\/user$")("./" + lang + "/user");
|
||
|
||
const {
|
||
infosExpirated,
|
||
infosNbDays
|
||
} = __webpack_require__("../lang sync recursive ^\\.\\/.*\\/subscription$")("./" + lang + "/subscription"); // Principaux éléments du DOM manipulés :
|
||
|
||
|
||
const divCrash = document.getElementById("crash");
|
||
const divMain = document.getElementById("main-content");
|
||
const divMessage = document.getElementById("message");
|
||
const divResponse = document.getElementById("response");
|
||
const divGodfatherInfos = document.getElementById("godfatherInfos");
|
||
const divGodchilds = document.getElementById("godchilds");
|
||
const divSubscribeInfos = document.getElementById("subscribeInfos");
|
||
const divSubscribeIntro = document.getElementById("subscribeIntro");
|
||
const formAccount = document.getElementById("accountUpdate");
|
||
const newPassword = document.getElementById("newPassword");
|
||
const showGFEmail = document.getElementById("godfatherEmail");
|
||
const showGFCode = document.getElementById("godfatherCode");
|
||
(0,_tools_everywhere_js__WEBPACK_IMPORTED_MODULE_3__.helloDev)();
|
||
|
||
const initialise = async () => {
|
||
try {
|
||
// Si l'utilisateur n'est pas connecté avec le bon statut, pas la peine d'aller + loin :
|
||
const isConnected = await (0,_tools_users_js__WEBPACK_IMPORTED_MODULE_6__.checkSession)(["user"], "/" + configTemplate.connectionPage, {
|
||
message: needBeConnected,
|
||
color: "error"
|
||
}, window.location);
|
||
|
||
if (isConnected) {
|
||
divMain.style.display = "block"; // l'éventuelle ancre est ignorée, car absente du DOM avant d'avoir vérifié la connexion
|
||
|
||
if (window.location.hash !== undefined) window.location.assign(window.location.hash);
|
||
|
||
if (!(0,_tools_main__WEBPACK_IMPORTED_MODULE_5__.isEmpty)((0,_tools_clientstorage_js__WEBPACK_IMPORTED_MODULE_1__.getLocaly)("message"))) {
|
||
(0,_tools_dom_js__WEBPACK_IMPORTED_MODULE_2__.addElement)(divMessage, "p", (0,_tools_clientstorage_js__WEBPACK_IMPORTED_MODULE_1__.getLocaly)("message", true).message, "", [(0,_tools_clientstorage_js__WEBPACK_IMPORTED_MODULE_1__.getLocaly)("message", true).color], "", false);
|
||
(0,_tools_clientstorage_js__WEBPACK_IMPORTED_MODULE_1__.removeLocaly)("message");
|
||
}
|
||
|
||
const user = (0,_tools_clientstorage_js__WEBPACK_IMPORTED_MODULE_1__.getLocaly)("user", true);
|
||
(0,_tools_everywhere_js__WEBPACK_IMPORTED_MODULE_3__.updateAccountLink)(user.status, configTemplate); // Initialise le formulaire permettant de mettre à jour les infos :
|
||
|
||
(0,_tools_forms_js__WEBPACK_IMPORTED_MODULE_4__.setAttributesToInputs)(configUsers, formAccount); // Certains navigateurs remplissent les champs password :
|
||
|
||
newPassword.value = ""; // Fonction affichant les infos connues au premier affichage, puis après envoi mise à jour
|
||
|
||
const getInfos = () => {
|
||
const xhrGetInfos = new XMLHttpRequest();
|
||
xhrGetInfos.open("GET", _config_instance_js__WEBPACK_IMPORTED_MODULE_0__.apiUrl + configUsers.userRoutes + configUsers.getUserInfos + user.id);
|
||
|
||
xhrGetInfos.onreadystatechange = function () {
|
||
if (this.readyState == XMLHttpRequest.DONE) {
|
||
let response = JSON.parse(this.responseText);
|
||
|
||
if (this.status === 200 && response.User != undefined && response.Subscription != undefined) {
|
||
for (let data in response.User) {
|
||
if (formAccount.elements[data] !== undefined) {
|
||
if (response.User[data] !== true && response.User[data] !== false) // booléen = case à cocher !
|
||
formAccount.elements[data].value = response.User[data];else if (response.User[data] == true) // si false, on ne fait rien
|
||
formAccount.elements["" + data].checked = "checked";
|
||
}
|
||
} // jours de réception
|
||
|
||
|
||
for (let i in response.Subscription.receiptDays) formAccount.elements["d" + response.Subscription.receiptDays[i]].checked = "checked"; // "codes" possibles à transmettre pour parrainer d'autres utilisateurs
|
||
|
||
|
||
showGFEmail.innerHTML = response.User.email;
|
||
showGFCode.innerHTML = beginCodeGodfather + response.User.id;
|
||
}
|
||
|
||
const beginSubTS = new Date(response.Subscription.createdAt).getTime();
|
||
|
||
if (response.Subscription.numberOfDays !== 0) {
|
||
divGodfatherInfos.style.display = "block";
|
||
divSubscribeInfos.style.display = "block";
|
||
const nbDaysOk = response.Subscription.numberOfDays - Math.round((Date.now() - beginSubTS) / 1000 / 3600 / 24);
|
||
if (nbDaysOk > 0) (0,_tools_dom_js__WEBPACK_IMPORTED_MODULE_2__.addElement)(divSubscribeIntro, "p", infosNbDays.replace("NB_DAYS", nbDaysOk), "", ["info"]);else {
|
||
(0,_tools_dom_js__WEBPACK_IMPORTED_MODULE_2__.addElement)(divSubscribeIntro, "p", infosExpirated.replace("NB_DAYS", nbDaysOk), "", ["error"]);
|
||
window.location.assign("#subscribe");
|
||
}
|
||
}
|
||
}
|
||
};
|
||
|
||
xhrGetInfos.setRequestHeader("Authorization", "Bearer " + user.token);
|
||
xhrGetInfos.send();
|
||
}; // Remonte les infos déjà enregistrées :
|
||
|
||
|
||
getInfos(); // Traitement de l'envoi d'une mise à jour des infos
|
||
|
||
formAccount.addEventListener("submit", function (e) {
|
||
e.preventDefault();
|
||
divResponse.innerHTML = "";
|
||
let datas = (0,_tools_forms_js__WEBPACK_IMPORTED_MODULE_4__.getDatasFromInputs)(formAccount); // recomposition des jours valables pour l'abonnement :
|
||
|
||
datas.receiptDays = "";
|
||
|
||
for (let i = 1; i <= 7; i++) {
|
||
if (datas["d" + i] !== undefined) datas.receiptDays += "" + i;
|
||
}
|
||
|
||
datas.timeDifference = (0,_tools_users_js__WEBPACK_IMPORTED_MODULE_6__.getTimeDifference)();
|
||
const xhrUserUpdate = new XMLHttpRequest();
|
||
if (datas.deleteOk !== undefined) xhrUserUpdate.open("DELETE", _config_instance_js__WEBPACK_IMPORTED_MODULE_0__.apiUrl + configUsers.userRoutes + "/" + user.id);else xhrUserUpdate.open("PUT", _config_instance_js__WEBPACK_IMPORTED_MODULE_0__.apiUrl + configUsers.userRoutes + configUsers.updateUserInfos + user.id);
|
||
|
||
xhrUserUpdate.onreadystatechange = function () {
|
||
if (this.readyState == XMLHttpRequest.DONE) {
|
||
let response = JSON.parse(this.responseText);
|
||
|
||
if (this.status === 200 && response.message != undefined) {
|
||
if (Array.isArray(response.message)) response.message = response.message.join("<br>");else response.message = response.message;
|
||
(0,_tools_dom_js__WEBPACK_IMPORTED_MODULE_2__.addElement)(divResponse, "p", response.message, "", ["success"]);
|
||
} else if (response.errors) {
|
||
if (Array.isArray(response.errors)) response.errors = response.errors.join("<br>");else response.errors = serverError;
|
||
(0,_tools_dom_js__WEBPACK_IMPORTED_MODULE_2__.addElement)(divResponse, "p", response.errors, "", ["error"]);
|
||
} else (0,_tools_dom_js__WEBPACK_IMPORTED_MODULE_2__.addElement)(divResponse, "p", serverError, "", ["error"]); // dans tous les cas, je mets à jour le contenu du formulaire :
|
||
|
||
|
||
getInfos();
|
||
}
|
||
};
|
||
|
||
xhrUserUpdate.setRequestHeader("Content-Type", "application/json");
|
||
xhrUserUpdate.setRequestHeader("Authorization", "Bearer " + user.token);
|
||
|
||
if (datas) {
|
||
datas.output = "html";
|
||
xhrUserUpdate.send(JSON.stringify(datas));
|
||
}
|
||
}); // on passe à la caisse ?
|
||
|
||
const abo9 = document.getElementById("abo9");
|
||
const abo18 = document.getElementById("abo18");
|
||
const abo36 = document.getElementById("abo36");
|
||
const abo54 = document.getElementById("abo54");
|
||
const CGV = document.getElementById("CGVOk");
|
||
const divWPBtns = document.getElementById("WPBtns");
|
||
divWPBtns.style.display = "none";
|
||
abo9.addEventListener("change", function (e) {
|
||
(0,_tools_webportage_js__WEBPACK_IMPORTED_MODULE_7__.unCheckAllOthers)("abo9");
|
||
});
|
||
abo18.addEventListener("change", function (e) {
|
||
(0,_tools_webportage_js__WEBPACK_IMPORTED_MODULE_7__.unCheckAllOthers)("abo18");
|
||
});
|
||
abo36.addEventListener("change", function (e) {
|
||
(0,_tools_webportage_js__WEBPACK_IMPORTED_MODULE_7__.unCheckAllOthers)("abo36");
|
||
});
|
||
abo54.addEventListener("change", function (e) {
|
||
(0,_tools_webportage_js__WEBPACK_IMPORTED_MODULE_7__.unCheckAllOthers)("abo54");
|
||
});
|
||
CGV.addEventListener("change", function (e) {
|
||
if (CGV.checked === true) {
|
||
divWPBtns.style.display = "block";
|
||
if (abo9.checked === true) (0,_tools_webportage_js__WEBPACK_IMPORTED_MODULE_7__.showBtnPayment)("btn9");else if (abo18.checked === true) (0,_tools_webportage_js__WEBPACK_IMPORTED_MODULE_7__.showBtnPayment)("btn18");else if (abo36.checked === true) (0,_tools_webportage_js__WEBPACK_IMPORTED_MODULE_7__.showBtnPayment)("btn36");else if (abo54.checked === true) (0,_tools_webportage_js__WEBPACK_IMPORTED_MODULE_7__.showBtnPayment)("btn54");else {
|
||
divWPBtns.style.display = "none";
|
||
CGV.checked = false;
|
||
}
|
||
} else divWPBtns.style.display = "none";
|
||
}); // Liste des filleuls, si il y en a
|
||
|
||
const xhrGetGodchilds = new XMLHttpRequest();
|
||
xhrGetGodchilds.open("GET", _config_instance_js__WEBPACK_IMPORTED_MODULE_0__.apiUrl + configUsers.userRoutes + configUsers.getGodChilds);
|
||
|
||
xhrGetGodchilds.onreadystatechange = function () {
|
||
if (this.readyState == XMLHttpRequest.DONE) {
|
||
let response = JSON.parse(this.responseText),
|
||
txtGodchilds = "";
|
||
|
||
if (this.status === 200) {
|
||
const nbGodchilds = response.length;
|
||
if (nbGodchilds === 0) txtGodchilds = infosUserNoGodchilds;else {
|
||
txtGodchilds = infosUserNbGodChilds.replace("#NB", nbGodchilds);
|
||
|
||
for (let i in response) txtGodchilds += response[i].name + " (" + response[i].email + ") ";
|
||
}
|
||
}
|
||
|
||
(0,_tools_dom_js__WEBPACK_IMPORTED_MODULE_2__.addElement)(divGodchilds, "p", txtGodchilds, "", ["info"]);
|
||
}
|
||
};
|
||
|
||
xhrGetGodchilds.setRequestHeader("Authorization", "Bearer " + user.token);
|
||
xhrGetGodchilds.send();
|
||
}
|
||
} catch (e) {
|
||
(0,_tools_dom_js__WEBPACK_IMPORTED_MODULE_2__.addElement)(divCrash, "p", serverError, "", ["error"]);
|
||
console.error(e);
|
||
}
|
||
};
|
||
|
||
initialise();
|
||
}();
|
||
/******/ })()
|
||
;
|
||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://wikilerni/../config/instance.js","webpack://wikilerni/../config/questionnaires.js","webpack://wikilerni/../config/users.js","webpack://wikilerni/./src/tools/clientstorage.js","webpack://wikilerni/./src/tools/dom.js","webpack://wikilerni/./src/tools/everywhere.js","webpack://wikilerni/./src/tools/forms.js","webpack://wikilerni/./src/tools/users.js","webpack://wikilerni/./src/tools/webportage.js","webpack://wikilerni/../lang/fr/general.js","webpack://wikilerni/../lang/fr/subscription.js","webpack://wikilerni/../lang/fr/user.js","webpack://wikilerni/../tools/main.js","webpack://wikilerni/../views/default/config/fr.js","webpack://wikilerni/../views/wikilerni/config/fr.js","webpack://wikilerni//home/fabrice/Documents/Bidouilles/wikilerni/lang|sync|/^\\.\\/.*\\/general$/","webpack://wikilerni//home/fabrice/Documents/Bidouilles/wikilerni/lang|sync|/^\\.\\/.*\\/subscription$/","webpack://wikilerni//home/fabrice/Documents/Bidouilles/wikilerni/lang|sync|/^\\.\\/.*\\/user$/","webpack://wikilerni//home/fabrice/Documents/Bidouilles/wikilerni/views|sync|/^\\.\\/.*\\.js$/","webpack://wikilerni/webpack/bootstrap","webpack://wikilerni/webpack/runtime/compat get default export","webpack://wikilerni/webpack/runtime/define property getters","webpack://wikilerni/webpack/runtime/hasOwnProperty shorthand","webpack://wikilerni/webpack/runtime/make namespace object","webpack://wikilerni/./src/accountUser.js"],"names":["users","require","questionnaires","module","exports","apiUrl","siteUrl","adminName","adminEmail","senderName","senderEmail","adminLang","theme","availableLangs","siteName","beginCodeGodfather","defaultReceiptDays","cronTimingAlertInSeconde","responseTimingAlertInSeconde","tokenSignupValidationTimeInHours","tokenLoginLinkTimeInHours","tokenConnexionMinTimeInHours","tokenConnexionMaxTimeInDays","tokenLoginChangingTimeInHours","tokenDeleteUserTimeInHours","tokenUnsubscribeLinkTimeInDays","freeAccountTimingInDays","freeAccountExpirationNotificationInDays","accountExpirationFirstNotificationInDays","accountExpirationSecondNotificationInDays","inactiveAccountTimeToDeleteInDays","nbQuestionsMin","nbQuestionsMax","nbChoicesMax","nbNewQuestionnaires","hourGiveNewQuestionnaireBegin","hourGiveNewQuestionnaireEnd","maxQuestionnaireSendedAtSameTime","minSearchQuestionnaires","fieldNewQuestionnaires","nbQuestionnairesByGroupMin","nbQuestionnairesByGroupMax","nbIllustrationsMin","nbIllustrationsMax","maxIllustrationSizeinOctet","mimeTypesForIllustration","illustrationsWidthMaxInPx","illustrationsMiniaturesWidthMaxInPx","nbLinksMin","nbLinksMax","passwordMinLength","password","minlength","dirCacheUsers","dirCacheUsersAnswers","dirCacheQuestionnaires","dirCacheQuestions","dirCacheUsersQuestionnaires","dirHTMLQuestionnaires","dirWebQuestionnaires","questionnaireRoutes","getListNextQuestionnaires","getQuestionnaireRoutes","getRandomQuestionnairesRoute","getStatsQuestionnaires","previewQuestionnaireRoutes","publishedQuestionnaireRoutes","regenerateHTML","searchAdminQuestionnairesRoute","searchQuestionnairesRoute","groupRoutes","getGroupRoute","previewGroupRoutes","searchGroupsRoute","questionsRoute","tagsSearchRoute","getAdminStats","getPreviousAnswers","getStatsAnswers","saveAnswersRoute","Questionnaire","title","maxlength","required","slug","introduction","searchQuestionnaires","Group","Question","text","rank","min","defaultValue","Choice","search","searchGroups","dirCacheGroups","dirCacheTags","dirHTMLGroups","dirHTMLNews","dirHTMLTags","dirWebGroups","dirWebNews","dirWebTags","nbRandomResults","nbTagsMin","nbTagsMax","userRoutes","checkDeleteLinkRoute","checkIfIsEmailfreeRoute","checkLoginRoute","checkNewLoginLinkRoute","checkSubscribeTokenRoute","connectionRoute","connectionWithLinkRoute","createUserRoute","getGodChilds","getGodfatherRoute","getLoginLinkRoute","getPayments","getUserInfos","getUsersQuestionnairesRoute","searchUserRoute","signupCompletionRoute","subscribeRoute","unsubscribeRoute","updateUserInfos","validateUserRoute","name","email","newPassword","codeGodfather","cguOk","value","timeDifferenceMin","timeDifferenceMax","dirCacheUsersWithoutAnswers","saveLocaly","data","localStorage","setItem","JSON","stringify","getLocaly","json","parse","getItem","removeLocaly","removeItem","addElement","eltParent","eltType","eltContent","eltId","eltClass","eltAttributes","replace","isEmpty","newElement","document","createElement","id","Array","isArray","length","i","classList","add","attributName","setAttribute","innerHTML","appendChild","helloDev","console","log","updateAccountLink","status","configTemplate","link","getElementById","homePage","href","setAttributesToInputs","inputsConf","myForm","elements","idInput","undefined","inputHTML","attribute","getDatasFromInputs","datas","formData","FormData","entrie","entries","empyForm","type","checked","empyAndHideForm","style","display","lang","getTimeDifference","timeLocal","Date","getTimezoneOffset","setSession","userId","token","durationTS","storageUser","duration","checkAnswerDatas","lastAnswer","answer","nbCorrectAnswers","nbQuestions","QuestionnaireId","GroupId","checkSession","urlRedirection","message","urlWanted","Promise","resolve","reject","userDatas","redirectUser","user","now","xhr","XMLHttpRequest","open","onload","response","responseText","isValid","language","timeDifference","nbDaysOk","urlAccount","accountPage","window","location","indexOf","assign","onerror","statusText","send","checkBoxes","divWPBtns","unCheckAllOthers","choice","btns","showBtnPayment","addBtnTxt","addOkMessage","alertNewWindow","badUrl","btnLinkToQuestionnaire","btnProposeConnection","btnProposeSubscribe","btnShowOnWebSite","deleteBtnTxt","deleteFailMessage","deleteOkMessage","failAuth","failAuthCron","failAuthHeader","failAuthId","failAuthToken","neededParams","nextPage","notAllowed","notRequired","notValidFormat","previousPage","serverError","serverErrorAdmin","siteHTMLTitle","siteMetaDescription","scriptTimingAlert","scriptTimingInfo","statsAdmin","subscriptionCall","updateBtnTxt","updateOkMessage","allSubscriptionProcessed","infosExpirated","infosExpiratedAdmin","infosNbDays","infosNbDaysAdmin","infosPaymentsAdmin","isNotValided","mailEndFreeTimeBodyHTML","mailEndFreeTimeBodyTxt","mailEndFreeTimeLinkTxt","mailEndFreeTimeMessage","mailEndFreeTimeSubject","mailExpirationBodyHTML","mailExpirationBodyTxt","mailExpirationLinkTxt","mailExpirationMessage","mailExpirationRelaunchTxt","mailExpirationSubject","mailNewElementForGroupTxt","mailNewQuestionnaireBodyTxt","mailStopMailLinkTxt","needKnowIfNoticeOk","needIntegerNumberOfDays","needMinNumberOfDays","needNotTooLongDaysList","needNumberOfDays","needUniqueDaysList","needValidDaysList","noNewQuestionnaireForUser","unsubscriptionOk","unsubscriptionFail","alreadyConnected","badLinkValidationMessage","badPassword","byebyeMessage","connectionOk","creationOkMessage","cronDeleteUnvalidedUsersMessage","deleteInactiveUsersMessage","emailNotFound","failBotTest","failBotTestLog","formsEmailLabel","formsEmailPlaceholder","formsEmail2Placeholder","formsCGUOkLabel","formsSubmitTxt","godfatherFound","godfatherNotFound","infosAdminGodfather","infosAdminNbGodChilds","infosUserForAdmin","infosUserNbGodChilds","infosUserNoGodchilds","mailDeleteBodyHTML","mailDeleteBodyTxt","mailDeleteLinkAlreadyMessage","mailDeleteLinkFailMessage","mailDeleteLinkMessage","mailDeleteLinkOkMessage","mailDeleteLinkTxt","mailDeleteSubject","mailLoginLinkBodyHTML","mailLoginLinkBodyTxt","mailLoginLinkMessage","mailLoginLinkSubject","mailLoginLinkTxt","mailThankGodfatherBodyHTML","mailThankGodfatherBodyTxt","mailThankGodfatherLinkTxt","mailThankGodfatherSubject","mailUpdateLoginBodyHTML","mailUpdateLoginBodyTxt","mailUpdateLoginLinkMessage","mailUpdateLoginLinkTxt","mailUpdateLoginOkMessage","mailUpdateLoginSubject","mailValidationLinkSBodyHTML","mailValidationLinkSBodyTxt","mailValidationLinkSubject","mailValidationLinkTxt","mailValidationMessage","mailWelcomeBodyHTML","mailWelcomeBodyTxt","mailWelcomeLinkTxt","mailWelcomeSubject","needBeConnected","needChooseLoginWay","needEmail","needKnowNewsletterOk","needLanguage","needLongPassWord","needMaxTimeDifference","needMinTimeDifference","needName","needNotTooLongName","needNotTooLongEmail","needPassWord","needSMTP","needSMTPNotFound","needStatus","needTimeDifference","needUGCOk","needUniqueEmail","needValidationToLogin","needValidLastConnectionDate","passwordCopied","searchUsersWithoutResult","tooManyLoginFails","updatedFailedGodfatherNotFound","updatedNeedGoodEmail","updatedNeedGoodGodfather","updatedNeedUniqueEmail","updatedNeedValidatedUser","updatedOkMessage","validationAlreadyMessage","validationAlreadyMessageAdmin","validationMessage","validationMessageAdmin","welcomeMessage","Tool","myVar","trim","trimIfNotNull","myString","shortenIfLongerThan","max","substring","replaceAll","mapObj","replaceElts","RegExp","Object","keys","join","matched","getRandomInt","Math","ceil","floor","random","dateFormat","dateString","myDate","myDay","getDate","myMounth","getMonth","myYear","getFullYear","getPassword","nbCarMin","nbCarMax","nbCar","letters","others","headLinks","anchor","attributes","footLinks","rel","maxQuestionnairesByPage","userHomePage","adminHomePage","managerHomePage","subscribePage","connectionPage","questionnairesManagementPage","usersManagementPage","nbQuestionnairesUserHomePage","illustrationDir","siteSlogan","homeTitle1","homeP1","homeTitle2","homeP2","newQuestionnairesTitle","newQuestionnairesIntro","explanationTitle","explanationTxt","noJSNotification","tagsListTxt","aboutPage","cguPage","deleteLinkPage","loginLinkPage","newLoginLinkPage","stopMailPage","updateAccountPage","userHomePageTxt","validationLinkPage","mailRecipientTxt","licenceTxt","homePageTxt","homeBtnAboutTxt","homeBtnSubscribeTxt","homeSubcriptionFormTitle","newsListTitle","tagListTitle","tagListMetaDesc","tagListIntro","answersExplanationsLinkText","quizElementLinksIntro","quizElementSubcriptionFormTitle","explanationElementTxt","twitterAccount","maxQuestionnairesSiteHomePage","configUsers","divCrash","divMain","divMessage","divResponse","divGodfatherInfos","divGodchilds","divSubscribeInfos","divSubscribeIntro","formAccount","showGFEmail","showGFCode","initialise","isConnected","color","hash","getInfos","xhrGetInfos","onreadystatechange","readyState","DONE","User","Subscription","receiptDays","beginSubTS","createdAt","getTime","numberOfDays","round","setRequestHeader","addEventListener","e","preventDefault","xhrUserUpdate","deleteOk","errors","output","abo9","abo18","abo36","abo54","CGV","xhrGetGodchilds","txtGodchilds","nbGodchilds","error"],"mappings":"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B,EAAE,ukBA/D3B;;AAgEI;AACAlC,iBAAe,EAAG,aAjEtB;AAkEImC,gBAAc,EAAE,WAlEpB;AAmEI5C,yBAAuB,EAAE,EAnE7B;AAoEI6C,+BAA6B,EAAE,CApEnC;AAqEIrC,8BAA4B,EAAG;AArEnC,CADA,C;;;;;;;;;;ACAA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kE;;;;;;;;;;ACtBA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uE;;;;;;;;;;ACtBA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+D;;;;;;;;;;ACtBA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8D;;;;;;UCvBA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA,cAAc,0BAA0B,EAAE;WAC1C,cAAc,eAAe;WAC7B,gCAAgC,YAAY;WAC5C;WACA,E;;;;;WCPA;WACA;WACA;WACA;WACA,wCAAwC,yCAAyC;WACjF;WACA;WACA,E;;;;;WCPA,6CAA6C,wDAAwD,E;;;;;WCArG;WACA;WACA;WACA,sDAAsD,kBAAkB;WACxE;WACA,+CAA+C,cAAc;WAC7D,E;;;;;;;;;;;;;;;;;;;;;;ACNA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA,MAAM/P,IAAI,GAAC7L,kEAAX;;AACA,MAAMoK,cAAc,GAAGhL,+DAAQ,IAAc,GAACW,sDAAf,GAAqB,UAArB,GAAgC8L,IAAhC,GAAqC,KAAtC,CAA9B,C,CAA2E;;;AAC3E,MAAM;AAAE3L;AAAF,IAAyBd,mBAAO,CAAC,oDAAD,CAAtC;;AACA,MAAM8e,WAAW,GAAG9e,mBAAO,CAAC,8CAAD,CAA3B,C,CAAmD;AAEnD;;;AACA;AACA;AACA;AACA;AACA;CAGA;;CAGA;;AACA,MAAM;AAAEqR;AAAF,IAAkBrR,mEAAQ,IAAa,GAACyM,IAAd,GAAmB,UAApB,CAA/B;;AACA,MAAM;AAAE0I,sBAAF;AAAwBC,sBAAxB;AAA8CiC;AAA9C,IAAkErX,gEAAQ,IAAa,GAACyM,IAAd,GAAmB,OAApB,CAA/E;;AACA,MAAM;AAAEuF,gBAAF;AAAkBE;AAAlB,IAAkClS,wEAAQ,IAAa,GAACyM,IAAd,GAAmB,eAApB,CAA/C,C,CAEA;;;AACA,MAAMsS,QAAQ,GAAGjV,QAAQ,CAACoB,cAAT,CAAwB,OAAxB,CAAjB;AACA,MAAM8T,OAAO,GAAGlV,QAAQ,CAACoB,cAAT,CAAwB,cAAxB,CAAhB;AACA,MAAM+T,UAAU,GAAGnV,QAAQ,CAACoB,cAAT,CAAwB,SAAxB,CAAnB;AACA,MAAMgU,WAAW,GAAGpV,QAAQ,CAACoB,cAAT,CAAwB,UAAxB,CAApB;AACA,MAAMiU,iBAAiB,GAAGrV,QAAQ,CAACoB,cAAT,CAAwB,gBAAxB,CAA1B;AACA,MAAMkU,YAAY,GAAGtV,QAAQ,CAACoB,cAAT,CAAwB,WAAxB,CAArB;AACA,MAAMmU,iBAAiB,GAAGvV,QAAQ,CAACoB,cAAT,CAAwB,gBAAxB,CAA1B;AACA,MAAMoU,iBAAiB,GAAGxV,QAAQ,CAACoB,cAAT,CAAwB,gBAAxB,CAA1B;AACA,MAAMqU,WAAW,GAAGzV,QAAQ,CAACoB,cAAT,CAAwB,eAAxB,CAApB;AACA,MAAMjD,WAAW,GAAG6B,QAAQ,CAACoB,cAAT,CAAwB,aAAxB,CAApB;AACA,MAAMsU,WAAW,GAAG1V,QAAQ,CAACoB,cAAT,CAAwB,gBAAxB,CAApB;AACA,MAAMuU,UAAU,GAAG3V,QAAQ,CAACoB,cAAT,CAAwB,eAAxB,CAAnB;AAEAP,8DAAQ;;AAER,MAAM+U,UAAU,GAAG,YACnB;AACI,MACA;AACI;AACA,UAAMC,WAAW,GAAC,MAAMhS,6DAAY,CAAC,CAAC,MAAD,CAAD,EAAW,MAAI3C,cAAc,CAACqR,cAA9B,EAA8C;AAAExO,aAAO,EAAEwJ,eAAX;AAA4BuI,WAAK,EAAC;AAAlC,KAA9C,EAA2F1Q,MAAM,CAACC,QAAlG,CAApC;;AACA,QAAGwQ,WAAH,EACA;AACIX,aAAO,CAACzS,KAAR,CAAcC,OAAd,GAAsB,OAAtB,CADJ,CAEI;;AACA,UAAG0C,MAAM,CAACC,QAAP,CAAgB0Q,IAAhB,KAAuBnU,SAA1B,EACIwD,MAAM,CAACC,QAAP,CAAgBE,MAAhB,CAAuBH,MAAM,CAACC,QAAP,CAAgB0Q,IAAvC;;AAEJ,UAAG,CAACjW,oDAAO,CAACd,kEAAS,CAAC,SAAD,CAAV,CAAX,EACA;AACIM,iEAAU,CAAC6V,UAAD,EAAa,GAAb,EAAkBnW,kEAAS,CAAC,SAAD,EAAY,IAAZ,CAAT,CAA2B+E,OAA7C,EAAsD,EAAtD,EAA0D,CAAC/E,kEAAS,CAAC,SAAD,EAAY,IAAZ,CAAT,CAA2B8W,KAA5B,CAA1D,EAA8F,EAA9F,EAAkG,KAAlG,CAAV;AACA1W,6EAAY,CAAC,SAAD,CAAZ;AACH;;AACD,YAAMkF,IAAI,GAACtF,kEAAS,CAAC,MAAD,EAAS,IAAT,CAApB;AACAgC,6EAAiB,CAACsD,IAAI,CAACrD,MAAN,EAAcC,cAAd,CAAjB,CAZJ,CAaI;;AACAK,4EAAqB,CAACyT,WAAD,EAAcS,WAAd,CAArB,CAdJ,CAeI;;AACAtX,iBAAW,CAACG,KAAZ,GAAkB,EAAlB,CAhBJ,CAkBI;;AACA,YAAM0X,QAAQ,GAAG,MACjB;AACI,cAAMC,WAAW,GAAG,IAAIxR,cAAJ,EAApB;AACAwR,mBAAW,CAACvR,IAAZ,CAAiB,KAAjB,EAAwBpO,uDAAM,GAAC0e,WAAW,CAACpY,UAAnB,GAA8BoY,WAAW,CAACvX,YAA1C,GAAuD6G,IAAI,CAACpE,EAApF;;AACA+V,mBAAW,CAACC,kBAAZ,GAAiC,YACjC;AACI,cAAI,KAAKC,UAAL,IAAmB1R,cAAc,CAAC2R,IAAtC,EACA;AACI,gBAAIxR,QAAQ,GAAC9F,IAAI,CAACI,KAAL,CAAW,KAAK2F,YAAhB,CAAb;;AACA,gBAAI,KAAK5D,MAAL,KAAgB,GAAhB,IAAuB2D,QAAQ,CAACyR,IAAT,IAAiBzU,SAAxC,IAAqDgD,QAAQ,CAAC0R,YAAT,IAAyB1U,SAAlF,EACA;AACI,mBAAI,IAAIjD,IAAR,IAAgBiG,QAAQ,CAACyR,IAAzB,EACA;AACI,oBAAGZ,WAAW,CAAC/T,QAAZ,CAAqB/C,IAArB,MAA6BiD,SAAhC,EACA;AACI,sBAAGgD,QAAQ,CAACyR,IAAT,CAAc1X,IAAd,MAAsB,IAAtB,IAA8BiG,QAAQ,CAACyR,IAAT,CAAc1X,IAAd,MAAsB,KAAvD,EAA6D;AACzD8W,+BAAW,CAAC/T,QAAZ,CAAqB/C,IAArB,EAA2BL,KAA3B,GAAiCsG,QAAQ,CAACyR,IAAT,CAAc1X,IAAd,CAAjC,CADJ,KAEK,IAAIiG,QAAQ,CAACyR,IAAT,CAAc1X,IAAd,KAAqB,IAAzB,EAA+B;AAChC8W,+BAAW,CAAC/T,QAAZ,CAAqB,KAAG/C,IAAxB,EAA8B4D,OAA9B,GAAsC,SAAtC;AACP;AACJ,eAVL,CAWI;;;AACA,mBAAI,IAAIjC,CAAR,IAAasE,QAAQ,CAAC0R,YAAT,CAAsBC,WAAnC,EACId,WAAW,CAAC/T,QAAZ,CAAqB,MAAIkD,QAAQ,CAAC0R,YAAT,CAAsBC,WAAtB,CAAkCjW,CAAlC,CAAzB,EAA+DiC,OAA/D,GAAuE,SAAvE,CAbR,CAcI;;;AACAmT,yBAAW,CAAC/U,SAAZ,GAAsBiE,QAAQ,CAACyR,IAAT,CAAcnY,KAApC;AACAyX,wBAAU,CAAChV,SAAX,GAAqB3J,kBAAkB,GAAC4N,QAAQ,CAACyR,IAAT,CAAcnW,EAAtD;AACH;;AACD,kBAAMsW,UAAU,GAAC,IAAI1T,IAAJ,CAAS8B,QAAQ,CAAC0R,YAAT,CAAsBG,SAA/B,EAA0CC,OAA1C,EAAjB;;AACA,gBAAG9R,QAAQ,CAAC0R,YAAT,CAAsBK,YAAtB,KAAuC,CAA1C,EACA;AACItB,+BAAiB,CAAC5S,KAAlB,CAAwBC,OAAxB,GAAgC,OAAhC;AACA6S,+BAAiB,CAAC9S,KAAlB,CAAwBC,OAAxB,GAAgC,OAAhC;AACA,oBAAMuC,QAAQ,GAACL,QAAQ,CAAC0R,YAAT,CAAsBK,YAAtB,GAAmCjG,IAAI,CAACkG,KAAL,CAAW,CAAC9T,IAAI,CAACyB,GAAL,KAAWiS,UAAZ,IAAwB,IAAxB,GAA6B,IAA7B,GAAkC,EAA7C,CAAlD;AACA,kBAAGvR,QAAQ,GAAG,CAAd,EACI3F,yDAAU,CAACkW,iBAAD,EAAoB,GAApB,EAAyBpN,WAAW,CAACvI,OAAZ,CAAoB,SAApB,EAA+BoF,QAA/B,CAAzB,EAAmE,EAAnE,EAAuE,CAAC,MAAD,CAAvE,CAAV,CADJ,KAGA;AACI3F,yEAAU,CAACkW,iBAAD,EAAoB,GAApB,EAAyBtN,cAAc,CAACrI,OAAf,CAAuB,SAAvB,EAAkCoF,QAAlC,CAAzB,EAAsE,EAAtE,EAA0E,CAAC,OAAD,CAA1E,CAAV;AACAG,sBAAM,CAACC,QAAP,CAAgBE,MAAhB,CAAuB,YAAvB;AACH;AACJ;AACJ;AACJ,SAvCD;;AAwCA0Q,mBAAW,CAACY,gBAAZ,CAA6B,eAA7B,EAA8C,YAAUvS,IAAI,CAACpB,KAA7D;AACA+S,mBAAW,CAACvQ,IAAZ;AACH,OA9CD,CAnBJ,CAkEI;;;AACAsQ,cAAQ,GAnEZ,CAqEI;;AACAP,iBAAW,CAACqB,gBAAZ,CAA6B,QAA7B,EAAuC,UAASC,CAAT,EACvC;AACIA,SAAC,CAACC,cAAF;AACA5B,mBAAW,CAACzU,SAAZ,GAAsB,EAAtB;AACA,YAAIqB,KAAK,GAACD,mEAAkB,CAAC0T,WAAD,CAA5B,CAHJ,CAII;;AACAzT,aAAK,CAACuU,WAAN,GAAkB,EAAlB;;AACA,aAAI,IAAIjW,CAAC,GAAC,CAAV,EAAaA,CAAC,IAAE,CAAhB,EAAmBA,CAAC,EAApB,EACA;AACI,cAAG0B,KAAK,CAAC,MAAI1B,CAAL,CAAL,KAAesB,SAAlB,EACII,KAAK,CAACuU,WAAN,IAAmB,KAAGjW,CAAtB;AACP;;AACD0B,aAAK,CAACgD,cAAN,GAAqBpC,kEAAiB,EAAtC;AACA,cAAMqU,aAAa,GAAG,IAAIxS,cAAJ,EAAtB;AACA,YAAGzC,KAAK,CAACkV,QAAN,KAAiBtV,SAApB,EACIqV,aAAa,CAACvS,IAAd,CAAmB,QAAnB,EAA6BpO,uDAAM,GAAC0e,WAAW,CAACpY,UAAnB,GAA8B,GAA9B,GAAkC0H,IAAI,CAACpE,EAApE,EADJ,KAGI+W,aAAa,CAACvS,IAAd,CAAmB,KAAnB,EAA0BpO,uDAAM,GAAC0e,WAAW,CAACpY,UAAnB,GAA8BoY,WAAW,CAACjX,eAA1C,GAA0DuG,IAAI,CAACpE,EAAzF;;AACJ+W,qBAAa,CAACf,kBAAd,GAAmC,YACnC;AACI,cAAI,KAAKC,UAAL,IAAmB1R,cAAc,CAAC2R,IAAtC,EACA;AACI,gBAAIxR,QAAQ,GAAC9F,IAAI,CAACI,KAAL,CAAW,KAAK2F,YAAhB,CAAb;;AACA,gBAAI,KAAK5D,MAAL,KAAgB,GAAhB,IAAuB2D,QAAQ,CAACb,OAAT,IAAkBnC,SAA7C,EACA;AACI,kBAAGzB,KAAK,CAACC,OAAN,CAAcwE,QAAQ,CAACb,OAAvB,CAAH,EACIa,QAAQ,CAACb,OAAT,GAAmBa,QAAQ,CAACb,OAAT,CAAiBwM,IAAjB,CAAsB,MAAtB,CAAnB,CADJ,KAGI3L,QAAQ,CAACb,OAAT,GAAmBa,QAAQ,CAACb,OAA5B;AACJzE,uEAAU,CAAC8V,WAAD,EAAc,GAAd,EAAmBxQ,QAAQ,CAACb,OAA5B,EAAqC,EAArC,EAAyC,CAAC,SAAD,CAAzC,CAAV;AACH,aAPD,MAQK,IAAIa,QAAQ,CAACuS,MAAb,EACL;AACI,kBAAGhX,KAAK,CAACC,OAAN,CAAcwE,QAAQ,CAACuS,MAAvB,CAAH,EACIvS,QAAQ,CAACuS,MAAT,GAAkBvS,QAAQ,CAACuS,MAAT,CAAgB5G,IAAhB,CAAqB,MAArB,CAAlB,CADJ,KAGI3L,QAAQ,CAACuS,MAAT,GAAkB5P,WAAlB;AACJjI,uEAAU,CAAC8V,WAAD,EAAc,GAAd,EAAmBxQ,QAAQ,CAACuS,MAA5B,EAAoC,EAApC,EAAwC,CAAC,OAAD,CAAxC,CAAV;AACH,aAPI,MASD7X,yDAAU,CAAC8V,WAAD,EAAc,GAAd,EAAmB7N,WAAnB,EAAgC,EAAhC,EAAoC,CAAC,OAAD,CAApC,CAAV,CAnBR,CAoBI;;;AACAyO,oBAAQ;AACX;AACJ,SA1BD;;AA2BAiB,qBAAa,CAACJ,gBAAd,CAA+B,cAA/B,EAA+C,kBAA/C;AACAI,qBAAa,CAACJ,gBAAd,CAA+B,eAA/B,EAAgD,YAAUvS,IAAI,CAACpB,KAA/D;;AACA,YAAGlB,KAAH,EACA;AACIA,eAAK,CAACoV,MAAN,GAAa,MAAb;AACAH,uBAAa,CAACvR,IAAd,CAAmB5G,IAAI,CAACC,SAAL,CAAeiD,KAAf,CAAnB;AACH;AACJ,OApDD,EAtEJ,CA4HI;;AACA,YAAMqV,IAAI,GAACrX,QAAQ,CAACoB,cAAT,CAAwB,MAAxB,CAAX;AACA,YAAMkW,KAAK,GAACtX,QAAQ,CAACoB,cAAT,CAAwB,OAAxB,CAAZ;AACA,YAAMmW,KAAK,GAACvX,QAAQ,CAACoB,cAAT,CAAwB,OAAxB,CAAZ;AACA,YAAMoW,KAAK,GAACxX,QAAQ,CAACoB,cAAT,CAAwB,OAAxB,CAAZ;AACA,YAAMqW,GAAG,GAACzX,QAAQ,CAACoB,cAAT,CAAwB,OAAxB,CAAV;AACA,YAAMwE,SAAS,GAAC5F,QAAQ,CAACoB,cAAT,CAAwB,QAAxB,CAAhB;AACAwE,eAAS,CAACnD,KAAV,CAAgBC,OAAhB,GAAwB,MAAxB;AACA2U,UAAI,CAACP,gBAAL,CAAsB,QAAtB,EAAgC,UAASC,CAAT,EAChC;AACIlR,8EAAgB,CAAC,MAAD,CAAhB;AACH,OAHD;AAIAyR,WAAK,CAACR,gBAAN,CAAuB,QAAvB,EAAiC,UAASC,CAAT,EACjC;AACIlR,8EAAgB,CAAC,OAAD,CAAhB;AACH,OAHD;AAIA0R,WAAK,CAACT,gBAAN,CAAuB,QAAvB,EAAiC,UAASC,CAAT,EACjC;AACIlR,8EAAgB,CAAC,OAAD,CAAhB;AACH,OAHD;AAIA2R,WAAK,CAACV,gBAAN,CAAuB,QAAvB,EAAiC,UAASC,CAAT,EACjC;AACIlR,8EAAgB,CAAC,OAAD,CAAhB;AACH,OAHD;AAIA4R,SAAG,CAACX,gBAAJ,CAAqB,QAArB,EAA+B,UAASC,CAAT,EAC/B;AACI,YAAGU,GAAG,CAAClV,OAAJ,KAAc,IAAjB,EACA;AACIqD,mBAAS,CAACnD,KAAV,CAAgBC,OAAhB,GAAwB,OAAxB;AACA,cAAG2U,IAAI,CAAC9U,OAAL,KAAe,IAAlB,EACIyD,oEAAc,CAAC,MAAD,CAAd,CADJ,KAEK,IAAGsR,KAAK,CAAC/U,OAAN,KAAgB,IAAnB,EACDyD,oEAAc,CAAC,OAAD,CAAd,CADC,KAEA,IAAGuR,KAAK,CAAChV,OAAN,KAAgB,IAAnB,EACDyD,oEAAc,CAAC,OAAD,CAAd,CADC,KAEA,IAAGwR,KAAK,CAACjV,OAAN,KAAgB,IAAnB,EACDyD,oEAAc,CAAC,OAAD,CAAd,CADC,KAGL;AACIJ,qBAAS,CAACnD,KAAV,CAAgBC,OAAhB,GAAwB,MAAxB;AACA+U,eAAG,CAAClV,OAAJ,GAAY,KAAZ;AACH;AACJ,SAhBD,MAkBIqD,SAAS,CAACnD,KAAV,CAAgBC,OAAhB,GAAwB,MAAxB;AACP,OArBD,EApJJ,CA2KI;;AACA,YAAMgV,eAAe,GAAG,IAAIjT,cAAJ,EAAxB;AACAiT,qBAAe,CAAChT,IAAhB,CAAqB,KAArB,EAA4BpO,uDAAM,GAAC0e,WAAW,CAACpY,UAAnB,GAA8BoY,WAAW,CAAC3X,YAAtE;;AACAqa,qBAAe,CAACxB,kBAAhB,GAAqC,YACrC;AACI,YAAI,KAAKC,UAAL,IAAmB1R,cAAc,CAAC2R,IAAtC,EACA;AACI,cAAIxR,QAAQ,GAAC9F,IAAI,CAACI,KAAL,CAAW,KAAK2F,YAAhB,CAAb;AAAA,cAA4C8S,YAAY,GAAC,EAAzD;;AACA,cAAI,KAAK1W,MAAL,KAAgB,GAApB,EACA;AACI,kBAAM2W,WAAW,GAAChT,QAAQ,CAACvE,MAA3B;AACA,gBAAGuX,WAAW,KAAG,CAAjB,EACID,YAAY,GAACrM,oBAAb,CADJ,KAGA;AACIqM,0BAAY,GAACtM,oBAAoB,CAACxL,OAArB,CAA6B,KAA7B,EAAoC+X,WAApC,CAAb;;AACA,mBAAI,IAAItX,CAAR,IAAasE,QAAb,EACI+S,YAAY,IAAE/S,QAAQ,CAACtE,CAAD,CAAR,CAAYrC,IAAZ,GAAiB,IAAjB,GAAsB2G,QAAQ,CAACtE,CAAD,CAAR,CAAYpC,KAAlC,GAAwC,IAAtD;AACP;AACJ;;AACDoB,mEAAU,CAACgW,YAAD,EAAe,GAAf,EAAoBqC,YAApB,EAAkC,EAAlC,EAAsC,CAAC,MAAD,CAAtC,CAAV;AACH;AACJ,OAnBD;;AAoBAD,qBAAe,CAACb,gBAAhB,CAAiC,eAAjC,EAAkD,YAAUvS,IAAI,CAACpB,KAAjE;AACAwU,qBAAe,CAAChS,IAAhB;AACH;AACJ,GA1MD,CA2MA,OAAMqR,CAAN,EACA;AACIzX,6DAAU,CAAC2V,QAAD,EAAW,GAAX,EAAgB1N,WAAhB,EAA6B,EAA7B,EAAiC,CAAC,OAAD,CAAjC,CAAV;AACAzG,WAAO,CAAC+W,KAAR,CAAcd,CAAd;AACH;AACJ,CAlND;;AAmNAnB,UAAU,G","file":"./JS/accountUser.app.js","sourcesContent":["const users = require(\"./users\");\nconst questionnaires = require(\"./questionnaires\");\n\nmodule.exports =\n{\n    apiUrl: \"http://localhost:3000/api\",\n    siteUrl: \"http://localhost:8080\",\n    adminName: \"Fabrice\",\n    adminEmail: \"dev@wikilerni.com\",\n    senderName: \"WikiLerni (local)\",\n    senderEmail: \"bonjour@wikilerni.com\",\n    adminLang: \"fr\",\n    theme: \"wikilerni\", // le thème utilisé (dans /views) pour générer les pages HTML. Contient ses propres fichiers de configuration.\n    availableLangs: [\"fr\"],// Languages in which the site is available. The first one is the default one.\n    siteName: \"WikiLerni (local)\",\n    beginCodeGodfather: \"WL\", // case-sensitive and can't contain \"@\" !\n    defaultReceiptDays: \"147\", // Par défaut, quel(s) jour(s) de la semaine, l'utilisateur reçoit-il quelque chose ? (1=dimanche, 2=lundi... 7=samedi)\n    cronTimingAlertInSeconde: 120, // for logs\n    responseTimingAlertInSeconde: 3, // idem\n    tokenSignupValidationTimeInHours: \"48h\", // https://github.com/zeit/ms\n    tokenLoginLinkTimeInHours: \"1h\",\n    tokenConnexionMinTimeInHours: \"24h\",\n    tokenConnexionMaxTimeInDays: \"180 days\",\n    tokenLoginChangingTimeInHours: \"1h\",// for email & password changing\n    tokenDeleteUserTimeInHours: \"1h\",\n    tokenUnsubscribeLinkTimeInDays: \"7 days\", // token send with subscription's emails\n    freeAccountTimingInDays: 0,// if 0 = unlimited\n    freeAccountExpirationNotificationInDays: 3,\n    accountExpirationFirstNotificationInDays: 10,\n    accountExpirationSecondNotificationInDays: 3,\n    inactiveAccountTimeToDeleteInDays: 180,\n    // Questionnaires:\n    nbQuestionsMin: 1, // minimum number of questions for the questionnaire to be publishable\n    nbQuestionsMax: 2, // if 0 = not maximum\n    nbChoicesMax: 10,\n    nbNewQuestionnaires: 12,// for RSS, etc.\n    hourGiveNewQuestionnaireBegin:7, // in user local time\n    hourGiveNewQuestionnaireEnd:21, // idem\n    maxQuestionnaireSendedAtSameTime: 50, // for subscription's e-mailing\n    minSearchQuestionnaires: 3,\n    fieldNewQuestionnaires : \"publishingAt\", // field to be used to create the list of the last questionnaires, can be \"createdAt\", \"updatedAt\" or \"publishingAt\"\n    // Groups :\n    nbQuestionnairesByGroupMin: 1,\n    nbQuestionnairesByGroupMax: 0,\n    // Illustrations:\n    nbIllustrationsMin: 1,\n    nbIllustrationsMax: 1,\n    maxIllustrationSizeinOctet: 1000000,// pas contrôlé pour l'instant. À revoir.\n    mimeTypesForIllustration: [ \"image/jpg\", \"image/jpeg\", \"image/png\", \"image/gif\", \"image/png\" ],\n    // -- Upload and resize:\n    illustrationsWidthMaxInPx: 500,\n    illustrationsMiniaturesWidthMaxInPx: 200,\n    // Links:\n    nbLinksMin: 1,\n    nbLinksMax: 0,\n    // Questions & responses:\n    nbQuestionsMin: 1,\n    nbQuestionsMax: 0,\n    nbChoicesMax: 10,\n    // à supprimer quand tous les \"require\" à jour:\n    passwordMinLength: users.password.minlength,\n    dirCacheUsers: users.dirCacheUsers,\n    dirCacheUsersAnswers: users.dirCacheUsersAnswers,\n    dirCacheQuestionnaires: questionnaires.dirCacheQuestionnaires,\n    dirCacheQuestions: questionnaires.dirCacheQuestions,\n    dirCacheUsersQuestionnaires: questionnaires.dirCacheUsersQuestionnaires,\n    dirHTMLQuestionnaires: questionnaires.dirHTMLQuestionnaires,\n    dirWebQuestionnaires: questionnaires.dirWebQuestionnaires\n};","module.exports =\n{    \n    // API'routes (after \"apiUrl\" defined in instance.js)\n    questionnaireRoutes: \"/questionnaire\",// la base à laquelle s'ajoute les routes suivantes\n    getListNextQuestionnaires: \"/getlistnextquestionnaires/\",\n    getQuestionnaireRoutes: \"/get\",\n    getRandomQuestionnairesRoute : \"/getrandom\", \n    getStatsQuestionnaires : \"/stats/\",\n    previewQuestionnaireRoutes: \"/preview\",\n    publishedQuestionnaireRoutes: \"/quiz/\",\n    regenerateHTML: \"/htmlregenerated\",\n    searchAdminQuestionnairesRoute : \"/searchadmin\",\n    searchQuestionnairesRoute : \"/search\",\n    // -- groupes :\n    groupRoutes: \"/group\",\n    getGroupRoute: \"/get/\",\n    previewGroupRoutes: \"/preview\",\n    searchGroupsRoute : \"/search\",\n    // -- questions & choices :\n    questionsRoute: \"/question/\",\n    // -- tags :\n    tagsSearchRoute: \"/tags/search/\",\n    // -- answers :\n    getAdminStats: \"/getadminstats/\",\n    getPreviousAnswers: \"/user/answers/\",\n    getStatsAnswers : \"/user/anwswers/stats/\",// fonctionne aussi pour les groupes\n    saveAnswersRoute: \"/answer/\",// idem\n    // forms : à compléter avec valeurs par défaut, etc. cf modèle\n    Questionnaire :\n    {\n        title: { maxlength: 255, required: true },\n        slug: { maxlength: 150 }, // champ requis mais calculé à partir du titre qd laissé vide dans le formulaire\n        introduction: { required: true }\n    },\n    searchQuestionnaires : { minlength: 3, required: true },\n    Group :\n    {\n        title: { maxlength: 255, required: true },\n        slug: { maxlength: 150 }, // champ requis mais calculé à partir du titre qd laissé vide dans le formulaire\n    },\n    Question :\n    {\n        text: { maxlength: 255, required: true },\n        rank: { required: true, min:1, defaultValue:1 }\n    },          \n    Choice :\n    {\n        text: { maxlength: 255, required: true }\n    },\n    search: { minlength: 3, required: true },\n    searchGroups: { minlength: 3, required: true },\n    // Emplacement des fichiers JSON générés :\n    dirCacheGroups : \"datas/questionnaires/groups\",\n    dirCacheQuestionnaires : \"datas/questionnaires\",\n    dirCacheQuestions : \"datas/questionnaires/questions\",\n    dirCacheTags : \"datas/questionnaires/tags\",\n    dirCacheUsersQuestionnaires : \"datas/users/questionnaires\",\n    // Emplacement des fichiers HTML générés :\n    dirHTMLGroups : \"front/public/quiz/gp\",\n    dirHTMLQuestionnaires : \"front/public/quiz\",\n    dirHTMLNews : \"front/public/quizs\",\n    dirHTMLTags : \"front/public/quizs\",\n    // Idem mais pour urls :\n    dirWebGroups : \"quiz/gp\",\n    dirWebQuestionnaires : \"quiz\",\n    dirWebNews : \"quizs/\",\n    dirWebTags : \"quizs/\",\n    // limite des résultat du moteur de recherche, quand demande de résultats au hasard :\n    nbRandomResults : 3,\n    /* Valeurs en fait définies dans instance.js donc à supprimer quand plus utilisées ailleurs : */\n    nbQuestionsMin: 1,\n    nbQuestionsMax: 0,\n    nbChoicesMax: 10,\n    nbTagsMin: 0,\n    nbTagsMax: 0, // 0 = not max    \n};","module.exports =\n{\n    // API'routes (after \"apiUrl\" defined in instance.js)\n    userRoutes: \"/user\",\n    checkDeleteLinkRoute: \"/confirmdelete/\",   \n    checkIfIsEmailfreeRoute: \"/isemailfree\",\n    checkLoginRoute: \"/checklogin/\",\n    checkNewLoginLinkRoute: \"/confirmnewlogin/\",\n    checkSubscribeTokenRoute: \"/validation/\",\n    connectionRoute: \"/login\",\n    connectionWithLinkRoute: \"/checkloginlink\",\n    createUserRoute: \"/create\",\n    getAdminStats: \"/getadminstats/\",\n    getGodChilds: \"/getgodchilds/\",    \n    getGodfatherRoute: \"/getgodfatherid\",\n    getLoginLinkRoute: \"/getloginlink\",\n    getPayments: \"/payment/getforoneuser/\",\n    getUserInfos: \"/get/\",\n    getUsersQuestionnairesRoute: \"/getusersquestionnaires/\",// les questionnaires auxquels l'utilisateur a déjà eu accès via son abonnement    \n    searchUserRoute: \"/search/\",\n    signupCompletionRoute: \"/signupcompletion/\",\n    subscribeRoute: \"/signup\",\n    unsubscribeRoute: \"/subscription/stop/\",\n    updateUserInfos: \"/modify/\",\n    validateUserRoute: \"/validate/\",\n    // forms : à compléter avec valeurs par défaut, etc. cf modèle\n    name: { maxlength: 70, required: true },\n    email: { maxlength: 255, required: true },\n    password: { minlength: 8, maxlength:72, required: true }, // https://www.npmjs.com/package/bcrypt#security-issues-and-concerns\n    newPassword: { minlength: 8, maxlength:72 },\n    codeGodfather: { maxlength: 255 },\n    cguOk: { value: \"true\", required: true },\n    search: { minlength: 1, required: true },\n    timeDifferenceMin: -720,\n    timeDifferenceMax: 840,\n    // JSON dir\n    dirCacheUsers : \"datas/users\",\n    dirCacheUsersAnswers : \"datas/users/questionnaires/answers\",\n    dirCacheUsersWithoutAnswers : \"datas/users/questionnaires/without\"\n};\n","// FONCTIONS UTILES AU STOCKAGE LOCAL (SESSION, COOKIES, INDEXDB, ETC.)\n// Revenir pour gérer le cas où local.storage n'est pas connu pour utiliser cookie\n    \nexport const saveLocaly = (name, data) =>\n{\n    localStorage.setItem(name, JSON.stringify(data));\n}\n\nexport const getLocaly = (name, json=false) =>\n{\n    if(json)\n        return JSON.parse(localStorage.getItem(name));\n    else\n        return localStorage.getItem(name);\n}\n\nexport const removeLocaly = (name) =>\n{\n    localStorage.removeItem(name);\n}","import { isEmpty } from \"../../../tools/main\";\n\n// Fonction associant les attributs fournis à un champ de formulaire\nexport const addElement = (eltParent, eltType, eltContent=\"\", eltId=\"\", eltClass=[], eltAttributes={}, replace=true) =>\n{\n    if(isEmpty(eltType) || isEmpty(eltParent))\n        return false;\n    else\n    {\n        const newElement=document.createElement(eltType);\n        \n        if(!isEmpty(eltId))// tester si l'id n'est pas déjà utilisé dans le DOM ?\n            newElement.id=eltId;\n\n        if(Array.isArray(eltClass) && eltClass.length!=0)\n        {\n            for(let i in eltClass)\n                newElement.classList.add(eltClass[i]);\n        }\n\n        if(typeof eltAttributes === \"object\") // !! tous les objets ne sont pas ok\n        {\n            for(let attributName in eltAttributes)\n                newElement.setAttribute(attributName, eltAttributes[attributName]);\n        }\n\n        if(!isEmpty(eltContent))\n            newElement.innerHTML=eltContent.replace(/\\n/g,\"<br>\");// innerHTML permet d'ajouter du texte ayant lui-même des balises, etc.\n            \n        if(replace)\n            eltParent.innerHTML=\"\";\n        eltParent.appendChild(newElement);\n    }    \n}","// Ce script fournit des fonctions utilisées sur toutes les pages du site\n\nexport const helloDev = () =>\n{\n    console.log(\"**** Hello ami développeur :-)\\n\\nLe code de WikiLerni est libre et vous pouvez le trouver à cette adresse :\\nhttps://forge.chapril.org/Fab_Blab/WikiLerni\\n\\nPour les suggestions d'amélioration ou questions : dev@wililerni.com ****\");\n    return true;\n}\n\nexport const updateAccountLink = (status, configTemplate) =>\n{\n    const link=document.getElementById(\"accountHeadLink\");\n    const homePage=status+\"HomePage\";\n    link.href=\"/\"+configTemplate[homePage];\n}","import { isEmpty } from \"../../../tools/main\";\n\n// Fonction associant les attributs fournis à un champ de formulaire\nexport const setAttributesToInputs = (inputsConf, myForm) =>\n{\n    for(let i in myForm.elements)\n    {\n        if(!isEmpty(myForm.elements[i].id))\n        {\n            let idInput=myForm.elements[i].id;\n            if(inputsConf[idInput]!==undefined)\n            {\n                let inputHTML=document.getElementById(idInput);\n                for (let attribute in inputsConf[idInput])\n                    inputHTML.setAttribute(attribute, inputsConf[idInput][attribute]);\n            }\n        }\n    }\n    return true;\n}\n\n// Récupère toutes les valeurs de champs en omettant les checkbox non cochées, etc.\nexport const getDatasFromInputs = (myForm) =>\n{\n    const datas={};\n    const formData = new FormData(myForm);\n    for(let entrie of formData.entries())\n       datas[entrie[0]]=entrie[1];\n    return datas;\n}\n\n// Vide tous les champs d'un formulaire, y compris hidden, checkbox, etc.\n// Revoir pour les select\nexport const empyForm = (myForm) =>\n{\n    const formData = new FormData(myForm);\n    for(let entrie of formData.entries())\n    {\n        if(myForm.elements[entrie[0]].type==\"checkbox\" || myForm.elements[entrie[0]].type==\"radio\")\n            myForm.elements[entrie[0]].checked=false;\n        else\n            myForm.elements[entrie[0]].value=\"\";\n    }\n    return true;\n}\n// Vide et cache le formulaire\nexport const empyAndHideForm = (myForm) =>\n{\n    empyForm(myForm);\n    myForm.style.display=\"none\";\n}","import { apiUrl, availableLangs, siteUrl, theme } from \"../../../config/instance.js\";\nconst lang=availableLangs[0];\n\nconst configTemplate = require(\"../../../views/\"+theme+\"/config/\"+lang+\".js\");\n\nimport {  checkLoginRoute, timeDifferenceMax, timeDifferenceMin, userRoutes } from \"../../../config/users.js\";\n\nimport { getLocaly, removeLocaly, saveLocaly } from \"./clientstorage.js\";\nimport { isEmpty } from \"../../../tools/main\";\n\nexport const getTimeDifference = () =>\n{\n    // multiplier par -1, car c'est ce qu'il faut \"ajouter\" à l'heure UTC pour revenir en heure locale qui m'intéresse et non l'inverse\n    const timeLocal=new Date().getTimezoneOffset()*-1;\n    if(timeLocal > timeDifferenceMax || timeLocal < timeDifferenceMin)\n        return 0;\n    else\n        return timeLocal;\n}\n\n// J'utilise le stockage local du navigateur pour enregistrer les données permettant de reconnaître l'utilisateur par la suite\n// Seul le serveur pourra vérifier que les identifiants sont (toujours) valides.\nexport const setSession = (userId, token, durationTS) =>\n{\n    const storageUser=\n    {\n        id: userId,\n        token: token,\n        duration: durationTS\n    }\n    saveLocaly(\"user\", storageUser);\n}\n\n// Vérifie qu'il y a des données locales concernant le résultat d'un quiz ou d'un groupe de quizs\n// Et les ajoute aux données envoyées par les formulaires d'inscription/connexion si c'est le cas\nexport const checkAnswerDatas = (datas) =>\n{\n    const lastAnswer=getLocaly(\"lastAnswer\");\n    if(!isEmpty(lastAnswer))\n    {\n        const answer=JSON.parse(lastAnswer);\n        if(!isEmpty(answer.duration) && !isEmpty(answer.nbCorrectAnswers) && !isEmpty(answer.nbQuestions) && (!isEmpty(answer.QuestionnaireId) || !isEmpty(answer.GroupId)))\n        {\n            datas.duration=answer.duration;\n            datas.nbCorrectAnswers=answer.nbCorrectAnswers;\n            datas.nbQuestions=answer.nbQuestions;\n            if(!isEmpty(answer.QuestionnaireId))\n                datas.QuestionnaireId=answer.QuestionnaireId;\n            else\n                datas.GroupId=answer.GroupId;\n        }\n    }\n    return datas;\n}\n\n// Cette fonction teste la connexion de l'utilisateur d'une page\n// On peut fournis une liste de statuts acceptés (si vide = tous), ainsi qu'une url de redirection si non connecté, un message d'erreur à afficher sur la page de destination et l'url sur laquelle revenir une fois connecté\nexport const checkSession = async (status=[], urlRedirection, message, urlWanted) =>\n{\n    return new Promise((resolve, reject) =>\n    {\n        const userDatas=getLocaly(\"user\");\n        if(isEmpty(userDatas))\n        {\n            redirectUser(urlRedirection, message, urlWanted);\n            resolve(false);\n        }\n        else\n        {\n            const user=JSON.parse(userDatas);\n            if(isEmpty(user.id) || isEmpty(user.token) || isEmpty(user.duration) || user.duration < Date.now())\n            {\n                removeLocaly(\"user\");\n                redirectUser(urlRedirection, message, urlWanted);\n                resolve(false);\n            }\n            else\n            {\n                const xhr = new XMLHttpRequest();\n                xhr.open(\"GET\", apiUrl+userRoutes+checkLoginRoute+user.token);\n                xhr.onload = () =>\n                {\n                    let response=JSON.parse(xhr.responseText);\n                    if (xhr.status === 200 && response.isValid && response.id != undefined)\n                    {\n                        if(response.id===user.id)\n                        {\n                            user.name=response.name;\n                            user.language=response.language;\n                            user.timeDifference=response.timeDifference;\n                            user.status=response.status;// c'est le token qui sert à vérifier le statut à chaque requête à l'API\n                            saveLocaly(\"user\", user);\n                            // si il s'agit d'un \"user\" et que son abonnement a expiré, je le redirige vers la caisse :-)\n                            if(response.status===\"user\" && response.nbDaysOk <= 0)\n                            {\n                                const urlAccount=siteUrl+\"/\"+configTemplate.accountPage;\n                                if(window.location.href.indexOf(urlAccount)===-1)\n                                    window.location.assign(\"/\"+configTemplate.accountPage+\"#subscribe\");// passée directement ici, l'ancre #subscribe ne fonctionne pas !?\n                                resolve(true);\n                            }\n                            else\n                            {\n                                if(status.length!==0 && status.indexOf(response.status)===-1)\n                                {\n                                    redirectUser(urlRedirection, message, urlWanted);\n                                    resolve(false);\n                                }\n                                else\n                                    resolve(true);\n                            }\n                        }\n                        else\n                        {\n                            removeLocaly(\"user\");\n                            redirectUser(urlRedirection, message, urlWanted);\n                            resolve(false);\n                        }\n                    }\n                    else\n                    {\n                        removeLocaly(\"user\");\n                        redirectUser(urlRedirection, message, urlWanted);\n                        resolve(false);\n                    }\n                }\n                xhr.onerror = () => reject(xhr.statusText);\n                xhr.send();\n            }\n        }\n    });\n}\n// Cette fonction sert à la précédente en cas de connexion non valide\nconst redirectUser = (urlRedirection, message, urlWanted) =>\n{\n    if(!isEmpty(message))\n        saveLocaly(\"message\", message);\n    if(!isEmpty(urlWanted))\n        saveLocaly(\"url\", urlWanted);\n    if(!isEmpty(urlRedirection))\n        window.location.assign(urlRedirection);\n}","const checkBoxes=\n{\n    \"CGV\" : document.getElementById(\"CGVOk\"),\n    \"abo1\" : document.getElementById(\"abo1\"),\n    \"abo2\" : document.getElementById(\"abo2\"),\n    \"abo3\" : document.getElementById(\"abo3\"),\n    \"abo4\" : document.getElementById(\"abo4\")\n}\nconst divWPBtns=document.getElementById(\"WPBtns\");\n\n// Lorsque l'on sélectionne un montant, les autres options + les CGV sont désélectionnés\nexport const unCheckAllOthers = (choice) =>\n{\n    for (let id in checkBoxes)\n    {\n        if(id!==choice)\n            checkBoxes[id].checked=false;\n        divWPBtns.style.display=\"none\";\n    }\n}\n\n\nconst btns=\n{\n    \"btn1\" : document.getElementById(\"WPBtn1\"),\n    \"btn2\" : document.getElementById(\"WPBtn2\"),\n    \"btn3\" : document.getElementById(\"WPBtn3\"),\n    \"btn4\" : document.getElementById(\"WPBtn4\")\n}\n\n// Affiche le bon bouton de paiement et cache les autres\nexport const showBtnPayment = (choice) =>\n{\n    for (let id in btns)\n    {\n        if(id!==choice)\n            btns[id].style.display=\"none\";\n        else\n            btns[id].style.display=\"block\";\n    }\n}","module.exports =\n{\n    addBtnTxt: \"Ajouter\",\n    addOkMessage : \"Les données ont bien été enregistrées.\",\n    alertNewWindow: \"nouvelle fenêtre\",\n    badUrl : \"Tentative d'accès à une page n'existant pas :\",\n    btnLinkToQuestionnaire : \"Afficher !\",\n    btnProposeConnection: \"Je me connecte.\",\n    btnProposeSubscribe: \"Je crée mon compte.\",\n    btnShowOnWebSite: \"Lire la suite sur #SITE_NAME\",\n    deleteBtnTxt: \"Supprimer\",\n    deleteFailMessage : \"La suppression de l'enregistrement #ID a échoué.\",\n    deleteOkMessage : \"La suppression a bien été enregistrée.\",\n    failAuth : \"Erreur d'authentification.\",\n    failAuthCron : \"Tentative de lancement d'un cron sans le bon token.\",\n    failAuthHeader : \"Absence de header Authorization.\",\n    failAuthId : \"Identifiant non valide : \",\n    failAuthToken : \"Token invalide ou utilisateur non trouvé.\",\n    neededParams : \"Des paramètres nécessaires manquants sont manquants.\",\n    nextPage : \"Page suivante\",\n    notAllowed : \"Vous n'avez pas les droits nécessaires pour cette action.\",\n    notRequired : \"Facultatif.\",\n    notValidFormat : \"Format non valide.\",\n    previousPage : \"Page précédente\",\n    serverError : \"Désolé. Une erreur imprévue est survenue. Si cela persiste, n'hésitez à prévenir l'administrateur du site.\",\n    serverErrorAdmin : \"Bug de l'application :\",\n    siteHTMLTitle : \"WikiLerni : la culture générale en liberté\",\n    siteMetaDescription : \"Avec WikiLerni, vous apprenez régulièrement de nouvelles choses. Vous recevez de courts articles lisibles en quelques minutes. Des quizs vous permettent ensuite de tester ce que vous avez retenu.\",\n    scriptTimingAlert : \"*** Script lent : SCRIPT_TIMING millisecondes, route : SCRIPT_URL\",\n    scriptTimingInfo : \"Durée de la réponse : SCRIPT_TIMING millisecondes, route : SCRIPT_URL\",\n    statsAdmin : \"Durant les dernières 24h : NB_USERS_24H comptes ont été créés, NB_SUBSCRIPTIONS_24H validés et NB_USERS_DELETED_24H supprimés. NB_ANSWERS_24H réponses aux quizs ont été enregistrées.<br>En tout, il y a : NB_USERS_TOT comptes, dont NB_SUBSCRIPTIONS_TOT validés et NB_SUBSCRIPTIONS_PREMIUM comptes prémium. NB_ANSWERS_TOT réponses aux quizs ont été enregistrées.<br>Parmi les NB_USERS_DELETED_TOT comptes supprimés, NB_USERS_DELETED_VALIDED avaient validé leur compte et NB_USERS_DELETED_PREMIUM avaient souscrit un compte prémium.\",\n    subscriptionCall: \"Inscrivez-vous !\",\n    updateBtnTxt: \"Modifier\",\n    updateOkMessage : \"La mise à jour à jour a bien été enregistrée.\"\n};","module.exports =\n{\n    allSubscriptionProcessed : \"Tous les abonnés ont été traités pour le moment.\",\n    infosExpirated: \"Votre abonnement a expiré, mais il vous reste encore quelques jours avant que votre compte et vos données ne soient complètement supprimées.<br>Pour ce faire, suivez sans tarder les indications ci-dessous :\",\n    infosExpiratedAdmin: \"Cet abonnement a expiré.\",\n    infosNbDays: \"Votre abonnement est encore valable <b>pendant NB_DAYS jours</b>.<br>Vous pouvez à tout moment prolonger votre abonnement en suivant les indications ci-dessous :\",\n    infosNbDaysAdmin: \"Cet abonnement est encore valable <b>pendant NB_DAYS jours</b>.\",\n    infosPaymentsAdmin : \"DATE_PAYMENT : paiement de AMOUNT € au nom de CLIENT_NAME.\",\n    isNotValided : \"Cet utilisateur n'a pas encore validé son compte.<br>Vous pouvez le faire à sa place <a href='#validationOk'>en cochant la case indiquée</a> et enregistrant.\",\n    mailEndFreeTimeBodyHTML: \"<h3>Bonjour USER_NAME,</h3><p>Votre abonnement gratuit à SITE_NAME va expirer d'ici quelques jours.<br><br>Pour continuer à utiliser le site, vous pouvez souscrire à un abonnement sans tarder en cliquant sur le lien ci-dessous.</p>\",\n    mailEndFreeTimeBodyTxt: \"Bonjour USER_NAME,\\n\\nVotre abonnement gratuit à SITE_NAME va expirer d'ici quelques jours.\\n\\nPour continuer à utiliser le site, vous pouvez sans attendre souscrire à un abonnement :\\nLINK_URL\",\n    mailEndFreeTimeLinkTxt : \"M'abonner.\",\n    mailEndFreeTimeMessage: \" relances envoyées.\",\n    mailEndFreeTimeSubject: \"Votre abonnement gratuit va expirer\",\n    mailExpirationBodyHTML: \"<h3>Bonjour USER_NAME,</h3><p>Votre abonnement à SITE_NAME va expirer d'ici quelques jours.<br><br>Pour continuer à utiliser SITE_NAME, vous pouvez le prolonger dès aujourd'hui en cliquant sur le lien ci-dessous.</p>\",\n    mailExpirationBodyTxt: \"Bonjour USER_NAME,\\n\\nVotre abonnement à SITE_NAME va expirer d'ici quelques jours.\\n\\nPour continuer à utiliser SITE_NAME, vous pouvez le prolonger dès aujourd'hui :\\nLINK_URL\",\n    mailExpirationLinkTxt : \"Prolonger mon abonnement.\",\n    mailExpirationMessage: \"FIRST premières et SECOND deuxièmes relances envoyées pour des abonnements expirant d'ici peu.\",\n    mailExpirationRelaunchTxt: \"[Rappel] \",\n    mailExpirationSubject: \"Votre abonnement va bientôt expirer\",\n    mailNewElementForGroupTxt : \"Bonjour USER_NAME,\\n\\nVoici le lien vers le nouvel article à lire :\\n\\nQUESTIONNAIRE_URL\\n\\nBonne lecture !\\n\\nStopper les envois ?\\nUNSUBSCRIBE_URL\",\n    mailNewQuestionnaireBodyTxt : \"Bonjour USER_NAME,\\n\\nVoici le lien vers le nouveau quiz :\\n\\nQUESTIONNAIRE_URL\\n\\nBonne lecture !\\n\\nStopper les envois ?\\nUNSUBSCRIBE_URL\",\n    mailStopMailLinkTxt : \"Stopper les envois.\",\n    needKnowIfNoticeOk : \"Il manque l'information sur l'acceptation ou non de recevoir des notifications.\",\n    needIntegerNumberOfDays : \"Le nombre de jours de l'abonnement doit être un nombre entier.\",\n    needMinNumberOfDays : \"Le nombre de jours de l'abonnement ne peut être négatif !\",\n    needNotTooLongDaysList : \"La liste de jours sélectionnés n'a pas le bon format (trop longue).\",\n    needNumberOfDays : \"Il faut un nombre de jours pour l'abonnement.\",\n    needUniqueDaysList : \"La liste de jours sélectionnés n'a pas le bon format. Doublon : \",\n    needValidDaysList : \"La liste de jours sélectionnés n'a pas le bon format. Caractère non valide : \",\n    noNewQuestionnaireForUser : \"Aucun nouveau questionnaire trouvé pour un abonné : \",\n    unsubscriptionOk : \"Votre demande a bien été prise en compte. Vous ne recevrez plus de messages venant du site, sauf pour vous signaler la fin de votre abonnement.<br>N'hésitez pas <a href='/#URL'>à accéder à votre compte</a> pour de nouveau autoriser certains envois.\",\n    unsubscriptionFail : \"Si vous voyez ce message, c'est que votre lien de désabonnement ne fonctionne pas.<br>Vous pouvez <a href='/#URL'>accéder à votre compte</a> pour désactiver les envois manuellement.\"\n};\n","module.exports =\n{\n    alreadyConnected: \"Vous êtes déjà connecté au site !\",\n    badLinkValidationMessage: \"Votre lien de confirmation ne semble pas valide ou bien il a expiré. Vous pouvez en recevoir un nouveau <a href='#URL'>en cliquant ici</a>.\",\n    badPassword: \"Aucun compte utilisateur ne correspond aux informations saisies.\",\n    byebyeMessage: \"Si vous voyez ce message, c'est que votre déconnexion s'est bien déroulée.<br>À bientôt !\", \n    connectionOk: \"Connexion réussie.\",\n    creationOkMessage: \"Le nouvel utilisateur a bien été enregistré.\",\n    cronDeleteUnvalidedUsersMessage: \" comptes utilisateurs non validés ont été supprimés.\",\n    deleteFailMessage: \"Tentative de suppression d'un utilisateur inexistant : \",\n    deleteInactiveUsersMessage: \" comptes utilisateurs inactifs ont été supprimés.\",\n    deleteOkMessage: \"L'utilisateur a bien été supprimé.\",\n    emailNotFound: \"Aucun compte utilisateur n'a été trouvé pour cette adresse e-mail.\",\n    failBotTest: \"Un problème a été rencontré durant votre inscription. En cas de difficulté, n'hésitez pas contacter l'administrateur du site.\",\n    failBotTestLog: \"Une inscription a été bloquée, parce que le champ email2 était renseigné avec : \",\n    formsEmailLabel: \"E-mail :\",\n    formsEmailPlaceholder: \"Votre adresse e-mail\",\n    formsEmail2Placeholder: \"Si vous voyez ce champ, laissez-le vide\",//champ qui ne devrait pas être visible par des humains\n    formsCGUOkLabel: \"J'accepte <a href=#link target=\\\"_blank\\\" rel=\\\"noopener\\\" title=\\\"À lire :)\\\">les Conditions Générale d'Utilisation</a> du site (requis).\",\n    formsSubmitTxt: \"Je m'abonne !\",\n    godfatherFound: \"Votre \\\"parrain\\\" a bien été trouvé. Cette personne sera avertie que vous l'avez désignée.\",\n    godfatherNotFound: \"Désolé mais aucun utilisateur n'a été trouvé pour ce code / e-mail de parrainage :(\",\n    infosAdminGodfather: \"Cet utilisateur a été parrainé par \",\n    infosAdminNbGodChilds: \"Ses #NB filleuls : \",\n    infosUserForAdmin: \"Cet utilisateur (id: ID_USER) a <b>créé son compte le DATE_CREA</b>, la dernière mise à jour datant du DATE_UPDATE.<br><b>Date de sa dernière connexion : DATE_CONNECTION.</b>\",\n    infosUserNbGodChilds: \"Voici les #NB utilisateur(s) inscrit(s) en vous désignant comme \\\"parrain\\\" : \",\n    infosUserNoGodchilds: \"Pour l'instant, aucune personne ne s'est inscrite, en vous désignant comme \\\"parrain\\\".\",\n    mailDeleteBodyHTML : \"<h3>Bonjour USER_NAME,</h3><p>Pour confirmer la suppression de votre compte, cliquez sur le lien ci-dessous sans tarder.</p>\",\n    mailDeleteBodyTxt : \"Bonjour USER_NAME,\\n\\nPour confirmer la suppression de votre compte, cliquez sur le lien suivant sans tarder :\\nLINK_URL\",\n    mailDeleteLinkAlreadyMessage: \"Il semble que vous ayez déjà validé la suppression de votre compte.\",\n    mailDeleteLinkFailMessage: \"Votre lien de suppression n'est pas valide ou alors il a expiré.\",\n    mailDeleteLinkMessage: \"Votre demande de suppression a bien été enregistrée. Merci de cliquer sans tarder sur le lien qui vient de vous être envoyé par e-mail pour confirmer.\",\n    mailDeleteLinkOkMessage: \"Votre compte a bien été supprimé. Merci d'avoir utilisé nos services.\",\n    mailDeleteLinkTxt : \"Confirmer.\",\n    mailDeleteSubject : \"Confirmer la suppression de votre compte.\",\n    mailLoginLinkBodyHTML : \"<h3>Bonjour USER_NAME,</h3><p>Pour vous connecter à votre compte, cliquez sur le lien suivant sans tarder :</p>\",\n    mailLoginLinkBodyTxt : \"Bonjour USER_NAME,\\n\\nPour vous connecter à votre compte, cliquez sur le lien suivant sans tarder :\\nLINK_URL\",\n    mailLoginLinkMessage : \"Un lien de connexion vient de vous être envoyé sur votre adresse e-mail. Ne tardez pas à l'utiliser, car il n'est valable que durant *TIMING* !\",\n    mailLoginLinkSubject : \"Votre lien de connexion.\",\n    mailLoginLinkTxt : \"Me connecter.\",\n    mailThankGodfatherBodyHTML : \"<h3>Bonjour USER_NAME,</h3><p>Grâce à vous, un nouvel utilisateur (EMAIL) vient de s'inscrire sur NOM_SITE.<br>Si dans l'avenir cette personne souscrit un abonnement prémium, votre propre abonnement sera prolongé de 30 jours.</p><p>Encore merci et à bientôt !</p>\",\n    mailThankGodfatherBodyTxt : \"Bonjour USER_NAME,\\nGrâce à vous, un nouvel utilisateur (EMAIL) vient de s'inscrire sur NOM_SITE.\\nSi dans l'avenir cette personne souscrit un abonnement prémium, votre propre abonnement sera prolongé de 30 jours.\\nEncore merci et à bientôt !\",\n    mailThankGodfatherLinkTxt : \"Me connecter à mon compte.\",\n    mailThankGodfatherSubject : \"Merci !\",\n    mailUpdateLoginBodyHTML : \"<h3>Bonjour USER_NAME,</h3><p>Pour valider vos nouveaux identifiants de connexion, cliquez sur le lien ci-dessous sans tarder.</p>\",\n    mailUpdateLoginBodyTxt : \"Bonjour USER_NAME,\\n\\nPour valider vos nouveaux identifiants de connexion, cliquez sur le lien suivant sans tarder :\\nLINK_URL\",\n    mailUpdateLoginLinkMessage: \"Cependant, vous avez modifié au moins un de vos identifiants de connexion (e-mail et/ou mot de passe) et <b>vous devez cliquer sur le lien qui vient de vous êtres envoyé sur votre adresse (NEW_EMAIL) pour valider ce changement</b>.<br>En attendant, merci de continuer à utiliser vos anciens identifiants.\",\n    mailUpdateLoginLinkTxt : \"Valider.\",\n    mailUpdateLoginOkMessage: \"La mise à jour de vos identifiants a bien été enregistrée.\",\n    mailUpdateLoginSubject : \"Merci de valider vos nouveaux identifiants.\",\n    mailValidationLinkSBodyHTML : \"<h3>Bonjour USER_NAME,</h3><p>Pour valider et compléter votre inscription, merci de cliquer sur le lien ci-dessous dans les 24h.</p>\",\n    mailValidationLinkSBodyTxt : \"Bonjour USER_NAME,\\n\\nPour valider et compléter votre inscription, merci de cliquer sur le lien suivant dans les 24h :\\nLINK_URL\",\n    mailValidationLinkSubject : \"Merci de valider votre inscription\",\n    mailValidationLinkTxt : \"Valider mon compte.\",\n    mailValidationMessage: \"Votre inscription est bien enregistrée.\\nPour la finaliser, merci de cliquer dans les 24 H sur le lien de confirmation qui vient d'être envoyé à votre adresse e-mail (#EMAIL).\",\n    mailWelcomeBodyHTML : \"<h3>Bonjour USER_NAME,</h3><p>Vous venez de valider votre inscription à NOM_SITE. Merci et bienvenue !<br><br>Si vous avez la moindre question ou suggestion concernant NOM_SITE, n'hésitez pas à me contacter en écrivant à <b>EMAIL</b>.<br><br>Je vous conseille d'ailleurs d'ajouter <b>EMAIL</b> à votre carnet d'adresses <b>pour éviter que les prochains envois de NOM_SITE n'arrivent en <i>spam</i></b>.<br><br>Par ailleurs, pour gérer votre abonnement, accéder à vos informations ou encore chercher plus facilement parmi le contenu du site, vous pouvez à tout moment vous connecter à votre compte utilisateur.<br><br>Pour ce faire, utilisez le lien ci-dessous.<br><br>À bientôt sur NOM_SITE.\",\n    mailWelcomeBodyTxt : \"Bonjour USER_NAME,\\n\\nVous venez de valider votre inscription à NOM_SITE. Merci et bienvenue !\\n\\nSi vous avez la moindre question ou suggestion concernant NOM_SITE, n'hésitez pas à me contacter en écrivant à EMAIL.\\n\\nJe vous conseille d'ailleurs d'ajouter EMAIL à votre carnet d'adresses pour éviter que les prochains envois de NOM_SITE n'arrivent en \\\"spam\\\".\\n\\nPar ailleurs, pour gérer votre abonnement, accéder à vos informations ou encore chercher plus facilement parmi le contenu du site, vous pouvez à tout moment vous connecter à votre compte utilisateur.\\n\\nPour ce faire, utilisez le lien suivant : LINK_URL\\n\\nÀ bientôt sur NOM_SITE.\",\n    mailWelcomeLinkTxt : \"Me connecter à mon compte.\",\n    mailWelcomeSubject : \"Bienvenue !\",\n    needBeConnected: \"Vous devez être connecté pour accéder à cette page.\",\n    needChooseLoginWay: \"Vous devez soit saisir votre mot de passe, soit cocher la case vous permettant de recevoir un lien de connexion par e-mail.\",\n    needEmail: \"Merci de saisir votre adresse e-mail.\",\n    needKnowNewsletterOk : \"Il faut savoir si l'utilisateur accepte ou refuse de recevoir la newsletter.\",\n    needLanguage : \"Il manque le code langue.\",\n    needLongPassWord : \"Merci de fournir un mot de passe d'au moins MIN_LENGTH caractères.\",\n    needMaxTimeDifference : \"Il faut fournir un nombre de minutes à ajouter à l'heure GMT ne dépassant pas 840.\",\n    needMinTimeDifference : \"Il faut fournir un nombre de minutes à enlever à l'heure GMT ne dépassant pas 720.\",\n    needName: \"Merci de choisir un nom d'utilisateur.\",\n    needNotTooLongName: \"Merci de choisir un nom d'utilisateur ne comptant pas plus de 70 caractères.\",\n    needNotTooLongEmail: \"Merci de saisir une adresse e-mail ne comptant pas plus de 255 caractères.\",\n    needPassWord : \"Merci de fournir un mot de passe.\",\n    needSMTP : \"Il manque le serveur SMTP.\",\n    needSMTPNotFound : \"Il manque un serveur SMTP valide.\",\n    needStatus : \"Il manque le statut.\",\n    needTimeDifference : \"Il faut connaître le nombre de minutes du décalage horaire.\",\n    needUGCOk : \"Merci d'accepter les CGU pour créer votre compte.\",\n    needUniqueEmail: \"L'adresse e-mail que vous avez saisie est déjà utilisée pour un compte utilisateur. Si vous avez déjà un compte, <a href='/#URL'>cliquez-ici pour vous connecter</a>.\",\n    needValidationToLogin : \"Vous devez d'abord valider votre compte avant de pouvoir vous connecter. Pour ce faire, un nouveau lien vient de vous être envoyé par e-mail.\",\n    needValidLastConnectionDate : \"La date de dernière connexion n'est pas valide.\",\n    passwordCopied: \"Le mot de passe généré a été copié dans le presse-papier de votre ordinateur (ou mobile). Vous pouvez le \\\"coller\\\" où vous le souhaitez.\",\n    searchUsersWithoutResult: \"L'utilisateur n'a pas été trouvé.\",\n    tooManyLoginFails : \"Désolé mais il y a eu trop de tentatives de connexion infructueuses pour cette adresse e-mail. Vous devez attendre MINUTES minutes pour essayer de nouveau.\",\n    updatedFailedGodfatherNotFound : \"L'identifiant fourni pour le parrain ne correspond à aucun utilisateur.\",\n    updatedNeedGoodEmail : \"Mais la nouvelle adresse e-mail n'a pu être enregistrée, car elle n'a pas un format correct.\",\n    updatedNeedGoodGodfather : \"Mais le nouveau code parrain n'a pu être retenu, car il ne correspond à aucun compte utilisateur ou à l'utilisateur lui-même.\",\n    updatedNeedUniqueEmail : \"Mais la nouvelle adresse e-mail saisie (NEW_EMAIL) n'a pu être enregistrée, car elle est déjà utilisée pour un autre compte.\",\n    updatedNeedValidatedUser: \"L'utilisateur que vous souhaitez modifier n'existe pas/plus ou n'a pas encore validé son compte.\",\n    updatedOkMessage: \"Vos informations ont bien été mises à jour.\",\n    validationAlreadyMessage: \"Il semble que vous ayez déjà validé votre compte. Vous pouvez vous y connecter <a href='#URL'>en cliquant ici</a>.\",\n    validationAlreadyMessageAdmin: \"Ce compte a déjà été validé.\",\n    validationMessage: \"Votre compte vient bien d'être validé. Merci et bienvenue !<br>Vous pouvez compléter les informations de votre abonnement ci-dessous.\",\n    validationMessageAdmin: \"Le compte a bien été validé.\",\n    welcomeMessage: \"Bienvenue #NAME !\"\n};","// Quelques fonctions utiles pour les chaînes\n\nclass Tool\n{\n    static isEmpty(myVar)\n    {\n        if(myVar===undefined || myVar===null)\n            return true;\n        else\n        {\n            myVar+=\"\";// si autre chose qu'une chaîne envoyé...\n            myVar=myVar.trim();\n            if(myVar===\"\")\n                return true;\n            else\n                return false;\n        }\n    }\n    \n    static trimIfNotNull(myString)\n    {\n        if(Tool.isEmpty(myString))\n            myString=null;\n        else\n        {\n            myString+=\"\";// si autre chose qu'une chaîne envoyé...\n            myString=myString.trim();\n        }\n        return myString;\n    }\n\n\n    static shortenIfLongerThan(myString, max)\n    {\n        myString+=\"\";// au cas où cela ne serait pas une chaîne...\n       if(myString.length > max)\n            myString=myString.substring(0, (max-3))+\"…\";\n        return myString;\n    }\n\n    // source : https://stackoverflow.com/questions/15604140/replace-multiple-strings-with-multiple-other-strings\n    static replaceAll(myString, mapObj)\n    {\n        const replaceElts = new RegExp(Object.keys(mapObj).join(\"|\"),\"gi\");\n        return myString.replace(replaceElts, (matched) =>\n        {\n            return mapObj[matched];\n        });\n    }\n\n    // source : https://developer.mozilla.org/fr/docs/Web/JavaScript/Reference/Objets_globaux/Math/random\n    static getRandomInt(min, max)\n    {\n        min = Math.ceil(min);\n        max = Math.floor(max);\n        return Math.floor(Math.random() * (max - min)) + min;\n    }\n\n    // à compléter : https://en.wikipedia.org/wiki/Date_format_by_country\n    static dateFormat(dateString, lang=\"fr\")\n    {\n        if(Tool.isEmpty(dateString))\n            return \"\";\n        let myDate=new Date(dateString);\n        let myDay=myDate.getDate()+\"\";\n        if(myDay.length===1)\n            myDay=\"0\"+myDay;\n        let myMounth=(myDate.getMonth()+1)+\"\";\n        if(myMounth.length===1)\n            myMounth=\"0\"+myMounth;\n        let myYear=myDate.getFullYear();\n        if(lang===\"fr\")\n            return myDay+\"/\"+myMounth+\"/\"+myYear;\n        else if (lang===\"form\")// 2014-02-09\n            return myYear+\"-\"+myMounth+\"-\"+myDay;\n        else\n            return myMounth+\"/\"+myDay+\"/\"+myYear;\n    }\n\n    // On enlève volontairement les 0/O pour éviter les confusions !\n    // Et mieux vaut aussi débuter et finir par une lettre simple.\n    static getPassword (nbCarMin, nbCarMax)\n    {\n        const nbCar=nbCarMin+Math.floor(Math.random()*(nbCarMax-nbCarMin));\n        const letters=\"ABCDEFGHIJKLMNPQRSTUVWXYZabcdefghijklmnpqrstuvwxyz\";\n        const others=\"123456789!?.*-_%@&ÉÀÈÙ€$ÂÊÛÎ\";\n        let password=letters[Math.floor(Math.random()*letters.length)];\n        for(let i=1;i<(nbCar-1);i++)\n        {\n            if((i % 2) ===1)\n                password+=others[Math.floor(Math.random()*others.length)];\n            else\n                password+=letters[Math.floor(Math.random()*letters.length)];   \n        }\n        password+=letters[Math.floor(Math.random()*letters.length)];\n        return password;\n    }\n}\n\nmodule.exports = Tool;","module.exports =\n{\n    headLinks:\n    [\n        { anchor: \"Accueil\", attributes: { href:\"/\" } },\n        { anchor: \"Mon compte\", attributes: { href:\"/connexion.html\", id: \"accountHeadLink\" } },\n        { anchor: \"À propos\", attributes: { href:\"/a-propos.html\" } },\n        { anchor: \"Contact\", attributes: { href:\"/contact.html\" } },\n    ],\n    footLinks:\n    [\n        { anchor: \"Crédits\", attributes: { href:\"/credits.html\" } },\n        { anchor: \"Mentions légales\", attributes: { href:\"/mentions-legales.html\", rel: \"nofollow\" } },\n        { anchor: \"Données personnelles\", attributes: { href:\"/donnees.html\" } },\n        { anchor: \"C.G.U.\", attributes: { href:\"/cgu.html\", rel: \"nofollow\" } },\n        { anchor: \"C.G.V.\", attributes: { href:\"/cgv.html\", rel: \"nofollow\" } },\n    ],\n    maxQuestionnairesByPage: 10,\n    userHomePage : \"accueil.html\",\n    adminHomePage : \"admin.html\",\n    managerHomePage : \"gestion.html\",\n    subscribePage : \"inscription.html\",\n    connectionPage : \"connexion.html\",\n    accountPage: \"compte.html\",\n    questionnairesManagementPage: \"gestion-quizs.html\",\n    usersManagementPage: \"gestion-utilisateurs.html\",\n    nbQuestionnairesUserHomePage : 10,\n    illustrationDir : \"/img/quizs/\",\n    siteSlogan: \"Cultivons notre jardin !\",\n    homeTitle1: \"De nature curieuse ?\",\n    homeP1: \"Avec WikiLerni vous apprenez chaque jour de nouvelles choses.<br>Des articles de Wikipédia sont sélectionnés pour vous et sont suivis d'un quiz vous permettant de tester ce que vous en avez retenu.<br>De jour en jour de nouvelles graines de savoir sont ainsi semées dans votre \\\"jardin\\\".\",\n    homeTitle2: \"La culture en liberté\",\n    homeP2: \"Tout comme sur Wikipédia (*), le logiciel et le contenu partagé sur WikiLerni sont libres.<br>Vous pouvez les utiliser, les modifier et les diffuser selon votre souhait.<br>Sur WikiLerni, pas de publicité, ni de commercialisation de vos données personnelles.<br>Vous pouvez venir y \\\"cultiver votre jardin\\\" en toute tranquillité.<br><br><small><em>(*) Bien que partageant ses valeurs, WikiLerni est un projet indépendant de la fondation Wikipédia.</em></small>\",\n    newQuestionnairesTitle: \"Les derniers quizs publiés sur WikiLerni\",\n    newQuestionnairesIntro: \"Liste des derniers quizs publiés sur WikiLerni.\",\n    explanationTitle: \"Vous découvrez WikiLerni ?\",\n    explanationTxt: \"Le principe est simple : vous commencez par lire l'article Wikipédia dont le lien vous est proposé.<br>Puis vous afficher le quiz pour vérifier ce que vous en avez retenu de votre lecture. Vous obtenez alors votre résultat immédiatement.<br><br>Toutes les réponses se trouvent dans l'article proposé à la lecture. <b>Vous êtes ici pour apprendre de nouvelles choses</b>, mais libre à vous d'essayer d'y répondre immédiatement.<br><br>Quand le sujet s'y prête, ne vous étonnez pas si certaines des réponses proposées peuvent être un peu décalées, absurdes... On peut apprendre avec le sourire, non ? :-)<br><br>Une fois votre résultat obtenu, il vous sera proposé de créer un compte pour le sauvegarder.<br>Ce compte vous permettra de tester de nouveau ce quiz pour vérifier ce que vous en avez retenu plusieurs jours, semaines, mois... Et de recevoir régulièrement de nouvelles suggestions de lectures.<br><br>Mais <b>la création de ce compte est facultative</b> et <a href='/quizs/' title='Les derniers quizs publiés'>vous pouvez parcourir WikiLerni librement</a>.\",\n    noJSNotification: \"Désolé, mais pour l'instant, l'utilisation de WikiLerni nécessite l'activation du JavaScript.\",\n    tagsListTxt: \"Parcourir les rubriques :\",\n};","module.exports =\n{\n    // liens de l'interface\n    headLinks:\n    [\n        { anchor: \"Contact\", attributes: { href:\"/contact.html\", rel: \"nofollow\" } },\n        { anchor: \"Parcourir\", attributes: { href:\"/quizs/\", id:\"indexHeadLink\", title:\"Les dernières publications\" } },\n        { anchor: \"Mon compte\", attributes: { href:\"/connexion.html\", id: \"accountHeadLink\", title:\"Accéder ou créez votre compte WikiLerni\" } },\n        { anchor: \"À propos\", attributes: { href:\"/a-propos.html\", title:\"En savoir + sur WikiLerni\" } },\n        { anchor: \"Accueil\", attributes: { href:\"/\", title:\"Page d'accueil\" } }\n    ],\n    footLinks:\n    [\n        { anchor: \"Blog\", attributes: { href:\"https://framasphere.org/people/7e54b7a0b53201389eef2a0000053625\", title:\"Le blog WikiLerni sur diaspora*\" } },\n        { anchor: \"Crédits\", attributes: { href:\"/credits.html\", title:\"Qui a créé WikiLerni ? Quels sont vos droits ?\" } },\n        { anchor: \"Mentions légales\", attributes: { href:\"/mentions-legales.html\", rel: \"nofollow\" } },\n        { anchor: \"Données personnelles\", attributes: { href:\"/donnees.html\", title:\"Vos données personnelles sur WikiLerni\" } },\n        { anchor: \"CGV & CGU\", attributes: { href:\"/CGV-CGU.html\", rel: \"nofollow\" } }\n    ],\n    accountPage: \"compte.html\",\n    aboutPage: \"a-propos.html\",\n    adminHomePage: \"admin.html\",\n    cguPage: \"CGV-CGU.html\",\n    connectionPage : \"connexion.html\",\n    deleteLinkPage : \"aurevoir.html?t=\",\n    loginLinkPage : \"login.html?t=\",\n    managerHomePage : \"gestion.html\",\n    newLoginLinkPage : \"newlogin.html?t=\",\n    questionnairesManagementPage: \"gestion-quizs.html\",    \n    stopMailPage : \"stop-mail.html?t=\",\n    subscribePage : \"inscription.html\",\n    updateAccountPage: \"compte.html\",\n    userHomePage : \"accueil.html\",\n    userHomePageTxt : \"Ma page d'accueil.\",\n    usersManagementPage: \"gestion-utilisateurs.html\",\n    validationLinkPage : \"validation.html?t=\",\n    /* Textes (général) */\n    siteSlogan: \"Cultivons notre jardin !\",\n    noJSNotification: \"Désolé, mais pour l'instant, l'utilisation de WikiLerni nécessite l'activation du JavaScript.\",\n    mailRecipientTxt: \"Message envoyé à :\",\n    licenceTxt: \"@copyleft Le contenu de WikiLerni <a href=\\\"/credits.html\\\" title=\\\"En savoir plus ?\\\">est libre</a> et vous est offert sans publicité. Vous pouvez <a href=\\\"/participer-financement.html\\\" title=\\\"Financement participatif avec contre-parties\\\">participer à son financement en cliquant ici</a>.\",\n    /* Page d'accueil */\n    homePageTxt: \"Page d'accueil\",\n    homeTitle1: \"De nature curieuse ?\",\n    homeP1: \"<b>Avec WikiLerni, vous apprenez régulièrement de nouvelles choses</b>.<br>Vous recevez de courts articles, lisibles en quelques minutes.<br>Des quizs vous permettent ensuite de tester ce que vous avez retenu.<br>De jour en jour <b>de nouvelles graines de culture sont ainsi semées dans votre jardin</b>.\",\n    homeTitle2: \"La culture générale en liberté\",\n    homeP2: \"<b>Pas de faits alternatifs</b>, tous les contenus sont <b>sourcés par des articles Wikipédia</b>.<br>Et tout comme sur Wikipédia, le logiciel et le contenu publié sur WikiLerni <a href=\\\"/credits.html\\\" title=\\\"En savoir plus sur ce sujet\\\">sont partagés sous licences libres</a>.<br>Le tout sans publicité, ni commercialisation de vos données.<br><b>Sur WikiLerni, vous cultivez votre jardin en toute tranquillité.</b>\",\n    homeBtnAboutTxt: \"En savoir plus sur WikiLerni ?\",\n    homeBtnSubscribeTxt:  \"Testez WikiLerni\",\n    homeSubcriptionFormTitle:  \"Recevez les prochains articles WikiLerni\",\n    /* Page dernières publications... */   \n    newQuestionnairesTitle: \"Culture générale - apprenez de nouvelles choses avec WikiLerni\",\n    newQuestionnairesIntro: \"WikiLerni : testez vos connaissances et apprenez de nouvelles choses avec WikiLerni.\",\n    newsListTitle: \"<p><b>Avec WikiLerni, vous apprenez chaque jour quelque chose de nouveau</b><br>Si dessous les dernières publications. Vous pouvez aussi <a href='/quizs/themes.html'>parcourir le site par thèmes ou mots-clés</a>.</p>\",\n    /* Plan du site, liste des tags */   \n    tagListTitle: \"Culture générale - des articles et quizs sur de nombreux thèmes !\",\n    tagListMetaDesc: \"WikiLerni : découvrir les différents thèmes abordés par WikiLerni. Inxex du site.\",\n    tagListIntro: \"<h3>Avec WikiLerni, devenez fort en thèmes... Oui mais quels thèmes ? :)</h3><blockquote>Aristote : « L’homme a naturellement la passion de connaître… »</blockquote>\",\n    /* Page quizs */\n    answersExplanationsLinkText: \"Relire\",\n    quizElementLinksIntro: \"En savoir plus\",\n    quizElementSubcriptionFormTitle: \"Recevez les prochains articles WikiLerni\",\n    explanationTitle: \"Vous découvrez WikiLerni ?\",\n    explanationTxt: \"<p>Le principe est simple : <b>vous commencez par lire l’article Wikipédia dont le lien vous est proposé</b>. Puis vous <b>afficher le quiz pour vérifier ce que vous avez retenu de votre lecture</b>. Suivant les questions, <b>une ou plusieurs réponses peuvent être correctes</b> et doivent donc être cochées. C’est toujours <b>le contenu de l’article Wikipédia qui fait foi</b> concernant les « bonnes » réponses. C’est une façon de tester à la fois votre capacité d’attention et votre mémoire. Les articles de Wikipédia peuvent évoluer, donc n’hésitez pas <a href='/contact.html'>à me signaler une erreur</a>.</p><p><b>WikiLerni vous propose d’autres solutions pour améliorer votre culture générale</b>. Pour en savoir plus, cliquez sur le bouton ci-dessous.</p>\",\n    explanationElementTxt: \"<p>WikiLerni vous propose de <b>recevoir par e-mail à la fréquence choisie, de courts articles lisibles en quelques minutes</b> et portant sur des sujets très variés de <b>culture générale</b> (arts, histoire, littérature, sciences, etc.).</p><p>Ces articles sont basés sur <b>une ou plusieurs pages de Wikipédia</b> (fournies en lien), dont <b>ils extraient certaines informations</b>.</p><p>Chaque série d’articles est <b>suivie d’un quiz</b> permettant de tester ce que vous en avez retenu.</p><p><b>Vous apprenez ainsi régulièrement de nouvelles choses</b> très simplement.</p>\",\n    /* Autres */\n    illustrationDir : \"/img/quizs/\",\n    twitterAccount: \"WikiLerni\",\n    maxQuestionnairesByPage: 12,\n    maxQuestionnairesSiteHomePage: 3,\n    nbQuestionnairesUserHomePage : 3,\n};","var map = {\n\t\"./fr/general\": \"../lang/fr/general.js\"\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = \"../lang sync recursive ^\\\\.\\\\/.*\\\\/general$\";","var map = {\n\t\"./fr/subscription\": \"../lang/fr/subscription.js\"\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = \"../lang sync recursive ^\\\\.\\\\/.*\\\\/subscription$\";","var map = {\n\t\"./fr/user\": \"../lang/fr/user.js\"\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = \"../lang sync recursive ^\\\\.\\\\/.*\\\\/user$\";","var map = {\n\t\"./default/config/fr.js\": \"../views/default/config/fr.js\",\n\t\"./wikilerni/config/fr.js\": \"../views/wikilerni/config/fr.js\"\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = \"../views sync recursive ^\\\\.\\\\/.*\\\\.js$\";","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// -- GESTION DES FORMULAIRES PERMETTANT AUX UTILISATEURS DE METTRE À JOUR LEURS INFORMATIONS + LEUR ABONNEMENT\n\n/// Vérifier que l'utilisateur est bien connecté, a le bon statut et le rediriger vers le formulaire d'inscription si ce n'est pas le cas.\n/// Si c'est ok, on récupère les infos de son compte et son abonnement et les affiche dans le formulaire.\n/// Une information est affichée concernant la possibilité de parrainage et liste les filleuls existants.\n/// Un menu permet à l'utilisateur d'accéder à la modification de ses infos, etc.\n/// Des boutons de paiement sont aussi affichés suivant le choix de l'utilisateur pour lui permettre de prolonger son abonnement.\n/// Un message venant d'une autre page peut aussi être à afficher lors du premier chargement.\n\n// Fichier de configuration côté client :\nimport { apiUrl, availableLangs, theme } from \"../../config/instance.js\";\nconst lang=availableLangs[0];\nconst configTemplate = require(\"../../views/\"+theme+\"/config/\"+lang+\".js\");// besoin de toutes les déclarations pour la fonction : updateAccountLink()\nconst { beginCodeGodfather } = require(\"../../config/instance\");\nconst configUsers = require(\"../../config/users\"); // besoin de tous le fichier pour configurer le formulaire\n\n// Fonctions utiles au script\nimport { getLocaly, removeLocaly } from \"./tools/clientstorage.js\";\nimport { addElement } from \"./tools/dom.js\";\nimport { helloDev, updateAccountLink } from \"./tools/everywhere.js\";\nimport { getDatasFromInputs, setAttributesToInputs } from \"./tools/forms.js\";\nimport { isEmpty } from \"../../tools/main\";\nimport { checkSession, getConfig, getTimeDifference } from \"./tools/users.js\";\n\n// Spécifique WebPortage pour paiements:\nimport { showBtnPayment, unCheckAllOthers } from \"./tools/webportage.js\";\n\n// Dictionnaires :\nconst { serverError } = require(\"../../lang/\"+lang+\"/general\");\nconst { infosUserNbGodChilds, infosUserNoGodchilds, needBeConnected } = require(\"../../lang/\"+lang+\"/user\");\nconst { infosExpirated, infosNbDays } = require(\"../../lang/\"+lang+\"/subscription\");\n\n// Principaux éléments du DOM manipulés :\nconst divCrash = document.getElementById(\"crash\");\nconst divMain = document.getElementById(\"main-content\");\nconst divMessage = document.getElementById(\"message\");\nconst divResponse = document.getElementById(\"response\");\nconst divGodfatherInfos = document.getElementById(\"godfatherInfos\");\nconst divGodchilds = document.getElementById(\"godchilds\");\nconst divSubscribeInfos = document.getElementById(\"subscribeInfos\");\nconst divSubscribeIntro = document.getElementById(\"subscribeIntro\");\nconst formAccount = document.getElementById(\"accountUpdate\");\nconst newPassword = document.getElementById(\"newPassword\");\nconst showGFEmail = document.getElementById(\"godfatherEmail\");\nconst showGFCode = document.getElementById(\"godfatherCode\");\n\nhelloDev();\n\nconst initialise = async () =>\n{\n    try\n    {\n        // Si l'utilisateur n'est pas connecté avec le bon statut, pas la peine d'aller + loin :\n        const isConnected=await checkSession([\"user\"], \"/\"+configTemplate.connectionPage, { message: needBeConnected, color:\"error\" }, window.location);\n        if(isConnected)\n        {\n            divMain.style.display=\"block\";\n            // l'éventuelle ancre est ignorée, car absente du DOM avant d'avoir vérifié la connexion\n            if(window.location.hash!==undefined)\n                window.location.assign(window.location.hash);\n            \n            if(!isEmpty(getLocaly(\"message\")))\n            {\n                addElement(divMessage, \"p\", getLocaly(\"message\", true).message, \"\", [getLocaly(\"message\", true).color], \"\", false);\n                removeLocaly(\"message\");\n            }\n            const user=getLocaly(\"user\", true);\n            updateAccountLink(user.status, configTemplate);\n            // Initialise le formulaire permettant de mettre à jour les infos :\n            setAttributesToInputs(configUsers, formAccount);\n            // Certains navigateurs remplissent les champs password :\n            newPassword.value=\"\";\n\n            // Fonction affichant les infos connues au premier affichage, puis après envoi mise à jour\n            const getInfos = () =>\n            {\n                const xhrGetInfos = new XMLHttpRequest();\n                xhrGetInfos.open(\"GET\", apiUrl+configUsers.userRoutes+configUsers.getUserInfos+user.id);\n                xhrGetInfos.onreadystatechange = function()\n                {\n                    if (this.readyState == XMLHttpRequest.DONE)\n                    {\n                        let response=JSON.parse(this.responseText);\n                        if (this.status === 200 && response.User != undefined && response.Subscription != undefined)\n                        {\n                            for(let data in response.User)\n                            {\n                                if(formAccount.elements[data]!==undefined)\n                                {\n                                    if(response.User[data]!==true && response.User[data]!==false)// booléen = case à cocher !\n                                        formAccount.elements[data].value=response.User[data];\n                                    else if (response.User[data]==true) // si false, on ne fait rien    \n                                        formAccount.elements[\"\"+data].checked=\"checked\";\n                                }\n                            }\n                            // jours de réception\n                            for(let i in response.Subscription.receiptDays)\n                                formAccount.elements[\"d\"+response.Subscription.receiptDays[i]].checked=\"checked\";\n                            // \"codes\" possibles à transmettre pour parrainer d'autres utilisateurs \n                            showGFEmail.innerHTML=response.User.email;\n                            showGFCode.innerHTML=beginCodeGodfather+response.User.id;\n                        }\n                        const beginSubTS=new Date(response.Subscription.createdAt).getTime();\n                        if(response.Subscription.numberOfDays !== 0)\n                        {\n                            divGodfatherInfos.style.display=\"block\";\n                            divSubscribeInfos.style.display=\"block\";\n                            const nbDaysOk=response.Subscription.numberOfDays-Math.round((Date.now()-beginSubTS)/1000/3600/24);\n                            if(nbDaysOk > 0)\n                                addElement(divSubscribeIntro, \"p\", infosNbDays.replace(\"NB_DAYS\", nbDaysOk), \"\", [\"info\"]);\n                            else\n                            {\n                                addElement(divSubscribeIntro, \"p\", infosExpirated.replace(\"NB_DAYS\", nbDaysOk), \"\", [\"error\"]);\n                                window.location.assign(\"#subscribe\");\n                            }\n                        }\n                    }\n                }\n                xhrGetInfos.setRequestHeader(\"Authorization\", \"Bearer \"+user.token);\n                xhrGetInfos.send();\n            }\n            // Remonte les infos déjà enregistrées :\n            getInfos();\n          \n            // Traitement de l'envoi d'une mise à jour des infos\n            formAccount.addEventListener(\"submit\", function(e)\n            {\n                e.preventDefault();\n                divResponse.innerHTML=\"\";\n                let datas=getDatasFromInputs(formAccount);\n                // recomposition des jours valables pour l'abonnement :\n                datas.receiptDays=\"\";\n                for(let i=1; i<=7; i++)\n                {\n                    if(datas[\"d\"+i]!==undefined)\n                        datas.receiptDays+=\"\"+i;\n                }\n                datas.timeDifference=getTimeDifference();\n                const xhrUserUpdate = new XMLHttpRequest();\n                if(datas.deleteOk!==undefined)\n                    xhrUserUpdate.open(\"DELETE\", apiUrl+configUsers.userRoutes+\"/\"+user.id);\n                else\n                    xhrUserUpdate.open(\"PUT\", apiUrl+configUsers.userRoutes+configUsers.updateUserInfos+user.id);\n                xhrUserUpdate.onreadystatechange = function()\n                {\n                    if (this.readyState == XMLHttpRequest.DONE)\n                    {\n                        let response=JSON.parse(this.responseText);\n                        if (this.status === 200 && response.message!=undefined)\n                        {\n                            if(Array.isArray(response.message))\n                                response.message = response.message.join(\"<br>\");\n                            else\n                                response.message = response.message;\n                            addElement(divResponse, \"p\", response.message, \"\", [\"success\"]);\n                        }\n                        else if (response.errors)\n                        {\n                            if(Array.isArray(response.errors))\n                                response.errors = response.errors.join(\"<br>\");\n                            else\n                                response.errors = serverError;\n                            addElement(divResponse, \"p\", response.errors, \"\", [\"error\"]);\n                        }\n                        else\n                            addElement(divResponse, \"p\", serverError, \"\", [\"error\"]);\n                        // dans tous les cas, je mets à jour le contenu du formulaire :\n                        getInfos();\n                    }\n                }\n                xhrUserUpdate.setRequestHeader(\"Content-Type\", \"application/json\");\n                xhrUserUpdate.setRequestHeader(\"Authorization\", \"Bearer \"+user.token);\n                if(datas)\n                {\n                    datas.output=\"html\";\n                    xhrUserUpdate.send(JSON.stringify(datas));\n                }\n            });\n\n            // on passe à la caisse ?\n            const abo9=document.getElementById(\"abo9\");\n            const abo18=document.getElementById(\"abo18\");\n            const abo36=document.getElementById(\"abo36\");\n            const abo54=document.getElementById(\"abo54\");\n            const CGV=document.getElementById(\"CGVOk\");\n            const divWPBtns=document.getElementById(\"WPBtns\");\n            divWPBtns.style.display=\"none\";\n            abo9.addEventListener(\"change\", function(e)\n            {\n                unCheckAllOthers(\"abo9\");\n            });\n            abo18.addEventListener(\"change\", function(e)\n            {\n                unCheckAllOthers(\"abo18\");\n            });\n            abo36.addEventListener(\"change\", function(e)\n            {\n                unCheckAllOthers(\"abo36\");\n            });\n            abo54.addEventListener(\"change\", function(e)\n            {\n                unCheckAllOthers(\"abo54\");\n            });\n            CGV.addEventListener(\"change\", function(e)\n            {\n                if(CGV.checked===true)\n                {\n                    divWPBtns.style.display=\"block\";\n                    if(abo9.checked===true)\n                        showBtnPayment(\"btn9\");\n                    else if(abo18.checked===true)\n                        showBtnPayment(\"btn18\");\n                    else if(abo36.checked===true)\n                        showBtnPayment(\"btn36\");\n                    else if(abo54.checked===true)\n                        showBtnPayment(\"btn54\");\n                    else\n                    {\n                        divWPBtns.style.display=\"none\";\n                        CGV.checked=false;\n                    }\n                }\n                else\n                    divWPBtns.style.display=\"none\";\n            });\n\n            // Liste des filleuls, si il y en a\n            const xhrGetGodchilds = new XMLHttpRequest();\n            xhrGetGodchilds.open(\"GET\", apiUrl+configUsers.userRoutes+configUsers.getGodChilds);\n            xhrGetGodchilds.onreadystatechange = function()\n            {\n                if (this.readyState == XMLHttpRequest.DONE)\n                {\n                    let response=JSON.parse(this.responseText), txtGodchilds=\"\";\n                    if (this.status === 200)\n                    {\n                        const nbGodchilds=response.length;\n                        if(nbGodchilds===0)\n                            txtGodchilds=infosUserNoGodchilds;\n                        else\n                        {\n                            txtGodchilds=infosUserNbGodChilds.replace(\"#NB\", nbGodchilds);\n                            for(let i in response)\n                                txtGodchilds+=response[i].name+\" (\"+response[i].email+\") \";\n                        }\n                    }\n                    addElement(divGodchilds, \"p\", txtGodchilds, \"\", [\"info\"]);\n                }\n            }\n            xhrGetGodchilds.setRequestHeader(\"Authorization\", \"Bearer \"+user.token); \n            xhrGetGodchilds.send();\n        }\n    }\n    catch(e)\n    {\n        addElement(divCrash, \"p\", serverError, \"\", [\"error\"]);\n        console.error(e);\n    }\n}\ninitialise();"],"sourceRoot":""}
|