You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
2.7 KiB
75 lines
2.7 KiB
const { insertEtudiant } = require('../Models/Etudiants')
|
|
const { database } = require('../database')
|
|
const { URL } = require('./Config')
|
|
const dayjs = require('dayjs')
|
|
|
|
const getEtudiants = async () => {
|
|
const XHR = new XMLHttpRequest()
|
|
const allEtudiants = await database.prepare('SELECT * FROM etudiants').all()
|
|
|
|
if (XHR.readyState === 4) {
|
|
if (XHR.status === 200) {
|
|
const etudiantFromWeb = JSON.parse(XHR.responseText)
|
|
|
|
let numInscArray = []
|
|
for (let index = 0; index < allEtudiants.length; index++) {
|
|
numInscArray.push(allEtudiants[index].num_inscription)
|
|
}
|
|
|
|
database.transaction(() => {
|
|
for (let index = 0; index < etudiantFromWeb.length; index++) {
|
|
if (numInscArray.includes(etudiantFromWeb[index]['num_inscription']) === false) {
|
|
insertEtudiant(
|
|
etudiantFromWeb[index]['nom'],
|
|
etudiantFromWeb[index]['prenom'],
|
|
etudiantFromWeb[index]['photos'],
|
|
etudiantFromWeb[index]['date_de_naissances'],
|
|
etudiantFromWeb[index]['niveau'],
|
|
etudiantFromWeb[index]['annee_scolaire'],
|
|
etudiantFromWeb[index]['status'],
|
|
etudiantFromWeb[index]['num_inscription'],
|
|
etudiantFromWeb[index]['mention_id']
|
|
)
|
|
} else {
|
|
const getTheEtudiant = database
|
|
.prepare('SELECT * FROM etudiants WHERE id = ?')
|
|
.get(etudiantFromWeb[index]['id'])
|
|
|
|
if (getTheEtudiant.updated_at < etudiantFromWeb[index]['updated_at']) {
|
|
database
|
|
.prepare(
|
|
'UPDATE etudiants SET nom = ?, prenom = ?, photos = ?, date_de_naissances = ?, niveau = ?, annee_scolaire = ?, status = ?, mention_id = ?, num_inscription = ? WHERE id = ?'
|
|
)
|
|
.run(
|
|
etudiantFromWeb[index]['nom'],
|
|
etudiantFromWeb[index]['prenom'],
|
|
etudiantFromWeb[index]['photos'],
|
|
etudiantFromWeb[index]['date_de_naissances'],
|
|
etudiantFromWeb[index]['niveau'],
|
|
etudiantFromWeb[index]['annee_scolaire'],
|
|
etudiantFromWeb[index]['status'],
|
|
etudiantFromWeb[index]['num_inscription'],
|
|
etudiantFromWeb[index]['mention_id'],
|
|
etudiantFromWeb[index]['id']
|
|
)
|
|
}
|
|
}
|
|
}
|
|
})()
|
|
} else {
|
|
console.log('impossible de contacter le server')
|
|
}
|
|
}
|
|
|
|
XHR.open('GET', `${URL}/getEtudiants`, true)
|
|
XHR.setRequestHeader('x-requested-with', 'xmlhttprequest')
|
|
XHR.send()
|
|
}
|
|
|
|
async function getAll() {
|
|
await getEtudiants()
|
|
}
|
|
|
|
module.exports = {
|
|
getAll
|
|
}
|
|
|